nokogiri 1.15.7-x86-linux → 1.16.0.rc1-x86-linux
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.
Potentially problematic release.
This version of nokogiri might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/Gemfile +11 -14
- data/README.md +1 -1
- data/dependencies.yml +6 -5
- data/ext/nokogiri/extconf.rb +3 -4
- data/ext/nokogiri/html4_sax_push_parser.c +1 -1
- data/ext/nokogiri/include/libxml2/libxml/HTMLparser.h +23 -0
- data/ext/nokogiri/include/libxml2/libxml/SAX.h +0 -2
- data/ext/nokogiri/include/libxml2/libxml/SAX2.h +0 -2
- data/ext/nokogiri/include/libxml2/libxml/c14n.h +0 -2
- data/ext/nokogiri/include/libxml2/libxml/dict.h +1 -0
- data/ext/nokogiri/include/libxml2/libxml/encoding.h +16 -14
- data/ext/nokogiri/include/libxml2/libxml/entities.h +4 -0
- data/ext/nokogiri/include/libxml2/libxml/globals.h +15 -503
- data/ext/nokogiri/include/libxml2/libxml/hash.h +57 -61
- data/ext/nokogiri/include/libxml2/libxml/nanoftp.h +2 -2
- data/ext/nokogiri/include/libxml2/libxml/parser.h +128 -18
- data/ext/nokogiri/include/libxml2/libxml/parserInternals.h +1 -0
- data/ext/nokogiri/include/libxml2/libxml/relaxng.h +2 -1
- data/ext/nokogiri/include/libxml2/libxml/schemasInternals.h +1 -0
- data/ext/nokogiri/include/libxml2/libxml/schematron.h +1 -0
- data/ext/nokogiri/include/libxml2/libxml/threads.h +4 -11
- data/ext/nokogiri/include/libxml2/libxml/tree.h +68 -20
- data/ext/nokogiri/include/libxml2/libxml/uri.h +2 -1
- data/ext/nokogiri/include/libxml2/libxml/valid.h +2 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlIO.h +65 -12
- data/ext/nokogiri/include/libxml2/libxml/xmlerror.h +37 -8
- data/ext/nokogiri/include/libxml2/libxml/xmlmemory.h +37 -40
- data/ext/nokogiri/include/libxml2/libxml/xmlreader.h +6 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlregexp.h +2 -9
- data/ext/nokogiri/include/libxml2/libxml/xmlsave.h +9 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlschemas.h +3 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlversion.h +28 -43
- data/ext/nokogiri/include/libxml2/libxml/xpath.h +1 -1
- data/ext/nokogiri/include/libxml2/libxml/xpathInternals.h +2 -1
- data/ext/nokogiri/include/libxml2/libxml/xpointer.h +5 -4
- data/ext/nokogiri/include/libxslt/xsltconfig.h +1 -1
- data/ext/nokogiri/nokogiri.h +10 -3
- data/ext/nokogiri/test_global_handlers.c +1 -1
- data/ext/nokogiri/xml_cdata.c +1 -2
- data/ext/nokogiri/xml_document.c +3 -3
- data/ext/nokogiri/xml_namespace.c +0 -4
- data/ext/nokogiri/xml_node.c +6 -15
- data/ext/nokogiri/xml_reader.c +1 -44
- data/ext/nokogiri/xml_relax_ng.c +1 -1
- data/ext/nokogiri/xml_sax_push_parser.c +1 -1
- data/ext/nokogiri/xml_schema.c +2 -3
- data/ext/nokogiri/xml_syntax_error.c +3 -3
- data/ext/nokogiri/xml_text.c +1 -2
- data/ext/nokogiri/xml_xpath_context.c +2 -5
- data/gumbo-parser/Makefile +15 -0
- data/lib/nokogiri/3.0/nokogiri.so +0 -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/css/parser_extras.rb +1 -1
- data/lib/nokogiri/css/xpath_visitor.rb +1 -21
- data/lib/nokogiri/html4/document.rb +1 -1
- data/lib/nokogiri/html4/encoding_reader.rb +1 -1
- data/lib/nokogiri/html5.rb +0 -66
- data/lib/nokogiri/version/constant.rb +1 -1
- data/lib/nokogiri/version/info.rb +6 -5
- data/lib/nokogiri/xml/attr.rb +2 -2
- data/lib/nokogiri/xml/document.rb +3 -3
- data/lib/nokogiri/xml/document_fragment.rb +2 -2
- data/lib/nokogiri/xml/namespace.rb +1 -2
- data/lib/nokogiri/xml/node.rb +6 -5
- data/lib/nokogiri/xml/node_set.rb +3 -3
- data/lib/nokogiri/xml/searchable.rb +3 -3
- data/lib/nokogiri/xml/syntax_error.rb +1 -1
- data/lib/nokogiri/xml.rb +1 -1
- data/lib/nokogiri/xslt.rb +1 -1
- data/lib/nokogiri.rb +1 -1
- metadata +8 -7
- data/lib/nokogiri/2.7/nokogiri.so +0 -0
| @@ -11,6 +11,10 @@ | |
| 11 11 | 
             
            #ifndef __XML_HASH_H__
         | 
| 12 12 | 
             
            #define __XML_HASH_H__
         | 
| 13 13 |  | 
| 14 | 
            +
            #include <libxml/xmlversion.h>
         | 
| 15 | 
            +
            #include <libxml/dict.h>
         | 
| 16 | 
            +
            #include <libxml/xmlstring.h>
         | 
| 17 | 
            +
             | 
