Lubos Kardos 165614f
From cddf43a56f19711866371f02f378dc4095b0fadd Mon Sep 17 00:00:00 2001
Lubos Kardos 165614f
From: Lubos Kardos <lkardos@redhat.com>
Lubos Kardos 165614f
Date: Mon, 25 Apr 2016 14:38:47 +0200
Lubos Kardos 165614f
Subject: [PATCH 2/2] Fix sigsegv in stringFormat() (rhbz:1316903)
Lubos Kardos 165614f
Lubos Kardos 165614f
Just skip duping of NULL and return it. Returned NULL is handled in
Lubos Kardos 165614f
upper layer.
Lubos Kardos 165614f
---
Lubos Kardos 165614f
 lib/formats.c | 7 +++++--
Lubos Kardos 165614f
 1 file changed, 5 insertions(+), 2 deletions(-)
Lubos Kardos 165614f
Lubos Kardos 165614f
diff --git a/lib/formats.c b/lib/formats.c
Lubos Kardos 165614f
index e3626ed..bad0b2d 100644
Lubos Kardos 165614f
--- a/lib/formats.c
Lubos Kardos 165614f
+++ b/lib/formats.c
Lubos Kardos 165614f
@@ -44,9 +44,12 @@ static char * stringFormat(rpmtd td)
Lubos Kardos 165614f
 	case RPM_NUMERIC_CLASS:
Lubos Kardos 165614f
 	    rasprintf(&val, "%" PRIu64, rpmtdGetNumber(td));
Lubos Kardos 165614f
 	    break;
Lubos Kardos 165614f
-	case RPM_STRING_CLASS:
Lubos Kardos 165614f
-	    val = xstrdup(rpmtdGetString(td));
Lubos Kardos 165614f
+	case RPM_STRING_CLASS: {
Lubos Kardos 165614f
+	    const char *str = rpmtdGetString(td);
Lubos Kardos 165614f
+	    if (str)
Lubos Kardos 165614f
+		val = xstrdup(str);
Lubos Kardos 165614f
 	    break;
Lubos Kardos 165614f
+	}
Lubos Kardos 165614f
 	case RPM_BINARY_CLASS:
Lubos Kardos 165614f
 	    val = pgpHexStr(td->data, td->count);
Lubos Kardos 165614f
 	    break;
Lubos Kardos 165614f
-- 
Lubos Kardos 165614f
1.9.3
Lubos Kardos 165614f