123456789_123456789_123456789_123456789_123456789_

Class: Range

Constant Summary

::ActiveSupport::RangeWithFormat - Prepended

RANGE_FORMATS

Instance Method Summary

::ActiveSupport::RangeWithFormat - Prepended

#to_formatted_s
#to_fs

Convert range to a formatted string.

::ActiveSupport::CompareWithRange - Prepended

#===

Extends the default Range#=== to support range comparisons.

#include?

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

Instance Method Details

#as_json(options = nil)

This method is for internal use only.
[ GitHub ]

  
# File 'activesupport/lib/active_support/core_ext/object/json.rb', line 158

def as_json(options = nil) # :nodoc:
  to_s
end

#overlaps?

[ GitHub ]

  
# File 'activesupport/lib/active_support/core_ext/range/overlap.rb', line 4

alias :overlaps? :overlap?

#sole

Returns the sole item in the range. If there are no items, or more than one item, raises ::Enumerable::SoleItemExpectedError.

(1..1).sole   # => 1
(2..1).sole   # => Enumerable::SoleItemExpectedError: no item found
(..1).sole    # => Enumerable::SoleItemExpectedError: infinite range cannot represent a sole item
[ GitHub ]

  
# File 'activesupport/lib/active_support/core_ext/range/sole.rb', line 10

def sole
  if self.begin.nil? || self.end.nil?
    raise ActiveSupport::EnumerableCoreExt::SoleItemExpectedError, "infinite range '#{inspect}' cannot represent a sole item"
  end

  super
end

#sum(initial_value = 0)

This method is for internal use only.

Optimize range sum to use arithmetic progression if a block is not given and we have a range of numeric values.

[ GitHub ]

  
# File 'activesupport/lib/active_support/core_ext/enumerable.rb', line 253

def sum(initial_value = 0)
  if block_given? || !(first.is_a?(Integer) && last.is_a?(Integer))
    super
  else
    actual_last = exclude_end? ? (last - 1) : last
    if actual_last >= first
      sum = initial_value || 0
      sum + (actual_last - first + 1) * (actual_last + first) / 2
    else
      initial_value || 0
    end
  end
end