| 14 18 | 
             
            #ifdef __cplusplus
         | 
| 15 19 | 
             
            extern "C" {
         | 
| 16 20 | 
             
            #endif
         | 
| @@ -21,18 +25,6 @@ extern "C" { | |
| 21 25 | 
             
            typedef struct _xmlHashTable xmlHashTable;
         | 
| 22 26 | 
             
            typedef xmlHashTable *xmlHashTablePtr;
         | 
| 23 27 |  | 
| 24 | 
            -
            #ifdef __cplusplus
         | 
| 25 | 
            -
            }
         | 
| 26 | 
            -
            #endif
         | 
| 27 | 
            -
             | 
| 28 | 
            -
            #include <libxml/xmlversion.h>
         | 
| 29 | 
            -
            #include <libxml/parser.h>
         | 
| 30 | 
            -
            #include <libxml/dict.h>
         | 
| 31 | 
            -
             | 
| 32 | 
            -
            #ifdef __cplusplus
         | 
| 33 | 
            -
            extern "C" {
         | 
| 34 | 
            -
            #endif
         | 
| 35 | 
            -
             | 
| 36 28 | 
             
            /*
         | 
| 37 29 | 
             
             * Recent version of gcc produce a warning when a function pointer is assigned
         | 
| 38 30 | 
             
             * to an object pointer, or vice versa.  The following macro is a dirty hack
         | 
| @@ -55,7 +47,6 @@ extern "C" { | |
| 55 47 |  | 
| 56 48 | 
             
            #define XML_CAST_FPTR(fptr) fptr
         | 
| 57 49 |  | 
| 58 | 
            -
             | 
| 59 50 | 
             
            /*
         | 
| 60 51 | 
             
             * function types:
         | 
| 61 52 | 
             
             */
         | 
| @@ -104,131 +95,136 @@ typedef void (*xmlHashScannerFull)(void *payload, void *data, | |
| 104 95 | 
             
             * Constructor and destructor.
         | 
| 105 96 | 
             
             */
         | 
| 106 97 | 
             
            XMLPUBFUN xmlHashTablePtr
         | 
| 107 | 
            -
             | 
| 98 | 
            +
            		xmlHashCreate		(int size);
         | 
| 108 99 | 
             
            XMLPUBFUN xmlHashTablePtr
         | 
| 109 | 
            -
             | 
| 100 | 
            +
            		xmlHashCreateDict	(int size,
         | 
| 110 101 | 
             
            					 xmlDictPtr dict);
         | 
| 111 102 | 
             
            XMLPUBFUN void
         | 
| 112 | 
            -
             | 
| 113 | 
            -
            					 xmlHashDeallocator  | 
| 103 | 
            +
            		xmlHashFree		(xmlHashTablePtr hash,
         | 
| 104 | 
            +
            					 xmlHashDeallocator dealloc);
         | 
| 114 105 | 
             
            XMLPUBFUN void
         | 
| 115 | 
            -
             | 
| 106 | 
            +
            		xmlHashDefaultDeallocator(void *entry,
         | 
| 116 107 | 
             
            					 const xmlChar *name);
         | 
| 117 108 |  | 
| 118 109 | 
             
            /*
         | 
| 119 110 | 
             
             * Add a new entry to the hash table.
         | 
| 120 111 | 
             
             */
         | 
| 121 112 | 
             
            XMLPUBFUN int
         | 
| 122 | 
            -
             | 
| 113 | 
            +
            		xmlHashAddEntry		(xmlHashTablePtr hash,
         | 
| 123 114 | 
             
            		                         const xmlChar *name,
         | 
| 124 115 | 
             
            		                         void *userdata);
         | 
| 125 116 | 
             
            XMLPUBFUN int
         | 
| 126 | 
            -
             | 
| 117 | 
            +
            		xmlHashUpdateEntry	(xmlHashTablePtr hash,
         | 
| 127 118 | 
             
            		                         const xmlChar *name,
         | 
| 128 119 | 
             
            		                         void *userdata,
         | 
| 129 | 
            -
            					 xmlHashDeallocator  | 
| 120 | 
            +
            					 xmlHashDeallocator dealloc);
         | 
| 130 121 | 
             
            XMLPUBFUN int
         | 
| 131 | 
            -
             | 
| 122 | 
            +
            		xmlHashAddEntry2	(xmlHashTablePtr hash,
         | 
| 132 123 | 
             
            		                         const xmlChar *name,
         | 
| 133 124 | 
             
            		                         const xmlChar *name2,
         | 
| 134 125 | 
             
            		                         void *userdata);
         | 
| 135 126 | 
             
            XMLPUBFUN int
         | 
| 136 | 
            -
             | 
| 127 | 
            +
            		xmlHashUpdateEntry2	(xmlHashTablePtr hash,
         | 
| 137 128 | 
             
            		                         const xmlChar *name,
         | 
| 138 129 | 
             
            		                         const xmlChar *name2,
         | 
| 139 130 | 
             
            		                         void *userdata,
         | 
| 140 | 
            -
            					 xmlHashDeallocator  | 
| 131 | 
            +
            					 xmlHashDeallocator dealloc);
         | 
| 141 132 | 
             
            XMLPUBFUN int
         | 
| 142 | 
            -
             | 
| 133 | 
            +
            		xmlHashAddEntry3	(xmlHashTablePtr hash,
         | 
| 143 134 | 
             
            		                         const xmlChar *name,
         | 
| 144 135 | 
             
            		                         const xmlChar *name2,
         | 
| 145 136 | 
             
            		                         const xmlChar *name3,
         | 
| 146 137 | 
             
            		                         void *userdata);
         | 
| 147 138 | 
             
            XMLPUBFUN int
         | 
| 148 | 
            -
             | 
| 139 | 
            +
            		xmlHashUpdateEntry3	(xmlHashTablePtr hash,
         | 
| 149 140 | 
             
            		                         const xmlChar *name,
         | 
| 150 141 | 
             
            		                         const xmlChar *name2,
         | 
| 151 142 | 
             
            		                         const xmlChar *name3,
         | 
| 152 143 | 
             
            		                         void *userdata,
         | 
| 153 | 
            -
            					 xmlHashDeallocator  | 
| 144 | 
            +
            					 xmlHashDeallocator dealloc);
         | 
| 154 145 |  | 
| 155 146 | 
             
            /*
         | 
| 156 147 | 
             
             * Remove an entry from the hash table.
         | 
| 157 148 | 
             
             */
         | 
| 158 149 | 
             
            XMLPUBFUN int
         | 
| 159 | 
            -
             | 
| 160 | 
            -
             | 
| 150 | 
            +
            		xmlHashRemoveEntry	(xmlHashTablePtr hash,
         | 
| 151 | 
            +
            					 const xmlChar *name,
         | 
| 152 | 
            +
            					 xmlHashDeallocator dealloc);
         | 
| 161 153 | 
             
            XMLPUBFUN int
         | 
| 162 | 
            -
             | 
| 163 | 
            -
             | 
| 154 | 
            +
            		xmlHashRemoveEntry2	(xmlHashTablePtr hash,
         | 
| 155 | 
            +
            					 const xmlChar *name,
         | 
| 156 | 
            +
            					 const xmlChar *name2,
         | 
| 157 | 
            +
            					 xmlHashDeallocator dealloc);
         | 
| 164 158 | 
             
            XMLPUBFUN int 
         | 
| 165 | 
            -
             | 
| 166 | 
            -
             | 
| 167 | 
            -
             | 
| 159 | 
            +
            		xmlHashRemoveEntry3	(xmlHashTablePtr hash,
         | 
| 160 | 
            +
            					 const xmlChar *name,
         | 
| 161 | 
            +
            					 const xmlChar *name2,
         | 
| 162 | 
            +
            					 const xmlChar *name3,
         | 
| 163 | 
            +
            					 xmlHashDeallocator dealloc);
         | 
| 168 164 |  | 
| 169 165 | 
             
            /*
         | 
| 170 | 
            -
             * Retrieve the  | 
| 166 | 
            +
             * Retrieve the payload.
         | 
| 171 167 | 
             
             */
         | 
| 172 168 | 
             
            XMLPUBFUN void *
         | 
| 173 | 
            -
             | 
| 169 | 
            +
            		xmlHashLookup		(xmlHashTablePtr hash,
         | 
| 174 170 | 
             
            					 const xmlChar *name);
         | 
| 175 171 | 
             
            XMLPUBFUN void *
         | 
| 176 | 
            -
             | 
| 172 | 
            +
            		xmlHashLookup2		(xmlHashTablePtr hash,
         | 
| 177 173 | 
             
            					 const xmlChar *name,
         | 
| 178 174 | 
             
            					 const xmlChar *name2);
         | 
| 179 175 | 
             
            XMLPUBFUN void *
         | 
| 180 | 
            -
             | 
| 176 | 
            +
            		xmlHashLookup3		(xmlHashTablePtr hash,
         | 
| 181 177 | 
             
            					 const xmlChar *name,
         | 
| 182 178 | 
             
            					 const xmlChar *name2,
         | 
| 183 179 | 
             
            					 const xmlChar *name3);
         | 
| 184 180 | 
             
            XMLPUBFUN void *
         | 
| 185 | 
            -
             | 
| 186 | 
            -
            					 const xmlChar *name,
         | 
| 187 | 
            -
            					 const xmlChar *prefix);
         | 
| 188 | 
            -
            XMLPUBFUN void *
         | 
| 189 | 
            -
            			xmlHashQLookup2	(xmlHashTablePtr table,
         | 
| 190 | 
            -
            					 const xmlChar *name,
         | 
| 181 | 
            +
            		xmlHashQLookup		(xmlHashTablePtr hash,
         | 
| 191 182 | 
             
            					 const xmlChar *prefix,
         | 
| 192 | 
            -
            					 const xmlChar * | 
| 193 | 
            -
            					 const xmlChar *prefix2);
         | 
| 183 | 
            +
            					 const xmlChar *name);
         | 
| 194 184 | 
             
            XMLPUBFUN void *
         | 
| 195 | 
            -
             | 
| 185 | 
            +
            		xmlHashQLookup2		(xmlHashTablePtr hash,
         | 
| 186 | 
            +
            					 const xmlChar *prefix,
         | 
| 196 187 | 
             
            					 const xmlChar *name,
         | 
| 188 | 
            +
            					 const xmlChar *prefix2,
         | 
| 189 | 
            +
            					 const xmlChar *name2);
         | 
| 190 | 
            +
            XMLPUBFUN void *
         | 
| 191 | 
            +
            		xmlHashQLookup3		(xmlHashTablePtr hash,
         | 
| 197 192 | 
             
            					 const xmlChar *prefix,
         | 
| 198 | 
            -
            					 const xmlChar * | 
| 193 | 
            +
            					 const xmlChar *name,
         | 
| 199 194 | 
             
            					 const xmlChar *prefix2,
         | 
| 200 | 
            -
            					 const xmlChar * | 
| 201 | 
            -
            					 const xmlChar *prefix3 | 
| 195 | 
            +
            					 const xmlChar *name2,
         | 
| 196 | 
            +
            					 const xmlChar *prefix3,
         | 
| 197 | 
            +
            					 const xmlChar *name3);
         | 
| 202 198 |  | 
| 203 199 | 
             
            /*
         | 
| 204 200 | 
             
             * Helpers.
         | 
| 205 201 | 
             
             */
         | 
| 206 202 | 
             
            XMLPUBFUN xmlHashTablePtr
         | 
| 207 | 
            -
             | 
| 208 | 
            -
            					 xmlHashCopier  | 
| 203 | 
            +
            		xmlHashCopy		(xmlHashTablePtr hash,
         | 
| 204 | 
            +
            					 xmlHashCopier copy);
         | 
| 209 205 | 
             
            XMLPUBFUN int
         | 
| 210 | 
            -
             | 
| 206 | 
            +
            		xmlHashSize		(xmlHashTablePtr hash);
         | 
| 211 207 | 
             
            XMLPUBFUN void
         | 
| 212 | 
            -
             | 
| 213 | 
            -
            					 xmlHashScanner  | 
| 208 | 
            +
            		xmlHashScan		(xmlHashTablePtr hash,
         | 
| 209 | 
            +
            					 xmlHashScanner scan,
         | 
| 214 210 | 
             
            					 void *data);
         | 
| 215 211 | 
             
            XMLPUBFUN void
         | 
| 216 | 
            -
             | 
| 212 | 
            +
            		xmlHashScan3		(xmlHashTablePtr hash,
         | 
| 217 213 | 
             
            					 const xmlChar *name,
         | 
| 218 214 | 
             
            					 const xmlChar *name2,
         | 
| 219 215 | 
             
            					 const xmlChar *name3,
         | 
| 220 | 
            -
            					 xmlHashScanner  | 
| 216 | 
            +
            					 xmlHashScanner scan,
         | 
| 221 217 | 
             
            					 void *data);
         | 
| 222 218 | 
             
            XMLPUBFUN void
         | 
| 223 | 
            -
             | 
| 224 | 
            -
            					 xmlHashScannerFull  | 
| 219 | 
            +
            		xmlHashScanFull		(xmlHashTablePtr hash,
         | 
| 220 | 
            +
            					 xmlHashScannerFull scan,
         | 
| 225 221 | 
             
            					 void *data);
         | 
| 226 222 | 
             
            XMLPUBFUN void
         | 
| 227 | 
            -
             | 
| 223 | 
            +
            		xmlHashScanFull3	(xmlHashTablePtr hash,
         | 
| 228 224 | 
             
            					 const xmlChar *name,
         | 
| 229 225 | 
             
            					 const xmlChar *name2,
         | 
| 230 226 | 
             
            					 const xmlChar *name3,
         | 
| 231 | 
            -
            					 xmlHashScannerFull  | 
| 227 | 
            +
            					 xmlHashScannerFull scan,
         | 
| 232 228 | 
             
            					 void *data);
         | 
| 233 229 | 
             
            #ifdef __cplusplus
         | 
| 234 230 | 
             
            }
         | 
| @@ -14,7 +14,7 @@ | |
| 14 14 |  | 
| 15 15 | 
             
            #include <libxml/xmlversion.h>
         | 
| 16 16 |  | 
| 17 | 
            -
            # | 
| 17 | 
            +
            #if defined(LIBXML_FTP_ENABLED)
         | 
| 18 18 |  | 
| 19 19 | 
             
            /* Needed for portability to Windows 64 bits */
         | 
| 20 20 | 
             
            #if defined(_WIN32)
         | 
| @@ -182,5 +182,5 @@ XMLPUBFUN int | |
| 182 182 | 
             
            #ifdef __cplusplus
         | 
| 183 183 | 
             
            }
         | 
