soap2r 1.5.8

Sign up to get free protection for your applications and to get access to all the features.
Files changed (161) hide show
  1. data/bin/wsdl2ruby.rb +137 -0
  2. data/bin/xsd2ruby.rb +90 -0
  3. data/lib/soap/attachment.rb +108 -0
  4. data/lib/soap/attrproxy.rb +34 -0
  5. data/lib/soap/baseData.rb +1094 -0
  6. data/lib/soap/element.rb +277 -0
  7. data/lib/soap/encodingstyle/aspDotNetHandler.rb +207 -0
  8. data/lib/soap/encodingstyle/handler.rb +120 -0
  9. data/lib/soap/encodingstyle/literalHandler.rb +195 -0
  10. data/lib/soap/encodingstyle/soapHandler.rb +559 -0
  11. data/lib/soap/filter.rb +13 -0
  12. data/lib/soap/filter/filterchain.rb +51 -0
  13. data/lib/soap/filter/handler.rb +31 -0
  14. data/lib/soap/filter/streamhandler.rb +29 -0
  15. data/lib/soap/generator.rb +299 -0
  16. data/lib/soap/header/handler.rb +61 -0
  17. data/lib/soap/header/handlerset.rb +70 -0
  18. data/lib/soap/header/mappinghandler.rb +47 -0
  19. data/lib/soap/header/simplehandler.rb +44 -0
  20. data/lib/soap/httpconfigloader.rb +141 -0
  21. data/lib/soap/mapping.rb +12 -0
  22. data/lib/soap/mapping/encodedregistry.rb +537 -0
  23. data/lib/soap/mapping/factory.rb +388 -0
  24. data/lib/soap/mapping/literalregistry.rb +391 -0
  25. data/lib/soap/mapping/mapping.rb +576 -0
  26. data/lib/soap/mapping/registry.rb +295 -0
  27. data/lib/soap/mapping/rubytypeFactory.rb +446 -0
  28. data/lib/soap/mapping/schemadefinition.rb +170 -0
  29. data/lib/soap/mapping/typeMap.rb +106 -0
  30. data/lib/soap/mapping/wsdlencodedregistry.rb +211 -0
  31. data/lib/soap/mapping/wsdlliteralregistry.rb +248 -0
  32. data/lib/soap/marshal.rb +59 -0
  33. data/lib/soap/mimemessage.rb +241 -0
  34. data/lib/soap/nestedexception.rb +42 -0
  35. data/lib/soap/netHttpClient.rb +241 -0
  36. data/lib/soap/ns.rb +34 -0
  37. data/lib/soap/parser.rb +252 -0
  38. data/lib/soap/processor.rb +66 -0
  39. data/lib/soap/property.rb +319 -0
  40. data/lib/soap/proxy.rb +14 -0
  41. data/lib/soap/rpc/cgistub.rb +247 -0
  42. data/lib/soap/rpc/driver.rb +221 -0
  43. data/lib/soap/rpc/element.rb +374 -0
  44. data/lib/soap/rpc/httpserver.rb +142 -0
  45. data/lib/soap/rpc/methodDef.rb +68 -0
  46. data/lib/soap/rpc/proxy.rb +572 -0
  47. data/lib/soap/rpc/router.rb +662 -0
  48. data/lib/soap/rpc/rpc.rb +25 -0
  49. data/lib/soap/rpc/soaplet.rb +200 -0
  50. data/lib/soap/rpc/standaloneServer.rb +43 -0
  51. data/lib/soap/soap.rb +151 -0
  52. data/lib/soap/streamHandler.rb +301 -0
  53. data/lib/soap/wsdlDriver.rb +164 -0
  54. data/lib/wsdl/binding.rb +65 -0
  55. data/lib/wsdl/data.rb +64 -0
  56. data/lib/wsdl/definitions.rb +236 -0
  57. data/lib/wsdl/documentation.rb +32 -0
  58. data/lib/wsdl/import.rb +80 -0
  59. data/lib/wsdl/importer.rb +38 -0
  60. data/lib/wsdl/info.rb +50 -0
  61. data/lib/wsdl/message.rb +54 -0
  62. data/lib/wsdl/operation.rb +151 -0
  63. data/lib/wsdl/operationBinding.rb +240 -0
  64. data/lib/wsdl/param.rb +93 -0
  65. data/lib/wsdl/parser.rb +164 -0
  66. data/lib/wsdl/part.rb +52 -0
  67. data/lib/wsdl/port.rb +66 -0
  68. data/lib/wsdl/portType.rb +75 -0
  69. data/lib/wsdl/service.rb +61 -0
  70. data/lib/wsdl/soap/address.rb +40 -0
  71. data/lib/wsdl/soap/binding.rb +49 -0
  72. data/lib/wsdl/soap/body.rb +58 -0
  73. data/lib/wsdl/soap/cgiStubCreator.rb +92 -0
  74. data/lib/wsdl/soap/classDefCreator.rb +433 -0
  75. data/lib/wsdl/soap/classDefCreatorSupport.rb +240 -0
  76. data/lib/wsdl/soap/classNameCreator.rb +54 -0
  77. data/lib/wsdl/soap/clientSkeltonCreator.rb +104 -0
  78. data/lib/wsdl/soap/complexType.rb +173 -0
  79. data/lib/wsdl/soap/data.rb +42 -0
  80. data/lib/wsdl/soap/definitions.rb +200 -0
  81. data/lib/wsdl/soap/driverCreator.rb +118 -0
  82. data/lib/wsdl/soap/element.rb +33 -0
  83. data/lib/wsdl/soap/encodedMappingRegistryCreator.rb +73 -0
  84. data/lib/wsdl/soap/fault.rb +56 -0
  85. data/lib/wsdl/soap/header.rb +86 -0
  86. data/lib/wsdl/soap/headerfault.rb +56 -0
  87. data/lib/wsdl/soap/literalMappingRegistryCreator.rb +115 -0
  88. data/lib/wsdl/soap/mappingRegistryCreator.rb +58 -0
  89. data/lib/wsdl/soap/mappingRegistryCreatorSupport.rb +376 -0
  90. data/lib/wsdl/soap/methodDefCreator.rb +199 -0
  91. data/lib/wsdl/soap/operation.rb +112 -0
  92. data/lib/wsdl/soap/servantSkeltonCreator.rb +89 -0
  93. data/lib/wsdl/soap/servletStubCreator.rb +104 -0
  94. data/lib/wsdl/soap/standaloneServerStubCreator.rb +100 -0
  95. data/lib/wsdl/soap/wsdl2ruby.rb +217 -0
  96. data/lib/wsdl/types.rb +44 -0
  97. data/lib/wsdl/wsdl.rb +24 -0
  98. data/lib/wsdl/xmlSchema/all.rb +24 -0
  99. data/lib/wsdl/xmlSchema/annotation.rb +34 -0
  100. data/lib/wsdl/xmlSchema/any.rb +61 -0
  101. data/lib/wsdl/xmlSchema/anyAttribute.rb +48 -0
  102. data/lib/wsdl/xmlSchema/attribute.rb +104 -0
  103. data/lib/wsdl/xmlSchema/attributeGroup.rb +68 -0
  104. data/lib/wsdl/xmlSchema/choice.rb +58 -0
  105. data/lib/wsdl/xmlSchema/complexContent.rb +97 -0
  106. data/lib/wsdl/xmlSchema/complexExtension.rb +119 -0
  107. data/lib/wsdl/xmlSchema/complexRestriction.rb +104 -0
  108. data/lib/wsdl/xmlSchema/complexType.rb +193 -0
  109. data/lib/wsdl/xmlSchema/content.rb +95 -0
  110. data/lib/wsdl/xmlSchema/data.rb +116 -0
  111. data/lib/wsdl/xmlSchema/element.rb +153 -0
  112. data/lib/wsdl/xmlSchema/enumeration.rb +36 -0
  113. data/lib/wsdl/xmlSchema/fractiondigits.rb +37 -0
  114. data/lib/wsdl/xmlSchema/group.rb +100 -0
  115. data/lib/wsdl/xmlSchema/import.rb +53 -0
  116. data/lib/wsdl/xmlSchema/importHandler.rb +45 -0
  117. data/lib/wsdl/xmlSchema/importer.rb +102 -0
  118. data/lib/wsdl/xmlSchema/include.rb +48 -0
  119. data/lib/wsdl/xmlSchema/length.rb +37 -0
  120. data/lib/wsdl/xmlSchema/list.rb +48 -0
  121. data/lib/wsdl/xmlSchema/maxexclusive.rb +37 -0
  122. data/lib/wsdl/xmlSchema/maxinclusive.rb +37 -0
  123. data/lib/wsdl/xmlSchema/maxlength.rb +37 -0
  124. data/lib/wsdl/xmlSchema/minexclusive.rb +37 -0
  125. data/lib/wsdl/xmlSchema/mininclusive.rb +37 -0
  126. data/lib/wsdl/xmlSchema/minlength.rb +37 -0
  127. data/lib/wsdl/xmlSchema/parser.rb +167 -0
  128. data/lib/wsdl/xmlSchema/pattern.rb +36 -0
  129. data/lib/wsdl/xmlSchema/ref.rb +33 -0
  130. data/lib/wsdl/xmlSchema/schema.rb +178 -0
  131. data/lib/wsdl/xmlSchema/sequence.rb +54 -0
  132. data/lib/wsdl/xmlSchema/simpleContent.rb +69 -0
  133. data/lib/wsdl/xmlSchema/simpleExtension.rb +62 -0
  134. data/lib/wsdl/xmlSchema/simpleRestriction.rb +132 -0
  135. data/lib/wsdl/xmlSchema/simpleType.rb +87 -0
  136. data/lib/wsdl/xmlSchema/totaldigits.rb +37 -0
  137. data/lib/wsdl/xmlSchema/union.rb +35 -0
  138. data/lib/wsdl/xmlSchema/unique.rb +34 -0
  139. data/lib/wsdl/xmlSchema/whitespace.rb +37 -0
  140. data/lib/wsdl/xmlSchema/xsd2ruby.rb +174 -0
  141. data/lib/xsd/charset.rb +193 -0
  142. data/lib/xsd/codegen.rb +12 -0
  143. data/lib/xsd/codegen/classdef.rb +208 -0
  144. data/lib/xsd/codegen/commentdef.rb +34 -0
  145. data/lib/xsd/codegen/gensupport.rb +273 -0
  146. data/lib/xsd/codegen/methoddef.rb +70 -0
  147. data/lib/xsd/codegen/moduledef.rb +208 -0
  148. data/lib/xsd/datatypes.rb +1466 -0
  149. data/lib/xsd/datatypes1999.rb +20 -0
  150. data/lib/xsd/iconvcharset.rb +39 -0
  151. data/lib/xsd/mapping.rb +68 -0
  152. data/lib/xsd/namedelements.rb +132 -0
  153. data/lib/xsd/ns.rb +182 -0
  154. data/lib/xsd/qname.rb +79 -0
  155. data/lib/xsd/xmlparser.rb +76 -0
  156. data/lib/xsd/xmlparser/libxmlparser.rb +115 -0
  157. data/lib/xsd/xmlparser/parser.rb +100 -0
  158. data/lib/xsd/xmlparser/rexmlparser.rb +58 -0
  159. data/lib/xsd/xmlparser/xmlparser.rb +50 -0
  160. data/lib/xsd/xmlparser/xmlscanner.rb +149 -0
  161. metadata +224 -0
