SHA256
1
0
forked from pool/crosstool-ng

Accepting request 499581 from electronics

1

OBS-URL: https://build.opensuse.org/request/show/499581
OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/crosstool-ng?expand=0&rev=6
This commit is contained in:
Dominique Leuenberger 2017-05-31 10:19:33 +00:00 committed by Git OBS Bridge
commit 34398c7a53
3 changed files with 113 additions and 1 deletions

View File

@ -0,0 +1,101 @@
diff -urd crosstool-ng.orig/configure crosstool-ng.new/configure
--- crosstool-ng.orig/configure 2015-11-20 14:03:36.000000000 +0100
+++ crosstool-ng.new/configure 2017-05-27 10:12:40.383087059 +0200
@@ -635,6 +635,7 @@
lzma
xz
kconfig_options
+GPERF_LEN_TYPE
automake
LIBTOOLIZE
LIBTOOL
@@ -5331,6 +5332,27 @@
{ $as_echo "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_automake" >&5
$as_echo "$ac_cv_path_automake" >&6; }
automake=$ac_cv_path_automake
+
+
+#----------------------------------------
+# Gperf 3.1 started generating functions with size_t rather than unsigned int
+{ $as_echo "$as_me:${as_lineno-$LINENO}: checking for the type used in gperf declarations" >&5
+$as_echo_n "checking for the type used in gperf declarations... " >&6; }
+echo "#include <string.h>" > conftest.gperf.c
+echo "const char * in_word_set(const char *, GPERF_LEN_TYPE);" >> conftest.gperf.c
+echo foo,bar | ${GPERF} -L ANSI-C >> conftest.gperf.c
+if ${CC} -c -o /dev/null conftest.gperf.c -DGPERF_LEN_TYPE='size_t' >/dev/null 2>&1; then :
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: size_t" >&5
+$as_echo "size_t" >&6; }
+ GPERF_LEN_TYPE='size_t'
+elif ${CC} -c -o /dev/null conftest.gperf.c -DGPERF_LEN_TYPE='unsigned int' >/dev/null 2>&1; then :
+ { $as_echo "$as_me:${as_lineno-$LINENO}: result: unsigned int" >&5
+$as_echo "unsigned int" >&6; }
+ GPERF_LEN_TYPE='unsigned int'
+else
+ as_fn_error $? "unable to determine gperf len type" "$LINENO" 5
+fi
+rm -f conftest.gperf.c
#--------------------------------------------------------------------
diff -urd crosstool-ng.orig/configure.ac crosstool-ng.new/configure.ac
--- crosstool-ng.orig/configure.ac 2015-11-18 06:29:15.000000000 +0100
+++ crosstool-ng.new/configure.ac 2017-05-27 10:00:57.411342197 +0200
@@ -290,6 +290,22 @@
AC_MSG_ERROR([could not find GNU automake >= 1.10])])])
AC_SUBST([automake], [$ac_cv_path_automake])
+#----------------------------------------
+# Gperf 3.1 started generating functions with size_t rather than unsigned int
+AC_MSG_CHECKING([for the type used in gperf declarations])
+echo "#include <string.h>" > conftest.gperf.c
+echo "const char * in_word_set(const char *, GPERF_LEN_TYPE);" >> conftest.gperf.c
+echo foo,bar | ${GPERF} -L ANSI-C >> conftest.gperf.c
+AS_IF([${CC} -c -o /dev/null conftest.gperf.c -DGPERF_LEN_TYPE='size_t' >/dev/null 2>&1],
+ [AC_MSG_RESULT([size_t])
+ GPERF_LEN_TYPE='size_t'],
+ [${CC} -c -o /dev/null conftest.gperf.c -DGPERF_LEN_TYPE='unsigned int' >/dev/null 2>&1],
+ [AC_MSG_RESULT([unsigned int])
+ GPERF_LEN_TYPE='unsigned int'],
+ [AC_MSG_ERROR([unable to determine gperf len type])])
+rm -f conftest.gperf.c
+AC_SUBST([GPERF_LEN_TYPE])
+
#--------------------------------------------------------------------
# Boring again... But still a bit of work to do...
#--------------------------------------------------------------------
diff -urd crosstool-ng.orig/kconfig/Makefile crosstool-ng.new/kconfig/Makefile
--- crosstool-ng.orig/kconfig/Makefile 2015-11-18 06:29:15.000000000 +0100
+++ crosstool-ng.new/kconfig/Makefile 2017-05-27 10:00:57.411342197 +0200
@@ -6,7 +6,8 @@
@true # Just be silent, you fscking son of a fscking beach...
# Build flags
-CFLAGS = -DCONFIG_=\"CT_\" -DPACKAGE="\"crosstool-NG $(VERSION)\""
+CFLAGS = -DCONFIG_=\"CT_\" -DPACKAGE="\"crosstool-NG $(VERSION)\"" \
+ -DGPERF_LEN_TYPE="$(gperf_len_type)"
LDFLAGS = $(INTL_LIBS)
# Compiler flags to use gettext
diff -urd crosstool-ng.orig/kconfig/zconf.gperf crosstool-ng.new/kconfig/zconf.gperf
--- crosstool-ng.orig/kconfig/zconf.gperf 2015-11-18 06:29:15.000000000 +0100
+++ crosstool-ng.new/kconfig/zconf.gperf 2017-05-27 10:00:57.411342197 +0200
@@ -9,7 +9,7 @@
struct kconf_id;
-static const struct kconf_id *kconf_id_lookup(register const char *str, register unsigned int len);
+static const struct kconf_id *kconf_id_lookup(register const char *str, register GPERF_LEN_TYPE len);
%%
mainmenu, T_MAINMENU, TF_COMMAND
diff -urd crosstool-ng.orig/Makefile.in crosstool-ng.new/Makefile.in
--- crosstool-ng.orig/Makefile.in 2015-11-19 23:43:15.000000000 +0100
+++ crosstool-ng.new/Makefile.in 2017-05-27 10:00:57.411342197 +0200
@@ -69,6 +69,7 @@
export readelf := @READELF@
export patch := @PATCH@
export gperf := @GPERF@
+export gperf_len_type := @GPERF_LEN_TYPE@
export CC := @CC@
export CPP := @CPP@
export CPPFLAGS := @CPPFLAGS@