| 184 184 | 
             
            #endif
         | 
| 185 | 
            -
            #endif /* LIBXML_FTP_ENABLED */
         | 
| 185 | 
            +
            #endif /* defined(LIBXML_FTP_ENABLED) || defined(LIBXML_LEGACY_ENABLED) */
         | 
| 186 186 | 
             
            #endif /* __NANO_FTP_H__ */
         | 
| @@ -11,13 +11,21 @@ | |
| 11 11 | 
             
            #define __XML_PARSER_H__
         | 
| 12 12 |  | 
| 13 13 | 
             
            #include <libxml/xmlversion.h>
         | 
| 14 | 
            +
            #define XML_TREE_INTERNALS
         | 
| 14 15 | 
             
            #include <libxml/tree.h>
         | 
| 16 | 
            +
            #undef XML_TREE_INTERNALS
         | 
| 15 17 | 
             
            #include <libxml/dict.h>
         | 
| 16 18 | 
             
            #include <libxml/hash.h>
         | 
| 17 19 | 
             
            #include <libxml/valid.h>
         | 
| 18 20 | 
             
            #include <libxml/entities.h>
         | 
| 19 21 | 
             
            #include <libxml/xmlerror.h>
         | 
| 20 22 | 
             
            #include <libxml/xmlstring.h>
         | 
