OSDN Git Service

It turns out the LIBXML_TEST_VERSION macro calls xmlInitParser().
authorTom Lane <tgl@sss.pgh.pa.us>
Sat, 12 Jan 2008 21:14:08 +0000 (21:14 +0000)
committerTom Lane <tgl@sss.pgh.pa.us>
Sat, 12 Jan 2008 21:14:08 +0000 (21:14 +0000)
Therefore we must xmlCleanupParser(), or we risk leaving behind
dangling pointers to whatever memory context is current when xml_init()
is called.  This seems to fix bug #3860, though we might still want
the more invasive solution being worked on by Alvaro.

src/backend/utils/adt/xml.c

index 622d4e0..411cd6c 100644 (file)
@@ -7,7 +7,7 @@
  * Portions Copyright (c) 1996-2008, PostgreSQL Global Development Group
  * Portions Copyright (c) 1994, Regents of the University of California
  *
- * $PostgreSQL: pgsql/src/backend/utils/adt/xml.c,v 1.66 2008/01/12 10:50:03 neilc Exp $
+ * $PostgreSQL: pgsql/src/backend/utils/adt/xml.c,v 1.67 2008/01/12 21:14:08 tgl Exp $
  *
  *-------------------------------------------------------------------------
  */
@@ -958,6 +958,9 @@ xml_init(void)
                /* Check library compatibility */
                LIBXML_TEST_VERSION;
 
+               /* The above calls xmlInitParser(); must clean up dangling pointers */
+               xmlCleanupParser();
+
                first_time = false;
        }
        else