View File

@ -1,3 +1,11 @@
-------------------------------------------------------------------
Fri May 26 19:27:55 UTC 2017 - bugs@vdm-design.de
- Add patch (crosstool-ng-gperf-fix.patch) to fix build
with gpref version >= 3.1, based on upstream commit
https://github.com/crosstool-ng/crosstool-ng/commit/3bb2bcd2a328fb56332398783e91899ce3bc3556
-------------------------------------------------------------------
Sun Jan 1 00:02:42 UTC 2017 - bwiedemann@suse.com

View File

@ -1,7 +1,7 @@
#
# spec file for package crosstool-ng
#
# Copyright (c) 2016 SUSE LINUX GmbH, Nuernberg, Germany.
# Copyright (c) 2017 SUSE LINUX GmbH, Nuernberg, Germany.
#
# All modifications and additions to the file contributed by third parties
# remain the property of their copyright owners, unless otherwise agreed
@ -26,6 +26,8 @@ Url: http://crosstool-ng.org
Source0: http://crosstool-ng.org/download/crosstool-ng/%{name}-%{version}.tar.bz2
# PATCH-FIX-TO-UPSTREAM -- bmwiedemann
Patch0: reproducible.patch
# PATCH-FIX-UPSTREAM crosstool-ng-gperf-fix.patch bugs@vdm-design.de -- fixes build with gperf >= 3.1
Patch1: crosstool-ng-gperf-fix.patch
BuildRequires: bison
BuildRequires: fdupes
BuildRequires: flex
@ -54,6 +56,7 @@ in the resulting binary/ies: static libraries are but an example.
%prep
%setup -qn %{name}
%patch0 -p1
%patch1 -p1
# from legal team
# "Distribution and use is free, also for commercial purposes" (no modification permission)
find patches/ -name '*-new-valencian-locale.patch' -type f -delete -print