nokogiri 1.18.0-aarch64-linux-gnu
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of nokogiri might be problematic. Click here for more details.
- checksums.yaml +7 -0
- data/Gemfile +39 -0
- data/LICENSE-DEPENDENCIES.md +2224 -0
- data/LICENSE.md +9 -0
- data/README.md +293 -0
- data/bin/nokogiri +131 -0
- data/dependencies.yml +42 -0
- data/ext/nokogiri/depend +38 -0
- data/ext/nokogiri/extconf.rb +1173 -0
- data/ext/nokogiri/gumbo.c +610 -0
- data/ext/nokogiri/html4_document.c +171 -0
- data/ext/nokogiri/html4_element_description.c +299 -0
- data/ext/nokogiri/html4_entity_lookup.c +37 -0
- data/ext/nokogiri/html4_sax_parser.c +40 -0
- data/ext/nokogiri/html4_sax_parser_context.c +98 -0
- data/ext/nokogiri/html4_sax_push_parser.c +96 -0
- data/ext/nokogiri/include/libexslt/exslt.h +108 -0
- data/ext/nokogiri/include/libexslt/exsltconfig.h +70 -0
- data/ext/nokogiri/include/libexslt/exsltexports.h +63 -0
- data/ext/nokogiri/include/libxml2/libxml/HTMLparser.h +336 -0
- data/ext/nokogiri/include/libxml2/libxml/HTMLtree.h +147 -0
- data/ext/nokogiri/include/libxml2/libxml/SAX.h +202 -0
- data/ext/nokogiri/include/libxml2/libxml/SAX2.h +171 -0
- data/ext/nokogiri/include/libxml2/libxml/c14n.h +115 -0
- data/ext/nokogiri/include/libxml2/libxml/catalog.h +182 -0
- data/ext/nokogiri/include/libxml2/libxml/chvalid.h +230 -0
- data/ext/nokogiri/include/libxml2/libxml/debugXML.h +217 -0
- data/ext/nokogiri/include/libxml2/libxml/dict.h +82 -0
- data/ext/nokogiri/include/libxml2/libxml/encoding.h +244 -0
- data/ext/nokogiri/include/libxml2/libxml/entities.h +166 -0
- data/ext/nokogiri/include/libxml2/libxml/globals.h +41 -0
- data/ext/nokogiri/include/libxml2/libxml/hash.h +251 -0
- data/ext/nokogiri/include/libxml2/libxml/list.h +137 -0
- data/ext/nokogiri/include/libxml2/libxml/nanoftp.h +186 -0
- data/ext/nokogiri/include/libxml2/libxml/nanohttp.h +98 -0
- data/ext/nokogiri/include/libxml2/libxml/parser.h +1390 -0
- data/ext/nokogiri/include/libxml2/libxml/parserInternals.h +671 -0
- data/ext/nokogiri/include/libxml2/libxml/pattern.h +106 -0
- data/ext/nokogiri/include/libxml2/libxml/relaxng.h +219 -0
- data/ext/nokogiri/include/libxml2/libxml/schemasInternals.h +959 -0
- data/ext/nokogiri/include/libxml2/libxml/schematron.h +143 -0
- data/ext/nokogiri/include/libxml2/libxml/threads.h +87 -0
- data/ext/nokogiri/include/libxml2/libxml/tree.h +1382 -0
- data/ext/nokogiri/include/libxml2/libxml/uri.h +106 -0
- data/ext/nokogiri/include/libxml2/libxml/valid.h +477 -0
- data/ext/nokogiri/include/libxml2/libxml/xinclude.h +136 -0
- data/ext/nokogiri/include/libxml2/libxml/xlink.h +189 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlIO.h +438 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlautomata.h +146 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlerror.h +962 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlexports.h +146 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlmemory.h +188 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlmodule.h +57 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlreader.h +436 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlregexp.h +215 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlsave.h +102 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlschemas.h +249 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlschemastypes.h +152 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlstring.h +140 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlunicode.h +366 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlversion.h +347 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlwriter.h +489 -0
- data/ext/nokogiri/include/libxml2/libxml/xpath.h +579 -0
- data/ext/nokogiri/include/libxml2/libxml/xpathInternals.h +633 -0
- data/ext/nokogiri/include/libxml2/libxml/xpointer.h +138 -0
- data/ext/nokogiri/include/libxslt/attributes.h +39 -0
- data/ext/nokogiri/include/libxslt/documents.h +93 -0
- data/ext/nokogiri/include/libxslt/extensions.h +262 -0
- data/ext/nokogiri/include/libxslt/extra.h +72 -0
- data/ext/nokogiri/include/libxslt/functions.h +78 -0
- data/ext/nokogiri/include/libxslt/imports.h +75 -0
- data/ext/nokogiri/include/libxslt/keys.h +53 -0
- data/ext/nokogiri/include/libxslt/namespaces.h +68 -0
- data/ext/nokogiri/include/libxslt/numbersInternals.h +73 -0
- data/ext/nokogiri/include/libxslt/pattern.h +84 -0
- data/ext/nokogiri/include/libxslt/preproc.h +43 -0
- data/ext/nokogiri/include/libxslt/security.h +104 -0
- data/ext/nokogiri/include/libxslt/templates.h +77 -0
- data/ext/nokogiri/include/libxslt/transform.h +207 -0
- data/ext/nokogiri/include/libxslt/variables.h +118 -0
- data/ext/nokogiri/include/libxslt/xslt.h +110 -0
- data/ext/nokogiri/include/libxslt/xsltInternals.h +1995 -0
- data/ext/nokogiri/include/libxslt/xsltconfig.h +146 -0
- data/ext/nokogiri/include/libxslt/xsltexports.h +64 -0
- data/ext/nokogiri/include/libxslt/xsltlocale.h +44 -0
- data/ext/nokogiri/include/libxslt/xsltutils.h +343 -0
- data/ext/nokogiri/libxml2_polyfill.c +114 -0
- data/ext/nokogiri/nokogiri.c +294 -0
- data/ext/nokogiri/nokogiri.h +238 -0
- data/ext/nokogiri/test_global_handlers.c +40 -0
- data/ext/nokogiri/xml_attr.c +103 -0
- data/ext/nokogiri/xml_attribute_decl.c +70 -0
- data/ext/nokogiri/xml_cdata.c +62 -0
- data/ext/nokogiri/xml_comment.c +57 -0
- data/ext/nokogiri/xml_document.c +784 -0
- data/ext/nokogiri/xml_document_fragment.c +29 -0
- data/ext/nokogiri/xml_dtd.c +208 -0
- data/ext/nokogiri/xml_element_content.c +131 -0
- data/ext/nokogiri/xml_element_decl.c +69 -0
- data/ext/nokogiri/xml_encoding_handler.c +112 -0
- data/ext/nokogiri/xml_entity_decl.c +112 -0
- data/ext/nokogiri/xml_entity_reference.c +50 -0
- data/ext/nokogiri/xml_namespace.c +181 -0
- data/ext/nokogiri/xml_node.c +2459 -0
- data/ext/nokogiri/xml_node_set.c +518 -0
- data/ext/nokogiri/xml_processing_instruction.c +54 -0
- data/ext/nokogiri/xml_reader.c +777 -0
- data/ext/nokogiri/xml_relax_ng.c +149 -0
- data/ext/nokogiri/xml_sax_parser.c +403 -0
- data/ext/nokogiri/xml_sax_parser_context.c +390 -0
- data/ext/nokogiri/xml_sax_push_parser.c +206 -0
- data/ext/nokogiri/xml_schema.c +226 -0
- data/ext/nokogiri/xml_syntax_error.c +93 -0
- data/ext/nokogiri/xml_text.c +59 -0
- data/ext/nokogiri/xml_xpath_context.c +486 -0
- data/ext/nokogiri/xslt_stylesheet.c +421 -0
- data/gumbo-parser/CHANGES.md +63 -0
- data/gumbo-parser/Makefile +129 -0
- data/gumbo-parser/THANKS +27 -0
- data/lib/nokogiri/3.1/nokogiri.so +0 -0
- data/lib/nokogiri/3.2/nokogiri.so +0 -0
- data/lib/nokogiri/3.3/nokogiri.so +0 -0
- data/lib/nokogiri/3.4/nokogiri.so +0 -0
- data/lib/nokogiri/class_resolver.rb +67 -0
- data/lib/nokogiri/css/node.rb +58 -0
- data/lib/nokogiri/css/parser.rb +772 -0
- data/lib/nokogiri/css/parser.y +277 -0
- data/lib/nokogiri/css/parser_extras.rb +36 -0
- data/lib/nokogiri/css/selector_cache.rb +38 -0
- data/lib/nokogiri/css/syntax_error.rb +9 -0
- data/lib/nokogiri/css/tokenizer.rb +155 -0
- data/lib/nokogiri/css/tokenizer.rex +57 -0
- data/lib/nokogiri/css/xpath_visitor.rb +375 -0
- data/lib/nokogiri/css.rb +132 -0
- data/lib/nokogiri/decorators/slop.rb +42 -0
- data/lib/nokogiri/encoding_handler.rb +57 -0
- data/lib/nokogiri/extension.rb +32 -0
- data/lib/nokogiri/gumbo.rb +15 -0
- data/lib/nokogiri/html.rb +48 -0
- data/lib/nokogiri/html4/builder.rb +37 -0
- data/lib/nokogiri/html4/document.rb +235 -0
- data/lib/nokogiri/html4/document_fragment.rb +166 -0
- data/lib/nokogiri/html4/element_description.rb +25 -0
- data/lib/nokogiri/html4/element_description_defaults.rb +2040 -0
- data/lib/nokogiri/html4/encoding_reader.rb +121 -0
- data/lib/nokogiri/html4/entity_lookup.rb +15 -0
- data/lib/nokogiri/html4/sax/parser.rb +48 -0
- data/lib/nokogiri/html4/sax/parser_context.rb +15 -0
- data/lib/nokogiri/html4/sax/push_parser.rb +37 -0
- data/lib/nokogiri/html4.rb +42 -0
- data/lib/nokogiri/html5/builder.rb +40 -0
- data/lib/nokogiri/html5/document.rb +199 -0
- data/lib/nokogiri/html5/document_fragment.rb +200 -0
- data/lib/nokogiri/html5/node.rb +103 -0
- data/lib/nokogiri/html5.rb +368 -0
- data/lib/nokogiri/jruby/dependencies.rb +3 -0
- data/lib/nokogiri/jruby/nokogiri_jars.rb +43 -0
- data/lib/nokogiri/syntax_error.rb +6 -0
- data/lib/nokogiri/version/constant.rb +6 -0
- data/lib/nokogiri/version/info.rb +224 -0
- data/lib/nokogiri/version.rb +4 -0
- data/lib/nokogiri/xml/attr.rb +66 -0
- data/lib/nokogiri/xml/attribute_decl.rb +22 -0
- data/lib/nokogiri/xml/builder.rb +494 -0
- data/lib/nokogiri/xml/cdata.rb +13 -0
- data/lib/nokogiri/xml/character_data.rb +9 -0
- data/lib/nokogiri/xml/document.rb +514 -0
- data/lib/nokogiri/xml/document_fragment.rb +276 -0
- data/lib/nokogiri/xml/dtd.rb +34 -0
- data/lib/nokogiri/xml/element_content.rb +46 -0
- data/lib/nokogiri/xml/element_decl.rb +17 -0
- data/lib/nokogiri/xml/entity_decl.rb +23 -0
- data/lib/nokogiri/xml/entity_reference.rb +20 -0
- data/lib/nokogiri/xml/namespace.rb +57 -0
- data/lib/nokogiri/xml/node/save_options.rb +76 -0
- data/lib/nokogiri/xml/node.rb +1650 -0
- data/lib/nokogiri/xml/node_set.rb +449 -0
- data/lib/nokogiri/xml/notation.rb +19 -0
- data/lib/nokogiri/xml/parse_options.rb +213 -0
- data/lib/nokogiri/xml/pp/character_data.rb +21 -0
- data/lib/nokogiri/xml/pp/node.rb +73 -0
- data/lib/nokogiri/xml/pp.rb +4 -0
- data/lib/nokogiri/xml/processing_instruction.rb +11 -0
- data/lib/nokogiri/xml/reader.rb +139 -0
- data/lib/nokogiri/xml/relax_ng.rb +75 -0
- data/lib/nokogiri/xml/sax/document.rb +258 -0
- data/lib/nokogiri/xml/sax/parser.rb +199 -0
- data/lib/nokogiri/xml/sax/parser_context.rb +129 -0
- data/lib/nokogiri/xml/sax/push_parser.rb +64 -0
- data/lib/nokogiri/xml/sax.rb +54 -0
- data/lib/nokogiri/xml/schema.rb +140 -0
- data/lib/nokogiri/xml/searchable.rb +274 -0
- data/lib/nokogiri/xml/syntax_error.rb +94 -0
- data/lib/nokogiri/xml/text.rb +11 -0
- data/lib/nokogiri/xml/xpath/syntax_error.rb +13 -0
- data/lib/nokogiri/xml/xpath.rb +21 -0
- data/lib/nokogiri/xml/xpath_context.rb +27 -0
- data/lib/nokogiri/xml.rb +65 -0
- data/lib/nokogiri/xslt/stylesheet.rb +49 -0
- data/lib/nokogiri/xslt.rb +129 -0
- data/lib/nokogiri.rb +128 -0
- data/lib/xsd/xmlparser/nokogiri.rb +105 -0
- metadata +321 -0
@@ -0,0 +1,189 @@
|
|
1
|
+
/*
|
2
|
+
* Summary: unfinished XLink detection module
|
3
|
+
* Description: unfinished XLink detection module
|
4
|
+
*
|
5
|
+
* Copy: See Copyright for the status of this software.
|
6
|
+
*
|
7
|
+
* Author: Daniel Veillard
|
8
|
+
*/
|
9
|
+
|
10
|
+
#ifndef __XML_XLINK_H__
|
11
|
+
#define __XML_XLINK_H__
|
12
|
+
|
13
|
+
#include <libxml/xmlversion.h>
|
14
|
+
#include <libxml/tree.h>
|
15
|
+
|
16
|
+
#ifdef LIBXML_XPTR_ENABLED
|
17
|
+
|
18
|
+
#ifdef __cplusplus
|
19
|
+
extern "C" {
|
20
|
+
#endif
|
21
|
+
|
22
|
+
/**
|
23
|
+
* Various defines for the various Link properties.
|
24
|
+
*
|
25
|
+
* NOTE: the link detection layer will try to resolve QName expansion
|
26
|
+
* of namespaces. If "foo" is the prefix for "http://foo.com/"
|
27
|
+
* then the link detection layer will expand role="foo:myrole"
|
28
|
+
* to "http://foo.com/:myrole".
|
29
|
+
* NOTE: the link detection layer will expand URI-References found on
|
30
|
+
* href attributes by using the base mechanism if found.
|
31
|
+
*/
|
32
|
+
typedef xmlChar *xlinkHRef;
|
33
|
+
typedef xmlChar *xlinkRole;
|
34
|
+
typedef xmlChar *xlinkTitle;
|
35
|
+
|
36
|
+
typedef enum {
|
37
|
+
XLINK_TYPE_NONE = 0,
|
38
|
+
XLINK_TYPE_SIMPLE,
|
39
|
+
XLINK_TYPE_EXTENDED,
|
40
|
+
XLINK_TYPE_EXTENDED_SET
|
41
|
+
} xlinkType;
|
42
|
+
|
43
|
+
typedef enum {
|
44
|
+
XLINK_SHOW_NONE = 0,
|
45
|
+
XLINK_SHOW_NEW,
|
46
|
+
XLINK_SHOW_EMBED,
|
47
|
+
XLINK_SHOW_REPLACE
|
48
|
+
} xlinkShow;
|
49
|
+
|
50
|
+
typedef enum {
|
51
|
+
XLINK_ACTUATE_NONE = 0,
|
52
|
+
XLINK_ACTUATE_AUTO,
|
53
|
+
XLINK_ACTUATE_ONREQUEST
|
54
|
+
} xlinkActuate;
|
55
|
+
|
56
|
+
/**
|
57
|
+
* xlinkNodeDetectFunc:
|
58
|
+
* @ctx: user data pointer
|
59
|
+
* @node: the node to check
|
60
|
+
*
|
61
|
+
* This is the prototype for the link detection routine.
|
62
|
+
* It calls the default link detection callbacks upon link detection.
|
63
|
+
*/
|
64
|
+
typedef void (*xlinkNodeDetectFunc) (void *ctx, xmlNodePtr node);
|
65
|
+
|
66
|
+
/*
|
67
|
+
* The link detection module interact with the upper layers using
|
68
|
+
* a set of callback registered at parsing time.
|
69
|
+
*/
|
70
|
+
|
71
|
+
/**
|
72
|
+
* xlinkSimpleLinkFunk:
|
73
|
+
* @ctx: user data pointer
|
74
|
+
* @node: the node carrying the link
|
75
|
+
* @href: the target of the link
|
76
|
+
* @role: the role string
|
77
|
+
* @title: the link title
|
78
|
+
*
|
79
|
+
* This is the prototype for a simple link detection callback.
|
80
|
+
*/
|
81
|
+
typedef void
|
82
|
+
(*xlinkSimpleLinkFunk) (void *ctx,
|
83
|
+
xmlNodePtr node,
|
84
|
+
const xlinkHRef href,
|
85
|
+
const xlinkRole role,
|
86
|
+
const xlinkTitle title);
|
87
|
+
|
88
|
+
/**
|
89
|
+
* xlinkExtendedLinkFunk:
|
90
|
+
* @ctx: user data pointer
|
91
|
+
* @node: the node carrying the link
|
92
|
+
* @nbLocators: the number of locators detected on the link
|
93
|
+
* @hrefs: pointer to the array of locator hrefs
|
94
|
+
* @roles: pointer to the array of locator roles
|
95
|
+
* @nbArcs: the number of arcs detected on the link
|
96
|
+
* @from: pointer to the array of source roles found on the arcs
|
97
|
+
* @to: pointer to the array of target roles found on the arcs
|
98
|
+
* @show: array of values for the show attributes found on the arcs
|
99
|
+
* @actuate: array of values for the actuate attributes found on the arcs
|
100
|
+
* @nbTitles: the number of titles detected on the link
|
101
|
+
* @title: array of titles detected on the link
|
102
|
+
* @langs: array of xml:lang values for the titles
|
103
|
+
*
|
104
|
+
* This is the prototype for a extended link detection callback.
|
105
|
+
*/
|
106
|
+
typedef void
|
107
|
+
(*xlinkExtendedLinkFunk)(void *ctx,
|
108
|
+
xmlNodePtr node,
|
109
|
+
int nbLocators,
|
110
|
+
const xlinkHRef *hrefs,
|
111
|
+
const xlinkRole *roles,
|
112
|
+
int nbArcs,
|
113
|
+
const xlinkRole *from,
|
114
|
+
const xlinkRole *to,
|
115
|
+
xlinkShow *show,
|
116
|
+
xlinkActuate *actuate,
|
117
|
+
int nbTitles,
|
118
|
+
const xlinkTitle *titles,
|
119
|
+
const xmlChar **langs);
|
120
|
+
|
121
|
+
/**
|
122
|
+
* xlinkExtendedLinkSetFunk:
|
123
|
+
* @ctx: user data pointer
|
124
|
+
* @node: the node carrying the link
|
125
|
+
* @nbLocators: the number of locators detected on the link
|
126
|
+
* @hrefs: pointer to the array of locator hrefs
|
127
|
+
* @roles: pointer to the array of locator roles
|
128
|
+
* @nbTitles: the number of titles detected on the link
|
129
|
+
* @title: array of titles detected on the link
|
130
|
+
* @langs: array of xml:lang values for the titles
|
131
|
+
*
|
132
|
+
* This is the prototype for a extended link set detection callback.
|
133
|
+
*/
|
134
|
+
typedef void
|
135
|
+
(*xlinkExtendedLinkSetFunk) (void *ctx,
|
136
|
+
xmlNodePtr node,
|
137
|
+
int nbLocators,
|
138
|
+
const xlinkHRef *hrefs,
|
139
|
+
const xlinkRole *roles,
|
140
|
+
int nbTitles,
|
141
|
+
const xlinkTitle *titles,
|
142
|
+
const xmlChar **langs);
|
143
|
+
|
144
|
+
/**
|
145
|
+
* This is the structure containing a set of Links detection callbacks.
|
146
|
+
*
|
147
|
+
* There is no default xlink callbacks, if one want to get link
|
148
|
+
* recognition activated, those call backs must be provided before parsing.
|
149
|
+
*/
|
150
|
+
typedef struct _xlinkHandler xlinkHandler;
|
151
|
+
typedef xlinkHandler *xlinkHandlerPtr;
|
152
|
+
struct _xlinkHandler {
|
153
|
+
xlinkSimpleLinkFunk simple;
|
154
|
+
xlinkExtendedLinkFunk extended;
|
155
|
+
xlinkExtendedLinkSetFunk set;
|
156
|
+
};
|
157
|
+
|
158
|
+
/*
|
159
|
+
* The default detection routine, can be overridden, they call the default
|
160
|
+
* detection callbacks.
|
161
|
+
*/
|
162
|
+
|
163
|
+
XMLPUBFUN xlinkNodeDetectFunc
|
164
|
+
xlinkGetDefaultDetect (void);
|
165
|
+
XMLPUBFUN void
|
166
|
+
xlinkSetDefaultDetect (xlinkNodeDetectFunc func);
|
167
|
+
|
168
|
+
/*
|
169
|
+
* Routines to set/get the default handlers.
|
170
|
+
*/
|
171
|
+
XMLPUBFUN xlinkHandlerPtr
|
172
|
+
xlinkGetDefaultHandler (void);
|
173
|
+
XMLPUBFUN void
|
174
|
+
xlinkSetDefaultHandler (xlinkHandlerPtr handler);
|
175
|
+
|
176
|
+
/*
|
177
|
+
* Link detection module itself.
|
178
|
+
*/
|
179
|
+
XMLPUBFUN xlinkType
|
180
|
+
xlinkIsLink (xmlDocPtr doc,
|
181
|
+
xmlNodePtr node);
|
182
|
+
|
183
|
+
#ifdef __cplusplus
|
184
|
+
}
|
185
|
+
#endif
|
186
|
+
|
187
|
+
#endif /* LIBXML_XPTR_ENABLED */
|
188
|
+
|
189
|
+
#endif /* __XML_XLINK_H__ */
|
@@ -0,0 +1,438 @@
|
|
1
|
+
/*
|
2
|
+
* Summary: interface for the I/O interfaces used by the parser
|
3
|
+
* Description: interface for the I/O interfaces used by the parser
|
4
|
+
*
|
5
|
+
* Copy: See Copyright for the status of this software.
|
6
|
+
*
|
7
|
+
* Author: Daniel Veillard
|
8
|
+
*/
|
9
|
+
|
10
|
+
#ifndef __XML_IO_H__
|
11
|
+
#define __XML_IO_H__
|
12
|
+
|
13
|
+
/** DOC_DISABLE */
|
14
|
+
#include <stdio.h>
|
15
|
+
#include <libxml/xmlversion.h>
|
16
|
+
#include <libxml/encoding.h>
|
17
|
+
#define XML_TREE_INTERNALS
|
18
|
+
#include <libxml/tree.h>
|
19
|
+
#undef XML_TREE_INTERNALS
|
20
|
+
/** DOC_ENABLE */
|
21
|
+
|
22
|
+
#ifdef __cplusplus
|
23
|
+
extern "C" {
|
24
|
+
#endif
|
25
|
+
|
26
|
+
/*
|
27
|
+
* Those are the functions and datatypes for the parser input
|
28
|
+
* I/O structures.
|
29
|
+
*/
|
30
|
+
|
31
|
+
/**
|
32
|
+
* xmlInputMatchCallback:
|
33
|
+
* @filename: the filename or URI
|
34
|
+
*
|
35
|
+
* Callback used in the I/O Input API to detect if the current handler
|
36
|
+
* can provide input functionality for this resource.
|
37
|
+
*
|
38
|
+
* Returns 1 if yes and 0 if another Input module should be used
|
39
|
+
*/
|
40
|
+
typedef int (*xmlInputMatchCallback) (char const *filename);
|
41
|
+
/**
|
42
|
+
* xmlInputOpenCallback:
|
43
|
+
* @filename: the filename or URI
|
44
|
+
*
|
45
|
+
* Callback used in the I/O Input API to open the resource
|
46
|
+
*
|
47
|
+
* Returns an Input context or NULL in case or error
|
48
|
+
*/
|
49
|
+
typedef void * (*xmlInputOpenCallback) (char const *filename);
|
50
|
+
/**
|
51
|
+
* xmlInputReadCallback:
|
52
|
+
* @context: an Input context
|
53
|
+
* @buffer: the buffer to store data read
|
54
|
+
* @len: the length of the buffer in bytes
|
55
|
+
*
|
56
|
+
* Callback used in the I/O Input API to read the resource
|
57
|
+
*
|
58
|
+
* Returns the number of bytes read or -1 in case of error
|
59
|
+
*/
|
60
|
+
typedef int (*xmlInputReadCallback) (void * context, char * buffer, int len);
|
61
|
+
/**
|
62
|
+
* xmlInputCloseCallback:
|
63
|
+
* @context: an Input context
|
64
|
+
*
|
65
|
+
* Callback used in the I/O Input API to close the resource
|
66
|
+
*
|
67
|
+
* Returns 0 or -1 in case of error
|
68
|
+
*/
|
69
|
+
typedef int (*xmlInputCloseCallback) (void * context);
|
70
|
+
|
71
|
+
#ifdef LIBXML_OUTPUT_ENABLED
|
72
|
+
/*
|
73
|
+
* Those are the functions and datatypes for the library output
|
74
|
+
* I/O structures.
|
75
|
+
*/
|
76
|
+
|
77
|
+
/**
|
78
|
+
* xmlOutputMatchCallback:
|
79
|
+
* @filename: the filename or URI
|
80
|
+
*
|
81
|
+
* Callback used in the I/O Output API to detect if the current handler
|
82
|
+
* can provide output functionality for this resource.
|
83
|
+
*
|
84
|
+
* Returns 1 if yes and 0 if another Output module should be used
|
85
|
+
*/
|
86
|
+
typedef int (*xmlOutputMatchCallback) (char const *filename);
|
87
|
+
/**
|
88
|
+
* xmlOutputOpenCallback:
|
89
|
+
* @filename: the filename or URI
|
90
|
+
*
|
91
|
+
* Callback used in the I/O Output API to open the resource
|
92
|
+
*
|
93
|
+
* Returns an Output context or NULL in case or error
|
94
|
+
*/
|
95
|
+
typedef void * (*xmlOutputOpenCallback) (char const *filename);
|
96
|
+
/**
|
97
|
+
* xmlOutputWriteCallback:
|
98
|
+
* @context: an Output context
|
99
|
+
* @buffer: the buffer of data to write
|
100
|
+
* @len: the length of the buffer in bytes
|
101
|
+
*
|
102
|
+
* Callback used in the I/O Output API to write to the resource
|
103
|
+
*
|
104
|
+
* Returns the number of bytes written or -1 in case of error
|
105
|
+
*/
|
106
|
+
typedef int (*xmlOutputWriteCallback) (void * context, const char * buffer,
|
107
|
+
int len);
|
108
|
+
/**
|
109
|
+
* xmlOutputCloseCallback:
|
110
|
+
* @context: an Output context
|
111
|
+
*
|
112
|
+
* Callback used in the I/O Output API to close the resource
|
113
|
+
*
|
114
|
+
* Returns 0 or -1 in case of error
|
115
|
+
*/
|
116
|
+
typedef int (*xmlOutputCloseCallback) (void * context);
|
117
|
+
#endif /* LIBXML_OUTPUT_ENABLED */
|
118
|
+
|
119
|
+
/**
|
120
|
+
* xmlParserInputBufferCreateFilenameFunc:
|
121
|
+
* @URI: the URI to read from
|
122
|
+
* @enc: the requested source encoding
|
123
|
+
*
|
124
|
+
* Signature for the function doing the lookup for a suitable input method
|
125
|
+
* corresponding to an URI.
|
126
|
+
*
|
127
|
+
* Returns the new xmlParserInputBufferPtr in case of success or NULL if no
|
128
|
+
* method was found.
|
129
|
+
*/
|
130
|
+
typedef xmlParserInputBufferPtr
|
131
|
+
(*xmlParserInputBufferCreateFilenameFunc)(const char *URI, xmlCharEncoding enc);
|
132
|
+
|
133
|
+
/**
|
134
|
+
* xmlOutputBufferCreateFilenameFunc:
|
135
|
+
* @URI: the URI to write to
|
136
|
+
* @enc: the requested target encoding
|
137
|
+
*
|
138
|
+
* Signature for the function doing the lookup for a suitable output method
|
139
|
+
* corresponding to an URI.
|
140
|
+
*
|
141
|
+
* Returns the new xmlOutputBufferPtr in case of success or NULL if no
|
142
|
+
* method was found.
|
143
|
+
*/
|
144
|
+
typedef xmlOutputBufferPtr
|
145
|
+
(*xmlOutputBufferCreateFilenameFunc)(const char *URI,
|
146
|
+
xmlCharEncodingHandlerPtr encoder, int compression);
|
147
|
+
|
148
|
+
struct _xmlParserInputBuffer {
|
149
|
+
void* context;
|
150
|
+
xmlInputReadCallback readcallback;
|
151
|
+
xmlInputCloseCallback closecallback;
|
152
|
+
|
153
|
+
xmlCharEncodingHandlerPtr encoder; /* I18N conversions to UTF-8 */
|
154
|
+
|
155
|
+
xmlBufPtr buffer; /* Local buffer encoded in UTF-8 */
|
156
|
+
xmlBufPtr raw; /* if encoder != NULL buffer for raw input */
|
157
|
+
int compressed; /* -1=unknown, 0=not compressed, 1=compressed */
|
158
|
+
int error;
|
159
|
+
unsigned long rawconsumed;/* amount consumed from raw */
|
160
|
+
};
|
161
|
+
|
162
|
+
|
163
|
+
#ifdef LIBXML_OUTPUT_ENABLED
|
164
|
+
struct _xmlOutputBuffer {
|
165
|
+
void* context;
|
166
|
+
xmlOutputWriteCallback writecallback;
|
167
|
+
xmlOutputCloseCallback closecallback;
|
168
|
+
|
169
|
+
xmlCharEncodingHandlerPtr encoder; /* I18N conversions to UTF-8 */
|
170
|
+
|
171
|
+
xmlBufPtr buffer; /* Local buffer encoded in UTF-8 or ISOLatin */
|
172
|
+
xmlBufPtr conv; /* if encoder != NULL buffer for output */
|
173
|
+
int written; /* total number of byte written */
|
174
|
+
int error;
|
175
|
+
};
|
176
|
+
#endif /* LIBXML_OUTPUT_ENABLED */
|
177
|
+
|
178
|
+
/** DOC_DISABLE */
|
179
|
+
#define XML_GLOBALS_IO \
|
180
|
+
XML_OP(xmlParserInputBufferCreateFilenameValue, \
|
181
|
+
xmlParserInputBufferCreateFilenameFunc, XML_DEPRECATED) \
|
182
|
+
XML_OP(xmlOutputBufferCreateFilenameValue, \
|
183
|
+
xmlOutputBufferCreateFilenameFunc, XML_DEPRECATED)
|
184
|
+
|
185
|
+
#define XML_OP XML_DECLARE_GLOBAL
|
186
|
+
XML_GLOBALS_IO
|
187
|
+
#undef XML_OP
|
188
|
+
|
189
|
+
#if defined(LIBXML_THREAD_ENABLED) && !defined(XML_GLOBALS_NO_REDEFINITION)
|
190
|
+
#define xmlParserInputBufferCreateFilenameValue \
|
191
|
+
XML_GLOBAL_MACRO(xmlParserInputBufferCreateFilenameValue)
|
192
|
+
#define xmlOutputBufferCreateFilenameValue \
|
193
|
+
XML_GLOBAL_MACRO(xmlOutputBufferCreateFilenameValue)
|
194
|
+
#endif
|
195
|
+
/** DOC_ENABLE */
|
196
|
+
|
197
|
+
/*
|
198
|
+
* Interfaces for input
|
199
|
+
*/
|
200
|
+
XMLPUBFUN void
|
201
|
+
xmlCleanupInputCallbacks (void);
|
202
|
+
|
203
|
+
XMLPUBFUN int
|
204
|
+
xmlPopInputCallbacks (void);
|
205
|
+
|
206
|
+
XMLPUBFUN void
|
207
|
+
xmlRegisterDefaultInputCallbacks (void);
|
208
|
+
XMLPUBFUN xmlParserInputBufferPtr
|
209
|
+
xmlAllocParserInputBuffer (xmlCharEncoding enc);
|
210
|
+
|
211
|
+
XMLPUBFUN xmlParserInputBufferPtr
|
212
|
+
xmlParserInputBufferCreateFilename (const char *URI,
|
213
|
+
xmlCharEncoding enc);
|
214
|
+
XMLPUBFUN xmlParserInputBufferPtr
|
215
|
+
xmlParserInputBufferCreateFile (FILE *file,
|
216
|
+
xmlCharEncoding enc);
|
217
|
+
XMLPUBFUN xmlParserInputBufferPtr
|
218
|
+
xmlParserInputBufferCreateFd (int fd,
|
219
|
+
xmlCharEncoding enc);
|
220
|
+
XMLPUBFUN xmlParserInputBufferPtr
|
221
|
+
xmlParserInputBufferCreateMem (const char *mem, int size,
|
222
|
+
xmlCharEncoding enc);
|
223
|
+
XMLPUBFUN xmlParserInputBufferPtr
|
224
|
+
xmlParserInputBufferCreateStatic (const char *mem, int size,
|
225
|
+
xmlCharEncoding enc);
|
226
|
+
XMLPUBFUN xmlParserInputBufferPtr
|
227
|
+
xmlParserInputBufferCreateIO (xmlInputReadCallback ioread,
|
228
|
+
xmlInputCloseCallback ioclose,
|
229
|
+
void *ioctx,
|
230
|
+
xmlCharEncoding enc);
|
231
|
+
XMLPUBFUN int
|
232
|
+
xmlParserInputBufferRead (xmlParserInputBufferPtr in,
|
233
|
+
int len);
|
234
|
+
XMLPUBFUN int
|
235
|
+
xmlParserInputBufferGrow (xmlParserInputBufferPtr in,
|
236
|
+
int len);
|
237
|
+
XMLPUBFUN int
|
238
|
+
xmlParserInputBufferPush (xmlParserInputBufferPtr in,
|
239
|
+
int len,
|
240
|
+
const char *buf);
|
241
|
+
XMLPUBFUN void
|
242
|
+
xmlFreeParserInputBuffer (xmlParserInputBufferPtr in);
|
243
|
+
XMLPUBFUN char *
|
244
|
+
xmlParserGetDirectory (const char *filename);
|
245
|
+
|
246
|
+
XMLPUBFUN int
|
247
|
+
xmlRegisterInputCallbacks (xmlInputMatchCallback matchFunc,
|
248
|
+
xmlInputOpenCallback openFunc,
|
249
|
+
xmlInputReadCallback readFunc,
|
250
|
+
xmlInputCloseCallback closeFunc);
|
251
|
+
|
252
|
+
xmlParserInputBufferPtr
|
253
|
+
__xmlParserInputBufferCreateFilename(const char *URI,
|
254
|
+
xmlCharEncoding enc);
|
255
|
+
|
256
|
+
#ifdef LIBXML_OUTPUT_ENABLED
|
257
|
+
/*
|
258
|
+
* Interfaces for output
|
259
|
+
*/
|
260
|
+
XMLPUBFUN void
|
261
|
+
xmlCleanupOutputCallbacks (void);
|
262
|
+
XMLPUBFUN int
|
263
|
+
xmlPopOutputCallbacks (void);
|
264
|
+
XMLPUBFUN void
|
265
|
+
xmlRegisterDefaultOutputCallbacks(void);
|
266
|
+
XMLPUBFUN xmlOutputBufferPtr
|
267
|
+
xmlAllocOutputBuffer (xmlCharEncodingHandlerPtr encoder);
|
268
|
+
|
269
|
+
XMLPUBFUN xmlOutputBufferPtr
|
270
|
+
xmlOutputBufferCreateFilename (const char *URI,
|
271
|
+
xmlCharEncodingHandlerPtr encoder,
|
272
|
+
int compression);
|
273
|
+
|
274
|
+
XMLPUBFUN xmlOutputBufferPtr
|
275
|
+
xmlOutputBufferCreateFile (FILE *file,
|
276
|
+
xmlCharEncodingHandlerPtr encoder);
|
277
|
+
|
278
|
+
XMLPUBFUN xmlOutputBufferPtr
|
279
|
+
xmlOutputBufferCreateBuffer (xmlBufferPtr buffer,
|
280
|
+
xmlCharEncodingHandlerPtr encoder);
|
281
|
+
|
282
|
+
XMLPUBFUN xmlOutputBufferPtr
|
283
|
+
xmlOutputBufferCreateFd (int fd,
|
284
|
+
xmlCharEncodingHandlerPtr encoder);
|
285
|
+
|
286
|
+
XMLPUBFUN xmlOutputBufferPtr
|
287
|
+
xmlOutputBufferCreateIO (xmlOutputWriteCallback iowrite,
|
288
|
+
xmlOutputCloseCallback ioclose,
|
289
|
+
void *ioctx,
|
290
|
+
xmlCharEncodingHandlerPtr encoder);
|
291
|
+
|
292
|
+
/* Couple of APIs to get the output without digging into the buffers */
|
293
|
+
XMLPUBFUN const xmlChar *
|
294
|
+
xmlOutputBufferGetContent (xmlOutputBufferPtr out);
|
295
|
+
XMLPUBFUN size_t
|
296
|
+
xmlOutputBufferGetSize (xmlOutputBufferPtr out);
|
297
|
+
|
298
|
+
XMLPUBFUN int
|
299
|
+
xmlOutputBufferWrite (xmlOutputBufferPtr out,
|
300
|
+
int len,
|
301
|
+
const char *buf);
|
302
|
+
XMLPUBFUN int
|
303
|
+
xmlOutputBufferWriteString (xmlOutputBufferPtr out,
|
304
|
+
const char *str);
|
305
|
+
XMLPUBFUN int
|
306
|
+
xmlOutputBufferWriteEscape (xmlOutputBufferPtr out,
|
307
|
+
const xmlChar *str,
|
308
|
+
xmlCharEncodingOutputFunc escaping);
|
309
|
+
|
310
|
+
XMLPUBFUN int
|
311
|
+
xmlOutputBufferFlush (xmlOutputBufferPtr out);
|
312
|
+
XMLPUBFUN int
|
313
|
+
xmlOutputBufferClose (xmlOutputBufferPtr out);
|
314
|
+
|
315
|
+
XMLPUBFUN int
|
316
|
+
xmlRegisterOutputCallbacks (xmlOutputMatchCallback matchFunc,
|
317
|
+
xmlOutputOpenCallback openFunc,
|
318
|
+
xmlOutputWriteCallback writeFunc,
|
319
|
+
xmlOutputCloseCallback closeFunc);
|
320
|
+
|
321
|
+
xmlOutputBufferPtr
|
322
|
+
__xmlOutputBufferCreateFilename(const char *URI,
|
323
|
+
xmlCharEncodingHandlerPtr encoder,
|
324
|
+
int compression);
|
325
|
+
|
326
|
+
#ifdef LIBXML_HTTP_ENABLED
|
327
|
+
/* This function only exists if HTTP support built into the library */
|
328
|
+
XML_DEPRECATED
|
329
|
+
XMLPUBFUN void
|
330
|
+
xmlRegisterHTTPPostCallbacks (void );
|
331
|
+
#endif /* LIBXML_HTTP_ENABLED */
|
332
|
+
|
333
|
+
#endif /* LIBXML_OUTPUT_ENABLED */
|
334
|
+
|
335
|
+
XML_DEPRECATED
|
336
|
+
XMLPUBFUN xmlParserInputPtr
|
337
|
+
xmlCheckHTTPInput (xmlParserCtxtPtr ctxt,
|
338
|
+
xmlParserInputPtr ret);
|
339
|
+
|
340
|
+
/*
|
341
|
+
* A predefined entity loader disabling network accesses
|
342
|
+
*/
|
343
|
+
XMLPUBFUN xmlParserInputPtr
|
344
|
+
xmlNoNetExternalEntityLoader (const char *URL,
|
345
|
+
const char *ID,
|
346
|
+
xmlParserCtxtPtr ctxt);
|
347
|
+
|
348
|
+
XML_DEPRECATED
|
349
|
+
XMLPUBFUN xmlChar *
|
350
|
+
xmlNormalizeWindowsPath (const xmlChar *path);
|
351
|
+
|
352
|
+
XML_DEPRECATED
|
353
|
+
XMLPUBFUN int
|
354
|
+
xmlCheckFilename (const char *path);
|
355
|
+
/**
|
356
|
+
* Default 'file://' protocol callbacks
|
357
|
+
*/
|
358
|
+
XML_DEPRECATED
|
359
|
+
XMLPUBFUN int
|
360
|
+
xmlFileMatch (const char *filename);
|
361
|
+
XML_DEPRECATED
|
362
|
+
XMLPUBFUN void *
|
363
|
+
xmlFileOpen (const char *filename);
|
364
|
+
XML_DEPRECATED
|
365
|
+
XMLPUBFUN int
|
366
|
+
xmlFileRead (void * context,
|
367
|
+
char * buffer,
|
368
|
+
int len);
|
369
|
+
XML_DEPRECATED
|
370
|
+
XMLPUBFUN int
|
371
|
+
xmlFileClose (void * context);
|
372
|
+
|
373
|
+
/**
|
374
|
+
* Default 'http://' protocol callbacks
|
375
|
+
*/
|
376
|
+
#ifdef LIBXML_HTTP_ENABLED
|
377
|
+
XML_DEPRECATED
|
378
|
+
XMLPUBFUN int
|
379
|
+
xmlIOHTTPMatch (const char *filename);
|
380
|
+
XML_DEPRECATED
|
381
|
+
XMLPUBFUN void *
|
382
|
+
xmlIOHTTPOpen (const char *filename);
|
383
|
+
#ifdef LIBXML_OUTPUT_ENABLED
|
384
|
+
XML_DEPRECATED
|
385
|
+
XMLPUBFUN void *
|
386
|
+
xmlIOHTTPOpenW (const char * post_uri,
|
387
|
+
int compression );
|
388
|
+
#endif /* LIBXML_OUTPUT_ENABLED */
|
389
|
+
XML_DEPRECATED
|
390
|
+
XMLPUBFUN int
|
391
|
+
xmlIOHTTPRead (void * context,
|
392
|
+
char * buffer,
|
393
|
+
int len);
|
394
|
+
XML_DEPRECATED
|
395
|
+
XMLPUBFUN int
|
396
|
+
xmlIOHTTPClose (void * context);
|
397
|
+
#endif /* LIBXML_HTTP_ENABLED */
|
398
|
+
|
399
|
+
/**
|
400
|
+
* Default 'ftp://' protocol callbacks
|
401
|
+
*/
|
402
|
+
#if defined(LIBXML_FTP_ENABLED)
|
403
|
+
XML_DEPRECATED
|
404
|
+
XMLPUBFUN int
|
405
|
+
xmlIOFTPMatch (const char *filename);
|
406
|
+
XML_DEPRECATED
|
407
|
+
XMLPUBFUN void *
|
408
|
+
xmlIOFTPOpen (const char *filename);
|
409
|
+
XML_DEPRECATED
|
410
|
+
XMLPUBFUN int
|
411
|
+
xmlIOFTPRead (void * context,
|
412
|
+
char * buffer,
|
413
|
+
int len);
|
414
|
+
XML_DEPRECATED
|
415
|
+
XMLPUBFUN int
|
416
|
+
xmlIOFTPClose (void * context);
|
417
|
+
#endif /* defined(LIBXML_FTP_ENABLED) */
|
418
|
+
|
419
|
+
XMLPUBFUN xmlParserInputBufferCreateFilenameFunc
|
420
|
+
xmlParserInputBufferCreateFilenameDefault(
|
421
|
+
xmlParserInputBufferCreateFilenameFunc func);
|
422
|
+
XMLPUBFUN xmlOutputBufferCreateFilenameFunc
|
423
|
+
xmlOutputBufferCreateFilenameDefault(
|
424
|
+
xmlOutputBufferCreateFilenameFunc func);
|
425
|
+
XML_DEPRECATED
|
426
|
+
XMLPUBFUN xmlOutputBufferCreateFilenameFunc
|
427
|
+
xmlThrDefOutputBufferCreateFilenameDefault(
|
428
|
+
xmlOutputBufferCreateFilenameFunc func);
|
429
|
+
XML_DEPRECATED
|
430
|
+
XMLPUBFUN xmlParserInputBufferCreateFilenameFunc
|
431
|
+
xmlThrDefParserInputBufferCreateFilenameDefault(
|
432
|
+
xmlParserInputBufferCreateFilenameFunc func);
|
433
|
+
|
434
|
+
#ifdef __cplusplus
|
435
|
+
}
|
436
|
+
#endif
|
437
|
+
|
438
|
+
#endif /* __XML_IO_H__ */
|