summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndroid Build Coastguard Worker <android-build-coastguard-worker@google.com>2023-05-10 16:10:46 +0000
committerAndroid Build Coastguard Worker <android-build-coastguard-worker@google.com>2023-05-10 16:10:46 +0000
commitd4eed30ccba325359204e5a2152a1d88a3541de7 (patch)
tree3501dadfc8a8559645900663b74f481da07c113f
parentfdaad93e5e7a46031af10d0a7d191c73f25c0def (diff)
parent410c5f4d73806d462e26350d4a3c47498af77427 (diff)
downloadexpat-android13-mainline-tzdata4-release.tar.gz
Snap for 10102166 from 410c5f4d73806d462e26350d4a3c47498af77427 to mainline-tzdata4-releaseaml_tz4_332714070aml_tz4_332714050aml_tz4_332714010aml_tz4_331910000android13-mainline-tzdata4-releaseaml_tz4_332714010
Change-Id: Ia096fa065812ead39ae76662d9b9a05cbd1415e4
-rw-r--r--lib/xmlparse.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/lib/xmlparse.c b/lib/xmlparse.c
index 7db28d07..7e981919 100644
--- a/lib/xmlparse.c
+++ b/lib/xmlparse.c
@@ -1066,6 +1066,14 @@ parserCreate(const XML_Char *encodingName,
parserInit(parser, encodingName);
if (encodingName && ! parser->m_protocolEncodingName) {
+ if (dtd) {
+ // We need to stop the upcoming call to XML_ParserFree from happily
+ // destroying parser->m_dtd because the DTD is shared with the parent
+ // parser and the only guard that keeps XML_ParserFree from destroying
+ // parser->m_dtd is parser->m_isParamEntity but it will be set to
+ // XML_TRUE only later in XML_ExternalEntityParserCreate (or not at all).
+ parser->m_dtd = NULL;
+ }
XML_ParserFree(parser);
return NULL;
}