diff options
| author | Ryan Scott <[email protected]> | 2013-07-19 22:40:54 +1000 |
|---|---|---|
| committer | Ryan Scott <[email protected]> | 2013-07-19 22:40:54 +1000 |
| commit | eb0ee358157d063b3bfc87b94ecfc2e20f6ec764 (patch) | |
| tree | ae7e30ed6b2cfc23a1e22b48c6e67245d75345a3 /mrblib | |
| parent | 75f8aab247abf58b61b3700c078d61ccf7e168bf (diff) | |
| parent | fe5324bd17d1716592b244762173e7478ebf7853 (diff) | |
| download | mruby-eb0ee358157d063b3bfc87b94ecfc2e20f6ec764.tar.gz mruby-eb0ee358157d063b3bfc87b94ecfc2e20f6ec764.zip | |
Merge branch 'master' into attr-perf-fix
Conflicts:
mrblib/class.rb
Diffstat (limited to 'mrblib')
| -rw-r--r-- | mrblib/class.rb | 20 |
1 files changed, 13 insertions, 7 deletions
diff --git a/mrblib/class.rb b/mrblib/class.rb index d6ef34f17..0678d943d 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) + 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?('$') + + name2 = ('@'+name).intern define_method(name){self.instance_variable_get(name2)} - } + end end # 15.2.2.4.14 def attr_writer(*names) - names.each{|name| - name2 = ('@'+name.to_s) - name = (name.to_s+"=") + 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?('$') + + name2 = ('@'+name).intern + name = (name+"=").intern define_method(name){|v|self.instance_variable_set(name2,v)} - } + end end # 15.2.2.4.12 def attr_accessor(*names) |
