a probably-Solaris-/bin/sh-workable improved algorithm
This commit is contained in:
parent
0eb31f6a82
commit
cca3f93e59
59
Build.sh
59
Build.sh
@ -1,5 +1,5 @@
|
|||||||
#!/bin/sh
|
#!/bin/sh
|
||||||
# $MirOS: src/bin/mksh/Build.sh,v 1.43 2006/08/12 19:38:44 tg Exp $
|
# $MirOS: src/bin/mksh/Build.sh,v 1.44 2006/08/12 19:51:08 tg Exp $
|
||||||
#-
|
#-
|
||||||
# This script recognises CC, CFLAGS, CPPFLAGS, LDFLAGS, LIBS and NROFF.
|
# This script recognises CC, CFLAGS, CPPFLAGS, LDFLAGS, LIBS and NROFF.
|
||||||
|
|
||||||
@ -9,14 +9,14 @@ srcdir="${srcdir:-`dirname "$0"`}"
|
|||||||
curdir="`pwd`"
|
curdir="`pwd`"
|
||||||
|
|
||||||
: ${NROFF:=nroff}
|
: ${NROFF:=nroff}
|
||||||
echo | $NROFF -v 2>&1 | fgrep GNU >&- 2>&- && NROFF="$NROFF -c"
|
echo | $NROFF -v 2>&1 | grep GNU >&- 2>&- && NROFF="$NROFF -c"
|
||||||
|
|
||||||
e=echo
|
e=echo
|
||||||
q=0
|
q=0
|
||||||
r=0
|
r=0
|
||||||
x=0
|
x=0
|
||||||
|
|
||||||
while [ -n "$1" ]; do
|
while test -n "$1"; do
|
||||||
case $1 in
|
case $1 in
|
||||||
-d)
|
-d)
|
||||||
LDSTATIC=
|
LDSTATIC=
|
||||||
@ -45,16 +45,20 @@ v()
|
|||||||
eval "$@"
|
eval "$@"
|
||||||
}
|
}
|
||||||
|
|
||||||
[ $x = 1 ] || LDSTATIC=-static
|
if test $x = 0; then
|
||||||
[ $x = 1 ] || SRCS=
|
LDSTATIC=-static
|
||||||
|
SRCS=
|
||||||
|
sigseen=
|
||||||
|
fi
|
||||||
SRCS="$SRCS alloc.c edit.c eval.c exec.c expr.c funcs.c histrap.c"
|
SRCS="$SRCS alloc.c edit.c eval.c exec.c expr.c funcs.c histrap.c"
|
||||||
SRCS="$SRCS jobs.c lex.c main.c misc.c shf.c syn.c tree.c var.c"
|
SRCS="$SRCS jobs.c lex.c main.c misc.c shf.c syn.c tree.c var.c"
|
||||||
|
|
||||||
[ $x = 1 ] || case "`uname -s 2>/dev/null || uname`" in
|
test $x = 1 || case "`uname -s 2>/dev/null || uname`" in
|
||||||
CYGWIN*)
|
CYGWIN*)
|
||||||
LDSTATIC= # they don't want it
|
LDSTATIC= # they don't want it
|
||||||
SRCS="$SRCS compat.c"
|
SRCS="$SRCS compat.c"
|
||||||
CPPFLAGS="$CPPFLAGS -DNEED_COMPAT"
|
CPPFLAGS="$CPPFLAGS -DNEED_COMPAT"
|
||||||
|
sigseen=:
|
||||||
;;
|
;;
|
||||||
Darwin)
|
Darwin)
|
||||||
LDSTATIC= # never works
|
LDSTATIC= # never works
|
||||||
@ -69,6 +73,7 @@ Linux)
|
|||||||
CPPFLAGS="$CPPFLAGS -D_POSIX_C_SOURCE=2 -D_BSD_SOURCE -D_GNU_SOURCE"
|
CPPFLAGS="$CPPFLAGS -D_POSIX_C_SOURCE=2 -D_BSD_SOURCE -D_GNU_SOURCE"
|
||||||
CPPFLAGS="$CPPFLAGS -D_FILE_OFFSET_BITS=64 -DNEED_COMPAT"
|
CPPFLAGS="$CPPFLAGS -D_FILE_OFFSET_BITS=64 -DNEED_COMPAT"
|
||||||
LDSTATIC= # glibc dlopens the PAM library with getpwnam at runtime
|
LDSTATIC= # glibc dlopens the PAM library with getpwnam at runtime
|
||||||
|
sigseen=:
|
||||||
;;
|
;;
|
||||||
SunOS)
|
SunOS)
|
||||||
SRCS="$SRCS compat.c"
|
SRCS="$SRCS compat.c"
|
||||||
@ -76,22 +81,25 @@ SunOS)
|
|||||||
CPPFLAGS="$CPPFLAGS -D__EXTENSIONS__"
|
CPPFLAGS="$CPPFLAGS -D__EXTENSIONS__"
|
||||||
CPPFLAGS="$CPPFLAGS -D_FILE_OFFSET_BITS=64 -DNEED_COMPAT"
|
CPPFLAGS="$CPPFLAGS -D_FILE_OFFSET_BITS=64 -DNEED_COMPAT"
|
||||||
LDSTATIC= # alternatively you need libdl... same suckage as above
|
LDSTATIC= # alternatively you need libdl... same suckage as above
|
||||||
|
sigseen=:
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
sigseen=:; $e Generating list of signal names
|
if test x"$sigseen" = x:; then
|
||||||
NSIG=`( echo '#include <signal.h>'; echo "__mksh_test: NSIG" ) \
|
$e Generating list of signal names
|
||||||
| $CC $CPPFLAGS -E - | grep __mksh_test: | sed 's/^__mksh_test: //'`
|
NSIG=`( echo '#include <signal.h>'; echo "mksh_test: NSIG" ) | \
|
||||||
NSIG=`printf %d "$NSIG"`
|
$CC $CPPFLAGS -E - | grep mksh_test: | sed 's/^mksh_test: //'`
|
||||||
echo '#include <signal.h>' | $CC $CPPFLAGS -E -dD - \
|
NSIG=`printf %d "$NSIG" 2>&-`
|
||||||
| grep '[ ]SIG[A-Z0-9]*[ ]' \
|
test $NSIG -gt 1 || exit 1
|
||||||
| sed 's/^\(.*[ ]SIG\)\([A-Z0-9]*\)\([ ].*\)$/\2/' \
|
echo '#include <signal.h>' | $CC $CPPFLAGS -E -dD - | \
|
||||||
| while read name; do
|
grep '[ ]SIG[A-Z0-9]*[ ]' | \
|
||||||
( echo '#include <signal.h>'; echo "__mksh_test: SIG$name" ) \
|
sed 's/^\(.*[ ]SIG\)\([A-Z0-9]*\)\([ ].*\)$/\2/' | \
|
||||||
| $CC $CPPFLAGS -E - | grep __mksh_test: | sed \
|
while read name; do
|
||||||
's/^__mksh_test: \([0-9]*\).*$/\1:'$name/
|
( echo '#include <signal.h>'; echo "mksh_test: SIG$name" ) | \
|
||||||
done | grep -v '^:' | while IFS=: read number name; do
|
$CC $CPPFLAGS -E - | grep mksh_test: | \
|
||||||
nr=`printf %d "$number"`
|
sed 's/^mksh_test: \([0-9]*\).*$/\1:'$name/
|
||||||
|
done | grep -v '^:' | while IFS=: read nr name; do
|
||||||
|
nr=`printf %d "$nr" 2>&-`
|
||||||
test $nr -gt 0 -a $nr -lt $NSIG || continue
|
test $nr -gt 0 -a $nr -lt $NSIG || continue
|
||||||
case $sigseen in
|
case $sigseen in
|
||||||
*:$nr:*) ;;
|
*:$nr:*) ;;
|
||||||
@ -99,14 +107,15 @@ done | grep -v '^:' | while IFS=: read number name; do
|
|||||||
sigseen=$sigseen$nr:
|
sigseen=$sigseen$nr:
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
done >signames.inc
|
done >signames.inc
|
||||||
test -s signames.inc || exit 1
|
test -s signames.inc || exit 1
|
||||||
|
fi
|
||||||
(v "cd '$srcdir' && exec $CC $CFLAGS -I'$curdir' $CPPFLAGS" \
|
(v "cd '$srcdir' && exec $CC $CFLAGS -I'$curdir' $CPPFLAGS" \
|
||||||
"$LDFLAGS $LDSTATIC -o '$curdir/mksh' $SRCS $LIBS") || exit 1
|
"$LDFLAGS $LDSTATIC -o '$curdir/mksh' $SRCS $LIBS") || exit 1
|
||||||
test -x mksh || exit 1
|
test -x mksh || exit 1
|
||||||
[ $r = 1 ] || v "$NROFF -mdoc <'$srcdir/mksh.1' >mksh.cat1" \
|
test $r = 1 || v "$NROFF -mdoc <'$srcdir/mksh.1' >mksh.cat1" || \
|
||||||
|| rm -f mksh.cat1
|
rm -f mksh.cat1
|
||||||
[ $q = 1 ] || v size mksh
|
test $q = 1 || v size mksh
|
||||||
echo "#!$curdir/mksh" >Test.sh
|
echo "#!$curdir/mksh" >Test.sh
|
||||||
echo "exec perl '$srcdir/check.pl' -s '$srcdir/check.t'" \
|
echo "exec perl '$srcdir/check.pl' -s '$srcdir/check.t'" \
|
||||||
"-p '$curdir/mksh' -C pdksh \$*" >>Test.sh
|
"-p '$curdir/mksh' -C pdksh \$*" >>Test.sh
|
||||||
@ -116,7 +125,7 @@ $e To test mksh, execute ./Test.sh
|
|||||||
$e
|
$e
|
||||||
$e Installing the shell:
|
$e Installing the shell:
|
||||||
$e "# install -c -s -o root -g bin -m 555 mksh /bin/mksh"
|
$e "# install -c -s -o root -g bin -m 555 mksh /bin/mksh"
|
||||||
$e "# fgrep -qx /bin/mksh /etc/shells || echo /bin/mksh >>/etc/shells"
|
$e "# grep -qx /bin/mksh /etc/shells || echo /bin/mksh >>/etc/shells"
|
||||||
$e "# install -c -o root -g bin -m 444 dot.mkshrc /usr/share/doc/mksh/examples/"
|
$e "# install -c -o root -g bin -m 444 dot.mkshrc /usr/share/doc/mksh/examples/"
|
||||||
$e
|
$e
|
||||||
$e Installing the manual:
|
$e Installing the manual:
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
|
|
||||||
#include "sh.h"
|
#include "sh.h"
|
||||||
|
|
||||||
__RCSID("$MirOS: src/bin/mksh/histrap.c,v 1.19 2006/08/01 14:09:19 tg Exp $");
|
__RCSID("$MirOS: src/bin/mksh/histrap.c,v 1.20 2006/08/12 19:51:09 tg Exp $");
|
||||||
|
|
||||||
static int histfd;
|
static int histfd;
|
||||||
static int hsize;
|
static int hsize;
|
||||||
@ -37,7 +37,7 @@ static Source *hist_source;
|
|||||||
#define mksh_signame(x) _sys_signame[(x)]
|
#define mksh_signame(x) _sys_signame[(x)]
|
||||||
#define mksh_siglist(x) _sys_siglist[(x)]
|
#define mksh_siglist(x) _sys_siglist[(x)]
|
||||||
#elif defined(__gnu_linux__) || defined(__sun__) || defined(__CYGWIN__)
|
#elif defined(__gnu_linux__) || defined(__sun__) || defined(__CYGWIN__)
|
||||||
#define NEED_MKSH_SIGNAME
|
#define NEED_MKSH_SIGNAME /* sync the list above with Build.sh */
|
||||||
#define mksh_siglist(x) strsignal(x)
|
#define mksh_siglist(x) strsignal(x)
|
||||||
#else
|
#else
|
||||||
# error "Define sys_sig{name,list} for this platform!"
|
# error "Define sys_sig{name,list} for this platform!"
|
||||||
|
Loading…
x
Reference in New Issue
Block a user