X-Git-Url: https://git.distorted.org.uk/~mdw/termux-packages/blobdiff_plain/3a6638274a0817edbfa28b25a8e6c428bc6d6d19..d323204924832391c5ff2b90fcadda45ad2972e4:/packages/ruby/build.sh diff --git a/packages/ruby/build.sh b/packages/ruby/build.sh index 287bf5f4..f85f9797 100644 --- a/packages/ruby/build.sh +++ b/packages/ruby/build.sh @@ -1,21 +1,28 @@ TERMUX_PKG_HOMEPAGE=https://www.ruby-lang.org/ TERMUX_PKG_DESCRIPTION="Dynamic programming language with a focus on simplicity and productivity" -_MAJOR_VERSION=2.2 +_MAJOR_VERSION=2.4 TERMUX_PKG_VERSION=${_MAJOR_VERSION}.3 -TERMUX_PKG_BUILD_REVISION=4 -TERMUX_PKG_SRCURL=http://cache.ruby-lang.org/pub/ruby/${_MAJOR_VERSION}/ruby-${TERMUX_PKG_VERSION}.tar.xz +TERMUX_PKG_SHA256=23677d40bf3b7621ba64593c978df40b1e026d8653c74a0599f0ead78ed92b51 +TERMUX_PKG_SRCURL=https://cache.ruby-lang.org/pub/ruby/${_MAJOR_VERSION}/ruby-${TERMUX_PKG_VERSION}.tar.xz # libbffi is used by the fiddle extension module: -TERMUX_PKG_DEPENDS="libffi, libgmp, readline, openssl" -TERMUX_PKG_KEEP_HEADER_FILES="true" +TERMUX_PKG_DEPENDS="libandroid-support, libffi, libgmp, readline, openssl, libutil, libyaml" # Needed to fix compilation on android: TERMUX_PKG_EXTRA_CONFIGURE_ARGS="ac_cv_func_setgroups=no ac_cv_func_setresuid=no ac_cv_func_setreuid=no --enable-rubygems" +# The gdbm module seems to be very little used: +TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" --without-gdbm" +# Do not link in libcrypt.so if available (now in disabled-packages): +TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" ac_cv_lib_crypt_crypt=no" +# Fix DEPRECATED_TYPE macro clang compatibility: +TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" rb_cv_type_deprecated=x" +# getresuid(2) does not work on ChromeOS - https://github.com/termux/termux-app/issues/147: +# TERMUX_PKG_EXTRA_CONFIGURE_ARGS+=" ac_cv_func_getresuid=no" -# Ruby does not use this directly, but specify for gem building C++-using extensions: -CXXFLAGS+=" -frtti -fexceptions" # -lgnustl_shared" - -termux_step_pre_configure () { - export GEM_HOME=$TERMUX_PREFIX/var/lib/gems - mkdir -p $GEM_HOME +termux_step_pre_configure() { + # This exception is to avoid a broken ruby on 32-bit arm + # with NDK r15c and ruby 2.4.2 - see #1520. + if [ "$TERMUX_ARCH" = arm ]; then + CFLAGS=${CFLAGS/Oz/O1} + fi } termux_step_make_install () { @@ -23,19 +30,19 @@ termux_step_make_install () { make uninstall # remove possible remains to get fresh timestamps make install - # rbconfig.rb, used to build native gems, thinks that ${TERMUX_HOST_PLATFORM}-$TOOLNAME should - # be used, but we want the unprefixed $TOOLNAME: - local RBCONFIG=$TERMUX_PREFIX/lib/ruby/${_MAJOR_VERSION}.0/${TERMUX_HOST_PLATFORM}/rbconfig.rb - for tool in gcc "g\+\+" strip nm objdump ar ranlib ld cpp; do - perl -p -i -e "s/${TERMUX_HOST_PLATFORM}-$tool/$tool/g" $RBCONFIG - done + local RBCONFIG=$TERMUX_PREFIX/lib/ruby/${_MAJOR_VERSION}.0/${TERMUX_HOST_PLATFORM}/rbconfig.rb # Fix absolute paths to executables: - perl -p -i -e 's@"/bin/mkdir@"mkdir@' $RBCONFIG - perl -p -i -e "s@/usr/bin/install@install@" $RBCONFIG + perl -p -i -e 's/^.*CONFIG\["INSTALL"\].*$/ CONFIG["INSTALL"] = "install -c"/' $RBCONFIG + perl -p -i -e 's/^.*CONFIG\["PKG_CONFIG"\].*$/ CONFIG["PKG_CONFIG"] = "pkg-config"/' $RBCONFIG + perl -p -i -e 's/^.*CONFIG\["MAKEDIRS"\].*$/ CONFIG["MAKEDIRS"] = "mkdir -p"/' $RBCONFIG + perl -p -i -e 's/^.*CONFIG\["MKDIR_P"\].*$/ CONFIG["MKDIR_P"] = "mkdir -p"/' $RBCONFIG + perl -p -i -e 's/^.*CONFIG\["EGREP"\].*$/ CONFIG["EGREP"] = "grep -E"/' $RBCONFIG + perl -p -i -e 's/^.*CONFIG\["GREP"\].*$/ CONFIG["GREP"] = "grep"/' $RBCONFIG +} - # Make C++-using gems link against libgnustl_shared instead of the limited system libstdc++: - perl -p -i -e 's/\(CXX\) -shared/\(CXX\) -shared -lgnustl_shared/' $RBCONFIG - # Fix mention of $_SPECSFLAG in rbconfig: - perl -p -i -e "s|${_SPECSFLAG}||g" $RBCONFIG +termux_step_post_massage () { + if [ ! -f $TERMUX_PREFIX/lib/ruby/${_MAJOR_VERSION}.0/${TERMUX_HOST_PLATFORM}/readline.so ]; then + echo "Error: The readline extension was not built" + fi }