From: Tom Lane <tgl@sss.pgh.pa.us> Date: Sat, 23 Mar 2019 21:35:04 +0000 (-0400) Subject: Revert strlen -> strnlen optimization pre-v11. X-Git-Tag: REL_10_8~60 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=d88d71e3100c0d9687715e4ffa05a72f4599065c;p=postgresql Revert strlen -> strnlen optimization pre-v11. We don't have a src/port substitute for that function in older branches, so it fails on platforms lacking the function natively. Per buildfarm. --- diff --git a/src/backend/utils/adt/xml.c b/src/backend/utils/adt/xml.c index 102c1d983a..f8f271c626 100644 --- a/src/backend/utils/adt/xml.c +++ b/src/backend/utils/adt/xml.c @@ -1213,15 +1213,8 @@ parse_xml_decl(const xmlChar *str, size_t *lenp, if (xmlStrncmp(p, (xmlChar *) "<?xml", 5) != 0) goto finished; - /* - * If next char is a name char, it's a PI like <?xml-stylesheet ...?> - * rather than an XMLDecl, so we have done what we came to do and found no - * XMLDecl. - * - * We need an input length value for xmlGetUTF8Char, but there's no need - * to count the whole document size, so use strnlen not strlen. - */ - utf8len = strnlen((const char *) (p + 5), MAX_MULTIBYTE_CHAR_LEN); + /* if next char is name char, it's a PI like <?xml-stylesheet ...?> */ + utf8len = strlen((const char *) (p + 5)); utf8char = xmlGetUTF8Char(p + 5, &utf8len); if (PG_XMLISNAMECHAR(utf8char)) goto finished;