buildroot/package/popt/0005-fix-build-without-mbstate_t.patch
Fabrice Fontaine 2cb057314a package/popt: fix build without wchar
Commit 82442b54b6 removed
0001-no-wchar.patch but without importing an upstream patch that
"should" have been equivalent to our patch but resulted in a build
failure on toolchains with wchar but without mbsrtowcs

So add a bunch of upstream patches and a new patch to fix this build
failure

While at it, also put back 0003-glob-detection.patch which, again, has
been upstreamed but is not in version 1.18 ...

Fixes:
 - http://autobuild.buildroot.org/results/27f184af35468941173628e5e847a284c0b80d73

Signed-off-by: Fabrice Fontaine <fontaine.fabrice@gmail.com>
Signed-off-by: Thomas Petazzoni <thomas.petazzoni@bootlin.com>
2020-09-19 21:55:35 +02:00

69 lines
2.2 KiB
Diff

From e4788a0f9d820574a165b2609ff16b717ce0baba Mon Sep 17 00:00:00 2001
From: Fabrice Fontaine <fontaine.fabrice@gmail.com>
Date: Sat, 19 Sep 2020 18:51:15 +0200
Subject: [PATCH] fix build without mbstate_t
Commit 41911aac46d69df6a205af59d60f23a418b0e875 tried to fix build
without wchar by checking for the availability of wchar.h however some
toolchains have wchar.h but does not define mbstate_t and mbsrtowcs so
replace HAVE_WCHAR_H by HAVE_MBSRTOWCS
Fixes:
- http://autobuild.buildroot.org/results/27f184af35468941173628e5e847a284c0b80d73
Signed-off-by: Fabrice Fontaine <fontaine.fabrice@gmail.com>
[Upstream status:
https://github.com/rpm-software-management/popt/pull/51]
---
configure.ac | 4 ++--
src/popthelp.c | 4 ++--
2 files changed, 4 insertions(+), 4 deletions(-)
diff --git a/configure.ac b/configure.ac
index 1fce6df..442086b 100644
--- a/configure.ac
+++ b/configure.ac
@@ -18,7 +18,7 @@ LT_INIT
AC_SYS_LARGEFILE
-AC_CHECK_HEADERS([fnmatch.h glob.h langinfo.h libintl.h mcheck.h stdalign.h wchar.h])
+AC_CHECK_HEADERS([fnmatch.h glob.h langinfo.h libintl.h mcheck.h stdalign.h])
# For some systems we know that we have ld_version scripts.
# Use it then as default.
@@ -50,7 +50,7 @@ AC_ARG_ENABLE([build-gcov],
])
AC_SEARCH_LIBS([setreuid], [ucb])
-AC_CHECK_FUNCS([getuid geteuid iconv mtrace secure_getenv __secure_getenv setreuid setuid stpcpy strerror vasprintf srandom glob_pattern_p])
+AC_CHECK_FUNCS([getuid geteuid iconv mtrace secure_getenv __secure_getenv setreuid setuid stpcpy strerror vasprintf srandom glob_pattern_p mbsrtowcs])
AM_GNU_GETTEXT_VERSION([0.18.2])
AM_GNU_GETTEXT([external])
diff --git a/src/popthelp.c b/src/popthelp.c
index f604516..b4ab9b4 100644
--- a/src/popthelp.c
+++ b/src/popthelp.c
@@ -15,7 +15,7 @@
#include <sys/ioctl.h>
#endif
-#ifdef HAVE_WCHAR_H
+#ifdef HAVE_MBSRTOWCS
#include <wchar.h> /* for mbsrtowcs */
#endif
#include "poptint.h"
@@ -117,7 +117,7 @@ static size_t maxColumnWidth(FILE *fp)
static inline size_t stringDisplayWidth(const char *s)
{
size_t n = strlen(s);
-#ifdef HAVE_WCHAR_H
+#ifdef HAVE_MBSRTOWCS
mbstate_t t;
memset ((void *)&t, 0, sizeof (t)); /* In initial state. */
--
2.28.0