summaryrefslogtreecommitdiff
path: root/lib/soap/baseData.rb
diff options
context:
space:
mode:
Diffstat (limited to 'lib/soap/baseData.rb')
-rw-r--r--lib/soap/baseData.rb128
1 files changed, 103 insertions, 25 deletions
diff --git a/lib/soap/baseData.rb b/lib/soap/baseData.rb
index bf2fe6b25c..6d0f628be9 100644
--- a/lib/soap/baseData.rb
+++ b/lib/soap/baseData.rb
@@ -1,5 +1,5 @@
# soap/baseData.rb: SOAP4R - Base type library
-# Copyright (C) 2000, 2001, 2003, 2004 NAKAMURA, Hiroshi <nahi@ruby-lang.org>.
+# Copyright (C) 2000, 2001, 2003-2005 NAKAMURA, Hiroshi <nahi@ruby-lang.org>.
# This program is copyrighted free software by NAKAMURA, Hiroshi. You can
# redistribute it and/or modify it under the same terms of Ruby's license;
@@ -56,6 +56,14 @@ module SOAPType
@extraattr = {}
end
+ def inspect
+ if self.is_a?(XSD::NSDBase)
+ sprintf("#<%s:0x%x %s %s>", self.class.name, __id__, self.elename, self.type)
+ else
+ sprintf("#<%s:0x%x %s>", self.class.name, __id__, self.elename)
+ end
+ end
+
def rootnode
node = self
while node = node.parent
@@ -399,7 +407,7 @@ public
def to_s()
str = ''
self.each do |key, data|
- str << "#{ key }: #{ data }\n"
+ str << "#{key}: #{data}\n"
end
str
end
@@ -442,6 +450,25 @@ public
@array
end
+ def to_obj
+ hash = {}
+ proptype = {}
+ each do |k, v|
+ value = v.respond_to?(:to_obj) ? v.to_obj : v.to_s
+ case proptype[k]
+ when :single
+ hash[k] = [hash[k], value]
+ proptype[k] = :multi
+ when :multi
+ hash[k] << value
+ else
+ hash[k] = value
+ proptype[k] = :single
+ end
+ end
+ hash
+ end
+
def each
for i in 0..(@array.length - 1)
yield(@array[i], @data[i])
@@ -509,6 +536,10 @@ class SOAPElement
@text = text
end
+ def inspect
+ sprintf("#<%s:0x%x %s>", self.class.name, __id__, self.elename)
+ end
+
# Text interface.
attr_accessor :text
alias data text
@@ -548,8 +579,19 @@ class SOAPElement
@text
else
hash = {}
+ proptype = {}
each do |k, v|
- hash[k] = v.is_a?(SOAPElement) ? v.to_obj : v.to_s
+ value = v.respond_to?(:to_obj) ? v.to_obj : v.to_s
+ case proptype[k]
+ when :single
+ hash[k] = [hash[k], value]
+ proptype[k] = :multi
+ when :multi
+ hash[k] << value
+ else
+ hash[k] = value
+ proptype[k] = :single
+ end
end
hash
end
@@ -566,20 +608,41 @@ class SOAPElement
o
end
- def self.from_obj(hash_or_string)
+ def self.from_obj(obj, namespace = nil)
o = SOAPElement.new(nil)
- if hash_or_string.is_a?(Hash)
- hash_or_string.each do |k, v|
- child = self.from_obj(v)
- child.elename = k.is_a?(XSD::QName) ? k : XSD::QName.new(nil, k.to_s)
- o.add(child)
+ case obj
+ when nil
+ o.text = nil
+ when Hash
+ obj.each do |elename, value|
+ if value.is_a?(Array)
+ value.each do |subvalue|
+ child = from_obj(subvalue, namespace)
+ child.elename = to_elename(elename, namespace)
+ o.add(child)
+ end
+ else
+ child = from_obj(value, namespace)
+ child.elename = to_elename(elename, namespace)
+ o.add(child)
+ end
end
else
- o.text = hash_or_string
+ o.text = obj.to_s
end
o
end
+ def self.to_elename(obj, namespace = nil)
+ if obj.is_a?(XSD::QName)
+ obj
+ elsif /\A(.+):([^:]+)\z/ =~ obj.to_s
+ XSD::QName.new($1, $2)
+ else
+ XSD::QName.new(namespace, obj.to_s)
+ end
+ end
+
private
def add_member(name, value)
@@ -590,18 +653,32 @@ private
value
end
- def add_accessor(name)
- methodname = name
- if self.respond_to?(methodname)
- methodname = safe_accessor_name(methodname)
+ if RUBY_VERSION > "1.7.0"
+ def add_accessor(name)
+ methodname = name
+ if self.respond_to?(methodname)
+ methodname = safe_accessor_name(methodname)
+ end
+ Mapping.define_singleton_method(self, methodname) do
+ @data[@array.index(name)]
+ end
+ Mapping.define_singleton_method(self, methodname + '=') do |value|
+ @data[@array.index(name)] = value
+ end
+ end
+ else
+ def add_accessor(name)
+ methodname = safe_accessor_name(name)
+ instance_eval <<-EOS
+ def #{methodname}
+ @data[@array.index(#{name.dump})]
+ end
+
+ def #{methodname}=(value)
+ @data[@array.index(#{name.dump})] = value
+ end
+ EOS
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)
@@ -624,7 +701,7 @@ public
def initialize(type = nil, rank = 1, arytype = nil)
super()
- @type = type || XSD::QName.new
+ @type = type || ValueArrayName
@rank = rank
@data = Array.new
@sparse = false
@@ -646,7 +723,7 @@ public
def [](*idxary)
if idxary.size != @rank
- raise ArgumentError.new("Given #{ idxary.size } params does not match rank: #{ @rank }")
+ raise ArgumentError.new("given #{idxary.size} params does not match rank: #{@rank}")
end
retrieve(idxary)
@@ -656,7 +733,8 @@ public
value = idxary.slice!(-1)
if idxary.size != @rank
- raise ArgumentError.new("Given #{ idxary.size } params(#{ idxary }) does not match rank: #{ @rank }")
+ raise ArgumentError.new("given #{idxary.size} params(#{idxary})" +
+ " does not match rank: #{@rank}")
end
for i in 0..(idxary.size - 1)
@@ -836,7 +914,7 @@ public
private
def self.create_arytype(typename, rank)
- "#{ typename }[" << ',' * (rank - 1) << ']'
+ "#{typename}[" << ',' * (rank - 1) << ']'
end
TypeParseRegexp = Regexp.new('^(.+)\[([\d,]*)\]$')