Merge pull request #22556 from imanel/range_prepend
Use Module.prepend instead of alias_method for Range#to_s
This commit is contained in:
commit
27710b1eda
@ -1,34 +1,31 @@
|
|||||||
class Range
|
module ActiveSupport::RangeWithFormat
|
||||||
RANGE_FORMATS = {
|
RANGE_FORMATS = {
|
||||||
:db => Proc.new { |start, stop| "BETWEEN '#{start.to_s(:db)}' AND '#{stop.to_s(:db)}'" }
|
:db => Proc.new { |start, stop| "BETWEEN '#{start.to_s(:db)}' AND '#{stop.to_s(:db)}'" }
|
||||||
}
|
}
|
||||||
|
|
||||||
# Convert range to a formatted string. See RANGE_FORMATS for predefined formats.
|
# Convert range to a formatted string. See RANGE_FORMATS for predefined formats.
|
||||||
#
|
#
|
||||||
# This method is aliased to <tt>to_s</tt>.
|
|
||||||
#
|
|
||||||
# range = (1..100) # => 1..100
|
# range = (1..100) # => 1..100
|
||||||
#
|
#
|
||||||
# range.to_formatted_s # => "1..100"
|
|
||||||
# range.to_s # => "1..100"
|
# range.to_s # => "1..100"
|
||||||
#
|
|
||||||
# range.to_formatted_s(:db) # => "BETWEEN '1' AND '100'"
|
|
||||||
# range.to_s(:db) # => "BETWEEN '1' AND '100'"
|
# range.to_s(:db) # => "BETWEEN '1' AND '100'"
|
||||||
#
|
#
|
||||||
# == Adding your own range formats to to_formatted_s
|
# == Adding your own range formats to to_s
|
||||||
# You can add your own formats to the Range::RANGE_FORMATS hash.
|
# You can add your own formats to the Range::RANGE_FORMATS hash.
|
||||||
# Use the format name as the hash key and a Proc instance.
|
# Use the format name as the hash key and a Proc instance.
|
||||||
#
|
#
|
||||||
# # config/initializers/range_formats.rb
|
# # config/initializers/range_formats.rb
|
||||||
# Range::RANGE_FORMATS[:short] = ->(start, stop) { "Between #{start.to_s(:db)} and #{stop.to_s(:db)}" }
|
# Range::RANGE_FORMATS[:short] = ->(start, stop) { "Between #{start.to_s(:db)} and #{stop.to_s(:db)}" }
|
||||||
def to_formatted_s(format = :default)
|
def to_s(format = :default)
|
||||||
if formatter = RANGE_FORMATS[format]
|
if formatter = RANGE_FORMATS[format]
|
||||||
formatter.call(first, last)
|
formatter.call(first, last)
|
||||||
else
|
else
|
||||||
to_default_s
|
super()
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
alias_method :to_default_s, :to_s
|
alias_method :to_default_s, :to_s
|
||||||
alias_method :to_s, :to_formatted_s
|
alias_method :to_formatted_s, :to_s
|
||||||
end
|
end
|
||||||
|
|
||||||
|
Range.prepend(ActiveSupport::RangeWithFormat)
|
||||||
|
Loading…
Reference in New Issue
Block a user