From: Markus Armbruster Date: Tue, 27 Jan 2015 16:13:52 +0000 (+0100) Subject: util/uri: URI member path can be null, compare more carfully X-Git-Tag: TizenStudio_2.0_p2.3.2~208^2~350^2~17 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=afb30dde3ad71349fc65726946d58e5d3c61f8af;p=sdk%2Femulator%2Fqemu.git util/uri: URI member path can be null, compare more carfully uri_resolve_relative() calls strcmp(bas->path, ref->path). However, either argument could be null! Evidence: the code checks for null after the comparison. Spotted by Coverity. I suspect this was screwed up when we stole the code from libxml2. There the conditional reads xmlStrEqual((xmlChar *)bas->path, (xmlChar *)ref->path) with int xmlStrEqual(const xmlChar *str1, const xmlChar *str2) { if (str1 == str2) return(1); if (str1 == NULL) return(0); if (str2 == NULL) return(0); do { if (*str1++ != *str2) return(0); } while (*str2++); return(1); } Fix by replicating libxml2's logic faithfully. Cc: Paolo Bonzini Signed-off-by: Markus Armbruster Signed-off-by: Michael Tokarev --- diff --git a/util/uri.c b/util/uri.c index b9a7b54..1cfd78b 100644 --- a/util/uri.c +++ b/util/uri.c @@ -1935,7 +1935,8 @@ uri_resolve_relative (const char *uri, const char * base) val = g_strdup (uri); goto done; } - if (!strcmp(bas->path, ref->path)) { + if (bas->path == ref->path || + (bas->path && ref->path && !strcmp(bas->path, ref->path))) { val = g_strdup(""); goto done; }