| 23 | 
            +
            #include <libxml/xmlmemory.h>
         | 
| 24 | 
            +
            #include <libxml/encoding.h>
         | 
| 25 | 
            +
            #include <libxml/xmlIO.h>
         | 
| 26 | 
            +
            /* for compatibility */
         | 
| 27 | 
            +
            #include <libxml/SAX2.h>
         | 
| 28 | 
            +
            #include <libxml/threads.h>
         | 
| 21 29 |  | 
| 22 30 | 
             
            #ifdef __cplusplus
         | 
| 23 31 | 
             
            extern "C" {
         | 
| @@ -63,9 +71,9 @@ struct _xmlParserInput { | |
| 63 71 | 
             
                int col;                          /* Current column */
         | 
| 64 72 | 
             
                unsigned long consumed;           /* How many xmlChars already consumed */
         | 
| 65 73 | 
             
                xmlParserInputDeallocate free;    /* function to deallocate the base */
         | 
| 66 | 
            -
                const xmlChar *encoding;          /*  | 
| 74 | 
            +
                const xmlChar *encoding;          /* unused */
         | 
| 67 75 | 
             
                const xmlChar *version;           /* the version string for entity */
         | 
| 68 | 
            -
                int  | 
| 76 | 
            +
                int flags;                        /* Flags */
         | 
| 69 77 | 
             
                int id;                           /* an unique identifier for the entity */
         | 
| 70 78 | 
             
                unsigned long parentConsumed;     /* consumed bytes from parents */
         | 
| 71 79 | 
             
                xmlEntityPtr entity;              /* entity, if any */
         | 
| @@ -122,7 +130,8 @@ typedef enum { | |
| 122 130 | 
             
                XML_PARSER_SYSTEM_LITERAL,	/* within a SYSTEM value */
         | 
| 123 131 | 
             
                XML_PARSER_EPILOG,		/* the Misc* after the last end tag */
         | 
| 124 132 | 
             
                XML_PARSER_IGNORE,		/* within an IGNORED section */
         | 
| 125 | 
            -
                XML_PARSER_PUBLIC_LITERAL	/* within a PUBLIC value */
         | 
| 133 | 
            +
                XML_PARSER_PUBLIC_LITERAL,	/* within a PUBLIC value */
         | 
| 134 | 
            +
                XML_PARSER_XML_DECL         /* before XML decl (but after BOM) */
         | 
| 126 135 | 
             
            } xmlParserInputState;
         | 
| 127 136 |  | 
| 128 137 | 
             
            /**
         | 
| @@ -165,6 +174,8 @@ typedef enum { | |
| 165 174 | 
             
            } xmlParserMode;
         | 
| 166 175 |  | 
| 167 176 | 
             
            typedef struct _xmlStartTag xmlStartTag;
         | 
| 177 | 
            +
            typedef struct _xmlParserNsData xmlParserNsData;
         | 
| 178 | 
            +
            typedef struct _xmlAttrHashBucket xmlAttrHashBucket;
         | 
| 168 179 |  | 
| 169 180 | 
             
            /**
         | 
| 170 181 | 
             
             * xmlParserCtxt:
         | 
| @@ -245,8 +256,7 @@ struct _xmlParserCtxt { | |
| 245 256 |  | 
| 246 257 | 
             
                int                depth;         /* to prevent entity substitution loops */
         | 
| 247 258 | 
             
                xmlParserInputPtr  entity;        /* used to check entities boundaries */
         | 
| 248 | 
            -
                int                charset;       /*  | 
| 249 | 
            -
            				         actually an xmlCharEncoding */
         | 
| 259 | 
            +
                int                charset;       /* unused */
         | 
| 250 260 | 
             
                int                nodelen;       /* Those two fields are there to */
         | 
| 251 261 | 
             
                int                nodemem;       /* Speed up large node parsing */
         | 
| 252 262 | 
             
                int                pedantic;      /* signal pedantic warnings */
         | 
| @@ -276,7 +286,7 @@ struct _xmlParserCtxt { | |
| 276 286 | 
             
                int                nsNr;          /* the number of inherited namespaces */
         | 
| 277 287 | 
             
                int                nsMax;         /* the size of the arrays */
         | 
| 278 288 | 
             
                const xmlChar *   *nsTab;         /* the array of prefix/namespace name */
         | 
| 279 | 
            -
                 | 
| 289 | 
            +
                unsigned          *attallocs;     /* which attribute were allocated */
         | 
| 280 290 | 
             
                xmlStartTag       *pushTab;       /* array of data for push */
         | 
| 281 291 | 
             
                xmlHashTablePtr    attsDefault;   /* defaulted attributes if any */
         | 
| 282 292 | 
             
                xmlHashTablePtr    attsSpecial;   /* non-CDATA attributes if any */
         | 
| @@ -312,6 +322,11 @@ struct _xmlParserCtxt { | |
| 312 322 | 
             
                int           endCheckState;    /* quote state for push parser */
         | 
| 313 323 | 
             
                unsigned short     nbErrors;    /* number of errors */
         | 
| 314 324 | 
             
                unsigned short   nbWarnings;    /* number of warnings */
         | 
| 325 | 
            +
                unsigned            maxAmpl;    /* maximum amplification factor */
         | 
| 326 | 
            +
             | 
| 327 | 
            +
                xmlParserNsData       *nsdb;    /* namespace database */
         | 
| 328 | 
            +
                unsigned        attrHashMax;    /* allocated size */
         | 
| 329 | 
            +
                xmlAttrHashBucket *attrHash;    /* atttribute hash table */
         | 
| 315 330 | 
             
            };
         | 
| 316 331 |  | 
| 317 332 | 
             
            /**
         | 
| @@ -732,6 +747,19 @@ struct _xmlSAXHandler { | |
| 732 747 | 
             
                setDocumentLocatorSAXFunc setDocumentLocator;
         | 
| 733 748 | 
             
                startDocumentSAXFunc startDocument;
         | 
| 734 749 | 
             
                endDocumentSAXFunc endDocument;
         | 
| 750 | 
            +
                /*
         | 
| 751 | 
            +
                 * `startElement` and `endElement` are only used by the legacy SAX1
         | 
| 752 | 
            +
                 * interface and should not be used in new software. If you really
         | 
| 753 | 
            +
                 * have to enable SAX1, the preferred way is set the `initialized`
         | 
| 754 | 
            +
                 * member to 1 instead of XML_SAX2_MAGIC.
         | 
| 755 | 
            +
                 *
         | 
| 756 | 
            +
                 * For backward compatibility, it's also possible to set the
         | 
| 757 | 
            +
                 * `startElementNs` and `endElementNs` handlers to NULL.
         | 
| 758 | 
            +
                 *
         | 
| 759 | 
            +
                 * You can also set the XML_PARSE_SAX1 parser option, but versions
         | 
| 760 | 
            +
                 * older than 2.12.0 will probably crash if this option is provided
         | 
| 761 | 
            +
                 * together with custom SAX callbacks.
         | 
| 762 | 
            +
                 */
         | 
| 735 763 | 
             
                startElementSAXFunc startElement;
         | 
| 736 764 | 
             
                endElementSAXFunc endElement;
         | 
| 737 765 | 
             
                referenceSAXFunc reference;
         | 
| @@ -745,8 +773,14 @@ struct _xmlSAXHandler { | |
| 745 773 | 
             
                getParameterEntitySAXFunc getParameterEntity;
         | 
| 746 774 | 
             
                cdataBlockSAXFunc cdataBlock;
         | 
| 747 775 | 
             
                externalSubsetSAXFunc externalSubset;
         | 
| 776 | 
            +
                /*
         | 
| 777 | 
            +
                 * `initialized` should always be set to XML_SAX2_MAGIC to enable the
         | 
| 778 | 
            +
                 * modern SAX2 interface.
         | 
| 779 | 
            +
                 */
         | 
| 748 780 | 
             
                unsigned int initialized;
         | 
| 749 | 
            -
                /* | 
| 781 | 
            +
                /*
         | 
| 782 | 
            +
                 * The following members are only used by the SAX2 interface.
         | 
| 783 | 
            +
                 */
         | 
| 750 784 | 
             
                void *_private;
         | 
| 751 785 | 
             
                startElementNsSAX2Func startElementNs;
         | 
| 752 786 | 
             
                endElementNsSAX2Func endElementNs;
         | 
| @@ -804,18 +838,69 @@ typedef xmlParserInputPtr (*xmlExternalEntityLoader) (const char *URL, | |
| 804 838 | 
             
            					 const char *ID,
         | 
| 805 839 | 
             
            					 xmlParserCtxtPtr context);
         | 
| 806 840 |  | 
| 807 | 
            -
             | 
| 808 | 
            -
             | 
| 841 | 
            +
            /*
         | 
| 842 | 
            +
             * Variables
         | 
| 843 | 
            +
             */
         | 
| 844 | 
            +
             | 
| 845 | 
            +
            XMLPUBVAR const char *const xmlParserVersion;
         | 
| 846 | 
            +
            #ifdef LIBXML_THREAD_ENABLED
         | 
| 847 | 
            +
            /* backward compatibility */
         | 
| 848 | 
            +
            XMLPUBFUN const char *const *__xmlParserVersion(void);
         | 
| 809 849 | 
             
            #endif
         | 
| 810 850 |  | 
| 811 | 
            -
             | 
| 812 | 
            -
            # | 
| 813 | 
            -
             | 
| 851 | 
            +
            /** DOC_DISABLE */
         | 
| 852 | 
            +
            #define XML_GLOBALS_PARSER_CORE \
         | 
| 853 | 
            +
              XML_OP(oldXMLWDcompatibility, int, XML_DEPRECATED) \
         | 
| 854 | 
            +
              XML_OP(xmlDefaultSAXLocator, xmlSAXLocator, XML_DEPRECATED) \
         | 
| 855 | 
            +
              XML_OP(xmlDoValidityCheckingDefaultValue, int, XML_DEPRECATED) \
         | 
| 856 | 
            +
              XML_OP(xmlGetWarningsDefaultValue, int, XML_DEPRECATED) \
         | 
| 857 | 
            +
              XML_OP(xmlKeepBlanksDefaultValue, int, XML_DEPRECATED) \
         | 
| 858 | 
            +
              XML_OP(xmlLineNumbersDefaultValue, int, XML_DEPRECATED) \
         | 
| 859 | 
            +
              XML_OP(xmlLoadExtDtdDefaultValue, int, XML_DEPRECATED) \
         | 
| 860 | 
            +
              XML_OP(xmlParserDebugEntities, int, XML_DEPRECATED) \
         | 
| 861 | 
            +
              XML_OP(xmlPedanticParserDefaultValue, int, XML_DEPRECATED) \
         | 
| 862 | 
            +
              XML_OP(xmlSubstituteEntitiesDefaultValue, int, XML_DEPRECATED) \
         | 
| 863 | 
            +
              XML_OP(xmlIndentTreeOutput, int, XML_NO_ATTR) \
         | 
| 864 | 
            +
              XML_OP(xmlTreeIndentString, const char *, XML_NO_ATTR) \
         | 
| 865 | 
            +
              XML_OP(xmlSaveNoEmptyTags, int, XML_NO_ATTR)
         | 
| 814 866 |  | 
| 815 | 
            -
            #ifdef  | 
| 816 | 
            -
             | 
| 867 | 
            +
            #ifdef LIBXML_SAX1_ENABLED
         | 
| 868 | 
            +
              #define XML_GLOBALS_PARSER_SAX1 \
         | 
| 869 | 
            +
                XML_OP(xmlDefaultSAXHandler, xmlSAXHandlerV1, XML_DEPRECATED)
         | 
| 870 | 
            +
            #else
         | 
| 871 | 
            +
              #define XML_GLOBALS_PARSER_SAX1
         | 
| 817 872 | 
             
            #endif
         | 
| 818 873 |  | 
| 874 | 
            +
            #define XML_GLOBALS_PARSER \
         | 
| 875 | 
            +
              XML_GLOBALS_PARSER_CORE \
         | 
| 876 | 
            +
              XML_GLOBALS_PARSER_SAX1
         | 
| 877 | 
            +
             | 
| 878 | 
            +
            #define XML_OP XML_DECLARE_GLOBAL
         | 
| 879 | 
            +
            XML_GLOBALS_PARSER
         | 
| 880 | 
            +
            #undef XML_OP
         | 
| 881 | 
            +
             | 
| 882 | 
            +
            #if defined(LIBXML_THREAD_ENABLED) && !defined(XML_GLOBALS_NO_REDEFINITION)
         | 
| 883 | 
            +
              #define oldXMLWDcompatibility XML_GLOBAL_MACRO(oldXMLWDcompatibility)
         | 
| 884 | 
            +
              #define xmlDefaultSAXHandler XML_GLOBAL_MACRO(xmlDefaultSAXHandler)
         | 
| 885 | 
            +
              #define xmlDefaultSAXLocator XML_GLOBAL_MACRO(xmlDefaultSAXLocator)
         | 
| 886 | 
            +
              #define xmlDoValidityCheckingDefaultValue \
         | 
| 887 | 
            +
                XML_GLOBAL_MACRO(xmlDoValidityCheckingDefaultValue)
         | 
| 888 | 
            +
              #define xmlGetWarningsDefaultValue \
         | 
| 889 | 
            +
                XML_GLOBAL_MACRO(xmlGetWarningsDefaultValue)
         | 
| 890 | 
            +
              #define xmlKeepBlanksDefaultValue XML_GLOBAL_MACRO(xmlKeepBlanksDefaultValue)
         | 
| 891 | 
            +
              #define xmlLineNumbersDefaultValue \
         | 
| 892 | 
            +
                XML_GLOBAL_MACRO(xmlLineNumbersDefaultValue)
         | 
| 893 | 
            +
              #define xmlLoadExtDtdDefaultValue XML_GLOBAL_MACRO(xmlLoadExtDtdDefaultValue)
         | 
| 894 | 
            +
              #define xmlParserDebugEntities XML_GLOBAL_MACRO(xmlParserDebugEntities)
         | 
| 895 | 
            +
              #define xmlPedanticParserDefaultValue \
         | 
| 896 | 
            +
                XML_GLOBAL_MACRO(xmlPedanticParserDefaultValue)
         | 
| 897 | 
            +
              #define xmlSubstituteEntitiesDefaultValue \
         | 
| 898 | 
            +
                XML_GLOBAL_MACRO(xmlSubstituteEntitiesDefaultValue)
         | 
| 899 | 
            +
              #define xmlIndentTreeOutput XML_GLOBAL_MACRO(xmlIndentTreeOutput)
         | 
| 900 | 
            +
              #define xmlTreeIndentString XML_GLOBAL_MACRO(xmlTreeIndentString)
         | 
| 901 | 
            +
              #define xmlSaveNoEmptyTags XML_GLOBAL_MACRO(xmlSaveNoEmptyTags)
         | 
| 902 | 
            +
            #endif
         | 
| 903 | 
            +
            /** DOC_ENABLE */
         | 
| 819 904 |  | 
| 820 905 | 
             
            /*
         | 
| 821 906 | 
             
             * Init/Cleanup
         | 
| @@ -824,6 +909,12 @@ XMLPUBFUN void | |
| 824 909 | 
             
            		xmlInitParser		(void);
         | 
| 825 910 | 
             
            XMLPUBFUN void
         | 
| 826 911 | 
             
            		xmlCleanupParser	(void);
         | 
| 912 | 
            +
            XML_DEPRECATED
         | 
| 913 | 
            +
            XMLPUBFUN void
         | 
| 914 | 
            +
            		xmlInitGlobals		(void);
         | 
| 915 | 
            +
            XML_DEPRECATED
         | 
| 916 | 
            +
            XMLPUBFUN void
         | 
| 917 | 
            +
            		xmlCleanupGlobals	(void);
         | 
| 827 918 |  | 
| 828 919 | 
             
            /*
         | 
| 829 920 | 
             
             * Input functions
         | 
| @@ -849,16 +940,32 @@ XMLPUBFUN xmlDocPtr | |
| 849 940 | 
             
            		xmlParseMemory		(const char *buffer,
         | 
| 850 941 | 
             
            					 int size);
         | 
| 851 942 | 
             
            #endif /* LIBXML_SAX1_ENABLED */
         | 
| 852 | 
            -
            XMLPUBFUN int
         | 
| 943 | 
            +
            XML_DEPRECATED XMLPUBFUN int
         | 
| 853 944 | 
             
            		xmlSubstituteEntitiesDefault(int val);
         | 
| 854 | 
            -
            XMLPUBFUN int
         | 
| 945 | 
            +
            XML_DEPRECATED XMLPUBFUN int
         | 
| 946 | 
            +
                            xmlThrDefSubstituteEntitiesDefaultValue(int v);
         | 
| 947 | 
            +
            XML_DEPRECATED XMLPUBFUN int
         | 
| 855 948 | 
             
            		xmlKeepBlanksDefault	(int val);
         | 
| 949 | 
            +
            XML_DEPRECATED XMLPUBFUN int
         | 
| 950 | 
            +
            		xmlThrDefKeepBlanksDefaultValue(int v);
         | 
| 856 951 | 
             
            XMLPUBFUN void
         | 
| 857 952 | 
             
            		xmlStopParser		(xmlParserCtxtPtr ctxt);
         | 
| 858 | 
            -
            XMLPUBFUN int
         | 
| 953 | 
            +
            XML_DEPRECATED XMLPUBFUN int
         | 
| 859 954 | 
             
            		xmlPedanticParserDefault(int val);
         | 
| 860 | 
            -
            XMLPUBFUN int
         | 
| 955 | 
            +
            XML_DEPRECATED XMLPUBFUN int
         | 
| 956 | 
            +
                            xmlThrDefPedanticParserDefaultValue(int v);
         | 
| 957 | 
            +
            XML_DEPRECATED XMLPUBFUN int
         | 
| 861 958 | 
             
            		xmlLineNumbersDefault	(int val);
         | 
| 959 | 
            +
            XML_DEPRECATED XMLPUBFUN int
         | 
| 960 | 
            +
                            xmlThrDefLineNumbersDefaultValue(int v);
         | 
| 961 | 
            +
            XML_DEPRECATED XMLPUBFUN int
         | 
| 962 | 
            +
                            xmlThrDefDoValidityCheckingDefaultValue(int v);
         | 
| 963 | 
            +
            XML_DEPRECATED XMLPUBFUN int
         | 
| 964 | 
            +
                            xmlThrDefGetWarningsDefaultValue(int v);
         | 
| 965 | 
            +
            XML_DEPRECATED XMLPUBFUN int
         | 
| 966 | 
            +
                            xmlThrDefLoadExtDtdDefaultValue(int v);
         | 
| 967 | 
            +
            XML_DEPRECATED XMLPUBFUN int
         | 
| 968 | 
            +
                            xmlThrDefParserDebugEntities(int v);
         | 
| 862 969 |  | 
| 863 970 | 
             
            #ifdef LIBXML_SAX1_ENABLED
         | 
| 864 971 | 
             
            /*
         | 
| @@ -1149,6 +1256,9 @@ XMLPUBFUN int | |
| 1149 1256 | 
             
            XMLPUBFUN int
         | 
| 1150 1257 | 
             
            		xmlCtxtUseOptions	(xmlParserCtxtPtr ctxt,
         | 
| 1151 1258 | 
             
            					 int options);
         | 
| 1259 | 
            +
            XMLPUBFUN void
         | 
| 1260 | 
            +
            		xmlCtxtSetMaxAmplification(xmlParserCtxtPtr ctxt,
         | 
| 1261 | 
            +
            					 unsigned maxAmpl);
         | 
| 1152 1262 | 
             
            XMLPUBFUN xmlDocPtr
         | 
| 1153 1263 | 
             
            		xmlReadDoc		(const xmlChar *cur,
         | 
| 1154 1264 | 
             
            					 const char *URL,
         | 
| @@ -29,13 +29,9 @@ typedef xmlMutex *xmlMutexPtr; | |
| 29 29 | 
             
            typedef struct _xmlRMutex xmlRMutex;
         | 
| 30 30 | 
             
            typedef xmlRMutex *xmlRMutexPtr;
         | 
| 31 31 |  | 
| 32 | 
            -
             | 
| 33 | 
            -
             | 
| 34 | 
            -
             | 
| 35 | 
            -
            #include <libxml/globals.h>
         | 
| 36 | 
            -
            #ifdef __cplusplus
         | 
| 37 | 
            -
            extern "C" {
         | 
| 38 | 
            -
            #endif
         | 
| 32 | 
            +
            XMLPUBFUN int
         | 
| 33 | 
            +
            			xmlCheckThreadLocalStorage(void);
         | 
| 34 | 
            +
             | 
| 39 35 | 
             
            XMLPUBFUN xmlMutexPtr
         | 
| 40 36 | 
             
            			xmlNewMutex	(void);
         | 
| 41 37 | 
             
            XMLPUBFUN void
         | 
| @@ -73,13 +69,10 @@ XMLPUBFUN int | |
| 73 69 | 
             
            XML_DEPRECATED
         | 
| 74 70 | 
             
            XMLPUBFUN void
         | 
| 75 71 | 
             
            			xmlCleanupThreads(void);
         | 
| 76 | 
            -
            XML_DEPRECATED
         | 
| 77 | 
            -
            XMLPUBFUN xmlGlobalStatePtr
         | 
| 78 | 
            -
            			xmlGetGlobalState(void);
         | 
| 79 72 |  | 
| 80 73 | 
             
            /** DOC_DISABLE */
         | 
| 81 74 | 
             
            #if defined(LIBXML_THREAD_ENABLED) && defined(_WIN32) && \
         | 
| 82 | 
            -
                 | 
| 75 | 
            +
                defined(LIBXML_STATIC_FOR_DLL)
         | 
| 83 76 | 
             
            int
         | 
| 84 77 | 
             
            xmlDllMain(void *hinstDLL, unsigned long fdwReason,
         | 
| 85 78 | 
             
                       void *lpvReserved);
         |