Commit ff8a1204 authored by Tom Lane's avatar Tom Lane

Fix core dump in contrib/xml2's xpath_table() when the input query returns

a NULL value.  Per bug #4058.
parent c111a721
...@@ -803,12 +803,10 @@ xpath_table(PG_FUNCTION_ARGS) ...@@ -803,12 +803,10 @@ xpath_table(PG_FUNCTION_ARGS)
xmlXPathCompExprPtr comppath; xmlXPathCompExprPtr comppath;
/* Extract the row data as C Strings */ /* Extract the row data as C Strings */
spi_tuple = tuptable->vals[i]; spi_tuple = tuptable->vals[i];
pkey = SPI_getvalue(spi_tuple, spi_tupdesc, 1); pkey = SPI_getvalue(spi_tuple, spi_tupdesc, 1);
xmldoc = SPI_getvalue(spi_tuple, spi_tupdesc, 2); xmldoc = SPI_getvalue(spi_tuple, spi_tupdesc, 2);
/* /*
* Clear the values array, so that not-well-formed documents return * Clear the values array, so that not-well-formed documents return
* NULL in all columns. * NULL in all columns.
...@@ -822,11 +820,14 @@ xpath_table(PG_FUNCTION_ARGS) ...@@ -822,11 +820,14 @@ xpath_table(PG_FUNCTION_ARGS)
values[0] = pkey; values[0] = pkey;
/* Parse the document */ /* Parse the document */
doctree = xmlParseMemory(xmldoc, strlen(xmldoc)); if (xmldoc)
doctree = xmlParseMemory(xmldoc, strlen(xmldoc));
else /* treat NULL as not well-formed */
doctree = NULL;
if (doctree == NULL) if (doctree == NULL)
{ /* not well-formed, so output all-NULL tuple */ {
/* not well-formed, so output all-NULL tuple */
ret_tuple = BuildTupleFromCStrings(attinmeta, values); ret_tuple = BuildTupleFromCStrings(attinmeta, values);
oldcontext = MemoryContextSwitchTo(per_query_ctx); oldcontext = MemoryContextSwitchTo(per_query_ctx);
tuplestore_puttuple(tupstore, ret_tuple); tuplestore_puttuple(tupstore, ret_tuple);
...@@ -918,8 +919,10 @@ xpath_table(PG_FUNCTION_ARGS) ...@@ -918,8 +919,10 @@ xpath_table(PG_FUNCTION_ARGS)
xmlFreeDoc(doctree); xmlFreeDoc(doctree);
pfree(pkey); if (pkey)
pfree(xmldoc); pfree(pkey);
if (xmldoc)
pfree(xmldoc);
} }
xmlCleanupParser(); xmlCleanupParser();
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment