Blame 0077-util.h-make-strdupa-and-strndupa-pass-NULL-straight-.patch

38cfe28
From 07fbba7acf9c757a3ae8192a64cb3a1f631c5f74 Mon Sep 17 00:00:00 2001
38cfe28
From: Peter Jones <pjones@redhat.com>
38cfe28
Date: Thu, 30 Jan 2020 13:57:18 -0500
38cfe28
Subject: [PATCH 77/86] util.h: make strdupa() and strndupa() pass NULL
38cfe28
 straight through.
38cfe28
38cfe28
Signed-off-by: Peter Jones <pjones@redhat.com>
38cfe28
---
38cfe28
 src/util.h | 22 +++++++++++++++-------
38cfe28
 1 file changed, 15 insertions(+), 7 deletions(-)
38cfe28
38cfe28
diff --git a/src/util.h b/src/util.h
38cfe28
index b7b03931d7e..f4c6c27cc73 100644
38cfe28
--- a/src/util.h
38cfe28
+++ b/src/util.h
38cfe28
@@ -147,9 +147,13 @@ lcm(uint64_t x, uint64_t y)
38cfe28
 #define strdupa(s)						\
38cfe28
        (__extension__ ({					\
38cfe28
 		const char *__in = (s);				\
38cfe28
-		size_t __len = strlen (__in);			\
38cfe28
-		char *__out = (char *) alloca (__len + 1);	\
38cfe28
-		strcpy(__out, __in);				\
38cfe28
+		size_t __len;					\
38cfe28
+		char *__out = NULL;				\
38cfe28
+		if (__in) {					\
38cfe28
+			__len = strlen (__in);			\
38cfe28
+			__out = (char *) alloca (__len + 1);	\
38cfe28
+			strcpy(__out, __in);			\
38cfe28
+		}						\
38cfe28
 		__out;						\
38cfe28
 	}))
38cfe28
 #endif
38cfe28
@@ -158,10 +162,14 @@ lcm(uint64_t x, uint64_t y)
38cfe28
 #define strndupa(s, l)						\
38cfe28
        (__extension__ ({					\
38cfe28
 		const char *__in = (s);				\
38cfe28
-		size_t __len = strnlen (__in, (l));		\
38cfe28
-		char *__out = (char *) alloca (__len + 1);	\
38cfe28
-		strncpy(__out, __in, __len);			\
38cfe28
-		__out[__len] = '\0';				\
38cfe28
+		size_t __len;					\
38cfe28
+		char *__out = NULL;				\
38cfe28
+		if (__in) {					\
38cfe28
+			__len = strnlen (__in, (l));		\
38cfe28
+			__out = (char *) alloca (__len + 1);	\
38cfe28
+			strncpy(__out, __in, __len);		\
38cfe28
+			__out[__len] = '\0';			\
38cfe28
+		}						\
38cfe28
 		__out;						\
38cfe28
 	}))
38cfe28
 #endif
38cfe28
-- 
38cfe28
2.24.1
38cfe28