summaryrefslogtreecommitdiff
path: root/src/backend/access/gin/ginfast.c
diff options
context:
space:
mode:
authorTom Lane <tgl@sss.pgh.pa.us>2009-05-12 20:17:40 +0000
committerTom Lane <tgl@sss.pgh.pa.us>2009-05-12 20:17:40 +0000
commit546454f8a3ef2e749288cda972abfd1674aee340 (patch)
tree92bda56de4fe26a5e7c83459004750fdaa33c0b6 /src/backend/access/gin/ginfast.c
parentf23bdda3240d3aa511c843a4f91870d17b53b970 (diff)
Fix intratransaction memory leaks in xml_recv, xmlconcat, xmlroot, and
xml_parse, all arising from the same sloppy usage of parse_xml_decl. The original coding had that function returning its output string parameters in the libxml context, which is long-lived, and all but one of its callers neglected to free the strings afterwards. The easiest and most bulletproof fix is to return the strings in the local palloc context instead, since that's short-lived. This was only costing a dozen or two bytes per function call, but that adds up fast if the function is called repeatedly ... Noted while poking at the more general problem of what to do with our libxml memory allocation hooks. Back-patch to 8.3, which has the identical coding.
Diffstat (limited to 'src/backend/access/gin/ginfast.c')
0 files changed, 0 insertions, 0 deletions