X-Git-Url: https://git.distorted.org.uk/~mdw/termux-packages/blobdiff_plain/71430aa64e5287398bc8e3bd563eb9b7ecb9c493..a247ffe2c8389c377c75e6c4e1882f57ac660b02:/packages/picolisp/build.sh diff --git a/packages/picolisp/build.sh b/packages/picolisp/build.sh index ce834241..e315385b 100644 --- a/packages/picolisp/build.sh +++ b/packages/picolisp/build.sh @@ -1,13 +1,13 @@ TERMUX_PKG_HOMEPAGE=http://picolisp.com TERMUX_PKG_DESCRIPTION="Lisp interpreter and application server framework" TERMUX_PKG_DEPENDS="libcrypt, openssl" -_PICOLISP_YEAR=16 -_PICOLISP_MONTH=12 -_PICOLISP_DAY=22 +_PICOLISP_YEAR=17 +_PICOLISP_MONTH=3 +_PICOLISP_DAY=25 TERMUX_PKG_VERSION=${_PICOLISP_YEAR}.${_PICOLISP_MONTH}.${_PICOLISP_DAY} # We use our bintray mirror since old version snapshots are not kept on main site. TERMUX_PKG_SRCURL=https://dl.bintray.com/termux/upstream/picolisp_${TERMUX_PKG_VERSION}.tar.gz -TERMUX_PKG_SHA256=af64df40f87a0dfbdb1f61e1b319d96a07feed123175fc0d17a849f03c36b26a +TERMUX_PKG_SHA256=9eed147693ad07c7dfb945c271e2a1d1afe36a613a6e5555298bc1ac947651e8 TERMUX_PKG_FOLDERNAME=picoLisp TERMUX_PKG_BUILD_IN_SRC=true # The assembly is not position-independent (would be a major rewrite): @@ -15,14 +15,20 @@ TERMUX_PKG_BLACKLISTED_ARCHES="x86_64" if [ $TERMUX_ARCH_BITS = 32 ]; then # "Variable length array in structure won't be supported" TERMUX_PKG_CLANG=no +else + # FIXME: Use gcc for linking, as a clang build causes (tzo), + # the time zone offset, to return 0: + # Also, this call (and probably more) hangs: + # (call "termux-notification" "--title" "Title" "--content" "Message") + # These two problems only happen when using the gold linker, which + # Termux does by default). + TERMUX_PKG_CLANG=no fi termux_step_pre_configure() { # Validate that we have the right version: grep -q "Version $_PICOLISP_YEAR $_PICOLISP_MONTH $_PICOLISP_DAY" src64/version.l || { - echo "ERROR: Picolisp version needs to be bumped" 1>&2 - grep Version src64/version.l 1>&2 - exit 1 + termux_error_exit "Picolisp version needs to be bumped" } if [ $TERMUX_ARCH_BITS = 64 ]; then @@ -47,10 +53,15 @@ termux_step_make_install () { cd $TERMUX_PKG_SRCDIR/ if [ $TERMUX_ARCH_BITS = "64" ]; then - $CC -fno-integrated-as -pie -o ../bin/picolisp -rdynamic ${TERMUX_PKG_EXTRA_MAKE_ARGS}.base.s -lc -lm -ldl + $TERMUX_HOST_PLATFORM-as -o ${TERMUX_PKG_EXTRA_MAKE_ARGS}.base.o ${TERMUX_PKG_EXTRA_MAKE_ARGS}.base.s + $TERMUX_HOST_PLATFORM-as -o ${TERMUX_PKG_EXTRA_MAKE_ARGS}.ext.o ${TERMUX_PKG_EXTRA_MAKE_ARGS}.ext.s + $TERMUX_HOST_PLATFORM-as -o ${TERMUX_PKG_EXTRA_MAKE_ARGS}.ht.o ${TERMUX_PKG_EXTRA_MAKE_ARGS}.ht.s + + $CC -o ../bin/picolisp ${TERMUX_PKG_EXTRA_MAKE_ARGS}.base.o \ + -Wl,--no-as-needed -rdynamic -lc -lm -ldl -pie chmod +x ../bin/picolisp - $CC -fno-integrated-as -pie -o ../lib/ext -shared -export-dynamic ${TERMUX_PKG_EXTRA_MAKE_ARGS}.ext.s - $CC -fno-integrated-as -pie -o ../lib/ht -shared -export-dynamic ${TERMUX_PKG_EXTRA_MAKE_ARGS}.ht.s + $CC -o ../lib/ext -shared -rdynamic ${TERMUX_PKG_EXTRA_MAKE_ARGS}.ext.o + $CC -o ../lib/ht -shared -rdynamic ${TERMUX_PKG_EXTRA_MAKE_ARGS}.ht.o fi mkdir -p $TERMUX_PREFIX/share/man/man1