Class: InsertOrderPreservingHash

Inherits:
Hash
  • Object
show all
Includes:
Enumerable
Defined in:
lib/json/ld/extensions.rb

Instance Method Summary collapse

Methods inherited from Hash

ordered

Constructor Details

#initialize(*args, &block) ⇒ InsertOrderPreservingHash

Returns a new instance of InsertOrderPreservingHash.



74
75
76
77
# File 'lib/json/ld/extensions.rb', line 74

def initialize(*args, &block)
  super
  @ordered_keys = []
end

Instance Method Details

#[]=(key, val) ⇒ Object



79
80
81
82
# File 'lib/json/ld/extensions.rb', line 79

def []=(key, val)
  @ordered_keys << key unless has_key? key
  super
end

#clearObject



101
102
103
104
# File 'lib/json/ld/extensions.rb', line 101

def clear
  @ordered_keys.clear
  super
end

#delete(k, &block) ⇒ Object



106
107
108
109
# File 'lib/json/ld/extensions.rb', line 106

def delete(k, &block)
  @ordered_keys.delete(k)
  super
end

#delete_if(&block) ⇒ Object



118
119
120
121
# File 'lib/json/ld/extensions.rb', line 118

def delete_if(&block)
  reject!(&block)
  self
end

#eachObject Also known as: each_pair



84
85
86
# File 'lib/json/ld/extensions.rb', line 84

def each
  @ordered_keys.each {|k| yield(k, self[k])}
end

#each_keyObject



93
94
95
# File 'lib/json/ld/extensions.rb', line 93

def each_key
  @ordered_keys.each {|k| yield k}
end

#each_valueObject



89
90
91
# File 'lib/json/ld/extensions.rb', line 89

def each_value
  @ordered_keys.each {|k| yield(super[k])}
end

#keysObject



97
98
99
# File 'lib/json/ld/extensions.rb', line 97

def keys
  @ordered_keys
end

#merge(other) ⇒ Object



131
132
133
# File 'lib/json/ld/extensions.rb', line 131

def merge(other)
  self.dup.merge!(other)
end

#merge!(other) ⇒ Object



123
124
125
126
127
128
129
# File 'lib/json/ld/extensions.rb', line 123

def merge!(other)
  new_keys = other.instance_variable_get(:@ordered_keys) || other.keys
  new_keys -= @ordered_keys
  @ordered_keys += new_keys
  super
  self
end

#reject!Object



111
112
113
114
115
116
# File 'lib/json/ld/extensions.rb', line 111

def reject!
  del = []
  each_pair {|k,v| del << k if yield k,v}
  del.each {|k| delete k}
  del.empty? ? nil : self
end