Module: DeepSymbolizable::Symbolizers
Instance Method Summary collapse
-
#_recurse_(value, &block) ⇒ Object
handling recursion - any Enumerable elements (except String) is being extended with the module, and then symbolized.
-
#array(ary, &block) ⇒ Object
walking over arrays and symbolizing all nested elements.
-
#hash(hash, &block) ⇒ Object
the primary method - symbolizes keys of the given hash, preprocessing them with a block if one was given, and recursively going into all nested enumerables.
Instance Method Details
#_recurse_(value, &block) ⇒ Object
handling recursion - any Enumerable elements (except String) is being extended with the module, and then symbolized
50 51 52 53 54 55 56 57 |
# File 'lib/deep_symbolize.rb', line 50 def _recurse_(value, &block) if value.is_a?(Enumerable) && !value.is_a?(String) # support for a use case without extended core Hash value.extend DeepSymbolizable unless value.class.include?(DeepSymbolizable) value = value.deep_symbolize(&block) end value end |
#array(ary, &block) ⇒ Object
walking over arrays and symbolizing all nested elements
44 45 46 |
# File 'lib/deep_symbolize.rb', line 44 def array(ary, &block) ary.map { |v| _recurse_(v, &block) } end |
#hash(hash, &block) ⇒ Object
the primary method - symbolizes keys of the given hash, preprocessing them with a block if one was given, and recursively going into all nested enumerables
27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 |
# File 'lib/deep_symbolize.rb', line 27 def hash(hash, &block) hash.inject({}) do |result, (key, value)| # Recursively deep-symbolize subhashes value = _recurse_(value, &block) # Pre-process the key with a block if it was given key = yield key if block_given? # Symbolize the key string if it responds to to_sym sym_key = key.to_sym rescue key # write it back into the result and return the updated hash result[sym_key] = value result end end |