#define PHP_XML_H
#ifdef HAVE_XML
+
extern zend_module_entry xml_module_entry;
#define xml_module_ptr &xml_module_entry
#include "php_version.h"
#define PHP_XML_VERSION PHP_VERSION
-#else
-#define xml_module_ptr NULL
-#endif
-
-#ifdef HAVE_XML
-
#include "expat_compat.h"
#ifdef XML_UNICODE
#error "UTF-16 Unicode support not implemented!"
#endif
-ZEND_BEGIN_MODULE_GLOBALS(xml)
- XML_Char *default_encoding;
-ZEND_END_MODULE_GLOBALS(xml)
-
-typedef struct {
- int case_folding;
- XML_Parser parser;
- XML_Char *target_encoding;
-
- zval index;
- zval startElementHandler;
- zval endElementHandler;
- zval characterDataHandler;
- zval processingInstructionHandler;
- zval defaultHandler;
- zval unparsedEntityDeclHandler;
- zval notationDeclHandler;
- zval externalEntityRefHandler;
- zval unknownEncodingHandler;
- zval startNamespaceDeclHandler;
- zval endNamespaceDeclHandler;
-
- zend_function *startElementPtr;
- zend_function *endElementPtr;
- zend_function *characterDataPtr;
- zend_function *processingInstructionPtr;
- zend_function *defaultPtr;
- zend_function *unparsedEntityDeclPtr;
- zend_function *notationDeclPtr;
- zend_function *externalEntityRefPtr;
- zend_function *unknownEncodingPtr;
- zend_function *startNamespaceDeclPtr;
- zend_function *endNamespaceDeclPtr;
-
- zval object;
-
- zval data;
- zval info;
- int level;
- int toffset;
- int curtag;
- zval *ctag;
- char **ltags;
- int lastwasopen;
- int skipwhite;
- int isparsing;
-
- XML_Char *baseURI;
-} xml_parser;
-
-
-typedef struct {
- XML_Char *name;
- char (*decoding_function)(unsigned short);
- unsigned short (*encoding_function)(unsigned char);
-} xml_encoding;
-
-
-enum php_xml_option {
- PHP_XML_OPTION_CASE_FOLDING = 1,
- PHP_XML_OPTION_TARGET_ENCODING,
- PHP_XML_OPTION_SKIP_TAGSTART,
- PHP_XML_OPTION_SKIP_WHITE
-};
-
-/* for xml_parse_into_struct */
-
-#define XML_MAXLEVEL 255 /* XXX this should be dynamic */
-
-PHP_FUNCTION(xml_parser_create);
-PHP_FUNCTION(xml_parser_create_ns);
-PHP_FUNCTION(xml_set_object);
-PHP_FUNCTION(xml_set_element_handler);
-PHP_FUNCTION(xml_set_character_data_handler);
-PHP_FUNCTION(xml_set_processing_instruction_handler);
-PHP_FUNCTION(xml_set_default_handler);
-PHP_FUNCTION(xml_set_unparsed_entity_decl_handler);
-PHP_FUNCTION(xml_set_notation_decl_handler);
-PHP_FUNCTION(xml_set_external_entity_ref_handler);
-PHP_FUNCTION(xml_set_start_namespace_decl_handler);
-PHP_FUNCTION(xml_set_end_namespace_decl_handler);
-PHP_FUNCTION(xml_parse);
-PHP_FUNCTION(xml_get_error_code);
-PHP_FUNCTION(xml_error_string);
-PHP_FUNCTION(xml_get_current_line_number);
-PHP_FUNCTION(xml_get_current_column_number);
-PHP_FUNCTION(xml_get_current_byte_index);
-PHP_FUNCTION(xml_parser_free);
-PHP_FUNCTION(xml_parser_set_option);
-PHP_FUNCTION(xml_parser_get_option);
-PHP_FUNCTION(utf8_encode);
-PHP_FUNCTION(utf8_decode);
-PHP_FUNCTION(xml_parse_into_struct);
-
-PHP_XML_API char *_xml_zval_strdup(zval *);
-PHP_XML_API zend_string *xml_utf8_decode(const XML_Char *, size_t, const XML_Char *);
-PHP_XML_API zend_string *xml_utf8_encode(const char *, size_t, const XML_Char *);
-
-#endif /* HAVE_LIBEXPAT */
+#else
+#define xml_module_ptr NULL
+#endif /* HAVE_XML */
#define phpext_xml_ptr xml_module_ptr
-#define XML(v) ZEND_MODULE_GLOBALS_ACCESSOR(xml, v)
-
-#if defined(ZTS) && defined(COMPILE_DL_XML)
-ZEND_TSRMLS_CACHE_EXTERN()
-#endif
-
#endif /* PHP_XML_H */
/*
* - Weird things happen with <![CDATA[]]> sections.
*/
+ZEND_BEGIN_MODULE_GLOBALS(xml)
+ XML_Char *default_encoding;
+ZEND_END_MODULE_GLOBALS(xml)
+
ZEND_DECLARE_MODULE_GLOBALS(xml)
+#define XML(v) ZEND_MODULE_GLOBALS_ACCESSOR(xml, v)
+
+typedef struct {
+ int case_folding;
+ XML_Parser parser;
+ XML_Char *target_encoding;
+
+ zval index;
+ zval startElementHandler;
+ zval endElementHandler;
+ zval characterDataHandler;
+ zval processingInstructionHandler;
+ zval defaultHandler;
+ zval unparsedEntityDeclHandler;
+ zval notationDeclHandler;
+ zval externalEntityRefHandler;
+ zval unknownEncodingHandler;
+ zval startNamespaceDeclHandler;
+ zval endNamespaceDeclHandler;
+
+ zend_function *startElementPtr;
+ zend_function *endElementPtr;
+ zend_function *characterDataPtr;
+ zend_function *processingInstructionPtr;
+ zend_function *defaultPtr;
+ zend_function *unparsedEntityDeclPtr;
+ zend_function *notationDeclPtr;
+ zend_function *externalEntityRefPtr;
+ zend_function *unknownEncodingPtr;
+ zend_function *startNamespaceDeclPtr;
+ zend_function *endNamespaceDeclPtr;
+
+ zval object;
+
+ zval data;
+ zval info;
+ int level;
+ int toffset;
+ int curtag;
+ zval *ctag;
+ char **ltags;
+ int lastwasopen;
+ int skipwhite;
+ int isparsing;
+
+ XML_Char *baseURI;
+} xml_parser;
+
+
+typedef struct {
+ XML_Char *name;
+ char (*decoding_function)(unsigned short);
+ unsigned short (*encoding_function)(unsigned char);
+} xml_encoding;
+
+
+enum php_xml_option {
+ PHP_XML_OPTION_CASE_FOLDING = 1,
+ PHP_XML_OPTION_TARGET_ENCODING,
+ PHP_XML_OPTION_SKIP_TAGSTART,
+ PHP_XML_OPTION_SKIP_WHITE
+};
+
/* {{{ dynamically loadable module stuff */
#ifdef COMPILE_DL_XML
#ifdef ZTS
#endif /* COMPILE_DL_XML */
/* }}} */
+#define XML_MAXLEVEL 255 /* XXX this should be dynamic */
#define SKIP_TAGSTART(str) ((str) + (parser->toffset > (int)strlen(str) ? strlen(str) : parser->toffset))
PHP_MINFO_FUNCTION(xml);
static PHP_GINIT_FUNCTION(xml);
+PHP_FUNCTION(xml_parser_create);
+PHP_FUNCTION(xml_parser_create_ns);
+PHP_FUNCTION(xml_set_object);
+PHP_FUNCTION(xml_set_element_handler);
+PHP_FUNCTION(xml_set_character_data_handler);
+PHP_FUNCTION(xml_set_processing_instruction_handler);
+PHP_FUNCTION(xml_set_default_handler);
+PHP_FUNCTION(xml_set_unparsed_entity_decl_handler);
+PHP_FUNCTION(xml_set_notation_decl_handler);
+PHP_FUNCTION(xml_set_external_entity_ref_handler);
+PHP_FUNCTION(xml_set_start_namespace_decl_handler);
+PHP_FUNCTION(xml_set_end_namespace_decl_handler);
+PHP_FUNCTION(xml_parse);
+PHP_FUNCTION(xml_get_error_code);
+PHP_FUNCTION(xml_error_string);
+PHP_FUNCTION(xml_get_current_line_number);
+PHP_FUNCTION(xml_get_current_column_number);
+PHP_FUNCTION(xml_get_current_byte_index);
+PHP_FUNCTION(xml_parser_free);
+PHP_FUNCTION(xml_parser_set_option);
+PHP_FUNCTION(xml_parser_get_option);
+PHP_FUNCTION(xml_parse_into_struct);
+
+static zend_string *xml_utf8_decode(const XML_Char *, size_t, const XML_Char *);
static void xml_parser_dtor(zend_resource *rsrc);
static void xml_set_handler(zval *, zval *);
inline static unsigned short xml_encode_iso_8859_1(unsigned char);
}
/* }}} */
-/* {{{ xml_utf8_encode() */
-PHP_XML_API zend_string *xml_utf8_encode(const char *s, size_t len, const XML_Char *encoding)
-{
- size_t pos = len;
- zend_string *str;
- unsigned int c;
- unsigned short (*encoder)(unsigned char) = NULL;
- const xml_encoding *enc = xml_get_encoding(encoding);
-
- if (enc) {
- encoder = enc->encoding_function;
- } else {
- /* If the target encoding was unknown, fail */
- return NULL;
- }
- if (encoder == NULL) {
- /* If no encoder function was specified, return the data as-is.
- */
- str = zend_string_init(s, len, 0);
- return str;
- }
- /* This is the theoretical max (will never get beyond len * 2 as long
- * as we are converting from single-byte characters, though) */
- str = zend_string_safe_alloc(len, 4, 0, 0);
- ZSTR_LEN(str) = 0;
- while (pos > 0) {
- c = encoder ? encoder((unsigned char)(*s)) : (unsigned short)(*s);
- if (c < 0x80) {
- ZSTR_VAL(str)[ZSTR_LEN(str)++] = (char) c;
- } else if (c < 0x800) {
- ZSTR_VAL(str)[ZSTR_LEN(str)++] = (0xc0 | (c >> 6));
- ZSTR_VAL(str)[ZSTR_LEN(str)++] = (0x80 | (c & 0x3f));
- } else if (c < 0x10000) {
- ZSTR_VAL(str)[ZSTR_LEN(str)++] = (0xe0 | (c >> 12));
- ZSTR_VAL(str)[ZSTR_LEN(str)++] = (0xc0 | ((c >> 6) & 0x3f));
- ZSTR_VAL(str)[ZSTR_LEN(str)++] = (0x80 | (c & 0x3f));
- } else if (c < 0x200000) {
- ZSTR_VAL(str)[ZSTR_LEN(str)++] = (0xf0 | (c >> 18));
- ZSTR_VAL(str)[ZSTR_LEN(str)++] = (0xe0 | ((c >> 12) & 0x3f));
- ZSTR_VAL(str)[ZSTR_LEN(str)++] = (0xc0 | ((c >> 6) & 0x3f));
- ZSTR_VAL(str)[ZSTR_LEN(str)++] = (0x80 | (c & 0x3f));
- }
- pos--;
- s++;
- }
- ZSTR_VAL(str)[ZSTR_LEN(str)] = '\0';
- str = zend_string_truncate(str, ZSTR_LEN(str), 0);
- return str;
-}
-/* }}} */
-
/* {{{ xml_utf8_decode() */
-PHP_XML_API zend_string *xml_utf8_decode(const XML_Char *s, size_t len, const XML_Char *encoding)
+static zend_string *xml_utf8_decode(const XML_Char *s, size_t len, const XML_Char *encoding)
{
size_t pos = 0;
unsigned int c;
}
/* }}} */
-/* {{{ _xml_zval_strdup() */
-PHP_XML_API char *_xml_zval_strdup(zval *val)
-{
- if (Z_TYPE_P(val) == IS_STRING) {
- char *buf = emalloc(Z_STRLEN_P(val) + 1);
- memcpy(buf, Z_STRVAL_P(val), Z_STRLEN_P(val));
- buf[Z_STRLEN_P(val)] = '\0';
- return buf;
- }
- return NULL;
-}
-/* }}} */
-
/* {{{ _xml_add_to_info() */
static void _xml_add_to_info(xml_parser *parser,char *name)
{