summaryrefslogtreecommitdiff
path: root/lib/soap/baseData.rb
diff options
context:
space:
mode:
authornahi <nahi@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-12-21 15:08:56 +0000
committernahi <nahi@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-12-21 15:08:56 +0000
commit3edeb852fe27ae9d11596697ea74f9b583f69e8a (patch)
treeec583bf4781cefd0a19735386b456046b8993d70 /lib/soap/baseData.rb
parent3a664c4b407c9273b90eaca48da83b8719eb5b1b (diff)
* lib/soap/*, test/soap/*, sample/soap/authheader/*: eval cleanup.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@7628 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'lib/soap/baseData.rb')
-rw-r--r--lib/soap/baseData.rb21
1 files changed, 7 insertions, 14 deletions
diff --git a/lib/soap/baseData.rb b/lib/soap/baseData.rb
index 2d3d059ebf..bf2fe6b25c 100644
--- a/lib/soap/baseData.rb
+++ b/lib/soap/baseData.rb
@@ -595,20 +595,13 @@ private
if self.respond_to?(methodname)
methodname = safe_accessor_name(methodname)
end
- begin
- instance_eval <<-EOS
- def #{ methodname }()
- @data[@array.index('#{ name }')]
- end
-
- def #{ methodname }=(value)
- @data[@array.index('#{ name }')] = value
- end
- EOS
- rescue SyntaxError
- methodname = safe_accessor_name(methodname)
- retry
- end
+ sclass = class << self; self; end
+ sclass.__send__(:define_method, methodname, proc {
+ @data[@array.index(name)]
+ })
+ sclass.__send__(:define_method, methodname + '=', proc { |value|
+ @data[@array.index(name)] = value
+ })
end
def safe_accessor_name(name)