libxml-ruby 3.2.2-x64-mingw-ucrt → 3.2.4-x64-mingw-ucrt
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.
- checksums.yaml +4 -4
- data/HISTORY +16 -0
- data/ext/libxml/extconf.h +3 -0
- data/ext/libxml/ruby_libxml.h +0 -22
- data/ext/libxml/ruby_xml.c +6 -0
- data/ext/libxml/ruby_xml_document.c +6 -0
- data/ext/libxml/ruby_xml_encoding.h +2 -0
- data/ext/libxml/ruby_xml_error.h +2 -0
- data/ext/libxml/ruby_xml_html_parser.c +2 -0
- data/ext/libxml/ruby_xml_html_parser_context.c +1 -0
- data/ext/libxml/ruby_xml_html_parser_options.c +2 -0
- data/ext/libxml/ruby_xml_namespace.c +1 -0
- data/ext/libxml/ruby_xml_node.c +12 -4
- data/ext/libxml/ruby_xml_parser_context.c +2 -0
- data/ext/libxml/ruby_xml_reader.c +3 -0
- data/ext/libxml/ruby_xml_reader.h +0 -3
- data/ext/libxml/ruby_xml_relaxng.c +2 -0
- data/ext/libxml/ruby_xml_relaxng.h +0 -2
- data/ext/libxml/ruby_xml_schema.c +223 -81
- data/ext/libxml/ruby_xml_schema.h +4 -788
- data/ext/libxml/ruby_xml_schema_attribute.c +69 -71
- data/ext/libxml/ruby_xml_schema_attribute.h +25 -3
- data/ext/libxml/ruby_xml_schema_element.c +28 -54
- data/ext/libxml/ruby_xml_schema_element.h +0 -3
- data/ext/libxml/ruby_xml_schema_facet.c +19 -21
- data/ext/libxml/ruby_xml_schema_facet.h +0 -4
- data/ext/libxml/ruby_xml_schema_type.c +56 -37
- data/ext/libxml/ruby_xml_version.h +3 -3
- data/ext/libxml/ruby_xml_writer.c +4 -0
- data/ext/libxml/ruby_xml_writer.h +0 -4
- data/ext/libxml/ruby_xml_xinclude.c +4 -0
- data/ext/libxml/ruby_xml_xpath.c +1 -0
- data/ext/libxml/ruby_xml_xpath.h +2 -0
- data/ext/libxml/ruby_xml_xpath_context.c +2 -0
- data/ext/libxml/ruby_xml_xpath_object.c +1 -0
- data/ext/libxml/ruby_xml_xpointer.c +5 -1
- data/lib/3.1/libxml_ruby.so +0 -0
- data/lib/libxml-ruby.rb +1 -1
- data/test/model/shiporder.rnc +2 -2
- data/test/model/shiporder.rng +2 -2
- data/test/model/shiporder.xsd +7 -3
- data/test/model/shiporder_bad.xsd +40 -0
- data/test/model/shiporder_import.xsd +45 -0
- data/test/test_helper.rb +4 -0
- data/test/test_schema.rb +92 -29
- data/test/test_xml.rb +15 -3
- metadata +6 -3
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 133d86e0978fad8ee63caac2b000d64528da03c5141e484327dc1bd443f85ad5
|
4
|
+
data.tar.gz: 3d43359e5daed2d0e6ea23481aaf405aa9422419edaefe8a51d18767c463c052
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 7b91fe3b0daa9a90706a531e552ff16a3e785612e259aa7e379d9e948f72c0d2738c34a33a5e5697cee6ba4cb43c991e657347e40d35a13f749c494a64e54bea
|
7
|
+
data.tar.gz: 68afd10bef5ba4f05bdc275b526c319c0d6f98492ba039bff0ce599b58c5eeb72789669a361175491cca6225934a053054955a36ad4833d3bd5a79eee7e4da3d
|
data/HISTORY
CHANGED
@@ -1,5 +1,21 @@
|
|
1
1
|
= Release History
|
2
2
|
|
3
|
+
== 3.2.4 / 2022-10-29
|
4
|
+
|
5
|
+
* Support libxml2 version 2.10.2 (Charlie Savage)
|
6
|
+
* Reduce number of globally included C header files (Charlie Savage)
|
7
|
+
|
8
|
+
== 3.2.3 / 2022-05-22
|
9
|
+
|
10
|
+
* Change some getter methods to instance variables with attr_accessors for easier debuggability (David Hansen)
|
11
|
+
* Add a number of tests related to schemas (David Hansen)
|
12
|
+
* Add schema.imported_elements so we can find imported elements (David Hansen)
|
13
|
+
* Fix segfault under windows when dereferencing a pre-existing error where the node has already been freed (David Hansen)
|
14
|
+
* Update to change name from imported_elements to imported_ns_elements and return a hash of hashes for namespaced elements (David Hansen)
|
15
|
+
* Only call xmlGetFeaturesList if LIBXML_LEGACY_ENABLED is defined. Most distros still ship libxml2 with legacy features enabled, but this will change (Nick Wellnhofer)
|
16
|
+
* Update GitHub Actions to use ruby/setup-ruby (Greg)
|
17
|
+
* Fix memory leak in rxml_node_path, node.path (vovanmozg)
|
18
|
+
|
3
19
|
== 3.2.2 / 2022-01-15
|
4
20
|
* Switch to Github actions for CI/CD (Greg)
|
5
21
|
* Test fixes (Greg, Sergio Durigan Junior)
|
data/ext/libxml/ruby_libxml.h
CHANGED
@@ -4,29 +4,7 @@
|
|
4
4
|
#define __RUBY_LIBXML_H__
|
5
5
|
|
6
6
|
#include <ruby.h>
|
7
|
-
#include <libxml/parser.h>
|
8
|
-
#include <libxml/parserInternals.h>
|
9
|
-
#include <libxml/debugXML.h>
|
10
7
|
#include <libxml/xmlversion.h>
|
11
|
-
#include <libxml/xmlmemory.h>
|
12
|
-
#include <libxml/xpath.h>
|
13
|
-
#include <libxml/valid.h>
|
14
|
-
#include <libxml/catalog.h>
|
15
|
-
#include <libxml/HTMLparser.h>
|
16
|
-
#include <libxml/xmlreader.h>
|
17
|
-
#include <libxml/c14n.h>
|
18
|
-
|
19
|
-
#include <ruby/encoding.h>
|
20
|
-
|
21
|
-
#ifdef LIBXML_DEBUG_ENABLED
|
22
|
-
#include <libxml/xpathInternals.h>
|
23
|
-
#endif
|
24
|
-
#ifdef LIBXML_XINCLUDE_ENABLED
|
25
|
-
#include <libxml/xinclude.h>
|
26
|
-
#endif
|
27
|
-
#ifdef LIBXML_XPTR_ENABLED
|
28
|
-
#include <libxml/xpointer.h>
|
29
|
-
#endif
|
30
8
|
|
31
9
|
#include "ruby_xml_version.h"
|
32
10
|
#include "ruby_xml.h"
|
data/ext/libxml/ruby_xml.c
CHANGED
@@ -1,6 +1,8 @@
|
|
1
1
|
#include "ruby_libxml.h"
|
2
2
|
#include "ruby_xml.h"
|
3
3
|
|
4
|
+
#include <libxml/catalog.h>
|
5
|
+
|
4
6
|
VALUE mXML;
|
5
7
|
|
6
8
|
/*
|
@@ -764,6 +766,9 @@ static VALUE rxml_default_save_no_empty_tags_set(VALUE klass, VALUE value)
|
|
764
766
|
*/
|
765
767
|
static VALUE rxml_features(VALUE klass)
|
766
768
|
{
|
769
|
+
#ifndef LIBXML_LEGACY_ENABLED
|
770
|
+
return Qnil;
|
771
|
+
#else
|
767
772
|
VALUE arr, str;
|
768
773
|
int i, len = MAX_LIBXML_FEATURES_LEN;
|
769
774
|
char **list = NULL;
|
@@ -788,6 +793,7 @@ static VALUE rxml_features(VALUE klass)
|
|
788
793
|
|
789
794
|
ruby_xfree(list);
|
790
795
|
return (arr);
|
796
|
+
#endif /* LIBXML_LEGACY_ENABLED */
|
791
797
|
}
|
792
798
|
|
793
799
|
/*
|
@@ -52,6 +52,12 @@
|
|
52
52
|
#include "ruby_libxml.h"
|
53
53
|
#include "ruby_xml_document.h"
|
54
54
|
|
55
|
+
#include <libxml/c14n.h>
|
56
|
+
#include <libxml/debugXML.h>
|
57
|
+
#include <libxml/relaxng.h>
|
58
|
+
#include <libxml/xmlschemas.h>
|
59
|
+
#include <libxml/xinclude.h>
|
60
|
+
|
55
61
|
VALUE cXMLDocument;
|
56
62
|
|
57
63
|
void rxml_document_free(xmlDocPtr xdoc)
|
data/ext/libxml/ruby_xml_error.h
CHANGED
@@ -52,6 +52,7 @@ static VALUE rxml_namespace_initialize(VALUE self, VALUE node, VALUE prefix,
|
|
52
52
|
|
53
53
|
Check_Type(node, T_DATA);
|
54
54
|
Data_Get_Struct(node, xmlNode, xnode);
|
55
|
+
xmlResetLastError();
|
55
56
|
|
56
57
|
/* Prefix can be null - that means its the default namespace */
|
57
58
|
xmlPrefix = NIL_P(prefix) ? NULL : (xmlChar *)StringValuePtr(prefix);
|
data/ext/libxml/ruby_xml_node.c
CHANGED
@@ -2,6 +2,10 @@
|
|
2
2
|
#include "ruby_xml_node.h"
|
3
3
|
#include <assert.h>
|
4
4
|
|
5
|
+
#include <libxml/debugXML.h>
|
6
|
+
#include <libxml/parserInternals.h>
|
7
|
+
#include <libxml/xlink.h>
|
8
|
+
|
5
9
|
VALUE cXMLNode;
|
6
10
|
|
7
11
|
/* Document-class: LibXML::XML::Node
|
@@ -983,14 +987,18 @@ static VALUE rxml_node_path(VALUE self)
|
|
983
987
|
{
|
984
988
|
xmlNodePtr xnode;
|
985
989
|
xmlChar *path;
|
990
|
+
VALUE result = Qnil;
|
986
991
|
|
987
992
|
xnode = rxml_get_xnode(self);
|
988
993
|
path = xmlGetNodePath(xnode);
|
989
994
|
|
990
|
-
if (path
|
991
|
-
|
992
|
-
|
993
|
-
|
995
|
+
if (path)
|
996
|
+
{
|
997
|
+
result = rxml_new_cstr( path, NULL);
|
998
|
+
xmlFree(path);
|
999
|
+
}
|
1000
|
+
|
1001
|
+
return result;
|
994
1002
|
}
|
995
1003
|
|
996
1004
|
/*
|
@@ -1,6 +1,4 @@
|
|
1
1
|
#include "ruby_libxml.h"
|
2
|
-
#define LIBXML_OUTPUT_ENABLED
|
3
|
-
#define DUMP_CONTENT_MODEL
|
4
2
|
#include "ruby_xml_schema.h"
|
5
3
|
|
6
4
|
#include "ruby_xml_schema_type.h"
|
@@ -8,6 +6,78 @@
|
|
8
6
|
#include "ruby_xml_schema_attribute.h"
|
9
7
|
#include "ruby_xml_schema_facet.h"
|
10
8
|
|
9
|
+
#include <libxml/xmlschemas.h>
|
10
|
+
|
11
|
+
typedef struct _xmlSchemaBucket xmlSchemaBucket;
|
12
|
+
typedef xmlSchemaBucket *xmlSchemaBucketPtr;
|
13
|
+
|
14
|
+
/**
|
15
|
+
* xmlSchemaSchemaRelation:
|
16
|
+
*
|
17
|
+
* Used to create a graph of schema relationships.
|
18
|
+
*/
|
19
|
+
typedef struct _xmlSchemaSchemaRelation xmlSchemaSchemaRelation;
|
20
|
+
typedef xmlSchemaSchemaRelation *xmlSchemaSchemaRelationPtr;
|
21
|
+
struct _xmlSchemaSchemaRelation {
|
22
|
+
xmlSchemaSchemaRelationPtr next;
|
23
|
+
int type;
|
24
|
+
/* E.g. XML_SCHEMA_SCHEMA_IMPORT */
|
25
|
+
const xmlChar *importNamespace;
|
26
|
+
xmlSchemaBucketPtr bucket;
|
27
|
+
};
|
28
|
+
|
29
|
+
struct _xmlSchemaBucket {
|
30
|
+
int type;
|
31
|
+
int flags;
|
32
|
+
const xmlChar *schemaLocation;
|
33
|
+
const xmlChar *origTargetNamespace;
|
34
|
+
const xmlChar *targetNamespace;
|
35
|
+
xmlDocPtr doc;
|
36
|
+
xmlSchemaSchemaRelationPtr relations;
|
37
|
+
int located;
|
38
|
+
int parsed;
|
39
|
+
int imported;
|
40
|
+
int preserveDoc;
|
41
|
+
xmlSchemaItemListPtr globals;
|
42
|
+
/* Global components. */
|
43
|
+
xmlSchemaItemListPtr locals; /* Local components. */
|
44
|
+
};
|
45
|
+
|
46
|
+
/**
|
47
|
+
* xmlSchemaImport:
|
48
|
+
* (extends xmlSchemaBucket)
|
49
|
+
*
|
50
|
+
* Reflects a schema. Holds some information
|
51
|
+
* about the schema and its toplevel components. Duplicate
|
52
|
+
* toplevel components are not checked at this level.
|
53
|
+
*/
|
54
|
+
typedef struct _xmlSchemaImport xmlSchemaImport;
|
55
|
+
typedef xmlSchemaImport *xmlSchemaImportPtr;
|
56
|
+
struct _xmlSchemaImport {
|
57
|
+
int type;
|
58
|
+
/* Main OR import OR include. */
|
59
|
+
int flags;
|
60
|
+
const xmlChar *schemaLocation; /* The URI of the schema document. */
|
61
|
+
/* For chameleon includes, @origTargetNamespace will be NULL */
|
62
|
+
const xmlChar *origTargetNamespace;
|
63
|
+
/*
|
64
|
+
* For chameleon includes, @targetNamespace will be the
|
65
|
+
* targetNamespace of the including schema.
|
66
|
+
*/
|
67
|
+
const xmlChar *targetNamespace;
|
68
|
+
xmlDocPtr doc; /* The schema node-tree. */
|
69
|
+
/* @relations will hold any included/imported/redefined schemas. */
|
70
|
+
xmlSchemaSchemaRelationPtr relations;
|
71
|
+
int located;
|
72
|
+
int parsed;
|
73
|
+
int imported;
|
74
|
+
int preserveDoc;
|
75
|
+
xmlSchemaItemListPtr globals;
|
76
|
+
xmlSchemaItemListPtr locals;
|
77
|
+
/* The imported schema. */
|
78
|
+
xmlSchemaPtr schema;
|
79
|
+
};
|
80
|
+
|
11
81
|
/*
|
12
82
|
* Document-class: LibXML::XML::Schema
|
13
83
|
*
|
@@ -46,9 +116,37 @@ static void rxml_schema_free(xmlSchemaPtr xschema)
|
|
46
116
|
|
47
117
|
VALUE rxml_wrap_schema(xmlSchemaPtr xschema)
|
48
118
|
{
|
49
|
-
|
119
|
+
VALUE result;
|
120
|
+
|
121
|
+
if (!xschema)
|
122
|
+
rb_raise(rb_eArgError, "XML::Schema is required!");
|
123
|
+
|
124
|
+
result = Data_Wrap_Struct(cXMLSchema, NULL, rxml_schema_free, xschema);
|
125
|
+
|
126
|
+
/*
|
127
|
+
* Create these as instance variables to provide the output of inspect/to_str some
|
128
|
+
* idea of what schema this class contains.
|
129
|
+
*/
|
130
|
+
rb_iv_set(result, "@target_namespace", QNIL_OR_STRING(xschema->targetNamespace));
|
131
|
+
rb_iv_set(result, "@name", QNIL_OR_STRING(xschema->name));
|
132
|
+
rb_iv_set(result, "@id", QNIL_OR_STRING(xschema->id));
|
133
|
+
rb_iv_set(result, "@version", QNIL_OR_STRING(xschema->name));
|
134
|
+
|
135
|
+
return result;
|
50
136
|
}
|
51
137
|
|
138
|
+
static VALUE rxml_schema_init(VALUE class, xmlSchemaParserCtxtPtr xparser)
|
139
|
+
{
|
140
|
+
xmlSchemaPtr xschema;
|
141
|
+
|
142
|
+
xschema = xmlSchemaParse(xparser);
|
143
|
+
xmlSchemaFreeParserCtxt(xparser);
|
144
|
+
|
145
|
+
if (!xschema)
|
146
|
+
rxml_raise(&xmlLastError);
|
147
|
+
|
148
|
+
return rxml_wrap_schema(xschema);
|
149
|
+
}
|
52
150
|
|
53
151
|
/*
|
54
152
|
* call-seq:
|
@@ -59,15 +157,15 @@ VALUE rxml_wrap_schema(xmlSchemaPtr xschema)
|
|
59
157
|
static VALUE rxml_schema_init_from_uri(VALUE class, VALUE uri)
|
60
158
|
{
|
61
159
|
xmlSchemaParserCtxtPtr xparser;
|
62
|
-
xmlSchemaPtr xschema;
|
63
160
|
|
64
161
|
Check_Type(uri, T_STRING);
|
65
162
|
|
163
|
+
xmlResetLastError();
|
66
164
|
xparser = xmlSchemaNewParserCtxt(StringValuePtr(uri));
|
67
|
-
|
68
|
-
|
165
|
+
if (!xparser)
|
166
|
+
rxml_raise(&xmlLastError);
|
69
167
|
|
70
|
-
return
|
168
|
+
return rxml_schema_init(class, xparser);
|
71
169
|
}
|
72
170
|
|
73
171
|
/*
|
@@ -79,19 +177,16 @@ static VALUE rxml_schema_init_from_uri(VALUE class, VALUE uri)
|
|
79
177
|
static VALUE rxml_schema_init_from_document(VALUE class, VALUE document)
|
80
178
|
{
|
81
179
|
xmlDocPtr xdoc;
|
82
|
-
xmlSchemaPtr xschema;
|
83
180
|
xmlSchemaParserCtxtPtr xparser;
|
84
181
|
|
85
182
|
Data_Get_Struct(document, xmlDoc, xdoc);
|
86
183
|
|
184
|
+
xmlResetLastError();
|
87
185
|
xparser = xmlSchemaNewDocParserCtxt(xdoc);
|
88
|
-
|
89
|
-
|
186
|
+
if (!xparser)
|
187
|
+
rxml_raise(&xmlLastError);
|
90
188
|
|
91
|
-
|
92
|
-
return Qnil;
|
93
|
-
|
94
|
-
return Data_Wrap_Struct(cXMLSchema, NULL, rxml_schema_free, xschema);
|
189
|
+
return rxml_schema_init(class, xparser);
|
95
190
|
}
|
96
191
|
|
97
192
|
/*
|
@@ -100,57 +195,26 @@ static VALUE rxml_schema_init_from_document(VALUE class, VALUE document)
|
|
100
195
|
*
|
101
196
|
* Create a new schema using the specified string.
|
102
197
|
*/
|
103
|
-
static VALUE rxml_schema_init_from_string(VALUE
|
198
|
+
static VALUE rxml_schema_init_from_string(VALUE class, VALUE schema_str)
|
104
199
|
{
|
105
200
|
xmlSchemaParserCtxtPtr xparser;
|
106
|
-
xmlSchemaPtr xschema;
|
107
201
|
|
108
202
|
Check_Type(schema_str, T_STRING);
|
109
203
|
|
204
|
+
xmlResetLastError();
|
110
205
|
xparser = xmlSchemaNewMemParserCtxt(StringValuePtr(schema_str), (int)strlen(StringValuePtr(schema_str)));
|
111
|
-
|
112
|
-
|
206
|
+
if (!xparser)
|
207
|
+
rxml_raise(&xmlLastError);
|
113
208
|
|
114
|
-
return
|
115
|
-
}
|
116
|
-
|
117
|
-
|
118
|
-
static VALUE rxml_schema_target_namespace(VALUE self)
|
119
|
-
{
|
120
|
-
xmlSchemaPtr xschema;
|
121
|
-
|
122
|
-
Data_Get_Struct(self, xmlSchema, xschema);
|
123
|
-
|
124
|
-
QNIL_OR_STRING(xschema->targetNamespace)
|
125
|
-
}
|
126
|
-
|
127
|
-
static VALUE rxml_schema_name(VALUE self)
|
128
|
-
{
|
129
|
-
xmlSchemaPtr xschema;
|
130
|
-
|
131
|
-
Data_Get_Struct(self, xmlSchema, xschema);
|
132
|
-
|
133
|
-
QNIL_OR_STRING(xschema->name)
|
134
|
-
}
|
135
|
-
|
136
|
-
static VALUE rxml_schema_version(VALUE self)
|
137
|
-
{
|
138
|
-
xmlSchemaPtr xschema;
|
139
|
-
|
140
|
-
Data_Get_Struct(self, xmlSchema, xschema);
|
141
|
-
|
142
|
-
QNIL_OR_STRING(xschema->version)
|
143
|
-
}
|
144
|
-
|
145
|
-
static VALUE rxml_schema_id(VALUE self)
|
146
|
-
{
|
147
|
-
xmlSchemaPtr xschema;
|
148
|
-
|
149
|
-
Data_Get_Struct(self, xmlSchema, xschema);
|
150
|
-
|
151
|
-
QNIL_OR_STRING(xschema->id)
|
209
|
+
return rxml_schema_init(class, xparser);
|
152
210
|
}
|
153
211
|
|
212
|
+
/*
|
213
|
+
* call-seq:
|
214
|
+
* XML::Schema.document -> document
|
215
|
+
*
|
216
|
+
* Return the Schema XML Document
|
217
|
+
*/
|
154
218
|
static VALUE rxml_schema_document(VALUE self)
|
155
219
|
{
|
156
220
|
xmlSchemaPtr xschema;
|
@@ -160,7 +224,7 @@ static VALUE rxml_schema_document(VALUE self)
|
|
160
224
|
return rxml_node_wrap(xmlDocGetRootElement(xschema->doc));
|
161
225
|
}
|
162
226
|
|
163
|
-
static void scan_namespaces(xmlSchemaImportPtr ximport, VALUE array, xmlChar *nsname)
|
227
|
+
static void scan_namespaces(xmlSchemaImportPtr ximport, VALUE array, const xmlChar *nsname)
|
164
228
|
{
|
165
229
|
xmlNodePtr xnode;
|
166
230
|
xmlNsPtr xns;
|
@@ -171,7 +235,7 @@ static void scan_namespaces(xmlSchemaImportPtr ximport, VALUE array, xmlChar *ns
|
|
171
235
|
xns = xnode->nsDef;
|
172
236
|
|
173
237
|
while (xns)
|
174
|
-
|
238
|
+
{
|
175
239
|
VALUE namespace = rxml_namespace_wrap(xns);
|
176
240
|
rb_ary_push(array, namespace);
|
177
241
|
xns = xns->next;
|
@@ -179,6 +243,12 @@ static void scan_namespaces(xmlSchemaImportPtr ximport, VALUE array, xmlChar *ns
|
|
179
243
|
}
|
180
244
|
}
|
181
245
|
|
246
|
+
/*
|
247
|
+
* call-seq:
|
248
|
+
* XML::Schema.namespaces -> array
|
249
|
+
*
|
250
|
+
* Returns an array of Namespaces defined by the schema
|
251
|
+
*/
|
182
252
|
static VALUE rxml_schema_namespaces(VALUE self)
|
183
253
|
{
|
184
254
|
VALUE result;
|
@@ -192,7 +262,7 @@ static VALUE rxml_schema_namespaces(VALUE self)
|
|
192
262
|
return result;
|
193
263
|
}
|
194
264
|
|
195
|
-
static void
|
265
|
+
static void scan_schema_element(xmlSchemaElementPtr xelement, VALUE hash, const xmlChar *name)
|
196
266
|
{
|
197
267
|
VALUE element = rxml_wrap_schema_element(xelement);
|
198
268
|
rb_hash_aset(hash, rb_str_new2((const char*)name), element);
|
@@ -204,40 +274,77 @@ static VALUE rxml_schema_elements(VALUE self)
|
|
204
274
|
xmlSchemaPtr xschema;
|
205
275
|
|
206
276
|
Data_Get_Struct(self, xmlSchema, xschema);
|
207
|
-
xmlHashScan(xschema->elemDecl, (xmlHashScanner)
|
277
|
+
xmlHashScan(xschema->elemDecl, (xmlHashScanner)scan_schema_element, (void *)result);
|
208
278
|
|
209
279
|
return result;
|
210
280
|
}
|
211
281
|
|
212
|
-
static void
|
282
|
+
static void collect_imported_ns_elements(xmlSchemaImportPtr import, VALUE result, const xmlChar *name)
|
213
283
|
{
|
214
|
-
|
215
|
-
|
284
|
+
if (import->imported && import->schema)
|
285
|
+
{
|
286
|
+
VALUE elements = rb_hash_new();
|
287
|
+
xmlHashScan(import->schema->elemDecl, (xmlHashScanner)scan_schema_element, (void *)elements);
|
288
|
+
rb_hash_aset(result, QNIL_OR_STRING(import->schema->targetNamespace), elements);
|
289
|
+
}
|
290
|
+
}
|
291
|
+
|
292
|
+
/*
|
293
|
+
* call-seq:
|
294
|
+
* XML::Schema.imported_ns_elements -> hash
|
295
|
+
*
|
296
|
+
* Returns a hash by namespace of a hash of schema elements within the entire schema including imports
|
297
|
+
*/
|
298
|
+
static VALUE rxml_schema_imported_ns_elements(VALUE self)
|
299
|
+
{
|
300
|
+
xmlSchemaPtr xschema;
|
301
|
+
VALUE result = rb_hash_new();
|
302
|
+
|
303
|
+
Data_Get_Struct(self, xmlSchema, xschema);
|
304
|
+
|
305
|
+
if (xschema)
|
306
|
+
{
|
307
|
+
xmlHashScan(xschema->schemasImports, (xmlHashScanner)collect_imported_ns_elements, (void *)result);
|
308
|
+
}
|
309
|
+
|
310
|
+
return result;
|
311
|
+
}
|
312
|
+
|
313
|
+
static void scan_schema_type(xmlSchemaTypePtr xtype, VALUE hash, const xmlChar *name)
|
314
|
+
{
|
315
|
+
VALUE type = rxml_wrap_schema_type(xtype);
|
316
|
+
rb_hash_aset(hash, rb_str_new2((const char*)name), type);
|
216
317
|
}
|
217
318
|
|
218
319
|
static VALUE rxml_schema_types(VALUE self)
|
219
320
|
{
|
220
|
-
|
221
|
-
|
321
|
+
VALUE result = rb_hash_new();
|
322
|
+
xmlSchemaPtr xschema;
|
222
323
|
|
223
|
-
|
324
|
+
Data_Get_Struct(self, xmlSchema, xschema);
|
224
325
|
|
225
|
-
|
226
|
-
|
227
|
-
|
228
|
-
|
326
|
+
if (xschema != NULL && xschema->typeDecl != NULL)
|
327
|
+
{
|
328
|
+
xmlHashScan(xschema->typeDecl, (xmlHashScanner)scan_schema_type, (void *)result);
|
329
|
+
}
|
229
330
|
|
230
|
-
|
331
|
+
return result;
|
231
332
|
}
|
232
333
|
|
233
|
-
static void collect_imported_types(xmlSchemaImportPtr import, VALUE result)
|
334
|
+
static void collect_imported_types(xmlSchemaImportPtr import, VALUE result, const xmlChar *name)
|
234
335
|
{
|
235
336
|
if (import->imported && import->schema)
|
236
337
|
{
|
237
|
-
xmlHashScan(import->schema->typeDecl, (xmlHashScanner)
|
338
|
+
xmlHashScan(import->schema->typeDecl, (xmlHashScanner)scan_schema_type, (void *)result);
|
238
339
|
}
|
239
340
|
}
|
240
341
|
|
342
|
+
/*
|
343
|
+
* call-seq:
|
344
|
+
* XML::Schema.imported_types -> hash
|
345
|
+
*
|
346
|
+
* Returns a hash of all types within the entire schema including imports
|
347
|
+
*/
|
241
348
|
static VALUE rxml_schema_imported_types(VALUE self)
|
242
349
|
{
|
243
350
|
xmlSchemaPtr xschema;
|
@@ -247,7 +354,38 @@ static VALUE rxml_schema_imported_types(VALUE self)
|
|
247
354
|
|
248
355
|
if (xschema)
|
249
356
|
{
|
250
|
-
|
357
|
+
xmlHashScan(xschema->schemasImports, (xmlHashScanner)collect_imported_types, (void *)result);
|
358
|
+
}
|
359
|
+
|
360
|
+
return result;
|
361
|
+
}
|
362
|
+
|
363
|
+
static void collect_imported_ns_types(xmlSchemaImportPtr import, VALUE result, const xmlChar *name)
|
364
|
+
{
|
365
|
+
if (import->imported && import->schema)
|
366
|
+
{
|
367
|
+
VALUE types = rb_hash_new();
|
368
|
+
xmlHashScan(import->schema->typeDecl, (xmlHashScanner)scan_schema_type, (void *)types);
|
369
|
+
rb_hash_aset(result, QNIL_OR_STRING(import->schema->targetNamespace), types);
|
370
|
+
}
|
371
|
+
}
|
372
|
+
|
373
|
+
/*
|
374
|
+
* call-seq:
|
375
|
+
* XML::Schema.imported_ns_types -> hash
|
376
|
+
*
|
377
|
+
* Returns a hash by namespace of a hash of schema types within the entire schema including imports
|
378
|
+
*/
|
379
|
+
static VALUE rxml_schema_imported_ns_types(VALUE self)
|
380
|
+
{
|
381
|
+
xmlSchemaPtr xschema;
|
382
|
+
VALUE result = rb_hash_new();
|
383
|
+
|
384
|
+
Data_Get_Struct(self, xmlSchema, xschema);
|
385
|
+
|
386
|
+
if (xschema)
|
387
|
+
{
|
388
|
+
xmlHashScan(xschema->schemasImports, (xmlHashScanner)collect_imported_ns_types, (void *)result);
|
251
389
|
}
|
252
390
|
|
253
391
|
return result;
|
@@ -260,16 +398,20 @@ void rxml_init_schema(void)
|
|
260
398
|
rb_define_singleton_method(cXMLSchema, "from_string", rxml_schema_init_from_string, 1);
|
261
399
|
rb_define_singleton_method(cXMLSchema, "document", rxml_schema_init_from_document, 1);
|
262
400
|
|
263
|
-
|
264
|
-
|
265
|
-
|
266
|
-
|
267
|
-
|
401
|
+
/* Create attr_reader methods for the above instance variables */
|
402
|
+
rb_define_attr(cXMLSchema, "target_namespace", 1, 0);
|
403
|
+
rb_define_attr(cXMLSchema, "name", 1, 0);
|
404
|
+
rb_define_attr(cXMLSchema, "id", 1, 0);
|
405
|
+
rb_define_attr(cXMLSchema, "version", 1, 0);
|
268
406
|
|
269
|
-
|
270
|
-
rb_define_method(cXMLSchema, "
|
407
|
+
// These are just methods so as to hide their values and not overly clutter the output of inspect/to_str
|
408
|
+
rb_define_method(cXMLSchema, "document", rxml_schema_document, 0);
|
271
409
|
rb_define_method(cXMLSchema, "namespaces", rxml_schema_namespaces, 0);
|
410
|
+
rb_define_method(cXMLSchema, "elements", rxml_schema_elements, 0);
|
411
|
+
rb_define_method(cXMLSchema, "imported_ns_elements", rxml_schema_imported_ns_elements, 0);
|
272
412
|
rb_define_method(cXMLSchema, "types", rxml_schema_types, 0);
|
413
|
+
rb_define_method(cXMLSchema, "imported_types", rxml_schema_imported_types, 0);
|
414
|
+
rb_define_method(cXMLSchema, "imported_ns_types", rxml_schema_imported_ns_types, 0);
|
273
415
|
|
274
416
|
rxml_init_schema_facet();
|
275
417
|
rxml_init_schema_element();
|