Class: Rack::QueryParser::Params
- Inherits:
-
Object
- Object
- Rack::QueryParser::Params
- Defined in:
- lib/rack/query_parser.rb
Instance Method Summary collapse
- #[](key) ⇒ Object
- #[]=(key, value) ⇒ Object
-
#initialize ⇒ Params
constructor
A new instance of Params.
- #key?(key) ⇒ Boolean
-
#to_h ⇒ Object
(also: #to_params_hash)
Recursively unwraps nested `Params` objects and constructs an object of the same shape, but using the objects' internal representations (Ruby hashes) in place of the objects.
Constructor Details
#initialize ⇒ Params
Returns a new instance of Params.
204 205 206 207 |
# File 'lib/rack/query_parser.rb', line 204 def initialize @size = 0 @params = {} end |
Instance Method Details
#[](key) ⇒ Object
209 210 211 |
# File 'lib/rack/query_parser.rb', line 209 def [](key) @params[key] end |
#[]=(key, value) ⇒ Object
213 214 215 |
# File 'lib/rack/query_parser.rb', line 213 def []=(key, value) @params[key] = value end |
#key?(key) ⇒ Boolean
217 218 219 |
# File 'lib/rack/query_parser.rb', line 217 def key?(key) @params.key?(key) end |
#to_h ⇒ Object Also known as: to_params_hash
Recursively unwraps nested `Params` objects and constructs an object of the same shape, but using the objects' internal representations (Ruby hashes) in place of the objects. The result is a hash consisting purely of Ruby primitives.
Mutation warning!
1. This method mutates the internal representation of the `Params`
objects in order to save object allocations.
2. The value you get back is a reference to the internal hash
representation, not a copy.
3. Because the `Params` object's internal representation is mutable
through the `#[]=` method, it is not thread safe. The result of
getting the hash representation while another thread is adding a
key to it is non-deterministic.
239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 |
# File 'lib/rack/query_parser.rb', line 239 def to_h @params.each do |key, value| case value when self # Handle circular references gracefully. @params[key] = @params when Params @params[key] = value.to_h when Array value.map! { |v| v.kind_of?(Params) ? v.to_h : v } else # Ignore anything that is not a `Params` object or # a collection that can contain one. end end @params end |