Class: Thor::CoreExt::HashWithIndifferentAccess
- Inherits:
-
Hash
- Object
- Hash
- Thor::CoreExt::HashWithIndifferentAccess
show all
- Defined in:
- lib/bundler/vendor/thor/core_ext/hash_with_indifferent_access.rb
Overview
A hash with indifferent access and magic predicates.
hash = Thor::CoreExt::HashWithIndifferentAccess.new 'foo' => 'bar', 'baz' => 'bee', 'force' => true
hash[:foo] hash['foo'] hash.foo?
Instance Method Summary
collapse
Constructor Details
12
13
14
15
16
17
|
# File 'lib/bundler/vendor/thor/core_ext/hash_with_indifferent_access.rb', line 12
def initialize(hash = {})
super()
hash.each do |key, value|
self[convert_key(key)] = value
end
end
|
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(method, *args, &block) ⇒ Object
Magic predicates. For instance:
options.force? options.shebang options.test_framework?(:rspec)
63
64
65
66
67
68
69
70
71
72
73
74
|
# File 'lib/bundler/vendor/thor/core_ext/hash_with_indifferent_access.rb', line 63
def method_missing(method, *args, &block)
method = method.to_s
if method =~ /^(\w+)\?$/
if args.empty?
!!self[$1]
else
self[$1] == args.first
end
else
self[method]
end
end
|
Instance Method Details
#[](key) ⇒ Object
19
20
21
|
# File 'lib/bundler/vendor/thor/core_ext/hash_with_indifferent_access.rb', line 19
def [](key)
super(convert_key(key))
end
|
#[]=(key, value) ⇒ Object
23
24
25
|
# File 'lib/bundler/vendor/thor/core_ext/hash_with_indifferent_access.rb', line 23
def []=(key, value)
super(convert_key(key), value)
end
|
#delete(key) ⇒ Object
27
28
29
|
# File 'lib/bundler/vendor/thor/core_ext/hash_with_indifferent_access.rb', line 27
def delete(key)
super(convert_key(key))
end
|
#merge(other) ⇒ Object
35
36
37
|
# File 'lib/bundler/vendor/thor/core_ext/hash_with_indifferent_access.rb', line 35
def merge(other)
dup.merge!(other)
end
|
#merge!(other) ⇒ Object
39
40
41
42
43
44
|
# File 'lib/bundler/vendor/thor/core_ext/hash_with_indifferent_access.rb', line 39
def merge!(other)
other.each do |key, value|
self[convert_key(key)] = value
end
self
end
|
#to_hash ⇒ Object
Convert to a Hash with String keys.
47
48
49
|
# File 'lib/bundler/vendor/thor/core_ext/hash_with_indifferent_access.rb', line 47
def to_hash
Hash.new(default).merge!(self)
end
|
#values_at(*indices) ⇒ Object
31
32
33
|
# File 'lib/bundler/vendor/thor/core_ext/hash_with_indifferent_access.rb', line 31
def values_at(*indices)
indices.map { |key| self[convert_key(key)] }
end
|