libxml-ruby 2.9.0 → 3.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (139) hide show
  1. checksums.yaml +4 -4
  2. data/HISTORY +811 -790
  3. data/LICENSE +20 -20
  4. data/MANIFEST +166 -166
  5. data/README.rdoc +188 -184
  6. data/Rakefile +1 -1
  7. data/ext/libxml/libxml.c +80 -80
  8. data/ext/libxml/ruby_libxml.h +75 -75
  9. data/ext/libxml/ruby_xml.c +0 -84
  10. data/ext/libxml/ruby_xml.h +0 -10
  11. data/ext/libxml/ruby_xml_attr.h +12 -12
  12. data/ext/libxml/ruby_xml_attr_decl.c +153 -153
  13. data/ext/libxml/ruby_xml_attr_decl.h +11 -11
  14. data/ext/libxml/ruby_xml_attributes.c +275 -275
  15. data/ext/libxml/ruby_xml_attributes.h +15 -15
  16. data/ext/libxml/ruby_xml_document.c +21 -27
  17. data/ext/libxml/ruby_xml_document.h +11 -11
  18. data/ext/libxml/ruby_xml_dtd.c +2 -13
  19. data/ext/libxml/ruby_xml_dtd.h +9 -9
  20. data/ext/libxml/ruby_xml_error.c +996 -996
  21. data/ext/libxml/ruby_xml_error.h +12 -12
  22. data/ext/libxml/ruby_xml_html_parser.c +89 -92
  23. data/ext/libxml/ruby_xml_html_parser.h +10 -10
  24. data/ext/libxml/ruby_xml_html_parser_context.h +10 -10
  25. data/ext/libxml/ruby_xml_html_parser_options.c +46 -46
  26. data/ext/libxml/ruby_xml_html_parser_options.h +10 -10
  27. data/ext/libxml/ruby_xml_input_cbg.h +20 -20
  28. data/ext/libxml/ruby_xml_io.c +0 -1
  29. data/ext/libxml/ruby_xml_io.h +10 -10
  30. data/ext/libxml/ruby_xml_namespace.c +153 -153
  31. data/ext/libxml/ruby_xml_namespace.h +10 -10
  32. data/ext/libxml/ruby_xml_namespaces.c +293 -293
  33. data/ext/libxml/ruby_xml_namespaces.h +9 -9
  34. data/ext/libxml/ruby_xml_node.c +100 -143
  35. data/ext/libxml/ruby_xml_node.h +13 -11
  36. data/ext/libxml/ruby_xml_parser.c +91 -94
  37. data/ext/libxml/ruby_xml_parser.h +12 -12
  38. data/ext/libxml/ruby_xml_parser_context.h +10 -10
  39. data/ext/libxml/ruby_xml_parser_options.c +66 -66
  40. data/ext/libxml/ruby_xml_parser_options.h +12 -12
  41. data/ext/libxml/ruby_xml_reader.c +45 -37
  42. data/ext/libxml/ruby_xml_reader.h +17 -17
  43. data/ext/libxml/ruby_xml_relaxng.h +10 -10
  44. data/ext/libxml/ruby_xml_sax2_handler.c +3 -3
  45. data/ext/libxml/ruby_xml_sax2_handler.h +10 -10
  46. data/ext/libxml/ruby_xml_sax_parser.c +116 -120
  47. data/ext/libxml/ruby_xml_sax_parser.h +10 -10
  48. data/ext/libxml/ruby_xml_schema.h +809 -809
  49. data/ext/libxml/ruby_xml_schema_attribute.c +109 -109
  50. data/ext/libxml/ruby_xml_schema_attribute.h +15 -15
  51. data/ext/libxml/ruby_xml_schema_element.c +94 -94
  52. data/ext/libxml/ruby_xml_schema_element.h +14 -14
  53. data/ext/libxml/ruby_xml_schema_facet.c +52 -52
  54. data/ext/libxml/ruby_xml_schema_facet.h +13 -13
  55. data/ext/libxml/ruby_xml_schema_type.c +259 -259
  56. data/ext/libxml/ruby_xml_schema_type.h +9 -9
  57. data/ext/libxml/ruby_xml_version.h +9 -9
  58. data/ext/libxml/ruby_xml_writer.c +1136 -1136
  59. data/ext/libxml/ruby_xml_writer.h +10 -10
  60. data/ext/libxml/ruby_xml_xinclude.c +16 -16
  61. data/ext/libxml/ruby_xml_xinclude.h +11 -11
  62. data/ext/libxml/ruby_xml_xpath.c +42 -36
  63. data/ext/libxml/ruby_xml_xpath.h +13 -13
  64. data/ext/libxml/ruby_xml_xpath_context.c +1 -1
  65. data/ext/libxml/ruby_xml_xpath_context.h +9 -9
  66. data/ext/libxml/ruby_xml_xpath_expression.c +81 -81
  67. data/ext/libxml/ruby_xml_xpath_expression.h +10 -10
  68. data/ext/libxml/ruby_xml_xpath_object.c +5 -2
  69. data/ext/libxml/ruby_xml_xpath_object.h +17 -17
  70. data/ext/libxml/ruby_xml_xpointer.c +99 -99
  71. data/ext/libxml/ruby_xml_xpointer.h +11 -11
  72. data/ext/vc/libxml_ruby.sln +17 -15
  73. data/lib/libxml.rb +1 -6
  74. data/lib/libxml/node.rb +2 -78
  75. data/lib/libxml/parser.rb +0 -266
  76. data/lib/libxml/sax_parser.rb +0 -17
  77. data/lib/libxml/schema.rb +66 -66
  78. data/lib/libxml/schema/attribute.rb +19 -19
  79. data/lib/libxml/schema/element.rb +27 -27
  80. data/lib/libxml/schema/type.rb +29 -29
  81. data/script/benchmark/depixelate +634 -634
  82. data/script/benchmark/hamlet.xml +9054 -9054
  83. data/script/benchmark/parsecount +170 -170
  84. data/script/benchmark/throughput +41 -41
  85. data/script/test +6 -6
  86. data/test/c14n/given/example-1.xml +14 -14
  87. data/test/c14n/given/example-2.xml +11 -11
  88. data/test/c14n/given/example-3.xml +18 -18
  89. data/test/c14n/given/example-4.xml +9 -9
  90. data/test/c14n/given/example-5.xml +12 -12
  91. data/test/c14n/given/example-6.xml +2 -2
  92. data/test/c14n/given/example-7.xml +11 -11
  93. data/test/c14n/given/example-8.xml +11 -11
  94. data/test/c14n/given/example-8.xpath +9 -9
  95. data/test/c14n/result/1-1-without-comments/example-1 +3 -3
  96. data/test/c14n/result/1-1-without-comments/example-2 +10 -10
  97. data/test/c14n/result/1-1-without-comments/example-3 +13 -13
  98. data/test/c14n/result/1-1-without-comments/example-4 +8 -8
  99. data/test/c14n/result/1-1-without-comments/example-5 +2 -2
  100. data/test/c14n/result/with-comments/example-1 +5 -5
  101. data/test/c14n/result/with-comments/example-2 +10 -10
  102. data/test/c14n/result/with-comments/example-3 +13 -13
  103. data/test/c14n/result/with-comments/example-4 +8 -8
  104. data/test/c14n/result/with-comments/example-5 +3 -3
  105. data/test/c14n/result/without-comments/example-1 +3 -3
  106. data/test/c14n/result/without-comments/example-2 +10 -10
  107. data/test/c14n/result/without-comments/example-3 +13 -13
  108. data/test/c14n/result/without-comments/example-4 +8 -8
  109. data/test/c14n/result/without-comments/example-5 +2 -2
  110. data/test/model/atom.xml +12 -12
  111. data/test/model/bands.iso-8859-1.xml +4 -4
  112. data/test/model/bands.utf-8.xml +4 -4
  113. data/test/model/bands.xml +4 -4
  114. data/test/model/books.xml +153 -153
  115. data/test/model/merge_bug_data.xml +58 -58
  116. data/test/model/ruby-lang.html +238 -238
  117. data/test/model/rubynet.xml +79 -79
  118. data/test/model/shiporder.rnc +28 -28
  119. data/test/model/shiporder.rng +86 -86
  120. data/test/model/shiporder.xml +22 -22
  121. data/test/model/shiporder.xsd +39 -39
  122. data/test/model/soap.xml +27 -27
  123. data/test/model/xinclude.xml +4 -4
  124. data/test/tc_attributes.rb +0 -6
  125. data/test/tc_error.rb +157 -158
  126. data/test/tc_node.rb +33 -17
  127. data/test/tc_node_edit.rb +0 -15
  128. data/test/tc_node_pi.rb +39 -39
  129. data/test/tc_parser.rb +0 -48
  130. data/test/tc_reader.rb +12 -53
  131. data/test/tc_writer.rb +447 -447
  132. data/test/tc_xpath.rb +1 -1
  133. data/test/test_helper.rb +2 -2
  134. metadata +3 -8
  135. data/ext/libxml/extconf.h +0 -4
  136. data/lib/libxml/ns.rb +0 -22
  137. data/lib/libxml/properties.rb +0 -23
  138. data/lib/libxml/reader.rb +0 -29
  139. data/lib/libxml/xpath_object.rb +0 -16
