diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2013-07-21 17:46:54 -0700 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2013-07-21 17:46:54 -0700 |
| commit | 9f9418eacf39af44d85f204ee046ca8efac70199 (patch) | |
| tree | 1cb2180470b733bdbbabadf6e325778567d39c5a /mrblib | |
| parent | 9ddb2253d02d6a4f3bdef2e17fb492ce53b799fc (diff) | |
| parent | ab787ab9683b8295ab2cb03d94dbbad1ebfe5db7 (diff) | |
| download | mruby-9f9418eacf39af44d85f204ee046ca8efac70199.tar.gz mruby-9f9418eacf39af44d85f204ee046ca8efac70199.zip | |
Merge pull request #1396 from Archytaus/attr-perf-fix
Performance improvement of methods generated by Module#attr
Diffstat (limited to 'mrblib')
| -rw-r--r-- | mrblib/class.rb | 24 |
1 files changed, 15 insertions, 9 deletions
diff --git a/mrblib/class.rb b/mrblib/class.rb index 4f268b6c8..6d624ee83 100644 --- a/mrblib/class.rb +++ b/mrblib/class.rb @@ -1,18 +1,24 @@ class Module # 15.2.2.4.13 def attr_reader(*names) - names.each{|name| - name2 = ('@'+name.to_s).intern - define_method(name){self.instance_variable_get(name2)} - } + names.each do |name| + name = name.to_s + raise(NameError, "#{name.inspect} is not allowed as an instance variable name") if name.include?('@') || name.include?('?') || name.include?('$') + + attr_name = '@'+name + define_method(name){self.instance_variable_get(attr_name)} + end end # 15.2.2.4.14 def attr_writer(*names) - names.each{|name| - name2 = ('@'+name.to_s).intern - name = (name.to_s+"=").intern - define_method(name){|v|self.instance_variable_set(name2,v)} - } + names.each do |name| + name = name.to_s + raise(NameError, "#{name.inspect} is not allowed as an instance variable name") if name.include?('@') || name.include?('?') || name.include?('$') + + attr_name = '@'+name + name = (name+"=").intern + define_method(name){|v|self.instance_variable_set(attr_name,v)} + end end # 15.2.2.4.12 def attr_accessor(*names) |
