diff options
author | Jeremy Kemper <jeremy@bitsweat.net> | 2007-12-09 22:12:07 +0000 |
---|---|---|
committer | Jeremy Kemper <jeremy@bitsweat.net> | 2007-12-09 22:12:07 +0000 |
commit | 2d2fd67b51e204e77e24d1b493cebae72d8fa33d (patch) | |
tree | f44e6e4e785def5dbd8a117a22c1ef5ed79c3fa4 | |
parent | bafd698acb160fd241efe6f027b83676b9e80d1f (diff) | |
download | rails-2d2fd67b51e204e77e24d1b493cebae72d8fa33d.tar.gz rails-2d2fd67b51e204e77e24d1b493cebae72d8fa33d.tar.bz2 rails-2d2fd67b51e204e77e24d1b493cebae72d8fa33d.zip |
Move #to_query methods where they ought to belong. Closes #10395 [Chu Yeow]
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@8343 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
3 files changed, 17 insertions, 17 deletions
diff --git a/activesupport/lib/active_support/core_ext/array/conversions.rb b/activesupport/lib/active_support/core_ext/array/conversions.rb index b7d4434e85..c828e84112 100644 --- a/activesupport/lib/active_support/core_ext/array/conversions.rb +++ b/activesupport/lib/active_support/core_ext/array/conversions.rb @@ -29,6 +29,15 @@ module ActiveSupport #:nodoc: join '/' end + # Converts an array into a string suitable for use as a URL query string, using the given <tt>key</tt> as the + # param name. + # + # ==== Example: + # ['Rails', 'coding'].to_query('hobbies') => "hobbies%5B%5D=Rails&hobbies%5B%5D=coding" + def to_query(key) + collect { |value| value.to_query("#{key}[]") } * '&' + end + def self.included(base) #:nodoc: base.class_eval do alias_method :to_default_s, :to_s diff --git a/activesupport/lib/active_support/core_ext/hash/conversions.rb b/activesupport/lib/active_support/core_ext/hash/conversions.rb index e196c5d7b9..8021dfa87a 100644 --- a/activesupport/lib/active_support/core_ext/hash/conversions.rb +++ b/activesupport/lib/active_support/core_ext/hash/conversions.rb @@ -4,23 +4,6 @@ require 'base64' require 'builder' require 'xmlsimple' -# Extensions needed for Hash#to_query -class Object - def to_param #:nodoc: - to_s - end - - def to_query(key) #:nodoc: - "#{CGI.escape(key.to_s)}=#{CGI.escape(to_param.to_s)}" - end -end - -class Array - def to_query(key) #:nodoc: - collect { |value| value.to_query("#{key}[]") } * '&' - end -end - # Locked down XmlSimple#xml_in_string class XmlSimple # Same as xml_in but doesn't try to smartly shoot itself in the foot. @@ -100,6 +83,13 @@ module ActiveSupport #:nodoc: klass.extend(ClassMethods) end + # Converts a hash into a string suitable for use as a URL query string. An optional <tt>namespace</tt> can be + # passed to enclose the param names (see example below). + # + # ==== Example: + # { :name => 'David', :nationality => 'Danish' }.to_query # => "name=David&nationality=Danish" + # + # { :name => 'David', :nationality => 'Danish' }.to_query('user') # => "user%5Bname%5D=David&user%5Bnationality%5D=Danish" def to_query(namespace = nil) collect do |key, value| value.to_query(namespace ? "#{namespace}[#{key}]" : key) diff --git a/activesupport/lib/active_support/core_ext/object.rb b/activesupport/lib/active_support/core_ext/object.rb index 3b055d3185..bbc7d81672 100644 --- a/activesupport/lib/active_support/core_ext/object.rb +++ b/activesupport/lib/active_support/core_ext/object.rb @@ -1,3 +1,4 @@ +require 'active_support/core_ext/object/conversions' require 'active_support/core_ext/object/extending' require 'active_support/core_ext/object/instance_variables' require 'active_support/core_ext/object/misc' |