Class: Thor::CoreExt::OrderedHash
- Inherits:
-
Hash
- Object
- Hash
- Thor::CoreExt::OrderedHash
- Defined in:
- lib/thor-plus/core_ext/ordered_hash.rb
Instance Method Summary collapse
- #[]=(key, value) ⇒ Object
- #clear ⇒ Object
- #delete(key) ⇒ Object
- #delete_if ⇒ Object (also: #reject!)
- #each ⇒ Object
- #each_key ⇒ Object
- #each_pair ⇒ Object
- #each_value ⇒ Object
-
#initialize(*args, &block) ⇒ OrderedHash
constructor
A new instance of OrderedHash.
- #initialize_copy(other) ⇒ Object
- #inspect ⇒ Object
- #keys ⇒ Object
- #merge(other_hash, &block) ⇒ Object
- #merge!(other_hash) ⇒ Object (also: #update)
- #reject(&block) ⇒ Object
-
#replace(other) ⇒ Object
When replacing with another hash, the initial order of our keys must come from the other hash -ordered or not.
- #shift ⇒ Object
- #to_a ⇒ Object
- #to_hash ⇒ Object
- #values ⇒ Object
Constructor Details
#initialize(*args, &block) ⇒ OrderedHash
Returns a new instance of OrderedHash.
5 6 7 8 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 5 def initialize(*args, &block) super @keys = [] end |
Instance Method Details
#[]=(key, value) ⇒ Object
16 17 18 19 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 16 def []=(key, value) @keys << key unless key?(key) super end |
#clear ⇒ Object
83 84 85 86 87 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 83 def clear super @keys.clear self end |
#delete(key) ⇒ Object
21 22 23 24 25 26 27 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 21 def delete(key) if key? key index = @keys.index(key) @keys.delete_at index end super end |
#delete_if ⇒ Object Also known as: reject!
29 30 31 32 33 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 29 def delete_if super sync_keys! self end |
#each ⇒ Object
69 70 71 72 73 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 69 def each return to_enum(:each) unless block_given? @keys.each { |key| yield([key, self[key]]) } self end |
#each_key ⇒ Object
57 58 59 60 61 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 57 def each_key return to_enum(:each_key) unless block_given? @keys.each { |key| yield(key) } self end |
#each_pair ⇒ Object
75 76 77 78 79 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 75 def each_pair return to_enum(:each_pair) unless block_given? @keys.each { |key| yield(key, self[key]) } self end |
#each_value ⇒ Object
63 64 65 66 67 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 63 def each_value return to_enum(:each_value) unless block_given? @keys.each { |key| yield(self[key]) } self end |
#initialize_copy(other) ⇒ Object
10 11 12 13 14 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 10 def initialize_copy(other) super # make a deep copy of keys @keys = other.keys end |
#inspect ⇒ Object
117 118 119 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 117 def inspect "#<#{self.class} #{super}>" end |
#keys ⇒ Object
41 42 43 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 41 def keys @keys.dup end |
#merge(other_hash, &block) ⇒ Object
106 107 108 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 106 def merge(other_hash, &block) dup.merge!(other_hash, &block) end |
#merge!(other_hash) ⇒ Object Also known as: update
95 96 97 98 99 100 101 102 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 95 def merge!(other_hash) if block_given? other_hash.each { |k, v| self[k] = key?(k) ? yield(k, self[k], v) : v } else other_hash.each { |k, v| self[k] = v } end self end |
#reject(&block) ⇒ Object
37 38 39 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 37 def reject(&block) dup.reject!(&block) end |
#replace(other) ⇒ Object
When replacing with another hash, the initial order of our keys must come from the other hash -ordered or not.
111 112 113 114 115 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 111 def replace(other) super @keys = other.keys self end |
#shift ⇒ Object
89 90 91 92 93 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 89 def shift k = @keys.first v = delete(k) [k, v] end |
#to_a ⇒ Object
53 54 55 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 53 def to_a @keys.map { |key| [key, self[key]] } end |
#to_hash ⇒ Object
49 50 51 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 49 def to_hash self end |
#values ⇒ Object
45 46 47 |
# File 'lib/thor-plus/core_ext/ordered_hash.rb', line 45 def values @keys.map { |key| self[key] } end |