railsware-soap4r 1.5.8.1

Sign up to get free protection for your applications and to get access to all the features.
Files changed (174) hide show
  1. data/README +5 -0
  2. data/TODO +0 -0
  3. data/bin/wsdl2ruby.rb +137 -0
  4. data/bin/xsd2ruby.rb +90 -0
  5. data/lib/soap/XMLSchemaDatatypes.rb +9 -0
  6. data/lib/soap/XMLSchemaDatatypes1999.rb +10 -0
  7. data/lib/soap/attachment.rb +108 -0
  8. data/lib/soap/baseData.rb +1092 -0
  9. data/lib/soap/cgistub.rb +9 -0
  10. data/lib/soap/charset.rb +9 -0
  11. data/lib/soap/compat.rb +182 -0
  12. data/lib/soap/driver.rb +9 -0
  13. data/lib/soap/element.rb +277 -0
  14. data/lib/soap/encodingstyle/aspDotNetHandler.rb +207 -0
  15. data/lib/soap/encodingstyle/handler.rb +120 -0
  16. data/lib/soap/encodingstyle/literalHandler.rb +192 -0
  17. data/lib/soap/encodingstyle/soapHandler.rb +559 -0
  18. data/lib/soap/filter.rb +13 -0
  19. data/lib/soap/filter/filterchain.rb +51 -0
  20. data/lib/soap/filter/handler.rb +31 -0
  21. data/lib/soap/filter/streamhandler.rb +29 -0
  22. data/lib/soap/generator.rb +304 -0
  23. data/lib/soap/header/handler.rb +61 -0
  24. data/lib/soap/header/handlerset.rb +70 -0
  25. data/lib/soap/header/mappinghandler.rb +47 -0
  26. data/lib/soap/header/simplehandler.rb +44 -0
  27. data/lib/soap/httpconfigloader.rb +139 -0
  28. data/lib/soap/mapping.rb +12 -0
  29. data/lib/soap/mapping/encodedregistry.rb +548 -0
  30. data/lib/soap/mapping/factory.rb +388 -0
  31. data/lib/soap/mapping/literalregistry.rb +388 -0
  32. data/lib/soap/mapping/mapping.rb +609 -0
  33. data/lib/soap/mapping/registry.rb +295 -0
  34. data/lib/soap/mapping/rubytypeFactory.rb +478 -0
  35. data/lib/soap/mapping/schemadefinition.rb +170 -0
  36. data/lib/soap/mapping/typeMap.rb +106 -0
  37. data/lib/soap/mapping/wsdlencodedregistry.rb +211 -0
  38. data/lib/soap/mapping/wsdlliteralregistry.rb +243 -0
  39. data/lib/soap/mappingRegistry.rb +9 -0
  40. data/lib/soap/marshal.rb +59 -0
  41. data/lib/soap/mimemessage.rb +241 -0
  42. data/lib/soap/namespace.rb +9 -0
  43. data/lib/soap/nestedexception.rb +42 -0
  44. data/lib/soap/netHttpClient.rb +241 -0
  45. data/lib/soap/ns.rb +34 -0
  46. data/lib/soap/parser.rb +252 -0
  47. data/lib/soap/processor.rb +66 -0
  48. data/lib/soap/property.rb +333 -0
  49. data/lib/soap/proxy.rb +14 -0
  50. data/lib/soap/qname.rb +9 -0
  51. data/lib/soap/rpc/cgistub.rb +247 -0
  52. data/lib/soap/rpc/driver.rb +247 -0
  53. data/lib/soap/rpc/element.rb +369 -0
  54. data/lib/soap/rpc/httpserver.rb +169 -0
  55. data/lib/soap/rpc/proxy.rb +576 -0
  56. data/lib/soap/rpc/router.rb +669 -0
  57. data/lib/soap/rpc/rpc.rb +25 -0
  58. data/lib/soap/rpc/soaplet.rb +210 -0
  59. data/lib/soap/rpc/standaloneServer.rb +43 -0
  60. data/lib/soap/rpcRouter.rb +9 -0
  61. data/lib/soap/rpcUtils.rb +9 -0
  62. data/lib/soap/server.rb +9 -0
  63. data/lib/soap/soap.rb +151 -0
  64. data/lib/soap/standaloneServer.rb +9 -0
  65. data/lib/soap/streamHandler.rb +302 -0
  66. data/lib/soap/wsdlDriver.rb +597 -0
  67. data/lib/tags +5690 -0
  68. data/lib/wsdl/binding.rb +65 -0
  69. data/lib/wsdl/data.rb +64 -0
  70. data/lib/wsdl/definitions.rb +236 -0
  71. data/lib/wsdl/documentation.rb +32 -0
  72. data/lib/wsdl/import.rb +80 -0
  73. data/lib/wsdl/importer.rb +38 -0
  74. data/lib/wsdl/info.rb +50 -0
  75. data/lib/wsdl/message.rb +54 -0
  76. data/lib/wsdl/operation.rb +178 -0
  77. data/lib/wsdl/operationBinding.rb +130 -0
  78. data/lib/wsdl/param.rb +93 -0
  79. data/lib/wsdl/parser.rb +164 -0
  80. data/lib/wsdl/part.rb +52 -0
  81. data/lib/wsdl/port.rb +84 -0
  82. data/lib/wsdl/portType.rb +75 -0
  83. data/lib/wsdl/service.rb +61 -0
  84. data/lib/wsdl/soap/address.rb +40 -0
  85. data/lib/wsdl/soap/binding.rb +49 -0
  86. data/lib/wsdl/soap/body.rb +58 -0
  87. data/lib/wsdl/soap/cgiStubCreator.rb +93 -0
  88. data/lib/wsdl/soap/classDefCreator.rb +433 -0
  89. data/lib/wsdl/soap/classDefCreatorSupport.rb +230 -0
  90. data/lib/wsdl/soap/classNameCreator.rb +54 -0
  91. data/lib/wsdl/soap/clientSkeltonCreator.rb +95 -0
  92. data/lib/wsdl/soap/complexType.rb +172 -0
  93. data/lib/wsdl/soap/data.rb +42 -0
  94. data/lib/wsdl/soap/definitions.rb +200 -0
  95. data/lib/wsdl/soap/driverCreator.rb +118 -0
  96. data/lib/wsdl/soap/element.rb +33 -0
  97. data/lib/wsdl/soap/encodedMappingRegistryCreator.rb +73 -0
  98. data/lib/wsdl/soap/fault.rb +56 -0
  99. data/lib/wsdl/soap/header.rb +86 -0
  100. data/lib/wsdl/soap/headerfault.rb +56 -0
  101. data/lib/wsdl/soap/literalMappingRegistryCreator.rb +115 -0
  102. data/lib/wsdl/soap/mappingRegistryCreator.rb +58 -0
  103. data/lib/wsdl/soap/mappingRegistryCreatorSupport.rb +376 -0
  104. data/lib/wsdl/soap/methodDefCreator.rb +263 -0
  105. data/lib/wsdl/soap/operation.rb +122 -0
  106. data/lib/wsdl/soap/servantSkeltonCreator.rb +80 -0
  107. data/lib/wsdl/soap/servletStubCreator.rb +107 -0
  108. data/lib/wsdl/soap/standaloneServerStubCreator.rb +103 -0
  109. data/lib/wsdl/soap/wsdl2ruby.rb +217 -0
  110. data/lib/wsdl/types.rb +44 -0
  111. data/lib/wsdl/wsdl.rb +24 -0
  112. data/lib/wsdl/xmlSchema/all.rb +24 -0
  113. data/lib/wsdl/xmlSchema/annotation.rb +34 -0
  114. data/lib/wsdl/xmlSchema/any.rb +61 -0
  115. data/lib/wsdl/xmlSchema/anyAttribute.rb +48 -0
  116. data/lib/wsdl/xmlSchema/attribute.rb +123 -0
  117. data/lib/wsdl/xmlSchema/attributeGroup.rb +86 -0
  118. data/lib/wsdl/xmlSchema/choice.rb +58 -0
  119. data/lib/wsdl/xmlSchema/complexContent.rb +97 -0
  120. data/lib/wsdl/xmlSchema/complexExtension.rb +119 -0
  121. data/lib/wsdl/xmlSchema/complexRestriction.rb +104 -0
  122. data/lib/wsdl/xmlSchema/complexType.rb +193 -0
  123. data/lib/wsdl/xmlSchema/content.rb +95 -0
  124. data/lib/wsdl/xmlSchema/data.rb +116 -0
  125. data/lib/wsdl/xmlSchema/element.rb +173 -0
  126. data/lib/wsdl/xmlSchema/enumeration.rb +36 -0
  127. data/lib/wsdl/xmlSchema/fractiondigits.rb +37 -0
  128. data/lib/wsdl/xmlSchema/group.rb +118 -0
  129. data/lib/wsdl/xmlSchema/import.rb +53 -0
  130. data/lib/wsdl/xmlSchema/importHandler.rb +45 -0
  131. data/lib/wsdl/xmlSchema/importer.rb +102 -0
  132. data/lib/wsdl/xmlSchema/include.rb +48 -0
  133. data/lib/wsdl/xmlSchema/length.rb +37 -0
  134. data/lib/wsdl/xmlSchema/list.rb +48 -0
  135. data/lib/wsdl/xmlSchema/maxexclusive.rb +37 -0
  136. data/lib/wsdl/xmlSchema/maxinclusive.rb +37 -0
  137. data/lib/wsdl/xmlSchema/maxlength.rb +37 -0
  138. data/lib/wsdl/xmlSchema/minexclusive.rb +37 -0
  139. data/lib/wsdl/xmlSchema/mininclusive.rb +37 -0
  140. data/lib/wsdl/xmlSchema/minlength.rb +37 -0
  141. data/lib/wsdl/xmlSchema/parser.rb +167 -0
  142. data/lib/wsdl/xmlSchema/pattern.rb +36 -0
  143. data/lib/wsdl/xmlSchema/schema.rb +178 -0
  144. data/lib/wsdl/xmlSchema/sequence.rb +54 -0
  145. data/lib/wsdl/xmlSchema/simpleContent.rb +69 -0
  146. data/lib/wsdl/xmlSchema/simpleExtension.rb +62 -0
  147. data/lib/wsdl/xmlSchema/simpleRestriction.rb +132 -0
  148. data/lib/wsdl/xmlSchema/simpleType.rb +87 -0
  149. data/lib/wsdl/xmlSchema/totaldigits.rb +37 -0
  150. data/lib/wsdl/xmlSchema/union.rb +35 -0
  151. data/lib/wsdl/xmlSchema/unique.rb +34 -0
  152. data/lib/wsdl/xmlSchema/whitespace.rb +37 -0
  153. data/lib/wsdl/xmlSchema/xsd2ruby.rb +174 -0
  154. data/lib/xsd/charset.rb +189 -0
  155. data/lib/xsd/codegen.rb +12 -0
  156. data/lib/xsd/codegen/classdef.rb +208 -0
  157. data/lib/xsd/codegen/commentdef.rb +34 -0
  158. data/lib/xsd/codegen/gensupport.rb +273 -0
  159. data/lib/xsd/codegen/methoddef.rb +70 -0
  160. data/lib/xsd/codegen/moduledef.rb +208 -0
  161. data/lib/xsd/datatypes.rb +1466 -0
  162. data/lib/xsd/datatypes1999.rb +20 -0
  163. data/lib/xsd/iconvcharset.rb +33 -0
  164. data/lib/xsd/mapping.rb +67 -0
  165. data/lib/xsd/namedelements.rb +132 -0
  166. data/lib/xsd/ns.rb +182 -0
  167. data/lib/xsd/qname.rb +79 -0
  168. data/lib/xsd/xmlparser.rb +75 -0
  169. data/lib/xsd/xmlparser/parser.rb +100 -0
  170. data/lib/xsd/xmlparser/rexmlparser.rb +58 -0
  171. data/lib/xsd/xmlparser/xmlparser.rb +50 -0
  172. data/lib/xsd/xmlparser/xmlscanner.rb +149 -0
  173. data/soap4r.gemspec +218 -0
  174. metadata +233 -0
