Sha256: 078bcbdb5faa6bf9f32ffa4cc1bf6eaad98faa5bb5fa5ef56edaa84e129be2ba

Contents?: true

Size: 1.76 KB

Versions: 10

Compression:

Stored size: 1.76 KB

Contents

require 'facets/symbol/to_proc'

class Hash

  # Rekey a hash.
  #
  #   rekey()
  #   rekey(to_key, from_key)
  #   rekey{ |key| ... }
  #
  # If no arguments or block are given, then all keys are converted
  # to Symbols.
  #
  # If two keys are given, then the second key is changed to
  # the first. You can think of it as +alias+ for hash keys.
  #
  #   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, 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, 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

10 entries across 10 versions & 1 rubygems

Version Path
facets-2.8.4 lib/core/facets/hash/rekey.rb
facets-2.8.3 lib/core/facets/hash/rekey.rb
facets-2.8.2 lib/core/facets/hash/rekey.rb
facets-2.8.1 lib/core/facets/hash/rekey.rb
facets-2.8.0 lib/core/facets/hash/rekey.rb
facets-2.7.0 lib/core/facets/hash/rekey.rb
facets-2.6.0 lib/core/facets/hash/rekey.rb
facets-2.5.1 lib/core/facets/hash/rekey.rb
facets-2.5.0 lib/core/facets/hash/rekey.rb
facets-2.5.2 lib/core/facets/hash/rekey.rb