diff options
| author | takahashim <[email protected]> | 2015-11-23 19:51:02 +0900 |
|---|---|---|
| committer | takahashim <[email protected]> | 2015-11-24 08:39:39 +0900 |
| commit | 621487a0cd8acc5bbec73c98ebbb23c519ba6e6d (patch) | |
| tree | 7c28981ea380b3fa0f1bc7f9e59f98e7b2a0cb2d /mrbgems/mruby-hash-ext/mrblib | |
| parent | 625a3fee7729a12b0ff613e80b7b45ba0e2f086b (diff) | |
| download | mruby-621487a0cd8acc5bbec73c98ebbb23c519ba6e6d.tar.gz mruby-621487a0cd8acc5bbec73c98ebbb23c519ba6e6d.zip | |
add {Array|Hash|String}.try_convert
Diffstat (limited to 'mrbgems/mruby-hash-ext/mrblib')
| -rw-r--r-- | mrbgems/mruby-hash-ext/mrblib/hash.rb | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/mrbgems/mruby-hash-ext/mrblib/hash.rb b/mrbgems/mruby-hash-ext/mrblib/hash.rb index f72cb54e8..2727e1f65 100644 --- a/mrbgems/mruby-hash-ext/mrblib/hash.rb +++ b/mrbgems/mruby-hash-ext/mrblib/hash.rb @@ -62,6 +62,25 @@ class Hash ## # call-seq: + # Hash.try_convert(obj) -> hash or nil + # + # Try to convert <i>obj</i> into a hash, using to_hash method. + # Returns converted hash or nil if <i>obj</i> cannot be converted + # for any reason. + # + # Hash.try_convert({1=>2}) # => {1=>2} + # Hash.try_convert("1=>2") # => nil + # + def self.try_convert(obj) + if obj.respond_to?(:to_hash) + obj.to_hash + else + nil + end + end + + ## + # call-seq: # hsh.merge!(other_hash) -> hsh # hsh.merge!(other_hash){|key, oldval, newval| block} -> hsh # |