@@ -1,10 +1,10 @@
1
- /* Please see the LICENSE file for copyright and distribution information */
2
-
3
- #ifndef __RXML_NAMESPACE__
4
- #define __RXML_NAMESPACE__
5
-
6
- extern VALUE cXMLNamespace;
7
-
8
- void rxml_init_namespace(void);
9
- VALUE rxml_namespace_wrap(xmlNsPtr xns);
10
- #endif
1
+ /* Please see the LICENSE file for copyright and distribution information */
2
+
3
+ #ifndef __RXML_NAMESPACE__
4
+ #define __RXML_NAMESPACE__
5
+
6
+ extern VALUE cXMLNamespace;
7
+
8
+ void rxml_init_namespace(void);
9
+ VALUE rxml_namespace_wrap(xmlNsPtr xns);
10
+ #endif
@@ -1,293 +1,293 @@
1
- /* Please see the LICENSE file for copyright and distribution information */
2
-
3
- #include "ruby_libxml.h"
4
- #include "ruby_xml_namespaces.h"
5
-
6
- VALUE cXMLNamespaces;
7
-
8
- /* Document-class: LibXML::XML::Namespaces
9
- *
10
- * The XML::Namespaces class is used to access information about
11
- * a node's namespaces. For each node, libxml maintains:
12
- *
13
- * * The node's namespace (#namespace)
14
- * * Which namespaces are defined on the node (#definnitions)
15
- * * Which namespaces are in scope for the node (#each)
16
- *
17
- * Let's look at an example:
18
- *
19
- * <soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"
20
- * xmlns:xsd="http://www.w3.org/2001/XMLSchema">
21
- * <soap:Body>
22
- * <order xmlns="http://mynamespace.com"/>
23
- * </soap:Body>
24
- * </soap>
25
- *
26
- * The Envelope node is in the soap namespace. It contains
27
- * two namespace definitions, one for soap and one for xsd.
28
- *
29
- * The Body node is also in the soap namespace and does not
30
- * contain any namespaces. However, the soap and xsd namespaces
31
- * are both in context.
32
- *
33
- * The order node is in its default namespace and contains
34
- * one namespace definition (http://mynamespace.com). There
35
- * are three namespaces in context soap, xsd and the
36
- * default namespace.
37
- */
38
-
39
- static VALUE rxml_namespaces_alloc(VALUE klass)
40
- {
41
- return Data_Wrap_Struct(klass, NULL, NULL, NULL);
42
- }
43
-
44
- /*
45
- * call-seq:
46
- * initialize(XML::Node) -> XML::Namespaces
47
- *
48
- * Creates a new namespaces object. Generally you
49
- * do not call this method directly, but instead
50
- * access a namespaces object via XML::Node#namespaces.
51
- *
52
- * Usage:
53
- *
54
- * doc = XML::Document.string('<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"/>')
55
- * namespaces = new XML::Namespaces(doc.root)
56
- */
57
- static VALUE rxml_namespaces_initialize(VALUE self, VALUE node)
58
- {
59
- xmlNodePtr xnode;
60
-
61
- Check_Type(node, T_DATA);
62
- Data_Get_Struct(node, xmlNode, xnode);
63
-
64
- DATA_PTR(self) = xnode;
65
- return self;
66
- }
67
-
68
- /*
69
- * call-seq:
70
- * namespaces.definitions -> [XML::Namespace, XML::Namespace]
71
- *
72
- * Returns an array of XML::Namespace objects that are
73
- * defined on this node.
74
- *
75
- * Usage:
76
- *
77
- * doc = XML::Document.string('<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"/>')
78
- * defs = doc.root.namespaces.definitions
79
- */
80
- static VALUE rxml_namespaces_definitions(VALUE self)
81
- {
82
- xmlNodePtr xnode;
83
- xmlNsPtr xns;
84
- VALUE arr;
85
-
86
- Data_Get_Struct(self, xmlNode, xnode);
87
-
88
- arr = rb_ary_new();
89
- xns = xnode->nsDef;
90
-
91
- while (xns)
92
- {
93
- VALUE anamespace = rxml_namespace_wrap(xns);
94
- rb_ary_push(arr, anamespace);
95
- xns = xns->next;
96
- }
97
-
98
- return arr;
99
- }
100
-
101
- /*
102
- * call-seq:
103
- * namespaces.each {|XML::Namespace|}
104
- *
105
- * Iterates over the namespace objects that are
106
- * in context for this node.
107
- *
108
- * Usage:
109
- *
110
- * doc = XML::Document.string('<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"/>')
111
- * doc.root.namespaces.each do |ns|
112
- * ..
113
- * end
114
- */
115
- static VALUE rxml_namespaces_each(VALUE self)
116
- {
117
- xmlNodePtr xnode;
118
- xmlNsPtr *nsList, *xns;
119
-
120
- Data_Get_Struct(self, xmlNode, xnode);
121
-
122
- nsList = xmlGetNsList(xnode->doc, xnode);
123
-
124
- if (nsList == NULL)
125
- return (Qnil);
126
-
127
- for (xns = nsList; *xns != NULL; xns++)
128
- {
129
- VALUE ns = rxml_namespace_wrap(*xns);
130
- rb_yield(ns);
131
- }
132
- xmlFree(nsList);
133
-
134
- return Qnil;
135
- }
136
-
137
- /*
138
- * call-seq:
139
- * namespaces.find_by_href(href) -> XML::Namespace
140
- *
141
- * Searches for a namespace that has the specified href.
142
- * The search starts at the current node and works upward
143
- * through the node's parents. If a namespace is found,
144
- * then an XML::Namespace instance is returned, otherwise nil
145
- * is returned.
146
- *
147
- * Usage:
148
- *
149
- * doc = XML::Document.string('<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"/>')
150
- * ns = doc.root.namespaces.find_by_href('http://schemas.xmlsoap.org/soap/envelope/')
151
- * assert_equal('soap', ns.prefix)
152
- * assert_equal('http://schemas.xmlsoap.org/soap/envelope/', ns.href)
153
- */
154
- static VALUE rxml_namespaces_find_by_href(VALUE self, VALUE href)
155
- {
156
- xmlNodePtr xnode;
157
- xmlNsPtr xns;
158
-
159
- Check_Type(href, T_STRING);
160
- Data_Get_Struct(self, xmlNode, xnode);
161
-
162
- xns = xmlSearchNsByHref(xnode->doc, xnode, (xmlChar*) StringValuePtr(href));
163
- if (xns)
164
- return rxml_namespace_wrap(xns);
165
- else
166
- return Qnil;
167
- }
168
-
169
- /*
170
- * call-seq:
171
- * namespaces.find_by_prefix(prefix=nil) -> XML::Namespace
172
- *
173
- * Searches for a namespace that has the specified prefix.
174
- * The search starts at the current node and works upward
175
- * through the node's parents. If a namespace is found,
176
- * then an XML::Namespace instance is returned, otherwise nil
177
- * is returned.
178
- *
179
- * Usage:
180
- *
181
- * doc = XML::Document.string('<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"/>')
182
- * ns = doc.root.namespaces.find_by_prefix('soap')
183
- * assert_equal('soap', ns.prefix)
184
- * assert_equal('http://schemas.xmlsoap.org/soap/envelope/', ns.href)
185
- */
186
- static VALUE rxml_namespaces_find_by_prefix(VALUE self, VALUE prefix)
187
- {
188
- xmlNodePtr xnode;
189
- xmlNsPtr xns;
190
- xmlChar* xprefix = NULL;
191
-
192
-
193
- if (!NIL_P(prefix))
194
- {
195
- Check_Type(prefix, T_STRING);
196
- xprefix = (xmlChar*) StringValuePtr(prefix);
197
- }
198
-
199
- Data_Get_Struct(self, xmlNode, xnode);
200
-
201
- xns = xmlSearchNs(xnode->doc, xnode, xprefix);
202
- if (xns)
203
- return rxml_namespace_wrap(xns);
204
- else
205
- return Qnil;
206
- }
207
-
208
- /*
209
- * call-seq:
210
- * namespaces.namespace -> XML::Namespace
211
- *
212
- * Returns the current node's namespace.
213
- *
214
- * Usage:
215
- *
216
- * doc = XML::Document.string('<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"/>')
217
- * ns = doc.root.namespaces.namespace
218
- * assert_equal('soap', ns.prefix)
219
- * assert_equal('http://schemas.xmlsoap.org/soap/envelope/', ns.href)
220
- */
221
- static VALUE rxml_namespaces_namespace_get(VALUE self)
222
- {
223
- xmlNodePtr xnode;
224
- Data_Get_Struct(self, xmlNode, xnode);
225
-
226
- if (xnode->ns)
227
- return rxml_namespace_wrap(xnode->ns);
228
- else
229
- return Qnil;
230
- }
231
-
232
- /*
233
- * call-seq:
234
- * namespaces.namespace = XML::Namespace
235
- *
236
- * Sets the current node's namespace.
237
- *
238
- * Basic usage:
239
- *
240
- * # Create a node
241
- * node = XML::Node.new('Envelope')
242
- *
243
- * # Define the soap namespace - this does *not* put the node in the namespace
244
- * ns = XML::Namespace.new(node, 'soap', 'http://schemas.xmlsoap.org/soap/envelope/')
245
- * assert_equal("<Envelope xmlns:soap=\"http://schemas.xmlsoap.org/soap/envelope/\"/>", node.to_s)
246
- *
247
- * # Now put the node in the soap namespace, not how the string representation changes
248
- * node.namespaces.namespace = ns
249
- * assert_equal("<soap:Envelope xmlns:soap=\"http://schemas.xmlsoap.org/soap/envelope/\"/>", node.to_s)
250
- */
251
- static VALUE rxml_namespaces_namespace_set(VALUE self, VALUE ns)
252
- {
253
- xmlNodePtr xnode;
254
- xmlNsPtr xns;
255
-
256
- Data_Get_Struct(self, xmlNode, xnode);
257
-
258
- Check_Type(ns, T_DATA);
259
- Data_Get_Struct(ns, xmlNs, xns);
260
-
261
- xmlSetNs(xnode, xns);
262
- return self;
263
- }
264
-
265
- /*
266
- * call-seq:
267
- * namespaces.node -> XML::Node
268
- *
269
- * Returns the current node.
270
- */
271
- static VALUE rxml_namespaces_node_get(VALUE self)
272
- {
273
- xmlNodePtr xnode;
274
- Data_Get_Struct(self, xmlNode, xnode);
275
- return rxml_node_wrap(xnode);
276
- }
277
-
278
- void rxml_init_namespaces(void)
279
- {
280
- cXMLNamespaces = rb_define_class_under(mXML, "Namespaces", rb_cObject);
281
- rb_include_module(cXMLNamespaces, rb_mEnumerable);
282
-
283
- rb_define_alloc_func(cXMLNamespaces, rxml_namespaces_alloc);
284
- rb_define_method(cXMLNamespaces, "initialize", rxml_namespaces_initialize, 1);
285
-
286
- rb_define_method(cXMLNamespaces, "definitions", rxml_namespaces_definitions, 0);
287
- rb_define_method(cXMLNamespaces, "each", rxml_namespaces_each, 0);
288
- rb_define_method(cXMLNamespaces, "find_by_href", rxml_namespaces_find_by_href, 1);
289
- rb_define_method(cXMLNamespaces, "find_by_prefix", rxml_namespaces_find_by_prefix, 1);
290
- rb_define_method(cXMLNamespaces, "namespace", rxml_namespaces_namespace_get, 0);
291
- rb_define_method(cXMLNamespaces, "namespace=", rxml_namespaces_namespace_set, 1);
292
- rb_define_method(cXMLNamespaces, "node", rxml_namespaces_node_get, 0);
293
- }
1
+ /* Please see the LICENSE file for copyright and distribution information */
2
+
3
+ #include "ruby_libxml.h"
4
+ #include "ruby_xml_namespaces.h"
5
+
6
+ VALUE cXMLNamespaces;
7
+
8
+ /* Document-class: LibXML::XML::Namespaces
9
+ *
10
+ * The XML::Namespaces class is used to access information about
11
+ * a node's namespaces. For each node, libxml maintains:
12
+ *
13
+ * * The node's namespace (#namespace)
14
+ * * Which namespaces are defined on the node (#definnitions)
15
+ * * Which namespaces are in scope for the node (#each)
16
+ *
17
+ * Let's look at an example:
18
+ *
19
+ * <soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"
20
+ * xmlns:xsd="http://www.w3.org/2001/XMLSchema">
21
+ * <soap:Body>
22
+ * <order xmlns="http://mynamespace.com"/>
23
+ * </soap:Body>
24
+ * </soap>
25
+ *
26
+ * The Envelope node is in the soap namespace. It contains
27
+ * two namespace definitions, one for soap and one for xsd.
28
+ *
29
+ * The Body node is also in the soap namespace and does not
30
+ * contain any namespaces. However, the soap and xsd namespaces
31
+ * are both in context.
32
+ *
33
+ * The order node is in its default namespace and contains
34
+ * one namespace definition (http://mynamespace.com). There
35
+ * are three namespaces in context soap, xsd and the
36
+ * default namespace.
37
+ */
38
+
39
+ static VALUE rxml_namespaces_alloc(VALUE klass)
40
+ {
41
+ return Data_Wrap_Struct(klass, NULL, NULL, NULL);
42
+ }
43
+
44
+ /*
45
+ * call-seq:
46
+ * initialize(XML::Node) -> XML::Namespaces
47
+ *
48
+ * Creates a new namespaces object. Generally you
49
+ * do not call this method directly, but instead
50
+ * access a namespaces object via XML::Node#namespaces.
51
+ *
52
+ * Usage:
53
+ *
54
+ * doc = XML::Document.string('<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"/>')
55
+ * namespaces = new XML::Namespaces(doc.root)
56
+ */
57
+ static VALUE rxml_namespaces_initialize(VALUE self, VALUE node)
58
+ {
59
+ xmlNodePtr xnode;
60
+
61
+ Check_Type(node, T_DATA);
62
+ Data_Get_Struct(node, xmlNode, xnode);
63
+
64
+ DATA_PTR(self) = xnode;
65
+ return self;
66
+ }
67
+
68
+ /*
69
+ * call-seq:
70
+ * namespaces.definitions -> [XML::Namespace, XML::Namespace]
71
+ *
72
+ * Returns an array of XML::Namespace objects that are
73
+ * defined on this node.
74
+ *
75
+ * Usage:
76
+ *
77
+ * doc = XML::Document.string('<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"/>')
78
+ * defs = doc.root.namespaces.definitions
79
+ */
80
+ static VALUE rxml_namespaces_definitions(VALUE self)
81
+ {
82
+ xmlNodePtr xnode;
83
+ xmlNsPtr xns;
84
+ VALUE arr;
85
+
86
+ Data_Get_Struct(self, xmlNode, xnode);
87
+
88
+ arr = rb_ary_new();
89
+ xns = xnode->nsDef;
90
+
91
+ while (xns)
92
+ {
93
+ VALUE anamespace = rxml_namespace_wrap(xns);
94
+ rb_ary_push(arr, anamespace);
95
+ xns = xns->next;
96
+ }
97
+
98
+ return arr;
99
+ }
100
+
101
+ /*
102
+ * call-seq:
103
+ * namespaces.each {|XML::Namespace|}
104
+ *
105
+ * Iterates over the namespace objects that are
106
+ * in context for this node.
107
+ *
108
+ * Usage:
109
+ *
110
+ * doc = XML::Document.string('<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"/>')
111
+ * doc.root.namespaces.each do |ns|
112
+ * ..
113
+ * end
114
+ */
115
+ static VALUE rxml_namespaces_each(VALUE self)
116
+ {
117
+ xmlNodePtr xnode;
118
+ xmlNsPtr *nsList, *xns;
119
+
120
+ Data_Get_Struct(self, xmlNode, xnode);
121
+
122
+ nsList = xmlGetNsList(xnode->doc, xnode);
123
+
124
+ if (nsList == NULL)
125
+ return (Qnil);
126
+
127
+ for (xns = nsList; *xns != NULL; xns++)
128
+ {
129
+ VALUE ns = rxml_namespace_wrap(*xns);
130
+ rb_yield(ns);
131
+ }
132
+ xmlFree(nsList);
133
+
134
+ return Qnil;
135
+ }
136
+
137
+ /*
138
+ * call-seq:
139
+ * namespaces.find_by_href(href) -> XML::Namespace
140
+ *
141
+ * Searches for a namespace that has the specified href.
142
+ * The search starts at the current node and works upward
143
+ * through the node's parents. If a namespace is found,
144
+ * then an XML::Namespace instance is returned, otherwise nil
145
+ * is returned.
146
+ *
147
+ * Usage:
148
+ *
149
+ * doc = XML::Document.string('<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"/>')
150
+ * ns = doc.root.namespaces.find_by_href('http://schemas.xmlsoap.org/soap/envelope/')
151
+ * assert_equal('soap', ns.prefix)
152
+ * assert_equal('http://schemas.xmlsoap.org/soap/envelope/', ns.href)
153
+ */
154
+ static VALUE rxml_namespaces_find_by_href(VALUE self, VALUE href)
155
+ {
156
+ xmlNodePtr xnode;
157
+ xmlNsPtr xns;
158
+
159
+ Check_Type(href, T_STRING);
160
+ Data_Get_Struct(self, xmlNode, xnode);
161
+
162
+ xns = xmlSearchNsByHref(xnode->doc, xnode, (xmlChar*) StringValuePtr(href));
163
+ if (xns)
164
+ return rxml_namespace_wrap(xns);
165
+ else
166
+ return Qnil;
167
+ }
168
+
169
+ /*
170
+ * call-seq:
171
+ * namespaces.find_by_prefix(prefix=nil) -> XML::Namespace
172
+ *
173
+ * Searches for a namespace that has the specified prefix.
174
+ * The search starts at the current node and works upward
175
+ * through the node's parents. If a namespace is found,
176
+ * then an XML::Namespace instance is returned, otherwise nil
177
+ * is returned.
178
+ *
179
+ * Usage:
180
+ *
181
+ * doc = XML::Document.string('<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"/>')
182
+ * ns = doc.root.namespaces.find_by_prefix('soap')
183
+ * assert_equal('soap', ns.prefix)
184
+ * assert_equal('http://schemas.xmlsoap.org/soap/envelope/', ns.href)
185
+ */
186
+ static VALUE rxml_namespaces_find_by_prefix(VALUE self, VALUE prefix)
187
+ {
188
+ xmlNodePtr xnode;
189
+ xmlNsPtr xns;
190
+ xmlChar* xprefix = NULL;
191
+
192
+
193
+ if (!NIL_P(prefix))
194
+ {
195
+ Check_Type(prefix, T_STRING);
196
+ xprefix = (xmlChar*) StringValuePtr(prefix);
197
+ }
198
+
199
+ Data_Get_Struct(self, xmlNode, xnode);
200
+
201
+ xns = xmlSearchNs(xnode->doc, xnode, xprefix);
202
+ if (xns)
203
+ return rxml_namespace_wrap(xns);
204
+ else
205
+ return Qnil;
206
+ }
207
+
208
+ /*
209
+ * call-seq:
210
+ * namespaces.namespace -> XML::Namespace
211
+ *
212
+ * Returns the current node's namespace.
213
+ *
214
+ * Usage:
215
+ *
216
+ * doc = XML::Document.string('<soap:Envelope xmlns:soap="http://schemas.xmlsoap.org/soap/envelope/"/>')
217
+ * ns = doc.root.namespaces.namespace
218
+ * assert_equal('soap', ns.prefix)
219
+ * assert_equal('http://schemas.xmlsoap.org/soap/envelope/', ns.href)
220
+ */
221
+ static VALUE rxml_namespaces_namespace_get(VALUE self)
222
+ {
223
+ xmlNodePtr xnode;
224
+ Data_Get_Struct(self, xmlNode, xnode);
225
+
226
+ if (xnode->ns)
227
+ return rxml_namespace_wrap(xnode->ns);
228
+ else
229
+ return Qnil;
230
+ }
231
+
232
+ /*
233
+ * call-seq:
234
+ * namespaces.namespace = XML::Namespace
235
+ *
236
+ * Sets the current node's namespace.
237
+ *
238
+ * Basic usage:
239
+ *
240
+ * # Create a node
241
+ * node = XML::Node.new('Envelope')
242
+ *
243
+ * # Define the soap namespace - this does *not* put the node in the namespace
244
+ * ns = XML::Namespace.new(node, 'soap', 'http://schemas.xmlsoap.org/soap/envelope/')
245
+ * assert_equal("<Envelope xmlns:soap=\"http://schemas.xmlsoap.org/soap/envelope/\"/>", node.to_s)
246
+ *
247
+ * # Now put the node in the soap namespace, not how the string representation changes
248
+ * node.namespaces.namespace = ns
249
+ * assert_equal("<soap:Envelope xmlns:soap=\"http://schemas.xmlsoap.org/soap/envelope/\"/>", node.to_s)
250
+ */
251
+ static VALUE rxml_namespaces_namespace_set(VALUE self, VALUE ns)
252
+ {
253
+ xmlNodePtr xnode;
254
+ xmlNsPtr xns;
255
+
256
+ Data_Get_Struct(self, xmlNode, xnode);
257
+
258
+ Check_Type(ns, T_DATA);
259
+ Data_Get_Struct(ns, xmlNs, xns);
260
+
261
+ xmlSetNs(xnode, xns);
262
+ return self;
263
+ }
264
+
265
+ /*
266
+ * call-seq:
267
+ * namespaces.node -> XML::Node
268
+ *
269
+ * Returns the current node.
270
+ */
271
+ static VALUE rxml_namespaces_node_get(VALUE self)
272
+ {
273
+ xmlNodePtr xnode;
274
+ Data_Get_Struct(self, xmlNode, xnode);
275
+ return rxml_node_wrap(xnode);
276
+ }
277
+
278
+ void rxml_init_namespaces(void)
279
+ {
280
+ cXMLNamespaces = rb_define_class_under(mXML, "Namespaces", rb_cObject);
281
+ rb_include_module(cXMLNamespaces, rb_mEnumerable);
282
+
283
+ rb_define_alloc_func(cXMLNamespaces, rxml_namespaces_alloc);
284
+ rb_define_method(cXMLNamespaces, "initialize", rxml_namespaces_initialize, 1);
285
+
286
+ rb_define_method(cXMLNamespaces, "definitions", rxml_namespaces_definitions, 0);
287
+ rb_define_method(cXMLNamespaces, "each", rxml_namespaces_each, 0);
288
+ rb_define_method(cXMLNamespaces, "find_by_href", rxml_namespaces_find_by_href, 1);
289
+ rb_define_method(cXMLNamespaces, "find_by_prefix", rxml_namespaces_find_by_prefix, 1);
290
+ rb_define_method(cXMLNamespaces, "namespace", rxml_namespaces_namespace_get, 0);
291
+ rb_define_method(cXMLNamespaces, "namespace=", rxml_namespaces_namespace_set, 1);
292
+ rb_define_method(cXMLNamespaces, "node", rxml_namespaces_node_get, 0);
293
+ }