AUTHOR
jan molic /mig/at/1984/dot/cz/
DESCRIPTION
Hash with preserved order and some array-like extensions Public domain.
THANKS
Andrew Johnson for his suggestions and fixes of Hash[], merge, to_a, inspect and shift
# File lib/nanoc/base/ordered_hash.rb, line 16 def [] *args hsh = OrderedHash.new if Hash === args[0] hsh.replace args[0] elsif (args.size % 2) != 0 raise ArgumentError, "odd number of elements for Hash" else 0.step(args.size - 1, 2) do |a| b = a + 1 hsh[args[a]] = args[b] end end hsh end
# File lib/nanoc/base/ordered_hash.rb, line 44 def == hsh2 return false if @order != hsh2.order super hsh2 end
# File lib/nanoc/base/ordered_hash.rb, line 160 def __class__ OrderedHash end
# File lib/nanoc/base/ordered_hash.rb, line 48 def clear @order = [] super end
# File lib/nanoc/base/ordered_hash.rb, line 52 def delete key @order.delete key super end
# File lib/nanoc/base/ordered_hash.rb, line 69 def delete_if @order.clone.each { |k| delete k if yield(k) } self end
# File lib/nanoc/base/ordered_hash.rb, line 64 def each @order.each { |k| yield k,self[k] } self end
# File lib/nanoc/base/ordered_hash.rb, line 56 def each_key @order.each { |k| yield k } self end
# File lib/nanoc/base/ordered_hash.rb, line 60 def each_value @order.each { |k| yield self[k] } self end
# File lib/nanoc/base/ordered_hash.rb, line 192 def each_with_index @order.each_with_index { |k, index| yield k, self[k], index } self end
# File lib/nanoc/base/ordered_hash.rb, line 83 def first {@order.first => self[@order.first]} end
# File lib/nanoc/base/ordered_hash.rb, line 139 def inspect ary = [] each {|k,v| ary << k.inspect + "=>" + v.inspect} '{' + ary.join(", ") + '}' end
# File lib/nanoc/base/ordered_hash.rb, line 89 def invert hsh2 = Hash.new @order.each { |k| hsh2[self[k]] = k } hsh2 end
# File lib/nanoc/base/ordered_hash.rb, line 86 def last {@order.last => self[@order.last]} end
# File lib/nanoc/base/ordered_hash.rb, line 149 def merge hsh2 self.dup update(hsh2) end
# File lib/nanoc/base/ordered_hash.rb, line 127 def pop key = @order.last key ? [key,delete(key)] : nil end
# File lib/nanoc/base/ordered_hash.rb, line 118 def push k,v unless self.include? k @order.push k orig_store(k,v) true else false end end
# File lib/nanoc/base/ordered_hash.rb, line 94 def reject &block self.dup.delete_if &block end
# File lib/nanoc/base/ordered_hash.rb, line 97 def reject! &block hsh2 = reject &block self == hsh2 ? nil : hsh2 end
# File lib/nanoc/base/ordered_hash.rb, line 101 def replace hsh2 @order = hsh2.keys super hsh2 end
# File lib/nanoc/base/ordered_hash.rb, line 152 def select ary = [] each { |k,v| ary << [k,v] if yield k,v } ary end
# File lib/nanoc/base/ordered_hash.rb, line 105 def shift key = @order.first key ? [key,delete(key)] : super end
# File lib/nanoc/base/ordered_hash.rb, line 39 def store a,b @order.push a unless has_key? a super a,b end
# File lib/nanoc/base/ordered_hash.rb, line 35 def store_only a,b store a,b end
# File lib/nanoc/base/ordered_hash.rb, line 131 def to_a ary = [] each { |k,v| ary << [k,v] } ary end
# File lib/nanoc/base/ordered_hash.rb, line 136 def to_s self.to_a.to_s end
# File lib/nanoc/base/ordered_hash.rb, line 109 def unshift k,v unless self.include? k @order.unshift k orig_store(k,v) true else false end end
# File lib/nanoc/base/ordered_hash.rb, line 144 def update hsh2 hsh2.each { |k,v| self[k] = v } self end
# File lib/nanoc/base/ordered_hash.rb, line 75 def values ary = [] @order.each { |k| ary.push self[k] } ary end
# File lib/nanoc/base/ordered_hash.rb, line 190 def yaml_inline!() self.yaml_inline = true end
# File lib/nanoc/base/ordered_hash.rb, line 165 def yaml_inline= bool if respond_to?("to_yaml_style") self.to_yaml_style = :inline else unless defined? @__yaml_inline_meth @__yaml_inline_meth = lambda {|opts| YAML::quick_emit(object_id, opts) {|emitter| emitter << '{ ' << map{|kv| kv.join ': '}.join(', ') << ' }' } } class << self def to_yaml opts = {} begin @__yaml_inline ? @__yaml_inline_meth[ opts ] : super rescue @to_yaml_style = :inline super end end end end end @__yaml_inline = bool end
Generated with the Darkfish Rdoc Generator 2.