@@ -0,0 +1,35 @@
1
+ # WSDL4R - XMLSchema union definition for WSDL.
2
+ # Copyright (C) 2000-2007 NAKAMURA, Hiroshi <nahi@ruby-lang.org>.
3
+
4
+ # This program is copyrighted free software by NAKAMURA, Hiroshi. You can
5
+ # redistribute it and/or modify it under the same terms of Ruby's license;
6
+ # either the dual license version in 2003, or any later version.
7
+
8
+
9
+ require 'wsdl/info'
10
+ require 'xsd/namedelements'
11
+
12
+
13
+ module WSDL
14
+ module XMLSchema
15
+
16
+
17
+ class Union < Info
18
+ attr_reader :member_types
19
+
20
+ def initialize
21
+ super
22
+ @member_types = nil
23
+ end
24
+
25
+ def parse_attr(attr, value)
26
+ case attr
27
+ when MemberTypesAttrName
28
+ @member_types = value.source
29
+ end
30
+ end
31
+ end
32
+
33
+
34
+ end
35
+ end
@@ -0,0 +1,34 @@
1
+ # WSDL4R - XMLSchema unique element.
2
+ # Copyright (C) 2000-2007 NAKAMURA, Hiroshi <nahi@ruby-lang.org>.
3
+
4
+ # This program is copyrighted free software by NAKAMURA, Hiroshi. You can
5
+ # redistribute it and/or modify it under the same terms of Ruby's license;
6
+ # either the dual license version in 2003, or any later version.
7
+
8
+
9
+ require 'wsdl/info'
10
+
11
+
12
+ module WSDL
13
+ module XMLSchema
14
+
15
+
16
+ class Unique < Info
17
+ def initialize
18
+ super
19
+ end
20
+
21
+ def parse_element(element)
22
+ # Accepts any element.
23
+ self
24
+ end
25
+
26
+ def parse_attr(attr, value)
27
+ # Accepts any attribute.
28
+ true
29
+ end
30
+ end
31
+
32
+
33
+ end
34
+ end
@@ -0,0 +1,37 @@
1
+ # WSDL4R - XMLSchema whiteSpace definition for WSDL.
2
+ # Copyright (C) 2000-2007 NAKAMURA, Hiroshi <nahi@ruby-lang.org>.
3
+
4
+ # This program is copyrighted free software by NAKAMURA, Hiroshi. You can
5
+ # redistribute it and/or modify it under the same terms of Ruby's license;
6
+ # either the dual license version in 2003, or any later version.
7
+
8
+
9
+ require 'wsdl/info'
10
+
11
+
12
+ module WSDL
13
+ module XMLSchema
14
+
15
+
16
+ class WhiteSpace < Info
17
+ def initialize
18
+ super
19
+ end
20
+
21
+ def parse_element(element)
22
+ nil
23
+ end
24
+
25
+ def parse_attr(attr, value)
26
+ case attr
27
+ when FixedAttrName
28
+ parent.fixed[:whitespace] = to_boolean(value)
29
+ when ValueAttrName
30
+ parent.whitespace = value.source
31
+ end
32
+ end
33
+ end
34
+
35
+
36
+ end
37
+ end
@@ -0,0 +1,174 @@
1
+ # XSD4R - XSD to ruby mapping library.
2
+ # Copyright (C) 2000-2007 NAKAMURA, Hiroshi <nahi@ruby-lang.org>.
3
+
4
+ # This program is copyrighted free software by NAKAMURA, Hiroshi. You can
5
+ # redistribute it and/or modify it under the same terms of Ruby's license;
6
+ # either the dual license version in 2003, or any later version.
7
+
8
+
9
+ require 'xsd/codegen/gensupport'
10
+ require 'wsdl/xmlSchema/importer'
11
+ require 'wsdl/soap/classDefCreator'
12
+ require 'wsdl/soap/classDefCreatorSupport'
13
+ require 'wsdl/soap/literalMappingRegistryCreator'
14
+ require 'wsdl/soap/classNameCreator'
15
+ require 'logger'
16
+
17
+
18
+ module WSDL
19
+ module XMLSchema
20
+
21
+
22
+ class XSD2Ruby
23
+ include WSDL::SOAP::ClassDefCreatorSupport
24
+
25
+ attr_accessor :location
26
+ attr_reader :opt
27
+ attr_accessor :logger
28
+ attr_accessor :basedir
29
+
30
+ def run
31
+ unless @location
32
+ raise RuntimeError, "XML Schema location not given"
33
+ end
34
+ @xsd = import(@location)
35
+ @name = @opt['classdef'] || create_classname(@xsd)
36
+ create_file
37
+ end
38
+
39
+ private
40
+
41
+ def initialize
42
+ @location = nil
43
+ @opt = {}
44
+ @logger = Logger.new(STDERR)
45
+ @basedir = nil
46
+ @xsd = nil
47
+ @name = nil
48
+ @name_creator = WSDL::SOAP::ClassNameCreator.new
49
+ end
50
+
51
+ def create_file
52
+ @modulepath = @opt['module_path']
53
+ create_classdef if @opt.key?('classdef')
54
+ create_mapping_registry if @opt.key?('mapping_registry')
55
+ create_mapper if @opt.key?('mapper')
56
+ end
57
+
58
+ def create_classdef
59
+ @logger.info { "Creating class definition." }
60
+ @classdef_filename = @name + '.rb'
61
+ check_file(@classdef_filename) or return
62
+ write_file(@classdef_filename) do |f|
63
+ f << WSDL::SOAP::ClassDefCreator.new(@xsd, @name_creator, @modulepath).dump
64
+ end
65
+ end
66
+
67
+ def create_mapping_registry
68
+ @logger.info { "Creating mapping registry definition." }
69
+ @mr_filename = @name + '_mapping_registry.rb'
70
+ check_file(@mr_filename) or return
71
+ write_file(@mr_filename) do |f|
72
+ f << dump_mapping_registry
73
+ end
74
+ end
75
+
76
+ def create_mapper
77
+ @logger.info { "Creating mapper definition." }
78
+ @mapper_filename = @name + '_mapper.rb'
79
+ check_file(@mapper_filename) or return
80
+ write_file(@mapper_filename) do |f|
81
+ f << dump_mapper
82
+ end
83
+ end
84
+
85
+ def dump_mapping_registry
86
+ defined_const = {}
87
+ creator = WSDL::SOAP::LiteralMappingRegistryCreator.new(@xsd, @name_creator, @modulepath, defined_const)
88
+ module_name = XSD::CodeGen::GenSupport.safeconstname(@name + 'MappingRegistry')
89
+ if @modulepath
90
+ module_name = [@modulepath, module_name].join('::')
91
+ end
92
+ m = XSD::CodeGen::ModuleDef.new(module_name)
93
+ m.def_require("xsd/mapping")
94
+ m.def_require("#{@classdef_filename}")
95
+ varname = 'Registry'
96
+ m.def_const(varname, '::SOAP::Mapping::LiteralRegistry.new')
97
+ m.def_code(creator.dump(varname))
98
+ #
99
+ defined_const.each do |ns, tag|
100
+ m.def_const(tag, dq(ns))
101
+ end
102
+ m.dump
103
+ end
104
+
105
+ def dump_mapper
106
+ class_name = XSD::CodeGen::GenSupport.safeconstname(@name + 'Mapper')
107
+ if @modulepath
108
+ class_name = [@modulepath, class_name].join('::')
109
+ end
110
+ mr_name = XSD::CodeGen::GenSupport.safeconstname(@name + 'MappingRegistry')
111
+ c = XSD::CodeGen::ClassDef.new(class_name, 'XSD::Mapping::Mapper')
112
+ c.def_require("#{@mr_filename}")
113
+ c.def_method("initialize") do
114
+ "super(#{mr_name}::Registry)"
115
+ end
116
+ c.dump
117
+ end
118
+
119
+ def write_file(filename)
120
+ if @basedir
121
+ filename = File.join(basedir, filename)
122
+ end
123
+ File.open(filename, "w") do |f|
124
+ yield f
125
+ end
126
+ end
127
+
128
+ def check_file(filename)
129
+ if @basedir
130
+ filename = File.join(basedir, filename)
131
+ end
132
+ if FileTest.exist?(filename)
133
+ if @opt.key?('force')
134
+ @logger.warn {
135
+ "File '#{filename}' exists but overrides it."
136
+ }
137
+ true
138
+ else
139
+ @logger.warn {
140
+ "File '#{filename}' exists. #{$0} did not override it."
141
+ }
142
+ false
143
+ end
144
+ else
145
+ @logger.info { "Creates file '#{filename}'." }
146
+ true
147
+ end
148
+ end
149
+
150
+ def create_classname(xsd)
151
+ name = nil
152
+ if xsd.targetnamespace
153
+ name = xsd.targetnamespace.scan(/[a-zA-Z0-9]+$/)[0]
154
+ end
155
+ if name.nil?
156
+ 'default'
157
+ else
158
+ XSD::CodeGen::GenSupport.safevarname(name)
159
+ end
160
+ end
161
+
162
+ def import(location)
163
+ WSDL::XMLSchema::Importer.import(location)
164
+ end
165
+ end
166
+
167
+
168
+ end
169
+ end
170
+
171
+
172
+ if __FILE__ == $0
173
+ warn("WARNING: #{File.expand_path(__FILE__)} is a library file used by bin/xsd2ruby.rb. Find bin/xsd2ruby.rb from tarball version of soap4r or install soap4r via gem.")
174
+ end
@@ -0,0 +1,189 @@
1
+ # XSD4R - Charset handling library.
2
+ # Copyright (C) 2000-2007 NAKAMURA, Hiroshi <nahi@ruby-lang.org>.
3
+
4
+ # This program is copyrighted free software by NAKAMURA, Hiroshi. You can
5
+ # redistribute it and/or modify it under the same terms of Ruby's license;
6
+ # either the dual license version in 2003, or any later version.
7
+
8
+
9
+ module XSD
10
+
11
+
12
+ module Charset
13
+ # @internal_encoding = $KCODE
14
+
15
+ class XSDError < StandardError; end
16
+ class CharsetError < XSDError; end
17
+ class UnknownCharsetError < CharsetError; end
18
+ class CharsetConversionError < CharsetError; end
19
+
20
+ public
21
+
22
+ ###
23
+ ## Maps
24
+ #
25
+ EncodingConvertMap = {}
26
+ def Charset.init
27
+ EncodingConvertMap[['UTF8', 'X_ISO_8859_1']] =
28
+ Proc.new { |str| str.unpack('U*').pack('C*') }
29
+ EncodingConvertMap[['X_ISO_8859_1', 'UTF8']] =
30
+ Proc.new { |str| str.unpack('C*').pack('U*') }
31
+ begin
32
+ require 'xsd/iconvcharset'
33
+ @internal_encoding = 'UTF8'
34
+ sjtag = (/(mswin|bccwin|mingw|cygwin|emx)/ =~ RUBY_PLATFORM) ? 'cp932' :
35
+ 'shift_jis'
36
+ EncodingConvertMap[['UTF8', 'EUC' ]] =
37
+ Proc.new { |str| IconvCharset.safe_iconv("euc-jp", "utf-8", str) }
38
+ EncodingConvertMap[['EUC' , 'UTF8']] =
39
+ Proc.new { |str| IconvCharset.safe_iconv("utf-8", "euc-jp", str) }
40
+ EncodingConvertMap[['EUC' , 'SJIS']] =
41
+ Proc.new { |str| IconvCharset.safe_iconv(sjtag, "euc-jp", str) }
42
+ EncodingConvertMap[['UTF8', 'SJIS']] =
43
+ Proc.new { |str| IconvCharset.safe_iconv(sjtag, "utf-8", str) }
44
+ EncodingConvertMap[['SJIS', 'UTF8']] =
45
+ Proc.new { |str| IconvCharset.safe_iconv("utf-8", sjtag, str) }
46
+ EncodingConvertMap[['SJIS', 'EUC' ]] =
47
+ Proc.new { |str| IconvCharset.safe_iconv("euc-jp", sjtag, str) }
48
+ rescue LoadError
49
+ begin
50
+ require 'nkf'
51
+ EncodingConvertMap[['EUC' , 'SJIS']] =
52
+ Proc.new { |str| NKF.nkf('-sXm0', str) }
53
+ EncodingConvertMap[['SJIS', 'EUC' ]] =
54
+ Proc.new { |str| NKF.nkf('-eXm0', str) }
55
+ rescue LoadError
56
+ end
57
+
58
+ begin
59
+ require 'uconv'
60
+ @internal_encoding = 'UTF8'
61
+ EncodingConvertMap[['UTF8', 'EUC' ]] = Uconv.method(:u8toeuc)
62
+ EncodingConvertMap[['UTF8', 'SJIS']] = Uconv.method(:u8tosjis)
63
+ EncodingConvertMap[['EUC' , 'UTF8']] = Uconv.method(:euctou8)
64
+ EncodingConvertMap[['SJIS', 'UTF8']] = Uconv.method(:sjistou8)
65
+ rescue LoadError
66
+ end
67
+ end
68
+ end
69
+ self.init
70
+
71
+ CharsetMap = {
72
+ 'NONE' => 'us-ascii',
73
+ 'EUC' => 'euc-jp',
74
+ 'SJIS' => 'shift_jis',
75
+ 'UTF8' => 'utf-8',
76
+ 'X_ISO_8859_1' => 'iso-8859-1',
77
+ 'X_UNKNOWN' => nil,
78
+ }
79
+
80
+ CharsetStrCache = {}
81
+
82
+
83
+ ###
84
+ ## handlers
85
+ #
86
+ def Charset.encoding
87
+ @internal_encoding
88
+ end
89
+
90
+ def Charset.encoding=(encoding)
91
+ warn("xsd charset is set to #{encoding}") if $DEBUG
92
+ @internal_encoding = encoding
93
+ end
94
+
95
+ def Charset.xml_encoding_label
96
+ charset_label(@internal_encoding)
97
+ end
98
+
99
+ def Charset.encoding_to_xml(str, charset)
100
+ encoding_conv(str, @internal_encoding, charset_str(charset))
101
+ end
102
+
103
+ def Charset.encoding_from_xml(str, charset)
104
+ encoding_conv(str, charset_str(charset), @internal_encoding)
105
+ end
106
+
107
+ def Charset.encoding_conv(str, enc_from, enc_to)
108
+ if enc_from == enc_to or enc_from == 'NONE' or enc_to == 'NONE'
109
+ str
110
+ elsif converter = EncodingConvertMap[[enc_from, enc_to]]
111
+ converter.call(str)
112
+ else
113
+ raise CharsetConversionError.new(
114
+ "Converter not found: #{enc_from} -> #{enc_to}")
115
+ end
116
+ end
117
+
118
+ def Charset.charset_label(encoding)
119
+ CharsetMap[encoding.upcase]
120
+ end
121
+
122
+ def Charset.charset_str(label)
123
+ if CharsetMap.respond_to?(:key)
124
+ CharsetStrCache[label] ||= CharsetMap.key(label.downcase) || 'X_UNKNOWN'
125
+ else
126
+ CharsetStrCache[label] ||= CharsetMap.index(label.downcase) || 'X_UNKNOWN'
127
+ end
128
+ end
129
+
130
+ # us_ascii = '[\x00-\x7F]'
131
+ us_ascii = '[\x9\xa\xd\x20-\x7F]' # XML 1.0 restricted.
132
+ USASCIIRegexp = Regexp.new("\\A#{us_ascii}*\\z", nil, 'NONE')
133
+
134
+ twobytes_euc = '(?:[\x8E\xA1-\xFE][\xA1-\xFE])'
135
+ threebytes_euc = '(?:\x8F[\xA1-\xFE][\xA1-\xFE])'
136
+ character_euc = "(?:#{us_ascii}|#{twobytes_euc}|#{threebytes_euc})"
137
+ EUCRegexp = Regexp.new("\\A#{character_euc}*\\z", nil, 'NONE')
138
+
139
+ # onebyte_sjis = '[\x00-\x7F\xA1-\xDF]'
140
+ onebyte_sjis = '[\x9\xa\xd\x20-\x7F\xA1-\xDF]' # XML 1.0 restricted.
141
+ twobytes_sjis = '(?:[\x81-\x9F\xE0-\xFC][\x40-\x7E\x80-\xFC])'
142
+ character_sjis = "(?:#{onebyte_sjis}|#{twobytes_sjis})"
143
+ SJISRegexp = Regexp.new("\\A#{character_sjis}*\\z", nil, 'NONE')
144
+
145
+ # 0xxxxxxx
146
+ # 110yyyyy 10xxxxxx
147
+ twobytes_utf8 = '(?:[\xC0-\xDF][\x80-\xBF])'
148
+ # 1110zzzz 10yyyyyy 10xxxxxx
149
+ threebytes_utf8 = '(?:[\xE0-\xEF][\x80-\xBF][\x80-\xBF])'
150
+ # 11110uuu 10uuuzzz 10yyyyyy 10xxxxxx
151
+ fourbytes_utf8 = '(?:[\xF0-\xF7][\x80-\xBF][\x80-\xBF][\x80-\xBF])'
152
+ character_utf8 =
153
+ "(?:#{us_ascii}|#{twobytes_utf8}|#{threebytes_utf8}|#{fourbytes_utf8})"
154
+ UTF8Regexp = Regexp.new("\\A#{character_utf8}*\\z", nil, 'NONE')
155
+
156
+ def Charset.is_us_ascii(str)
157
+ USASCIIRegexp =~ str
158
+ end
159
+
160
+ def Charset.is_utf8(str)
161
+ UTF8Regexp =~ str
162
+ end
163
+
164
+ def Charset.is_euc(str)
165
+ EUCRegexp =~ str
166
+ end
167
+
168
+ def Charset.is_sjis(str)
169
+ SJISRegexp =~ str
170
+ end
171
+
172
+ def Charset.is_ces(str, code = @internal_encoding)
173
+ case code
174
+ when 'NONE'
175
+ is_us_ascii(str)
176
+ when 'UTF8'
177
+ is_utf8(str)
178
+ when 'EUC'
179
+ is_euc(str)
180
+ when 'SJIS'
181
+ is_sjis(str)
182
+ else
183
+ raise UnknownCharsetError.new("Unknown charset: #{code}")
184
+ end
185
+ end
186
+ end
187
+
188
+
189
+ end