diff options
| author | nahi <nahi@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-04-01 11:02:34 +0000 |
|---|---|---|
| committer | nahi <nahi@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2004-04-01 11:02:34 +0000 |
| commit | 979f5771f180384e7986a029d254a1200c62b622 (patch) | |
| tree | e890e8181d44868f0fc0472c26e0b22cd75d40fa | |
| parent | 1518fc41c1990bb612937c1229afd958688abaae (diff) | |
* lib/soap/mapping/{factory.rb,registry.rb}: fixed illegal mapped URI
object with soap/marshal.
added URIFactory class for URI mapping. BasetypeFactory checks
instance_variables when original mapping is not allowed (ivar must
be empty). Instance of URI have instance_variables but it must be
llowed whenever original mapping is allowed or not.
* lib/xsd/datatypes.rb: check the smallest positive non-zero
single-precision float exactly instead of packing with "f".
[ruby-talk:88822]
* lib/soap/mapping/rubytypeFactory.rb: should not dump singleton class.
[ruby-dev:22588]
c = class << Object.new; class C; self; end; end; SOAPMarshal.dump(c)
git-svn-id: http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_8@6062 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
| -rw-r--r-- | ChangeLog | 17 | ||||
| -rw-r--r-- | lib/soap/mapping/factory.rb | 14 | ||||
| -rw-r--r-- | lib/soap/mapping/registry.rb | 5 | ||||
| -rw-r--r-- | lib/soap/mapping/rubytypeFactory.rb | 4 | ||||
| -rw-r--r-- | lib/xsd/datatypes.rb | 16 |
5 files changed, 48 insertions, 8 deletions
@@ -1,3 +1,20 @@ +Thu Apr 1 19:58:37 2004 NAKAMURA, Hiroshi <nakahiro@sarion.co.jp> + + * lib/soap/mapping/{factory.rb,registry.rb}: fixed illegal mapped URI + object with soap/marshal. + added URIFactory class for URI mapping. BasetypeFactory checks + instance_variables when original mapping is not allowed (ivar must + be empty). Instance of URI have instance_variables but it must be + llowed whenever original mapping is allowed or not. + + * lib/xsd/datatypes.rb: check the smallest positive non-zero + single-precision float exactly instead of packing with "f". + [ruby-talk:88822] + + * lib/soap/mapping/rubytypeFactory.rb: should not dump singleton class. + [ruby-dev:22588] + c = class << Object.new; class C; self; end; end; SOAPMarshal.dump(c) + Wed Mar 31 19:06:23 2004 Tanaka Akira <akr@m17n.org> * time.c (year_leap_p): new function. diff --git a/lib/soap/mapping/factory.rb b/lib/soap/mapping/factory.rb index bf6870122..fe6a6de7a 100644 --- a/lib/soap/mapping/factory.rb +++ b/lib/soap/mapping/factory.rb @@ -220,6 +220,20 @@ class Base64Factory_ < Factory end end +class URIFactory_ < Factory + def obj2soap(soap_class, obj, info, map) + soap_obj = soap_class.new(obj) + mark_marshalled_obj(obj, soap_obj) if soap_obj + soap_obj + end + + def soap2obj(obj_class, node, info, map) + obj = node.data + mark_unmarshalled_obj(node, obj) + return true, obj + end +end + class ArrayFactory_ < Factory def initialize(allow_original_mapping = false) super() diff --git a/lib/soap/mapping/registry.rb b/lib/soap/mapping/registry.rb index 46a04e368..814204772 100644 --- a/lib/soap/mapping/registry.rb +++ b/lib/soap/mapping/registry.rb @@ -186,6 +186,7 @@ class Registry DateTimeFactory = DateTimeFactory_.new ArrayFactory = ArrayFactory_.new Base64Factory = Base64Factory_.new + URIFactory = URIFactory_.new TypedArrayFactory = TypedArrayFactory_.new TypedStructFactory = TypedStructFactory_.new @@ -213,7 +214,7 @@ class Registry {:derived_class => true}], [::Integer, ::SOAP::SOAPShort, BasetypeFactory, {:derived_class => true}], - [::URI::Generic, ::SOAP::SOAPAnyURI, BasetypeFactory, + [::URI::Generic, ::SOAP::SOAPAnyURI, URIFactory, {:derived_class => true}], [::String, ::SOAP::SOAPBase64, Base64Factory], [::String, ::SOAP::SOAPHexBinary, Base64Factory], @@ -259,7 +260,7 @@ class Registry {:derived_class => true}], [::Integer, ::SOAP::SOAPShort, BasetypeFactory, {:derived_class => true}], - [::URI::Generic, ::SOAP::SOAPAnyURI, BasetypeFactory, + [::URI::Generic, ::SOAP::SOAPAnyURI, URIFactory, {:derived_class => true}], [::String, ::SOAP::SOAPBase64, Base64Factory], [::String, ::SOAP::SOAPHexBinary, Base64Factory], diff --git a/lib/soap/mapping/rubytypeFactory.rb b/lib/soap/mapping/rubytypeFactory.rb index a447715ad..f79bc78cc 100644 --- a/lib/soap/mapping/rubytypeFactory.rb +++ b/lib/soap/mapping/rubytypeFactory.rb @@ -167,7 +167,7 @@ class RubytypeFactory < Factory unless @allow_original_mapping return nil end - if obj.name.empty? + if obj.to_s[0] == ?# raise TypeError.new("Can't dump anonymous class #{ obj }.") end param = SOAPStruct.new(TYPE_CLASS) @@ -178,7 +178,7 @@ class RubytypeFactory < Factory unless @allow_original_mapping return nil end - if obj.name.empty? + if obj.to_s[0] == ?# raise TypeError.new("Can't dump anonymous module #{ obj }.") end param = SOAPStruct.new(TYPE_MODULE) diff --git a/lib/xsd/datatypes.rb b/lib/xsd/datatypes.rb index f318e612b..7223632b0 100644 --- a/lib/xsd/datatypes.rb +++ b/lib/xsd/datatypes.rb @@ -268,8 +268,11 @@ end module FloatConstants NaN = 0.0/0.0 - POSITIVE_INF = 1.0/0.0 + POSITIVE_INF = +1.0/0.0 NEGATIVE_INF = -1.0/0.0 + POSITIVE_ZERO = +1.0/POSITIVE_INF + NEGATIVE_ZERO = -1.0/POSITIVE_INF + MIN_POSITIVE_SINGLE = 2 ** -149 end class XSDFloat < XSDAnySimpleType @@ -320,7 +323,7 @@ private elsif @data.infinite? == -1 '-INF' else - sign = (1 / @data > 0.0) ? '+' : '-' + sign = XSDFloat.positive?(@data) ? '+' : '-' sign + sprintf("%.10g", @data.abs).sub(/[eE]([+-])?0+/) { 'e' + $1 } end end @@ -329,11 +332,16 @@ private def narrow32bit(f) if f.nan? || f.infinite? f + elsif f.abs < MIN_POSITIVE_SINGLE + XSDFloat.positive?(f) ? POSITIVE_ZERO : NEGATIVE_ZERO else - packed = [f].pack("f") - (/\A\0*\z/ =~ packed)? 0.0 : f + f end end + + def self.positive?(value) + (1 / value) > 0.0 + end end # Ruby's Float is double-precision 64-bit floating point value. |
