rrichards               Wed Mar  2 13:13:35 2005 EDT

  Modified files:              
    /php-src/ext/xml    compat.c 
  Log:
  Fixed bug #32001 (xml_parse_into_struct() exceeds maximum execution time)
  
http://cvs.php.net/diff.php/php-src/ext/xml/compat.c?r1=1.40&r2=1.41&ty=u
Index: php-src/ext/xml/compat.c
diff -u php-src/ext/xml/compat.c:1.40 php-src/ext/xml/compat.c:1.41
--- php-src/ext/xml/compat.c:1.40       Thu Feb 17 10:05:16 2005
+++ php-src/ext/xml/compat.c    Wed Mar  2 13:13:34 2005
@@ -379,8 +379,12 @@
        }
        if (encoding != NULL) {
                parser->parser->encoding = xmlStrdup(encoding);
+#if LIBXML_VERSION <= 20617
+       /* for older versions of libxml2, allow correct detection of
+        * charset in documents with a BOM: */
        } else {
                parser->parser->charset = XML_CHAR_ENCODING_NONE;
+#endif
        }
        parser->parser->replaceEntities = 1;
        parser->parser->wellFormed = 0;
@@ -478,6 +482,33 @@
 {
 #if LIBXML_VERSION >= 20600
        int error;
+#endif
+
+/* The following is a hack to keep BC with PHP 4 while avoiding 
+the inifite loop in libxml <= 2.6.17 which occurs when no encoding 
+has been defined and none can be detected */
+#if LIBXML_VERSION <= 20617
+       if (parser->parser->charset == XML_CHAR_ENCODING_NONE) {
+               if (data_len >= 4 || (parser->parser->input->buf->buffer->use + 
data_len >= 4)) {
+                       xmlChar start[4];
+                       int char_count;
+
+                       char_count = parser->parser->input->buf->buffer->use;
+                       if (char_count > 4) {
+                               char_count = 4;
+                       }
+
+                       memcpy(start, 
parser->parser->input->buf->buffer->content, (size_t)char_count);
+                       memcpy(start + char_count, data, (size_t)(4 - 
char_count));
+
+                       if (xmlDetectCharEncoding(&start[0], 4) == 
XML_CHAR_ENCODING_NONE) {
+                               parser->parser->charset = 
XML_CHAR_ENCODING_UTF8;
+                       }
+               }
+       }
+#endif
+
+#if LIBXML_VERSION >= 20600
        error = xmlParseChunk(parser->parser, data, data_len, is_final);
        if (!error) {
                return 1;

-- 
PHP CVS Mailing List (http://www.php.net/)
To unsubscribe, visit: http://www.php.net/unsub.php

Reply via email to