Methods
I
O
S
T
Constants
RANGE_FORMATS = { :db => Proc.new { |start, stop| "BETWEEN '#{start.to_s(:db)}' AND '#{stop.to_s(:db)}'" } }
Instance Public methods
include_with_range?(value)

Extends the default Range#include? to support range comparisons.

(1..5).include?(1..5) # => true
(1..5).include?(2..3) # => true
(1..5).include?(2..6) # => false

The native Range#include? behavior is untouched.

("a".."f").include?("c") # => true
(5..9).include?(11) # => false
# File activesupport/lib/active_support/core_ext/range/include_range.rb, line 10
def include_with_range?(value)
  if value.is_a?(::Range)
    operator = exclude_end? ? :< : :<=
    end_value = value.exclude_end? ? last.succ : last
    include_without_range?(value.first) && (value.last <=> end_value).send(operator, 0)
  else
    include_without_range?(value)
  end
end
overlaps?(other)

Compare two ranges and see if they overlap each other

(1..5).overlaps?(4..6) # => true
(1..5).overlaps?(7..9) # => false
# File activesupport/lib/active_support/core_ext/range/overlaps.rb, line 5
def overlaps?(other)
  include?(other.first) || other.include?(first)
end
step_with_blockless(*args, &block)

Return an array when step is called without a block.

# File activesupport/lib/active_support/core_ext/range/blockless_step.rb, line 9
def step_with_blockless(*args, &block)
  if block_given?
    step_without_blockless(*args, &block)
  else
    array = []
    step_without_blockless(*args) { |step| array << step }
    array
  end
end
to_default_s(format = :default)
to_formatted_s(format = :default)

Gives a human readable format of the range.

Example

[1..100].to_formatted_s # => "1..100"
This method is also aliased as to_s
# File activesupport/lib/active_support/core_ext/range/conversions.rb, line 11
def to_formatted_s(format = :default)
  if formatter = RANGE_FORMATS[format]
    formatter.call(first, last)
  else
    to_default_s
  end
end
to_s(format = :default)
This method is also aliased as to_default_s