multilib-fix: use '-' as field separator by default

Also remove --additional-suffix and add --field-separator option
instead.

Fixes https://github.com/devexp-db/db-rpm-config/issues/2.
This commit is contained in:
Pavel Raiskup 2016-06-13 23:38:43 +02:00
parent b8670bd82f
commit 9f438cfd13
2 changed files with 18 additions and 15 deletions

View File

@ -30,7 +30,7 @@ test "$opt_arch" = ppc64p7 && opt_arch=ppc64
opt_buildroot=$(pwd) opt_buildroot=$(pwd)
opt_verbose=: opt_verbose=:
opt_additional_suffix= opt_field_separator=-
# TODO: we could pretty easily implement other then 'cpp-header' stubs, if the # TODO: we could pretty easily implement other then 'cpp-header' stubs, if the
# target file type allows some kind of "transparent" file inclusion. For # target file type allows some kind of "transparent" file inclusion. For
@ -38,6 +38,7 @@ opt_additional_suffix=
# The solution is taken from Fedora PostgreSQL RPM package. # The solution is taken from Fedora PostgreSQL RPM package.
print_stub () print_stub ()
{ {
replacement=$filename$opt_field_separator
cat <<EOF cat <<EOF
/* /*
* Kluge to support multilib installation of both 32- and 64-bit RPMS: * Kluge to support multilib installation of both 32- and 64-bit RPMS:
@ -52,21 +53,21 @@ cat <<EOF
* But that option is deprecated anyway. * But that option is deprecated anyway.
*/ */
#if defined(__x86_64__) #if defined(__x86_64__)
#include "${filename}${opt_additional_suffix}_x86_64.h" #include "${replacement}x86_64.h"
#elif defined(__i386__) #elif defined(__i386__)
#include "${filename}${opt_additional_suffix}_i386.h" #include "${replacement}i386.h"
#elif defined(__ppc64__) || defined(__powerpc64__) #elif defined(__ppc64__) || defined(__powerpc64__)
#include "${filename}${opt_additional_suffix}_ppc64.h" #include "${replacement}ppc64.h"
#elif defined(__ppc__) || defined(__powerpc__) #elif defined(__ppc__) || defined(__powerpc__)
#include "${filename}${opt_additional_suffix}_ppc.h" #include "${replacement}ppc.h"
#elif defined(__s390x__) #elif defined(__s390x__)
#include "${filename}${opt_additional_suffix}_s390x.h" #include "${replacement}s390x.h"
#elif defined(__s390__) #elif defined(__s390__)
#include "${filename}${opt_additional_suffix}_s390.h" #include "${replacement}s390.h"
#elif defined(__sparc__) && defined(__arch64__) #elif defined(__sparc__) && defined(__arch64__)
#include "${filename}${opt_additional_suffix}_sparc64.h" #include "${replacement}sparc64.h"
#elif defined(__sparc__) #elif defined(__sparc__)
#include "${filename}${opt_additional_suffix}_sparc.h" #include "${replacement}sparc.h"
#endif #endif
EOF EOF
} }
@ -89,9 +90,8 @@ script only through available RPM macros.
--buildroot prefix (directory where we play with installed files, usually --buildroot prefix (directory where we play with installed files, usually
after 'make install DESTDIR=buildroot') after 'make install DESTDIR=buildroot')
--file for example /some/path/test.h --file for example /some/path/test.h
--additional-suffix we usually move 'test.h' to 'test_\$ARCH.h'. However --field-separator by default we move filename.h to filename<SEP><ARCH>.h; this
this file could already exist. With this option the multilib option option allows you to override the <SEP> part
file will be named 'test_\$ARCH\$SUFFIX.h'
--verbose print some useful information --verbose print some useful information
--help show this help --help show this help
EOF EOF
@ -122,7 +122,7 @@ while test $# -gt 0
do do
_opt=$1 ; shift _opt=$1 ; shift
case $_opt in case $_opt in
--buildroot|--arch|--additional-suffix|--file) --buildroot|--arch|--file|--field-separator)
_raw_opt=$(echo "$_opt" | sed -e 's/^--//' -e 's/-/_/g') _raw_opt=$(echo "$_opt" | sed -e 's/^--//' -e 's/-/_/g')
eval "opt_$_raw_opt=\$1" eval "opt_$_raw_opt=\$1"
shift || die "$_opt requires argument" shift || die "$_opt requires argument"
@ -159,7 +159,7 @@ filename=${orig_basename%%.[a-zA-Z0-9_]}
suffix=${orig_basename##${filename}} suffix=${orig_basename##${filename}}
# --> ../test_x86_64.h (on x86_64) # --> ../test_x86_64.h (on x86_64)
multilib_file="$destdir/$filename${opt_additional_suffix}_$opt_arch$suffix" multilib_file="$destdir/$filename$opt_field_separator$opt_arch$suffix"
test -f "$original_file" || die "can't find '$original_file'" test -f "$original_file" || die "can't find '$original_file'"

View File

@ -11,7 +11,7 @@
Summary: Multilib packaging helpers Summary: Multilib packaging helpers
Name: multilib-rpm-config Name: multilib-rpm-config
Version: 1 Version: 1
Release: 3%{?dist} Release: 4%{?dist}
License: GPLv2+ License: GPLv2+
URL: https://fedoraproject.org/wiki/PackagingDrafts/MultilibTricks URL: https://fedoraproject.org/wiki/PackagingDrafts/MultilibTricks
@ -56,6 +56,9 @@ install -m 755 -p %{SOURCE0} %{buildroot}/%{ml_fix}
%changelog %changelog
* Mon Jun 13 2016 Pavel Raiskup <praiskup@redhat.com> - 1-4
- use '-' as field separator
* Thu Jun 09 2016 Pavel Raiskup <praiskup@redhat.com> - 1-3 * Thu Jun 09 2016 Pavel Raiskup <praiskup@redhat.com> - 1-3
- package separately from redhat-rpm-config - package separately from redhat-rpm-config