Sha256: a51e4a2a971575cb04ee6bff2d966da8bc2f2c4c1b995ea688d3b6d72aa28291
Contents?: true
Size: 1.61 KB
Versions: 5
Compression:
Stored size: 1.61 KB
Contents
require 'facets/symbol/to_proc' class Hash # rekey(to_key, from_key) # rekey{ |key| ... } # # If two keys are given, then the second key is changed to # the first. # # foo = { :a=>1, :b=>2 } # foo.rekey('a',:a) #=> { 'a'=>1, :b=>2 } # foo.rekey('b',:b) #=> { 'a'=>1, 'b'=>2 } # foo.rekey('foo','bar') #=> { 'a'=>1, 'b'=>2 } # # If a block is given, converts all keys in the Hash accroding # to the given block. If the block returns +nil+ for given key, # then that key will be left intact. # # foo = { :name=>'Gavin', :wife=>:Lisa } # foo.rekey{ |k| k.to_s } #=> { "name"=>"Gavin", "wife"=>:Lisa } # foo.inspect #=> { :name =>"Gavin", :wife=>:Lisa } # # CREDIT: Trans # CREDIT: Gavin Kistner def rekey(*args, &block) dup.rekey!(*args, &block) end # Synonym for Hash#rekey, but modifies the receiver in place (and returns it). # # foo = { :name=>'Gavin', :wife=>:Lisa } # foo.rekey!{ |k| k.to_s } #=> { "name"=>"Gavin", "wife"=>:Lisa } # foo.inspect #=> { "name"=>"Gavin", "wife"=>:Lisa } # # CREDIT: Trans # CREDIT: Gavin Kistner def rekey!(*args, &block) # for backward comptability (TODO: DEPRECATE). block = args.pop.to_sym.to_proc if args.size == 1 # if no args use block. if args.empty? block = lambda{|k| k.to_sym} unless block keys.each do |k| nk = block[k] self[nk]=delete(k) if nk end else raise ArgumentError, "3 for 2" if block to, from = *args self[to] = self.delete(from) if self.has_key?(from) end self end end
Version data entries
5 entries across 5 versions & 2 rubygems