aboutsummaryrefslogtreecommitdiff
path: root/system/csh
diff options
context:
space:
mode:
Diffstat (limited to 'system/csh')
-rw-r--r--system/csh/README9
-rw-r--r--system/csh/csh.SlackBuild40
-rw-r--r--system/csh/csh.info8
-rw-r--r--system/csh/glibc-2.32-sys_siglist.diff38
4 files changed, 70 insertions, 25 deletions
diff --git a/system/csh/README b/system/csh/README
index 12230bebd9a21..525cb405ec18e 100644
--- a/system/csh/README
+++ b/system/csh/README
@@ -1,9 +1,10 @@
csh (C shell from BSD)
-The C shell was originally written at UCB to overcome limitations in the
-Bourne shell. Its flexibility and comfort (at that time) quickly made
-it the shell of choice until more advanced shells like ksh, bash, zsh
-or tcsh appeared. Most of the latter incorporate features original to csh.
+The C shell was originally written at UCB to overcome limitations in
+the Bourne shell. Its flexibility and comfort (at that time) quickly
+made it the shell of choice until more advanced shells like ksh, bash,
+zsh or tcsh appeared. Most of the latter incorporate features original
+to csh.
This build is based on OpenBSD sources from 2011.
diff --git a/system/csh/csh.SlackBuild b/system/csh/csh.SlackBuild
index cf3255cabd978..d18ab6e437b8e 100644
--- a/system/csh/csh.SlackBuild
+++ b/system/csh/csh.SlackBuild
@@ -6,6 +6,10 @@
# Licensed under the WTFPL. See http://www.wtfpl.net/txt/copying/ for details.
+# 20210827 bkw:
+# - update to latest debian patch (6), add deb version to VERSION.
+# - add -current fix for recent glibc.
+
# 20170621 bkw:
# - update to latest debian patch (-2.2, needed for -current).
# - quit compiling with -Werror (also needed for -current).
@@ -14,8 +18,8 @@
cd $(dirname $0) ; CWD=$(pwd)
PRGNAM=csh
-VERSION=${VERSION:-20110502}
-BUILD=${BUILD:-2}
+VERSION=${VERSION:-20110502_6}
+BUILD=${BUILD:-1}
TAG=${TAG:-_SBo}
PKGTYPE=${PKGTYPE:-tgz}
@@ -27,9 +31,6 @@ if [ -z "$ARCH" ]; then
esac
fi
-# If the variable PRINT_PACKAGE_NAME is set, then this script will report what
-# the name of the created package would be, and then exit. This information
-# could be useful to other scripts.
if [ ! -z "${PRINT_PACKAGE_NAME}" ]; then
echo "$PRGNAM-$VERSION-$ARCH-$BUILD$TAG.$PKGTYPE"
exit 0
@@ -55,11 +56,12 @@ fi
set -e
-DEBVER=2.2
+MAINVER="${VERSION%_*}" # 123_4 => 123
+DEBVER="${VERSION#*_}" # 123_4 => 4
# Grr.
-TARNAM="${PRGNAM}_${VERSION}.orig"
-DIRNAM="${PRGNAM}-${VERSION}.orig"
+TARNAM="${PRGNAM}_${MAINVER}.orig"
+DIRNAM="${PRGNAM}-${MAINVER}.orig"
rm -rf $PKG
mkdir -p $TMP $PKG $OUTPUT
@@ -67,17 +69,14 @@ cd $TMP
rm -rf $DIRNAM
tar xvf $CWD/$TARNAM.tar.gz
cd $DIRNAM
-tar xvf $CWD/${PRGNAM}_${VERSION}-$DEBVER.debian.tar.[xg]z
+tar xvf $CWD/${PRGNAM}_${MAINVER}-$DEBVER.debian.tar.[xg]z
chown -R root:root .
-find -L . \
- \( -perm 777 -o -perm 775 -o -perm 750 -o -perm 711 -o -perm 555 \
- -o -perm 511 \) -exec chmod 755 {} \; -o \
- \( -perm 666 -o -perm 664 -o -perm 640 -o -perm 600 -o -perm 444 \
- -o -perm 440 -o -perm 400 \) -exec chmod 644 {} \;
+find -L . -perm /111 -a \! -perm 755 -a -exec chmod 755 {} \+ -o \
+ \! -perm /111 -a \! -perm 644 -a -exec chmod 644 {} \+
-# Apply all of Debian's patches.
+# Apply all of Debian's patches. Except one...
for diff in debian/patches/*.diff; do
- patch -p1 < $diff
+ [ "$( basename $diff )" != "09_sys_signame.diff" ] && patch -p1 < $diff
done
# My own patch, keeps csh.h from defining its own (tiny) BUFSIZ. Might
@@ -85,8 +84,15 @@ done
# to set a giant $LS_OPTIONS value without "Word too long" error.
patch -p1 < $CWD/bufsiz.diff
+# 20210827 bkw: my own patch, glibc >= 2.32 no longer exports
+# sys_siglist so we have to use sigdescr_np() instead. Ditto
+# sys_signame and sigabbrev_np(). See glibc changelog:
+# https://sourceware.org/pipermail/libc-announce/2020/000029.html
+# This patch replaces Debian's 09_sys_signame.diff.
+patch -p1 < $CWD/glibc-2.32-sys_siglist.diff
+
# use Slackware standard flags
-sed -i "1iCFLAGS=$SLKCFLAGS" Makefile
+sed -i "1iCFLAGS=$SLKCFLAGS -fcommon" Makefile
# The LIBC= isn't even used, but Slackware64's pmake is broken: it has
# /usr/lib/libc.a hard-coded, and pmake wants to build that (and can't),
diff --git a/system/csh/csh.info b/system/csh/csh.info
index a8ac38100af5b..527b6dbe26226 100644
--- a/system/csh/csh.info
+++ b/system/csh/csh.info
@@ -1,10 +1,10 @@
PRGNAM="csh"
-VERSION="20110502"
+VERSION="20110502_6"
HOMEPAGE="https://packages.debian.org/sid/csh"
-DOWNLOAD="http://ftp.debian.org/debian/pool/main/c/csh/csh_20110502.orig.tar.gz \
- http://http.debian.net/debian/pool/main/c/csh/csh_20110502-2.2.debian.tar.xz"
+DOWNLOAD="https://deb.debian.org/debian/pool/main/c/csh/csh_20110502.orig.tar.gz \
+ https://deb.debian.org/debian/pool/main/c/csh/csh_20110502-6.debian.tar.xz"
MD5SUM="578c40bfa54c09c8affbc434e34fb40c \
- a66e38ff89e978970a4ade6eb419a69a"
+ 22bdcfe61cbbc4f8b8fd69176beadfe7"
DOWNLOAD_x86_64=""
MD5SUM_x86_64=""
REQUIRES="%README% libbsd"
diff --git a/system/csh/glibc-2.32-sys_siglist.diff b/system/csh/glibc-2.32-sys_siglist.diff
new file mode 100644
index 0000000000000..4830e62ae7440
--- /dev/null
+++ b/system/csh/glibc-2.32-sys_siglist.diff
@@ -0,0 +1,38 @@
+diff -Naur csh-20110502.orig/proc.c csh-20110502.orig.patched/proc.c
+--- csh-20110502.orig/proc.c 2009-10-27 19:59:21.000000000 -0400
++++ csh-20110502.orig.patched/proc.c 2021-08-27 02:56:08.386981036 -0400
+@@ -726,8 +726,7 @@
+ && (reason != SIGPIPE
+ || (pp->p_flags & PPOU) == 0))) {
+ (void) fprintf(cshout, format,
+- sys_siglist[(unsigned char)
+- pp->p_reason]);
++ sigdescr_np(pp->p_reason));
+ hadnl = 0;
+ }
+ break;
+@@ -948,10 +947,10 @@
+ else if (signum == 0)
+ (void) fputc('0', cshout); /* 0's symbolic name is '0' */
+ else
+- (void) fprintf(cshout, "%s ", sys_signame[signum]);
++ (void) fprintf(cshout, "%s ", sigabbrev_np(signum));
+ } else {
+ for (signum = 1; signum < NSIG; signum++) {
+- (void) fprintf(cshout, "%s ", sys_signame[signum]);
++ (void) fprintf(cshout, "%s ", sigabbrev_np(signum));
+ if (signum == NSIG / 2)
+ (void) fputc('\n', cshout);
+ }
+@@ -978,9 +977,9 @@
+ }
+
+ for (signum = 1; signum < NSIG; signum++)
+- if (!strcasecmp(sys_signame[signum], name) ||
++ if (!strcasecmp(sigabbrev_np(signum), name) ||
+ (strlen(name) > 3 && !strncasecmp("SIG", name, 3) &&
+- !strcasecmp(sys_signame[signum], name + 3)))
++ !strcasecmp(sigabbrev_np(signum), name + 3)))
+ break;
+
+ if (signum == NSIG) {