From: "charliesome (Charlie Somerville)" Date: 2013-07-17T04:09:19+09:00 Subject: [ruby-core:56051] [CommonRuby - Feature #8643] Add Binding.from_hash Issue #8643 has been updated by charliesome (Charlie Somerville). Personally I think hash keys should be local variables in the binding, not method calls against self. It's hard to express this in Ruby, but this can easily be done from the C side. ---------------------------------------- Feature #8643: Add Binding.from_hash https://bugs.ruby-lang.org/issues/8643#change-40537 Author: rosenfeld (Rodrigo Rosenfeld Rosas) Status: Open Priority: Normal Assignee: Category: Target version: Binding.from_hash would work like: class Binding def self.from_hash(hash) OpenStruct.new(hash){ binding } end end It would simplify things like: ERB.new(IO.read 'template.erb').result Binding.from_hash(template_local: 'example') Or if you need to eval some code in another process (JRuby, for instance) and need to pass some arguments to the eval code in a hash form. I didn't want to pollute Hash by adding Hash#to_binding. I believe Binding.from_hash is more appropriate. -- http://bugs.ruby-lang.org/