@@ -0,0 +1,12 @@
1
+ # XSD4R - Generating code 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 'xsd/codegen/moduledef'
11
+ require 'xsd/codegen/classdef'
12
+ require 'xsd/codegen/methoddef'
@@ -0,0 +1,208 @@
1
+ # XSD4R - Generating class definition code
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 'xsd/codegen/moduledef'
11
+ require 'xsd/codegen/methoddef'
12
+
13
+
14
+ module XSD
15
+ module CodeGen
16
+
17
+
18
+ class ClassDef < ModuleDef
19
+ include GenSupport
20
+
21
+ def initialize(name, baseclass = nil)
22
+ super(name)
23
+ @baseclass = baseclass
24
+ @classvar = []
25
+ @attrdef = []
26
+ end
27
+
28
+ def def_classvar(var, value)
29
+ var = var.sub(/\A@@/, "")
30
+ unless safevarname?(var)
31
+ raise ArgumentError.new("#{var} seems to be unsafe")
32
+ end
33
+ @classvar << [var, value]
34
+ end
35
+
36
+ def def_attr(attrname, writable = true, varname = nil)
37
+ unless safevarname?(varname || attrname)
38
+ raise ArgumentError.new("#{varname || attrname} seems to be unsafe")
39
+ end
40
+ @attrdef << [attrname, writable, varname]
41
+ end
42
+
43
+ def dump
44
+ buf = ""
45
+ unless @requirepath.empty?
46
+ buf << dump_requirepath
47
+ end
48
+ buf << dump_emptyline unless buf.empty?
49
+ package = @name.split(/::/)[0..-2]
50
+ buf << dump_package_def(package) unless package.empty?
51
+ buf << dump_comment if @comment
52
+ buf << dump_class_def
53
+ spacer = false
54
+ unless @classvar.empty?
55
+ spacer = true
56
+ buf << dump_classvar
57
+ end
58
+ unless @const.empty?
59
+ buf << dump_emptyline if spacer
60
+ spacer = true
61
+ buf << dump_const
62
+ end
63
+ unless @innermodule.empty?
64
+ buf << dump_emptyline # always add 1 empty line
65
+ spacer = true
66
+ buf << dump_innermodule
67
+ end
68
+ unless @code.empty?
69
+ buf << dump_emptyline if spacer
70
+ spacer = true
71
+ buf << dump_code
72
+ end
73
+ unless @attrdef.empty?
74
+ buf << dump_emptyline if spacer
75
+ spacer = true
76
+ buf << dump_attributes
77
+ end
78
+ unless @methoddef.empty?
79
+ buf << dump_emptyline if spacer
80
+ spacer = true
81
+ buf << dump_methods
82
+ end
83
+ buf << dump_class_def_end
84
+ buf << dump_package_def_end(package) unless package.empty?
85
+ buf.gsub(/^\s+$/, '')
86
+ end
87
+
88
+ private
89
+
90
+ def dump_class_def
91
+ name = @name.to_s.split(/::/)
92
+ if @baseclass
93
+ format("class #{name.last} < #{@baseclass}")
94
+ else
95
+ format("class #{name.last}")
96
+ end
97
+ end
98
+
99
+ def dump_class_def_end
100
+ str = format("end")
101
+ end
102
+
103
+ def dump_classvar
104
+ dump_static(
105
+ @classvar.collect { |var, value|
106
+ %Q(@@#{var.sub(/^@@/, "")} = #{dump_value(value)})
107
+ }.join("\n")
108
+ )
109
+ end
110
+
111
+ def dump_attributes
112
+ str = ""
113
+ @attrdef.each do |attrname, writable, varname|
114
+ varname ||= attrname
115
+ if attrname == varname
116
+ str << format(dump_accessor(attrname, writable), 2)
117
+ end
118
+ end
119
+ @attrdef.each do |attrname, writable, varname|
120
+ varname ||= attrname
121
+ if attrname != varname
122
+ str << "\n" unless str.empty?
123
+ str << format(dump_attribute(attrname, writable, varname), 2)
124
+ end
125
+ end
126
+ str
127
+ end
128
+
129
+ def dump_accessor(attrname, writable)
130
+ if writable
131
+ "attr_accessor :#{attrname}"
132
+ else
133
+ "attr_reader :#{attrname}"
134
+ end
135
+ end
136
+
137
+ def dump_attribute(attrname, writable, varname)
138
+ str = nil
139
+ mr = MethodDef.new(attrname)
140
+ mr.definition = "@#{varname}"
141
+ str = mr.dump
142
+ if writable
143
+ mw = MethodDef.new(attrname + "=", 'value')
144
+ mw.definition = "@#{varname} = value"
145
+ str << "\n" + mw.dump
146
+ end
147
+ str
148
+ end
149
+ end
150
+
151
+
152
+ end
153
+ end
154
+
155
+
156
+ if __FILE__ == $0
157
+ require 'xsd/codegen/classdef'
158
+ include XSD::CodeGen
159
+ c = ClassDef.new("Foo::Bar::HobbitName", String)
160
+ c.def_require("foo/bar")
161
+ c.comment = <<-EOD
162
+ foo
163
+ bar
164
+ baz
165
+ EOD
166
+ c.def_const("FOO", 1)
167
+ c.def_classvar("@@foo", "var".dump)
168
+ c.def_classvar("baz", "1".dump)
169
+ c.def_attr("Foo", true, "foo")
170
+ c.def_attr("bar")
171
+ c.def_attr("baz", true)
172
+ c.def_attr("Foo2", true, "foo2")
173
+ c.def_attr("foo3", false, "foo3")
174
+ c.def_method("foo") do
175
+ <<-EOD
176
+ foo.bar = 1
177
+ \tbaz.each do |ele|
178
+ \t ele
179
+ end
180
+ EOD
181
+ end
182
+ c.def_method("baz", "qux") do
183
+ <<-EOD
184
+ [1, 2, 3].each do |i|
185
+ p i
186
+ end
187
+ EOD
188
+ end
189
+
190
+ m = MethodDef.new("qux", "quxx", "quxxx") do
191
+ <<-EOD
192
+ p quxx + quxxx
193
+ EOD
194
+ end
195
+ m.comment = "hello world\n123"
196
+ c.add_method(m)
197
+ c.def_code <<-EOD
198
+ Foo.new
199
+ Bar.z
200
+ EOD
201
+ c.def_code <<-EOD
202
+ Foo.new
203
+ Bar.z
204
+ EOD
205
+ c.def_privatemethod("foo", "baz", "*arg", "&block")
206
+
207
+ puts c.dump
208
+ end
@@ -0,0 +1,34 @@
1
+ # XSD4R - Generating comment definition code
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
+
11
+
12
+ module XSD
13
+ module CodeGen
14
+
15
+
16
+ module CommentDef
17
+ include GenSupport
18
+
19
+ attr_accessor :comment
20
+
21
+ private
22
+
23
+ def dump_comment
24
+ if /\A#/ =~ @comment
25
+ format(@comment)
26
+ else
27
+ format(@comment).gsub(/^/, '# ')
28
+ end
29
+ end
30
+ end
31
+
32
+
33
+ end
34
+ end
@@ -0,0 +1,273 @@
1
+ # XSD4R - Code generation support
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
+ module CodeGen
11
+
12
+ # from the file 'keywords' in 1.9.
13
+ KEYWORDS = {}
14
+ %w(
15
+ __LINE__
16
+ __FILE__
17
+ BEGIN
18
+ END
19
+ alias
20
+ and
21
+ begin
22
+ break
23
+ case
24
+ class
25
+ def
26
+ defined?
27
+ do
28
+ else
29
+ elsif
30
+ end
31
+ ensure
32
+ false
33
+ for
34
+ if
35
+ in
36
+ module
37
+ next
38
+ nil
39
+ not
40
+ or
41
+ redo
42
+ rescue
43
+ retry
44
+ return
45
+ self
46
+ super
47
+ then
48
+ true
49
+ undef
50
+ unless
51
+ until
52
+ when
53
+ while
54
+ yield
55
+ ).each { |k| KEYWORDS[k] = nil }
56
+
57
+ # from Module.constants from 1.8 & 1.9
58
+ CONSTANTS = {}
59
+ %w(
60
+ ARGF
61
+ ARGV
62
+ ArgumentError
63
+ Array
64
+ BasicObject
65
+ Bignum
66
+ Binding
67
+ Class
68
+ Comparable
69
+ Continuation
70
+ Data
71
+ Dir
72
+ ENV
73
+ EOFError
74
+ Enumerable
75
+ Errno
76
+ Exception
77
+ FALSE
78
+ FalseClass
79
+ File
80
+ FileTest
81
+ Fixnum
82
+ Float
83
+ FloatDomainError
84
+ GC
85
+ Hash
86
+ IO
87
+ IOError
88
+ IndexError
89
+ Integer
90
+ Interrupt
91
+ Kernel
92
+ KeyError
93
+ LoadError
94
+ LocalJumpError
95
+ Marshal
96
+ MatchData
97
+ MatchingData
98
+ Math
99
+ Method
100
+ Module
101
+ Mutex
102
+ NIL
103
+ NameError
104
+ NilClass
105
+ NoMemoryError
106
+ NoMethodError
107
+ NotImplementedError
108
+ Numeric
109
+ Object
110
+ ObjectSpace
111
+ PLATFORM
112
+ Precision
113
+ Proc
114
+ Process
115
+ RELEASE_DATE
116
+ RUBY_PATCHLEVEL
117
+ RUBY_PLATFORM
118
+ RUBY_RELEASE_DATE
119
+ RUBY_VERSION
120
+ Range
121
+ RangeError
122
+ Regexp
123
+ RegexpError
124
+ RuntimeError
125
+ STDERR
126
+ STDIN
127
+ STDOUT
128
+ ScriptError
129
+ SecurityError
130
+ Signal
131
+ SignalException
132
+ StandardError
133
+ String
134
+ Struct
135
+ Symbol
136
+ SyntaxError
137
+ SystemCallError
138
+ SystemExit
139
+ SystemStackError
140
+ TOPLEVEL_BINDING
141
+ TRUE
142
+ Thread
143
+ ThreadError
144
+ ThreadGroup
145
+ Time
146
+ TrueClass
147
+ TypeError
148
+ UnboundMethod
149
+ VERSION
150
+ VM
151
+ ZeroDivisionError
152
+ ).each { |c| CONSTANTS[c] = nil }
153
+
154
+
155
+ module GenSupport
156
+ def capitalize(target)
157
+ target.sub(/^([a-z])/) { $1.upcase }
158
+ end
159
+ module_function :capitalize
160
+
161
+ def uncapitalize(target)
162
+ target.sub(/^([A-Z])/) { $1.downcase }
163
+ end
164
+ module_function :uncapitalize
165
+
166
+ def safeconstname(name)
167
+ safename = name.scan(/[a-zA-Z0-9_]+/).collect { |ele|
168
+ GenSupport.capitalize(ele)
169
+ }.join
170
+ if /\A[A-Z]/ !~ safename or keyword?(safename) or constant?(safename)
171
+ "C_#{safename}"
172
+ else
173
+ safename
174
+ end
175
+ end
176
+ module_function :safeconstname
177
+
178
+ def safeconstname?(name)
179
+ /\A[A-Z][a-zA-Z0-9_]*\z/ =~ name and !keyword?(name)
180
+ end
181
+ module_function :safeconstname?
182
+
183
+ def safemethodname(name)
184
+ postfix = name[/[=?!]$/]
185
+ safename = name.scan(/[a-zA-Z0-9_]+/).join('_')
186
+ safename = uncapitalize(safename)
187
+ safename += postfix if postfix
188
+ if /\A[a-z]/ !~ safename or keyword?(safename)
189
+ "m_#{safename}"
190
+ else
191
+ safename
192
+ end
193
+ end
194
+ module_function :safemethodname
195
+
196
+ def safemethodname?(name)
197
+ /\A[a-zA-Z_][a-zA-Z0-9_]*[=!?]?\z/ =~ name and !keyword?(name)
198
+ end
199
+ module_function :safemethodname?
200
+
201
+ def safevarname(name)
202
+ safename = uncapitalize(name.scan(/[a-zA-Z0-9_]+/).join('_'))
203
+ if /\A[a-z]/ !~ safename or keyword?(safename)
204
+ "v_#{safename}"
205
+ else
206
+ safename
207
+ end
208
+ end
209
+ module_function :safevarname
210
+
211
+ def safevarname?(name)
212
+ /\A[a-z_][a-zA-Z0-9_]*\z/ =~ name and !keyword?(name)
213
+ end
214
+ module_function :safevarname?
215
+
216
+ def keyword?(word)
217
+ KEYWORDS.key?(word)
218
+ end
219
+ module_function :keyword?
220
+
221
+ def constant?(word)
222
+ CONSTANTS.key?(word)
223
+ end
224
+ module_function :constant?
225
+
226
+ def format(str, indent = nil)
227
+ str = trim_eol(str)
228
+ str = trim_indent(str)
229
+ if indent
230
+ str.gsub(/^/, " " * indent)
231
+ else
232
+ str
233
+ end
234
+ end
235
+
236
+ private
237
+
238
+ def trim_eol(str)
239
+ str.lines.collect { |line|
240
+ line.sub(/\r?\n\z/, "") + "\n"
241
+ }.join
242
+ end
243
+
244
+ def trim_indent(str)
245
+ indent = nil
246
+ str = str.lines.collect { |line| untab(line) }.join
247
+ str.lines do |line|
248
+ head = line.index(/\S/)
249
+ if !head.nil? and (indent.nil? or head < indent)
250
+ indent = head
251
+ end
252
+ end
253
+ return str unless indent
254
+ str.lines.collect { |line|
255
+ line.sub(/^ {0,#{indent}}/, "")
256
+ }.join
257
+ end
258
+
259
+ def untab(line, ts = 8)
260
+ while pos = line.index(/\t/)
261
+ line = line.sub(/\t/, " " * (ts - (pos % ts)))
262
+ end
263
+ line
264
+ end
265
+
266
+ def dump_emptyline
267
+ "\n"
268
+ end
269
+ end
270
+
271
+
272
+ end
273
+ end