Issue #7793 has been updated by phluid61 (Matthew Kerwin).


nobu (Nobuyoshi Nakada) wrote:
> Anyway, why don't you make it a gem first?

That's a good idea.  Let's see what the uptake is, if any: https://rubygems.org/gems/hashmap

Note: I used #map_keys, #map_values and #map_pairs as my method names.

----------------------------------------
Feature #7793: New methods on Hash
https://bugs.ruby-lang.org/issues/7793#change-37553

Author: dsisnero (Dominic Sisneros)
Status: Assigned
Priority: Normal
Assignee: matz (Yukihiro Matsumoto)
Category: core
Target version: next minor


=begin
It would be nice to have the following methods added to hash

  h = { name: 'dominic', request: 'add the following methods', :why => 'convenience'}

  h.map_v{|v| v.upcase}
  #=> {:name=>"DOMINIC", :request=>"ADD THE FOLLOWING METHODS", :why=>"CONVENIENCE"}

  h.map_k{|k| k.to_s}
  #=> { "name"=> 'dominic', "request"=>"add the following methods', "why" => "convenience"}

  h.map_kv{|k,v| [k.to_s, v.upcase]}
  #=> { "name"=>"DOMINIC", "request"=>"ADD THE FOLLOWING METHODS", "why"=>"CONVENIENCE"}


  class Hash

    def map_v
      reduce({}) do |result, array|
        k,v = array
        new_val = yield v
        result.merge( k => new_val)
      end
    end

    def map_k
      reduce({}) do |result, array|
        k,v = array
        new_k = yield k
        result.merge(new_k => v)
      end
    end

    def map_kv
      reduce({}) do |result, array|
        new_k,new_v = yield array
        result.merge(new_k => new_v)
      end
    end

  end
=end



-- 
http://bugs.ruby-lang.org/