diff options
author | Xavier Noria <fxn@hashref.com> | 2009-09-13 21:04:10 +0200 |
---|---|---|
committer | Xavier Noria <fxn@hashref.com> | 2009-09-13 21:04:10 +0200 |
commit | 119040fafbbc48ae0dec867663edab3d744fc8e6 (patch) | |
tree | d3851a9ef390e99a0ef65c543b2cc5172361966d /railties/guides | |
parent | 924d9066cfabf8b410fa06a43a63b2264106fadc (diff) | |
download | rails-119040fafbbc48ae0dec867663edab3d744fc8e6.tar.gz rails-119040fafbbc48ae0dec867663edab3d744fc8e6.tar.bz2 rails-119040fafbbc48ae0dec867663edab3d744fc8e6.zip |
AS guide: documents symbolize_keys and symbolize_keys!
Diffstat (limited to 'railties/guides')
-rw-r--r-- | railties/guides/source/active_support_overview.textile | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/railties/guides/source/active_support_overview.textile b/railties/guides/source/active_support_overview.textile index 6305ed6d69..b6da20314a 100644 --- a/railties/guides/source/active_support_overview.textile +++ b/railties/guides/source/active_support_overview.textile @@ -1222,6 +1222,38 @@ The second line can safely access the "type" key, and let the user to pass eithe There's also the bang variant +stringify_keys!+ that stringifies keys in the very receiver. +h5. +symbolize_keys+ and +symbolize_keys!+ + +The method +symbolize_keys+ returns a hash that has a symbolized version of the keys in the receiver, where possible. It does so by sending +to_sym+ to them: + +<ruby> +{nil => nil, 1 => 1, "a" => "a"}.symbolize_keys +# => {1 => 1, nil => nil, :a => "a"} +</ruby> + +WARNING. Note in the previous example only one key was symbolized. + +The result in case of collision is undefined: + +<ruby> +{"a" => 1, :a => 2}.symbolize_keys +# => {:a => 2}, in my test, can't rely on this result though +</ruby> + +This method may be useful for example to easily accept both symbols and strings as options. For instance +ActionController::UrlRewriter+ defines + +<ruby> +def rewrite_path(options) + options = options.symbolize_keys + options.update(options[:params].symbolize_keys) if options[:params] + ... +end +</ruby> + +The second line can safely access the +:params+ key, and let the user to pass either +:params+ or "params". + +There's also the bang variant +symbolize_keys!+ that symbolizes keys in the very receiver. + h4. Indifferent Access The method +with_indifferent_access+ returns an +ActiveSupport::HashWithIndifferentAccess+ out of its receiver: |