aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorKasper Timm Hansen <kaspth@gmail.com>2015-02-28 17:42:36 +0100
committerKasper Timm Hansen <kaspth@gmail.com>2015-02-28 17:42:36 +0100
commit1db5ecf1e7c748b0414b5a4369d854c7b2c5541d (patch)
treebb4ecef376dee57d4727aa3c70c5d4ee4ccddb69
parent58aecb0f7e3ffd6a4e85b928b9aa38438599a254 (diff)
parent032d279268f73a012679294560b2da3232710434 (diff)
downloadrails-1db5ecf1e7c748b0414b5a4369d854c7b2c5541d.tar.gz
rails-1db5ecf1e7c748b0414b5a4369d854c7b2c5541d.tar.bz2
rails-1db5ecf1e7c748b0414b5a4369d854c7b2c5541d.zip
Merge pull request #19128 from davydovanton/update-doc-range-to-s
[ci skip] Update documentation for Range#to_formatted_s
-rw-r--r--activesupport/lib/active_support/core_ext/range/conversions.rb19
1 files changed, 17 insertions, 2 deletions
diff --git a/activesupport/lib/active_support/core_ext/range/conversions.rb b/activesupport/lib/active_support/core_ext/range/conversions.rb
index b1a12781f3..83eced50bf 100644
--- a/activesupport/lib/active_support/core_ext/range/conversions.rb
+++ b/activesupport/lib/active_support/core_ext/range/conversions.rb
@@ -3,9 +3,24 @@ class Range
:db => Proc.new { |start, stop| "BETWEEN '#{start.to_s(:db)}' AND '#{stop.to_s(:db)}'" }
}
- # Gives a human readable format of the range.
+ # Convert range to a formatted string. See RANGE_FORMATS for predefined formats.
#
- # (1..100).to_formatted_s # => "1..100"
+ # This method is aliased to <tt>to_s</tt>.
+ #
+ # range = (1..100) # => 1..100
+ #
+ # range.to_formatted_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'"
+ #
+ # == Adding your own range formats to to_formatted_s
+ # You can add your own formats to the Range::RANGE_FORMATS hash.
+ # Use the format name as the hash key and a Proc instance.
+ #
+ # # config/initializers/range_formats.rb
+ # Range::RANGE_FORMATS[:short] = ->(start, stop) { "Between #{start.to_s(:db)} and #{stop.to_s(:db)}" }
def to_formatted_s(format = :default)
if formatter = RANGE_FORMATS[format]
formatter.call(first, last)