5 # Utility function to log an error message and exit with an error code.
11 # Utility function to download a resource, optionally checking against a checksum.
14 local DESTINATION
="$2"
16 if [ -f
"$DESTINATION" ] && [ $# = 3 ] && [ -n
"$3" ]; then
17 # Keep existing file if checksum matches.
18 local EXISTING_CHECKSUM
19 EXISTING_CHECKSUM
=$
(sha256sum
"$DESTINATION" | cut
-f
1 -d
' ')
20 if [ "$EXISTING_CHECKSUM" = "$3" ]; then return; fi
24 TMPFILE
=$
(mktemp
"$TERMUX_PKG_TMPDIR/download.$TERMUX_PKG_NAME.XXXXXXXXX")
25 echo "Downloading ${URL}"
27 for try
in $
(seq 1 $TRYMAX); do
28 if curl
-L
--fail
--retry
2 -o
"$TMPFILE" "$URL"; then
30 ACTUAL_CHECKSUM
=$
(sha256sum
"$TMPFILE" | cut
-f
1 -d
' ')
31 if [ $# = 3 ] && [ -n
"$3" ]; then
32 # Optional checksum argument:
34 if [ "$EXPECTED" != "$ACTUAL_CHECKSUM" ]; then
35 >&2 printf "Wrong checksum for %s:\nExpected: %s\nActual: %s\n" \
36 "$URL" "$EXPECTED" "$ACTUAL_CHECKSUM"
40 printf "No validation of checksum for %s:\nActual: %s\n" \
41 "$URL" "$ACTUAL_CHECKSUM"
43 mv "$TMPFILE" "$DESTINATION"
46 echo "Download of $URL failed (attempt $try/$TRYMAX)" 1>&2
51 termux_error_exit
"Failed to download $URL"
54 # Utility function for golang-using packages to setup a go toolchain.
55 termux_setup_golang
() {
58 export GO_LDFLAGS
="-extldflags=-pie"
59 if [ "$TERMUX_ARCH" = "arm" ]; then
62 elif [ "$TERMUX_ARCH" = "i686" ]; then
65 elif [ "$TERMUX_ARCH" = "aarch64" ]; then
67 elif [ "$TERMUX_ARCH" = "x86_64" ]; then
70 termux_error_exit
"Unsupported arch: $TERMUX_ARCH"
73 local TERMUX_GO_VERSION
=go1.8
.1
74 local TERMUX_GO_PLATFORM
=linux-amd64
76 local TERMUX_BUILDGO_FOLDER
=$TERMUX_COMMON_CACHEDIR/${TERMUX_GO_VERSION}
77 export GOROOT
=$TERMUX_BUILDGO_FOLDER
78 export PATH
=$GOROOT/bin
:$PATH
80 if [ -d
"$TERMUX_BUILDGO_FOLDER" ]; then return; fi
82 local TERMUX_BUILDGO_TAR
=$TERMUX_COMMON_CACHEDIR/${TERMUX_GO_VERSION}.
${TERMUX_GO_PLATFORM}.
tar.gz
83 rm -Rf
"$TERMUX_COMMON_CACHEDIR/go" "$TERMUX_BUILDGO_FOLDER"
84 termux_download https
://storage.googleapis.com
/golang
/${TERMUX_GO_VERSION}.
${TERMUX_GO_PLATFORM}.
tar.gz \
85 "$TERMUX_BUILDGO_TAR" \
86 a579ab19d5237e263254f1eac5352efcf1d70b9dacadb6d6bb12b0911ede8994
88 ( cd "$TERMUX_COMMON_CACHEDIR"; tar xf
"$TERMUX_BUILDGO_TAR"; mv go
"$TERMUX_BUILDGO_FOLDER"; rm "$TERMUX_BUILDGO_TAR" )
91 # Utility function for cmake-built packages to setup a current cmake.
92 termux_setup_cmake
() {
93 local TERMUX_CMAKE_MAJORVESION
=3.8
94 local TERMUX_CMAKE_MINORVERSION
=0
95 local TERMUX_CMAKE_VERSION
=$TERMUX_CMAKE_MAJORVESION.
$TERMUX_CMAKE_MINORVERSION
96 local TERMUX_CMAKE_TARNAME
=cmake-
${TERMUX_CMAKE_VERSION}-Linux-x86_64.
tar.gz
97 local TERMUX_CMAKE_TARFILE
=$TERMUX_PKG_TMPDIR/$TERMUX_CMAKE_TARNAME
98 local TERMUX_CMAKE_FOLDER
=$TERMUX_COMMON_CACHEDIR/cmake-
$TERMUX_CMAKE_VERSION
99 if [ ! -d
"$TERMUX_CMAKE_FOLDER" ]; then
100 termux_download https
://cmake.org
/files
/v
$TERMUX_CMAKE_MAJORVESION/$TERMUX_CMAKE_TARNAME \
101 "$TERMUX_CMAKE_TARFILE" \
102 330357990d84599f9c1a87f568a724f0fe5de1687c32961dda689d52588a5b24
103 rm -Rf
"$TERMUX_PKG_TMPDIR/cmake-${TERMUX_CMAKE_VERSION}-Linux-x86_64"
104 tar xf
"$TERMUX_CMAKE_TARFILE" -C
"$TERMUX_PKG_TMPDIR"
105 mv "$TERMUX_PKG_TMPDIR/cmake-${TERMUX_CMAKE_VERSION}-Linux-x86_64" \
106 "$TERMUX_CMAKE_FOLDER"
108 export PATH
=$TERMUX_CMAKE_FOLDER/bin
:$PATH
109 export CMAKE_INSTALL_ALWAYS
=1
112 # First step is to handle command-line arguments. Not to be overridden by packages.
113 termux_step_handle_arguments
() {
114 # shellcheck source=/dev/null
115 test -f
"$HOME/.termuxrc" && source "$HOME/.termuxrc"
117 # Handle command-line arguments:
119 echo "Usage: ./build-package.sh [-a ARCH] [-d] [-D] PACKAGE"
120 echo "Build a package by creating a .deb file in the debs/ folder."
121 echo " -a The architecture to build for: aarch64(default), arm, i686, x86_64 or all."
122 echo " -d Build with debug symbols."
123 echo " -D Build a disabled package in disabled-packages/."
124 echo " -f Force build even if package has already been built."
125 echo " -s Skip dependency check."
128 while getopts :a
:hdDfs option
; do
130 a
) TERMUX_ARCH
="$OPTARG";;
132 d
) TERMUX_DEBUG
=true
;;
133 D
) local TERMUX_IS_DISABLED
=true
;;
134 f
) TERMUX_FORCE_BUILD
=true
;;
135 s
) export TERMUX_SKIP_DEPCHECK
=true
;;
136 ?
) termux_error_exit
"./build-package.sh: illegal option -$OPTARG";;
141 if [ "$#" -ne
1 ]; then _show_usage
; fi
145 if [ -n
"${TERMUX_ARCH+x}" ] && [ "${TERMUX_ARCH}" = 'all' ]; then
146 for arch
in 'aarch64' 'arm' 'i686' 'x86_64'; do
147 .
/build-package.sh
${TERMUX_FORCE_BUILD+-f} -a
$arch "$1"
152 # Check the package to build:
153 TERMUX_PKG_NAME
=$
(basename "$1")
154 export TERMUX_SCRIPTDIR
155 TERMUX_SCRIPTDIR
=$
(cd "$(dirname "$0")"; pwd)
156 if [[ $1 == *"/"* ]]; then
157 # Path to directory which may be outside this repo:
158 if [ ! -d
"$1" ]; then termux_error_exit
"'$1' seems to be a path but is not a directory"; fi
159 export TERMUX_PKG_BUILDER_DIR
160 TERMUX_PKG_BUILDER_DIR
=$
(realpath
"$1")
161 # Skip depcheck for external package:
162 TERMUX_SKIP_DEPCHECK
=true
165 if [ -n
"${TERMUX_IS_DISABLED=""}" ]; then
166 export TERMUX_PKG_BUILDER_DIR
=$TERMUX_SCRIPTDIR/disabled-packages
/$TERMUX_PKG_NAME
168 export TERMUX_PKG_BUILDER_DIR
=$TERMUX_SCRIPTDIR/packages
/$TERMUX_PKG_NAME
171 TERMUX_PKG_BUILDER_SCRIPT
=$TERMUX_PKG_BUILDER_DIR/build.sh
172 if test ! -f
"$TERMUX_PKG_BUILDER_SCRIPT"; then
173 termux_error_exit
"No build.sh script at package dir $TERMUX_PKG_BUILDER_DIR!"
177 # Setup variables used by the build. Not to be overridden by packages.
178 termux_step_setup_variables
() {
179 : "${ANDROID_HOME:="${HOME}/lib/android-sdk"}"
180 : "${NDK:="${HOME}/lib
/android-ndk
"}"
181 : "${TERMUX_MAKE_PROCESSES:="4"}"
182 : "${TERMUX_TOPDIR:="$HOME/.termux-build"}"
183 : "${TERMUX_ARCH:="aarch64"}" # arm, aarch64, i686 or x86_64.
184 : "${TERMUX_PREFIX:="/data/data/com.termux/files/usr"}"
185 : "${TERMUX_ANDROID_HOME:="/data/data/com.termux/files/home"}"
186 : "${TERMUX_DEBUG:=""}"
187 : "${TERMUX_API_LEVEL:="21"}"
188 : "${TERMUX_ANDROID_BUILD_TOOLS_VERSION:="25.0.1"}"
189 : "${TERMUX_NDK_VERSION:="14"}"
191 if [ "x86_64" = "$TERMUX_ARCH" ] ||
[ "aarch64" = "$TERMUX_ARCH" ]; then
197 TERMUX_HOST_PLATFORM
="${TERMUX_ARCH}-linux-android"
198 if [ "$TERMUX_ARCH" = "arm" ]; then TERMUX_HOST_PLATFORM
="${TERMUX_HOST_PLATFORM}eabi"; fi
200 if [ ! -d
"$NDK" ]; then
201 termux_error_exit
'NDK not pointing at a directory!'
203 if ! grep -s
-q
"Pkg.Revision = $TERMUX_NDK_VERSION" "$NDK/source.properties"; then
204 termux_error_exit
"Wrong NDK version - we need $TERMUX_NDK_VERSION"
207 # The build tuple that may be given to --build configure flag:
208 TERMUX_BUILD_TUPLE
=$
(sh
"$TERMUX_SCRIPTDIR/scripts/config.guess")
210 # We do not put all of build-tools/$TERMUX_ANDROID_BUILD_TOOLS_VERSION/ into PATH
211 # to avoid stuff like arm-linux-androideabi-ld there to conflict with ones from
212 # the standalone toolchain.
213 TERMUX_DX
=$ANDROID_HOME/build-tools
/$TERMUX_ANDROID_BUILD_TOOLS_VERSION/dx
214 TERMUX_JACK
=$ANDROID_HOME/build-tools
/$TERMUX_ANDROID_BUILD_TOOLS_VERSION/jack.jar
215 TERMUX_JILL
=$ANDROID_HOME/build-tools
/$TERMUX_ANDROID_BUILD_TOOLS_VERSION/jill.jar
217 TERMUX_COMMON_CACHEDIR
="$TERMUX_TOPDIR/_cache"
218 TERMUX_DEBDIR
="$TERMUX_SCRIPTDIR/debs"
219 TERMUX_ELF_CLEANER
=$TERMUX_COMMON_CACHEDIR/termux-elf-cleaner
221 TERMUX_STANDALONE_TOOLCHAIN
="$TERMUX_TOPDIR/_lib/toolchain-${TERMUX_ARCH}-ndk${TERMUX_NDK_VERSION}-api${TERMUX_API_LEVEL}"
222 # Bump the below version if a change is made in toolchain setup to ensure
223 # that everyone gets an updated toolchain:
224 TERMUX_STANDALONE_TOOLCHAIN
+="-v17"
226 export TERMUX_TAR
="tar"
227 export TERMUX_TOUCH
="touch"
228 export prefix
=${TERMUX_PREFIX}
229 export PREFIX
=${TERMUX_PREFIX}
230 export PKG_CONFIG_LIBDIR
=$TERMUX_PREFIX/lib
/pkgconfig
232 TERMUX_PKG_BUILDDIR
=$TERMUX_TOPDIR/$TERMUX_PKG_NAME/build
233 TERMUX_PKG_CACHEDIR
=$TERMUX_TOPDIR/$TERMUX_PKG_NAME/cache
234 TERMUX_PKG_MASSAGEDIR
=$TERMUX_TOPDIR/$TERMUX_PKG_NAME/massage
235 TERMUX_PKG_PACKAGEDIR
=$TERMUX_TOPDIR/$TERMUX_PKG_NAME/package
236 TERMUX_PKG_SRCDIR
=$TERMUX_TOPDIR/$TERMUX_PKG_NAME/src
238 TERMUX_PKG_TMPDIR
=$TERMUX_TOPDIR/$TERMUX_PKG_NAME/tmp
239 TERMUX_PKG_HOSTBUILD_DIR
=$TERMUX_TOPDIR/$TERMUX_PKG_NAME/host-build
240 TERMUX_PKG_PLATFORM_INDEPENDENT
=""
241 TERMUX_PKG_NO_DEVELSPLIT
=""
242 TERMUX_PKG_REVISION
="0" # http://www.debian.org/doc/debian-policy/ch-controlfields.html#s-f-Version
243 TERMUX_PKG_EXTRA_CONFIGURE_ARGS
=""
244 TERMUX_PKG_EXTRA_HOSTBUILD_CONFIGURE_ARGS
=""
245 TERMUX_PKG_EXTRA_MAKE_ARGS
=""
246 TERMUX_PKG_BUILD_IN_SRC
=""
247 TERMUX_PKG_RM_AFTER_INSTALL
=""
248 TERMUX_PKG_DEPENDS
=""
249 TERMUX_PKG_HOMEPAGE
=""
250 TERMUX_PKG_DESCRIPTION
="FIXME:Add description"
251 TERMUX_PKG_FOLDERNAME
=""
252 TERMUX_PKG_KEEP_STATIC_LIBRARIES
="false"
253 TERMUX_PKG_ESSENTIAL
=""
254 TERMUX_PKG_CONFLICTS
="" # https://www.debian.org/doc/debian-policy/ch-relationships.html#s-conflicts
255 TERMUX_PKG_REPLACES
=""
256 TERMUX_PKG_CONFFILES
=""
257 TERMUX_PKG_INCLUDE_IN_DEVPACKAGE
=""
258 TERMUX_PKG_DEVPACKAGE_DEPENDS
=""
259 # Set if a host build should be done in TERMUX_PKG_HOSTBUILD_DIR:
260 TERMUX_PKG_HOSTBUILD
=""
261 TERMUX_PKG_MAINTAINER
="Fredrik Fornwall @fornwall"
262 TERMUX_PKG_CLANG
=yes # does nothing for cmake based packages. clang is chosen by cmake
263 TERMUX_PKG_FORCE_CMAKE
=no
# if the package has autotools as well as cmake, then set this to prefer cmake
265 unset CFLAGS CPPFLAGS LDFLAGS CXXFLAGS
268 # Save away and restore build setups which may change between builds.
269 termux_step_handle_buildarch
() {
270 # If $TERMUX_PREFIX already exists, it may have been built for a different arch
271 local TERMUX_ARCH_FILE
=/data
/TERMUX_ARCH
272 if [ -f
"${TERMUX_ARCH_FILE}" ]; then
273 local TERMUX_PREVIOUS_ARCH
274 TERMUX_PREVIOUS_ARCH
=$
(cat $TERMUX_ARCH_FILE)
275 if [ "$TERMUX_PREVIOUS_ARCH" != "$TERMUX_ARCH" ]; then
276 local TERMUX_DATA_BACKUPDIRS
=$TERMUX_TOPDIR/_databackups
277 mkdir
-p
"$TERMUX_DATA_BACKUPDIRS"
278 local TERMUX_DATA_PREVIOUS_BACKUPDIR
=$TERMUX_DATA_BACKUPDIRS/$TERMUX_PREVIOUS_ARCH
279 local TERMUX_DATA_CURRENT_BACKUPDIR
=$TERMUX_DATA_BACKUPDIRS/$TERMUX_ARCH
280 # Save current /data (removing old backup if any)
281 if test -e
"$TERMUX_DATA_PREVIOUS_BACKUPDIR"; then
282 termux_error_exit
"Directory already exists"
284 mv /data
/data
"$TERMUX_DATA_PREVIOUS_BACKUPDIR"
285 # Restore new one (if any)
286 if [ -d
"$TERMUX_DATA_CURRENT_BACKUPDIR" ]; then
287 mv "$TERMUX_DATA_CURRENT_BACKUPDIR" /data
/data
292 # Keep track of current arch we are building for.
293 echo "$TERMUX_ARCH" > $TERMUX_ARCH_FILE
296 # Source the package build script and start building. No to be overridden by packages.
297 termux_step_start_build
() {
298 # shellcheck source=/dev/null
299 source "$TERMUX_PKG_BUILDER_SCRIPT"
301 if [ -n
"${TERMUX_PKG_BLACKLISTED_ARCHES:=""}" ] && [ "$TERMUX_PKG_BLACKLISTED_ARCHES" != "${TERMUX_PKG_BLACKLISTED_ARCHES/$TERMUX_ARCH/}" ]; then
302 echo "Skipping building $TERMUX_PKG_NAME for arch $TERMUX_ARCH"
306 if [ -z
"${TERMUX_SKIP_DEPCHECK:=""}" ]; then
307 local p TERMUX_ALL_DEPS
308 TERMUX_ALL_DEPS
=$
(.
/scripts
/buildorder.py
"$TERMUX_PKG_NAME")
309 for p
in $TERMUX_ALL_DEPS; do
310 if [ "$p" != "$TERMUX_PKG_NAME" ]; then
311 echo "Building dependency $p if necessary..."
312 .
/build-package.sh
-a
$TERMUX_ARCH -s
"$p"
317 TERMUX_PKG_FULLVERSION
=$TERMUX_PKG_VERSION
318 if [ "$TERMUX_PKG_REVISION" != "0" ] ||
[ "$TERMUX_PKG_FULLVERSION" != "${TERMUX_PKG_FULLVERSION/-/}" ]; then
319 # "0" is the default revision, so only include it if the upstream versions contains "-" itself
320 TERMUX_PKG_FULLVERSION
+="-$TERMUX_PKG_REVISION"
323 if [ -z
"$TERMUX_DEBUG" ] &&
324 [ -z
"${TERMUX_FORCE_BUILD+x}" ] &&
325 [ -e
"/data/data/.built-packages/$TERMUX_PKG_NAME" ]; then
326 if [ "$(cat "/data
/data
/.built-packages
/$TERMUX_PKG_NAME")" = "$TERMUX_PKG_FULLVERSION" ]; then
327 echo "$TERMUX_PKG_NAME@$TERMUX_PKG_FULLVERSION built - skipping (rm /data/data/.built-packages/$TERMUX_PKG_NAME to force rebuild)"
333 rm -Rf
"$TERMUX_PKG_BUILDDIR" \
334 "$TERMUX_PKG_PACKAGEDIR" \
335 "$TERMUX_PKG_SRCDIR" \
336 "$TERMUX_PKG_TMPDIR" \
337 "$TERMUX_PKG_MASSAGEDIR"
339 # Ensure folders present (but not $TERMUX_PKG_SRCDIR, it will be created in build)
340 mkdir
-p
"$TERMUX_COMMON_CACHEDIR" \
342 "$TERMUX_PKG_BUILDDIR" \
343 "$TERMUX_PKG_PACKAGEDIR" \
344 "$TERMUX_PKG_TMPDIR" \
345 "$TERMUX_PKG_CACHEDIR" \
346 "$TERMUX_PKG_MASSAGEDIR" \
348 $TERMUX_PREFIX/{bin
,etc
,lib
,libexec
,share
,tmp
,include
}
350 # Make $TERMUX_PREFIX/bin/sh executable on the builder, so that build
351 # scripts can assume that it works on both builder and host later on:
352 ln -f
-s
/bin
/sh
"$TERMUX_PREFIX/bin/sh"
354 local TERMUX_ELF_CLEANER_SRC
=$TERMUX_COMMON_CACHEDIR/termux-elf-cleaner.cpp
355 local TERMUX_ELF_CLEANER_VERSION
=$
(bash
-c
". $TERMUX_SCRIPTDIR/packages/termux-elf-cleaner/build.sh; echo \$TERMUX_PKG_VERSION")
357 https
://raw.githubusercontent.com
/termux
/termux-elf-cleaner
/v
$TERMUX_ELF_CLEANER_VERSION/termux-elf-cleaner.cpp \
358 $TERMUX_ELF_CLEANER_SRC \
359 11a38372f4d0e36b7556382c7ecffecae35cee8b68daaee2dbee025f758e17ee
360 if [ "$TERMUX_ELF_CLEANER_SRC" -nt
"$TERMUX_ELF_CLEANER" ]; then
361 g
++ -std
=c
++11 -Wall
-Wextra
-pedantic
-Os
"$TERMUX_ELF_CLEANER_SRC" -o
"$TERMUX_ELF_CLEANER"
364 if [ -n
"$TERMUX_PKG_BUILD_IN_SRC" ]; then
365 echo "Building in src due to TERMUX_PKG_BUILD_IN_SRC being set" > "$TERMUX_PKG_BUILDDIR/BUILDING_IN_SRC.txt"
366 TERMUX_PKG_BUILDDIR
=$TERMUX_PKG_SRCDIR
369 echo "termux - building $TERMUX_PKG_NAME for arch $TERMUX_ARCH..."
370 test -t
1 && printf "\033]0;%s...\007" "$TERMUX_PKG_NAME"
372 # Add a pkg-config file for the system zlib
373 cat > "$PKG_CONFIG_LIBDIR/zlib.pc" <<-HERE
375 Description: zlib compression library
381 # Keep track of when build started so we can see what files have been created.
382 # We start by sleeping so that any generated files above (such as zlib.pc) get
383 # an older timestamp than the TERMUX_BUILD_TS_FILE.
385 TERMUX_BUILD_TS_FILE
=$TERMUX_PKG_TMPDIR/timestamp_
$TERMUX_PKG_NAME
386 touch "$TERMUX_BUILD_TS_FILE"
389 # Run just after sourcing $TERMUX_PKG_BUILDER_SCRIPT. May be overridden by packages.
390 termux_step_extract_package
() {
391 if [ -z
"${TERMUX_PKG_SRCURL:=""}" ]; then
392 mkdir
-p
"$TERMUX_PKG_SRCDIR"
395 cd "$TERMUX_PKG_TMPDIR"
397 filename
=$
(basename "$TERMUX_PKG_SRCURL")
398 local file="$TERMUX_PKG_CACHEDIR/$filename"
399 termux_download
"$TERMUX_PKG_SRCURL" "$file" "$TERMUX_PKG_SHA256"
401 if [ "x$TERMUX_PKG_FOLDERNAME" = "x" ]; then
402 folder
=`basename $filename .tar.bz2` && folder
=`basename $folder .tar.gz` && folder
=`basename $folder .tar.xz` && folder
=`basename $folder .tar.lz` && folder
=`basename $folder .tgz` && folder
=`basename $folder .zip`
403 folder
="${folder/_/-}" # dpkg uses _ in tar filename, but - in folder
405 folder
=$TERMUX_PKG_FOLDERNAME
408 if [ "${file##*.}" = zip ]; then
411 $TERMUX_TAR xf
"$file"
413 mv $folder "$TERMUX_PKG_SRCDIR"
416 # Hook for packages to act just after the package has been extracted.
417 # Invoked in $TERMUX_PKG_SRCDIR.
418 termux_step_post_extract_package
() {
422 # Optional host build. Not to be overridden by packages.
423 termux_step_handle_hostbuild
() {
424 if [ "x$TERMUX_PKG_HOSTBUILD" = "x" ]; then return; fi
426 cd "$TERMUX_PKG_SRCDIR"
427 for patch in $TERMUX_PKG_BUILDER_DIR/*.
patch.beforehostbuild
; do
428 test -f
"$patch" && sed "s%\@TERMUX_PREFIX\@%${TERMUX_PREFIX}%g" "$patch" |
patch --silent
-p1
431 local TERMUX_HOSTBUILD_MARKER
="$TERMUX_PKG_HOSTBUILD_DIR/TERMUX_BUILT_FOR_$TERMUX_PKG_VERSION"
432 if [ ! -f
"$TERMUX_HOSTBUILD_MARKER" ]; then
433 rm -Rf
"$TERMUX_PKG_HOSTBUILD_DIR"
434 mkdir
-p
"$TERMUX_PKG_HOSTBUILD_DIR"
435 cd "$TERMUX_PKG_HOSTBUILD_DIR"
436 termux_step_host_build
437 touch "$TERMUX_HOSTBUILD_MARKER"
441 # Perform a host build. Will be called in $TERMUX_PKG_HOSTBUILD_DIR.
442 # After termux_step_post_extract_package() and before termux_step_patch_package()
443 termux_step_host_build
() {
444 "$TERMUX_PKG_SRCDIR/configure" ${TERMUX_PKG_EXTRA_HOSTBUILD_CONFIGURE_ARGS}
445 make -j
$TERMUX_MAKE_PROCESSES
448 # Setup a standalone Android NDK toolchain. Not to be overridden by packages.
449 termux_step_setup_toolchain
() {
450 # We put this after system PATH to avoid picking up toolchain stripped python
451 export PATH
=$PATH:$TERMUX_STANDALONE_TOOLCHAIN/bin
454 export LDFLAGS
="-L${TERMUX_PREFIX}/lib"
456 if [ "$TERMUX_PKG_CLANG" = "no" ]; then
457 export AS
=${TERMUX_HOST_PLATFORM}-gcc
458 export CC
=$TERMUX_HOST_PLATFORM-gcc
459 export CXX
=$TERMUX_HOST_PLATFORM-g
++
460 LDFLAGS
+=" -specs=$TERMUX_SCRIPTDIR/termux.spec"
461 CFLAGS
+=" -specs=$TERMUX_SCRIPTDIR/termux.spec"
463 export AS
=${TERMUX_HOST_PLATFORM}-clang
464 export CC
=$TERMUX_HOST_PLATFORM-clang
465 export CXX
=$TERMUX_HOST_PLATFORM-clang
++
468 export AR
=$TERMUX_HOST_PLATFORM-ar
469 export CPP
=${TERMUX_HOST_PLATFORM}-cpp
470 export CC_FOR_BUILD
=gcc
471 export LD
=$TERMUX_HOST_PLATFORM-ld
472 export OBJDUMP
=$TERMUX_HOST_PLATFORM-objdump
473 # Setup pkg-config for cross-compiling:
474 export PKG_CONFIG
=$TERMUX_STANDALONE_TOOLCHAIN/bin
/${TERMUX_HOST_PLATFORM}-pkg-config
475 export RANLIB
=$TERMUX_HOST_PLATFORM-ranlib
476 export READELF
=$TERMUX_HOST_PLATFORM-readelf
477 export STRIP
=$TERMUX_HOST_PLATFORM-strip
479 # Android 7 started to support DT_RUNPATH (but not DT_RPATH), so we may want
480 # LDFLAGS+="-Wl,-rpath=$TERMUX_PREFIX/lib -Wl,--enable-new-dtags"
481 # and no longer remove DT_RUNPATH in termux-elf-cleaner.
483 if [ "$TERMUX_ARCH" = "arm" ]; then
484 # https://developer.android.com/ndk/guides/standalone_toolchain.html#abi_compatibility:
485 # "We recommend using the -mthumb compiler flag to force the generation of 16-bit Thumb-2 instructions".
486 # With r13 of the ndk ruby 2.4.0 segfaults when built on arm with clang without -mthumb.
487 CFLAGS
+=" -march=armv7-a -mfpu=neon -mfloat-abi=softfp -mthumb"
488 LDFLAGS
+=" -march=armv7-a -Wl,--fix-cortex-a8"
489 elif [ "$TERMUX_ARCH" = "i686" ]; then
490 # From $NDK/docs/CPU-ARCH-ABIS.html:
491 CFLAGS
+=" -march=i686 -msse3 -mstackrealign -mfpmath=sse"
492 elif [ "$TERMUX_ARCH" = "aarch64" ]; then
494 elif [ "$TERMUX_ARCH" = "x86_64" ]; then
497 termux_error_exit
"Invalid arch '$TERMUX_ARCH' - support arches are 'arm', 'i686', 'aarch64', 'x86_64'"
500 if [ -n
"$TERMUX_DEBUG" ]; then
501 CFLAGS
+=" -g3 -O1 -fstack-protector --param ssp-buffer-size=4 -D_FORTIFY_SOURCE=2"
506 export CXXFLAGS
="$CFLAGS"
507 export CPPFLAGS
="-I${TERMUX_PREFIX}/include"
509 if [ "$TERMUX_PKG_DEPENDS" != "${TERMUX_PKG_DEPENDS/libandroid-support/}" ]; then
510 # If using the android support library, link to it and include its headers as system headers:
511 CPPFLAGS
+=" -isystem $TERMUX_PREFIX/include/libandroid-support"
512 LDFLAGS
+=" -landroid-support"
515 export ac_cv_func_getpwent
=no
516 export ac_cv_func_getpwnam
=no
517 export ac_cv_func_getpwuid
=no
519 if [ ! -d
$TERMUX_STANDALONE_TOOLCHAIN ]; then
520 # Do not put toolchain in place until we are done with setup, to avoid having a half setup
521 # toolchain left in place if something goes wrong (or process is just aborted):
522 local _TERMUX_TOOLCHAIN_TMPDIR
=${TERMUX_STANDALONE_TOOLCHAIN}-tmp
523 rm -Rf
$_TERMUX_TOOLCHAIN_TMPDIR
525 local _NDK_ARCHNAME
=$TERMUX_ARCH
526 if [ "$TERMUX_ARCH" = "aarch64" ]; then
528 elif [ "$TERMUX_ARCH" = "i686" ]; then
532 "$NDK/build/tools/make_standalone_toolchain.py" \
533 --api
"$TERMUX_API_LEVEL" \
534 --arch
$_NDK_ARCHNAME \
535 --install-dir
$_TERMUX_TOOLCHAIN_TMPDIR
537 local wrapped plusplus CLANG_TARGET
=$TERMUX_HOST_PLATFORM
538 if [ $TERMUX_ARCH = arm
]; then CLANG_TARGET
=${CLANG_TARGET/arm-/armv7a-}; fi
539 for wrapped
in ${TERMUX_HOST_PLATFORM}-clang clang
; do
540 for plusplus
in "" "++"; do
541 local FILE_TO_REPLACE
=$_TERMUX_TOOLCHAIN_TMPDIR/bin
/${wrapped}${plusplus}
542 if [ ! -f
$FILE_TO_REPLACE ]; then
543 termux_error_exit
"No toolchain file to override: $FILE_TO_REPLACE"
545 cp "$TERMUX_SCRIPTDIR/scripts/clang-pie-wrapper" $FILE_TO_REPLACE
546 sed -i
"s/COMPILER/clang38$plusplus/" $FILE_TO_REPLACE
547 sed -i
"s/CLANG_TARGET/$CLANG_TARGET/" $FILE_TO_REPLACE
551 if [ "$TERMUX_ARCH" = "arm" ]; then
552 # Fix to allow e.g. <bits/c++config.h> to be included:
553 cp $_TERMUX_TOOLCHAIN_TMPDIR/include
/c
++/4.9.x
/arm-linux-androideabi
/armv7-a
/bits
/* \
554 $_TERMUX_TOOLCHAIN_TMPDIR/include
/c
++/4.9.x
/bits
555 elif [ "$TERMUX_ARCH" = "aarch64" ]; then
556 # Use gold by default to work around https://github.com/android-ndk/ndk/issues/148
557 cp $_TERMUX_TOOLCHAIN_TMPDIR/bin
/aarch64-linux-android-ld.gold \
558 $_TERMUX_TOOLCHAIN_TMPDIR/bin
/aarch64-linux-android-ld
559 cp $_TERMUX_TOOLCHAIN_TMPDIR/aarch64-linux-android
/bin
/ld.gold \
560 $_TERMUX_TOOLCHAIN_TMPDIR/aarch64-linux-android
/bin
/ld
563 cd $_TERMUX_TOOLCHAIN_TMPDIR/sysroot
565 for f
in $TERMUX_SCRIPTDIR/ndk_patches
/*.
patch; do
566 sed "s%\@TERMUX_PREFIX\@%${TERMUX_PREFIX}%g" "$f" | \
567 sed "s%\@TERMUX_HOME\@%${TERMUX_ANDROID_HOME}%g" | \
570 # elf.h: Taken from glibc since the elf.h in the NDK is lacking.
571 # sysexits.h: Header-only and used by a few programs.
572 # ifaddrs.h: Added in android-24 unified headers, use a inline implementation for now.
573 cp "$TERMUX_SCRIPTDIR"/ndk_patches
/{elf.h
,sysexits.h
,ifaddrs.h
} $_TERMUX_TOOLCHAIN_TMPDIR/sysroot
/usr
/include
575 # Remove <sys/shm.h> from the NDK in favour of that from the libandroid-shmem.
576 # Also remove <sys/sem.h> as it doesn't work for non-root.
577 rm $_TERMUX_TOOLCHAIN_TMPDIR/sysroot
/usr
/include
/sys
/{shm.h
,sem.h
}
579 local _LIBDIR
=usr
/lib
580 if [ $TERMUX_ARCH = x86_64
]; then _LIBDIR
+=64; fi
581 $TERMUX_ELF_CLEANER $_LIBDIR/*.so
583 # zlib is really version 1.2.8 in the Android platform (at least
584 # starting from Android 5), not older as the NDK headers claim.
585 for file in zconf.h zlib.h
; do
586 curl
-o
$_TERMUX_TOOLCHAIN_TMPDIR/sysroot
/usr
/include
/$file \
587 https
://raw.githubusercontent.com
/madler
/zlib
/v1.2
.8/$file
591 mv $_TERMUX_TOOLCHAIN_TMPDIR $TERMUX_STANDALONE_TOOLCHAIN
594 if [ ! -f
$TERMUX_PREFIX/lib
/libstdc
++.so
]; then
595 # Setup libgnustl_shared.so in $PREFIX/lib and libstdc++.so as a symlink to it,
596 # so that other C++ using packages links to it instead of the default android
597 # C++ library which does not support exceptions or STL:
598 # https://developer.android.com/ndk/guides/cpp-support.html
599 # We do however want to avoid installing this, to avoid problems where e.g.
600 # libm.so on some i686 devices links against libstdc++.so.
601 # The libgnustl_shared.so library will be packaged in the libgnustl package
602 # which is part of the base Termux installation.
603 mkdir
-p
"$TERMUX_PREFIX/lib"
604 cd "$TERMUX_PREFIX/lib"
605 _STL_LIBFILE
=$TERMUX_STANDALONE_TOOLCHAIN/${TERMUX_HOST_PLATFORM}/lib
/libgnustl_shared.so
606 if [ "$TERMUX_ARCH" = arm
]; then
607 _STL_LIBFILE
=$TERMUX_STANDALONE_TOOLCHAIN/${TERMUX_HOST_PLATFORM}/lib
/armv7-a
/libgnustl_shared.so
608 elif [ "$TERMUX_ARCH" = x86_64
]; then
609 _STL_LIBFILE
=$TERMUX_STANDALONE_TOOLCHAIN/${TERMUX_HOST_PLATFORM}/lib64
/libgnustl_shared.so
612 $STRIP --strip-unneeded libgnustl_shared.so
613 $TERMUX_ELF_CLEANER libgnustl_shared.so
614 ln -f
-s libgnustl_shared.so libstdc
++.so
617 # Create a pkg-config wrapper. We use path to host pkg-config to
618 # avoid picking up a cross-compiled pkg-config later on.
619 local _HOST_PKGCONFIG
620 _HOST_PKGCONFIG
=$
(which pkg-config
)
621 mkdir
-p
$TERMUX_STANDALONE_TOOLCHAIN/bin
"$PKG_CONFIG_LIBDIR"
622 cat > "$PKG_CONFIG" <<-HERE
624 export PKG_CONFIG_DIR=
625 export PKG_CONFIG_LIBDIR=$PKG_CONFIG_LIBDIR
626 exec $_HOST_PKGCONFIG "\$@"
628 chmod +x
"$PKG_CONFIG"
631 # Apply all *.patch files for the package. Not to be overridden by packages.
632 termux_step_patch_package
() {
633 cd "$TERMUX_PKG_SRCDIR"
634 # Suffix patch with ".patch32" or ".patch64" to only apply for these bitnesses:
636 for patch in $TERMUX_PKG_BUILDER_DIR/*.
patch{$TERMUX_ARCH_BITS,}; do
637 test -f
"$patch" && sed "s%\@TERMUX_PREFIX\@%${TERMUX_PREFIX}%g" "$patch" | \
638 sed "s%\@TERMUX_HOME\@%${TERMUX_ANDROID_HOME}%g" | \
644 # Replace autotools build-aux/config.{sub,guess} with ours to add android targets.
645 termux_step_replace_guess_scripts
() {
646 cd "$TERMUX_PKG_SRCDIR"
647 find .
-name config.sub
-exec chmod u
+w
'{}' \
; -exec cp "$TERMUX_SCRIPTDIR/scripts/config.sub" '{}' \
;
648 find .
-name config.guess
-exec chmod u
+w
'{}' \
; -exec cp "$TERMUX_SCRIPTDIR/scripts/config.guess" '{}' \
;
651 # For package scripts to override. Called in $TERMUX_PKG_BUILDDIR.
652 termux_step_pre_configure
() {
656 termux_step_configure_autotools
() {
657 if [ ! -e
"$TERMUX_PKG_SRCDIR/configure" ]; then return; fi
659 DISABLE_STATIC
="--disable-static"
660 if [ "$TERMUX_PKG_EXTRA_CONFIGURE_ARGS" != "${TERMUX_PKG_EXTRA_CONFIGURE_ARGS/--enable-static/}" ]; then
661 # Do not --disable-static if package explicitly enables it (e.g. gdb needs enable-static to build)
665 DISABLE_NLS
="--disable-nls"
666 if [ "$TERMUX_PKG_EXTRA_CONFIGURE_ARGS" != "${TERMUX_PKG_EXTRA_CONFIGURE_ARGS/--enable-nls/}" ]; then
667 # Do not --disable-nls if package explicitly enables it (for gettext itself)
671 ENABLE_SHARED
="--enable-shared"
672 if [ "$TERMUX_PKG_EXTRA_CONFIGURE_ARGS" != "${TERMUX_PKG_EXTRA_CONFIGURE_ARGS/--disable-shared/}" ]; then
675 HOST_FLAG
="--host=$TERMUX_HOST_PLATFORM"
676 if [ "$TERMUX_PKG_EXTRA_CONFIGURE_ARGS" != "${TERMUX_PKG_EXTRA_CONFIGURE_ARGS/--host=/}" ]; then
679 LIBEXEC_FLAG
="--libexecdir=$TERMUX_PREFIX/libexec"
680 if [ "$TERMUX_PKG_EXTRA_CONFIGURE_ARGS" != "${TERMUX_PKG_EXTRA_CONFIGURE_ARGS/--libexecdir=/}" ]; then
684 # Some packages provides a $PKG-config script which some configure scripts pickup instead of pkg-config:
685 mkdir
"$TERMUX_PKG_TMPDIR/config-scripts"
686 for f
in $TERMUX_PREFIX/bin
/*config
; do
687 test -f
"$f" && cp "$f" "$TERMUX_PKG_TMPDIR/config-scripts"
689 export PATH
=$TERMUX_PKG_TMPDIR/config-scripts
:$PATH
691 # Avoid gnulib wrapping of functions when cross compiling. See
692 # http://wiki.osdev.org/Cross-Porting_Software#Gnulib
693 # https://gitlab.com/sortix/sortix/wikis/Gnulib
694 # https://github.com/termux/termux-packages/issues/76
695 local AVOID_GNULIB
=""
696 AVOID_GNULIB
+=" ac_cv_func_malloc_0_nonnull=yes"
697 AVOID_GNULIB
+=" ac_cv_func_realloc_0_nonnull=yes"
698 AVOID_GNULIB
+=" am_cv_func_working_getline=yes"
699 AVOID_GNULIB
+=" gl_cv_func_dup2_works=yes"
700 AVOID_GNULIB
+=" gl_cv_func_fcntl_f_dupfd_cloexec=yes"
701 AVOID_GNULIB
+=" gl_cv_func_fcntl_f_dupfd_works=yes"
702 AVOID_GNULIB
+=" gl_cv_func_fnmatch_posix=yes"
703 AVOID_GNULIB
+=" gl_cv_func_getcwd_abort_bug=no"
704 AVOID_GNULIB
+=" gl_cv_func_getcwd_null=yes"
705 AVOID_GNULIB
+=" gl_cv_func_getcwd_path_max=yes"
706 AVOID_GNULIB
+=" gl_cv_func_getcwd_posix_signature=yes"
707 AVOID_GNULIB
+=" gl_cv_func_gettimeofday_clobber=no"
708 AVOID_GNULIB
+=" gl_cv_func_gettimeofday_posix_signature=yes"
709 AVOID_GNULIB
+=" gl_cv_func_link_works=yes"
710 AVOID_GNULIB
+=" gl_cv_func_lstat_dereferences_slashed_symlink=yes"
711 AVOID_GNULIB
+=" gl_cv_func_malloc_0_nonnull=yes"
712 AVOID_GNULIB
+=" gl_cv_func_memchr_works=yes"
713 AVOID_GNULIB
+=" gl_cv_func_mkdir_trailing_dot_works=yes"
714 AVOID_GNULIB
+=" gl_cv_func_mkdir_trailing_slash_works=yes"
715 AVOID_GNULIB
+=" gl_cv_func_select_detects_ebadf=yes"
716 AVOID_GNULIB
+=" gl_cv_func_snprintf_posix=yes"
717 AVOID_GNULIB
+=" gl_cv_func_snprintf_retval_c99=yes"
718 AVOID_GNULIB
+=" gl_cv_func_snprintf_truncation_c99=yes"
719 AVOID_GNULIB
+=" gl_cv_func_stat_dir_slash=yes"
720 AVOID_GNULIB
+=" gl_cv_func_stat_file_slash=yes"
721 AVOID_GNULIB
+=" gl_cv_func_strerror_0_works=yes"
722 AVOID_GNULIB
+=" gl_cv_func_symlink_works=yes"
723 AVOID_GNULIB
+=" gl_cv_func_tzset_clobber=no"
724 AVOID_GNULIB
+=" gl_cv_func_unlink_honors_slashes=yes"
725 AVOID_GNULIB
+=" gl_cv_func_unlink_honors_slashes=yes"
726 AVOID_GNULIB
+=" gl_cv_func_vsnprintf_posix=yes"
727 AVOID_GNULIB
+=" gl_cv_func_vsnprintf_zerosize_c99=yes"
728 AVOID_GNULIB
+=" gl_cv_func_wcwidth_works=yes"
729 AVOID_GNULIB
+=" gl_cv_func_working_getdelim=yes"
730 AVOID_GNULIB
+=" gl_cv_func_working_mkstemp=yes"
731 AVOID_GNULIB
+=" gl_cv_func_working_mktime=yes"
732 AVOID_GNULIB
+=" gl_cv_func_working_strerror=yes"
733 AVOID_GNULIB
+=" gl_cv_header_working_fcntl_h=yes"
735 # NOTE: We do not want to quote AVOID_GNULIB as we want word expansion.
736 env
$AVOID_GNULIB "$TERMUX_PKG_SRCDIR/configure" \
737 --disable-dependency-tracking \
738 --prefix
=$TERMUX_PREFIX \
739 --disable-rpath
--disable-rpath-hack \
741 $TERMUX_PKG_EXTRA_CONFIGURE_ARGS \
748 termux_step_configure_cmake
() {
751 local TOOLCHAIN_ARGS
="-DCMAKE_ANDROID_STANDALONE_TOOLCHAIN=$TERMUX_STANDALONE_TOOLCHAIN"
752 local BUILD_TYPE
=MinSizeRel
753 test -n
"$TERMUX_DEBUG" && BUILD_TYPE
=Debug
755 local CMAKE_PROC
=$TERMUX_ARCH
756 test $CMAKE_PROC == "arm" && CMAKE_PROC
='armv7-a'
758 # XXX: CMAKE_{AR,RANLIB} needed for at least jsoncpp build to not
759 # pick up cross compiled binutils tool in $PREFIX/bin:
760 cmake
-G
'Unix Makefiles' "$TERMUX_PKG_SRCDIR" \
761 -DCMAKE_AR
="$(which $AR)" \
762 -DCMAKE_RANLIB
="$(which $RANLIB)" \
763 -DCMAKE_BUILD_TYPE
=$BUILD_TYPE \
764 -DCMAKE_CROSSCOMPILING
=True \
765 -DCMAKE_C_FLAGS
="$CFLAGS $CPPFLAGS" \
766 -DCMAKE_CXX_FLAGS
="$CXXFLAGS $CPPFLAGS" \
767 -DCMAKE_LINKER
="$TERMUX_STANDALONE_TOOLCHAIN/bin/$LD $LDFLAGS" \
768 -DCMAKE_FIND_ROOT_PATH
=$TERMUX_PREFIX \
769 -DCMAKE_FIND_ROOT_PATH_MODE_INCLUDE
=ONLY \
770 -DCMAKE_FIND_ROOT_PATH_MODE_LIBRARY
=ONLY \
771 -DCMAKE_INSTALL_PREFIX
=$TERMUX_PREFIX \
772 -DCMAKE_MAKE_PROGRAM
=`which make` \
773 -DCMAKE_SYSTEM_PROCESSOR
=$CMAKE_PROC \
774 -DCMAKE_SYSTEM_NAME
=Android \
775 -DCMAKE_SYSTEM_VERSION
=21 \
776 -DCMAKE_SKIP_INSTALL_RPATH
=ON \
777 -DCMAKE_USE_SYSTEM_LIBRARIES
=True \
778 -DBUILD_TESTING
=OFF \
779 $TERMUX_PKG_EXTRA_CONFIGURE_ARGS $TOOLCHAIN_ARGS
782 termux_step_configure
() {
783 if [ "$TERMUX_PKG_FORCE_CMAKE" == 'no' ] && [ -f
"$TERMUX_PKG_SRCDIR/configure" ]; then
784 termux_step_configure_autotools
785 elif [ -f
"$TERMUX_PKG_SRCDIR/CMakeLists.txt" ]; then
786 termux_step_configure_cmake
790 termux_step_post_configure
() {
795 if ls .
/*akefile
&> /dev
/null
; then
796 if [ -z
"$TERMUX_PKG_EXTRA_MAKE_ARGS" ]; then
797 make -j
$TERMUX_MAKE_PROCESSES
799 make -j
$TERMUX_MAKE_PROCESSES ${TERMUX_PKG_EXTRA_MAKE_ARGS}
804 termux_step_make_install
() {
805 if ls .
/*akefile
&> /dev
/null
; then
806 : "${TERMUX_PKG_MAKE_INSTALL_TARGET:="install"}"
807 # Some packages have problem with parallell install, and it does not buy much, so use -j 1.
808 if [ -z
"$TERMUX_PKG_EXTRA_MAKE_ARGS" ]; then
809 make -j
1 ${TERMUX_PKG_MAKE_INSTALL_TARGET}
811 make -j
1 ${TERMUX_PKG_EXTRA_MAKE_ARGS} ${TERMUX_PKG_MAKE_INSTALL_TARGET}
816 # Hook function for package scripts to override.
817 termux_step_post_make_install
() {
821 termux_step_extract_into_massagedir
() {
822 local TARBALL_ORIG
=$TERMUX_PKG_PACKAGEDIR/${TERMUX_PKG_NAME}_orig.
tar.gz
824 # Build diff tar with what has changed during the build:
826 $TERMUX_TAR -N
"$TERMUX_BUILD_TS_FILE" -czf
"$TARBALL_ORIG" .
828 # Extract tar in order to massage it
829 mkdir
-p
"$TERMUX_PKG_MASSAGEDIR/$TERMUX_PREFIX"
830 cd "$TERMUX_PKG_MASSAGEDIR/$TERMUX_PREFIX"
831 $TERMUX_TAR xf
"$TARBALL_ORIG"
835 termux_step_massage
() {
836 cd "$TERMUX_PKG_MASSAGEDIR/$TERMUX_PREFIX"
838 # Remove lib/charset.alias which is installed by gettext-using packages:
839 rm -f lib
/charset.
alias
841 # Remove non-english man pages:
842 test -d share
/man
&& (cd share
/man
; for f
in `ls | grep -v man`; do rm -Rf
$f; done )
844 if [ -z
"${TERMUX_PKG_KEEP_INFOPAGES+x}" ]; then
849 # Remove locale files we're not interested in::
851 if [ -z
"${TERMUX_PKG_KEEP_SHARE_DOC+x}" ]; then
856 # Remove old kept libraries (readline):
857 find .
-name
'*.old' -delete
859 # Remove static libraries:
860 if [ $TERMUX_PKG_KEEP_STATIC_LIBRARIES = "false" ]; then
861 find .
-name
'*.a' -delete
862 find .
-name
'*.la' -delete
865 # Move over sbin to bin:
866 for file in sbin
/*; do if test -f
"$file"; then mv "$file" bin
/; fi; done
868 # Remove world permissions and add write permissions.
869 # The -f flag is used to suppress warnings about dangling symlinks (such
870 # as ones to /system/... which may not exist on the build machine):
871 find .
-exec chmod -f u
+w
,o-rwx \
{\
} \
;
872 if [ "$TERMUX_DEBUG" = "" ]; then
873 # Strip binaries. file(1) may fail for certain unusual files, so disable pipefail.
875 find .
-type f |
xargs -r
file |
grep -E
"(executable|shared object)" |
grep ELF | cut
-f
1 -d
: | \
876 xargs -r
"$STRIP" --strip-unneeded
--preserve-dates
879 # Remove DT_ entries which the android 5.1 linker warns about:
880 find .
-type f
-print0 |
xargs -r
-0 "$TERMUX_ELF_CLEANER"
883 while IFS
= read -r
-d
'' file
885 head -c
100 "$file" |
grep -E
"^#\!.*\\/bin\\/.*" |
grep -q
-E
-v
"^#\! ?\\/system" && sed --follow-symlinks
-i
-E
"1 s@^#\!(.*)/bin/(.*)@#\!$TERMUX_PREFIX/bin/\2@" "$file"
886 done < <(find -L .
-type f
-print0
)
888 test ! -z
"$TERMUX_PKG_RM_AFTER_INSTALL" && rm -Rf
$TERMUX_PKG_RM_AFTER_INSTALL
890 find .
-type d
-empty
-delete
# Remove empty directories
893 if [ -d include
] && [ -z
"${TERMUX_PKG_NO_DEVELSPLIT}" ]; then
894 # Add virtual -dev sub package if there are include files:
895 local _DEVEL_SUBPACKAGE_FILE
=$TERMUX_PKG_TMPDIR/${TERMUX_PKG_NAME}-dev.subpackage.sh
896 echo TERMUX_SUBPKG_INCLUDE
=\"include share
/vala share
/man
/man3 lib
/pkgconfig share
/aclocal lib
/cmake
$TERMUX_PKG_INCLUDE_IN_DEVPACKAGE\" > "$_DEVEL_SUBPACKAGE_FILE"
897 echo "TERMUX_SUBPKG_DESCRIPTION=\"Development files for ${TERMUX_PKG_NAME}\"" >> "$_DEVEL_SUBPACKAGE_FILE"
898 if [ -n
"$TERMUX_PKG_DEVPACKAGE_DEPENDS" ]; then
899 echo "TERMUX_SUBPKG_DEPENDS=\"$TERMUX_PKG_NAME,$TERMUX_PKG_DEVPACKAGE_DEPENDS\"" >> "$_DEVEL_SUBPACKAGE_FILE"
901 echo "TERMUX_SUBPKG_DEPENDS=\"$TERMUX_PKG_NAME\"" >> "$_DEVEL_SUBPACKAGE_FILE"
904 # Now build all sub packages
905 rm -Rf
"$TERMUX_TOPDIR/$TERMUX_PKG_NAME/subpackages"
906 for subpackage
in $TERMUX_PKG_BUILDER_DIR/*.subpackage.sh
$TERMUX_PKG_TMPDIR/*subpackage.sh
; do
907 test ! -f
"$subpackage" && continue
909 SUB_PKG_NAME
=$
(basename "$subpackage" .subpackage.sh
)
910 # Default value is same as main package, but sub package may override:
911 local TERMUX_SUBPKG_PLATFORM_INDEPENDENT
=$TERMUX_PKG_PLATFORM_INDEPENDENT
912 local SUB_PKG_DIR
=$TERMUX_TOPDIR/$TERMUX_PKG_NAME/subpackages
/$SUB_PKG_NAME
913 local TERMUX_SUBPKG_DEPENDS
=""
914 local TERMUX_SUBPKG_CONFLICTS
=""
915 local TERMUX_SUBPKG_CONFFILES
=""
916 local SUB_PKG_MASSAGE_DIR
=$SUB_PKG_DIR/massage
/$TERMUX_PREFIX
917 local SUB_PKG_PACKAGE_DIR
=$SUB_PKG_DIR/package
918 mkdir
-p
"$SUB_PKG_MASSAGE_DIR" "$SUB_PKG_PACKAGE_DIR"
920 # shellcheck source=/dev/null
923 for includeset
in $TERMUX_SUBPKG_INCLUDE; do
924 local _INCLUDE_DIRSET
925 _INCLUDE_DIRSET
=$
(dirname "$includeset")
926 test "$_INCLUDE_DIRSET" = "." && _INCLUDE_DIRSET
=""
927 if [ -e
"$includeset" ] ||
[ -L
"$includeset" ]; then
928 # Add the -L clause to handle relative symbolic links:
929 mkdir
-p
"$SUB_PKG_MASSAGE_DIR/$_INCLUDE_DIRSET"
930 mv "$includeset" "$SUB_PKG_MASSAGE_DIR/$_INCLUDE_DIRSET"
934 local SUB_PKG_ARCH
=$TERMUX_ARCH
935 test -n
"$TERMUX_SUBPKG_PLATFORM_INDEPENDENT" && SUB_PKG_ARCH
=all
937 cd "$SUB_PKG_DIR/massage"
938 local SUB_PKG_INSTALLSIZE
939 SUB_PKG_INSTALLSIZE
=$
(du
-sk . | cut
-f
1)
940 $TERMUX_TAR -cJf
"$SUB_PKG_PACKAGE_DIR/data.tar.xz" .
944 cat > control
<<-HERE
945 Package: $SUB_PKG_NAME
946 Architecture: ${SUB_PKG_ARCH}
947 Installed-Size: ${SUB_PKG_INSTALLSIZE}
948 Maintainer: $TERMUX_PKG_MAINTAINER
949 Version: $TERMUX_PKG_FULLVERSION
950 Description: $TERMUX_SUBPKG_DESCRIPTION
951 Homepage: $TERMUX_PKG_HOMEPAGE
953 test ! -z
"$TERMUX_SUBPKG_DEPENDS" && echo "Depends: $TERMUX_SUBPKG_DEPENDS" >> control
954 test ! -z
"$TERMUX_SUBPKG_CONFLICTS" && echo "Conflicts: $TERMUX_SUBPKG_CONFLICTS" >> control
955 $TERMUX_TAR -cJf
"$SUB_PKG_PACKAGE_DIR/control.tar.xz" .
957 for f
in $TERMUX_SUBPKG_CONFFILES; do echo "$TERMUX_PREFIX/$f" >> conffiles
; done
959 # Create the actual .deb file:
960 TERMUX_SUBPKG_DEBFILE
=$TERMUX_DEBDIR/${SUB_PKG_NAME}_
${TERMUX_PKG_FULLVERSION}_
${SUB_PKG_ARCH}.deb
961 test ! -f
"$TERMUX_COMMON_CACHEDIR/debian-binary" && echo "2.0" > "$TERMUX_COMMON_CACHEDIR/debian-binary"
962 ar cr
"$TERMUX_SUBPKG_DEBFILE" \
963 "$TERMUX_COMMON_CACHEDIR/debian-binary" \
964 "$SUB_PKG_PACKAGE_DIR/control.tar.xz" \
965 "$SUB_PKG_PACKAGE_DIR/data.tar.xz"
967 # Go back to main package:
968 cd "$TERMUX_PKG_MASSAGEDIR/$TERMUX_PREFIX"
971 # .. remove empty directories (NOTE: keep this last):
972 find .
-type d
-empty
-delete
973 # Make sure user can read and write all files (problem with dpkg otherwise):
977 termux_step_post_massage
() {
981 # Create data.tar.gz with files to package. Not to be overridden by package scripts.
982 termux_step_create_datatar
() {
983 # Create data tarball containing files to package:
984 cd "$TERMUX_PKG_MASSAGEDIR"
986 local HARDLINKS
="$(find . -type f -links +1)"
987 if [ -n
"$HARDLINKS" ]; then
988 termux_error_exit
"Package contains hard links: $HARDLINKS"
991 if [ -z
"${TERMUX_PKG_METAPACKAGE+x}" ] && [ "$(find . -type f)" = "" ]; then
992 termux_error_exit
"No files in package"
994 $TERMUX_TAR -cJf
"$TERMUX_PKG_PACKAGEDIR/data.tar.xz" .
997 termux_step_create_debscripts
() {
1001 # Create the build deb file. Not to be overridden by package scripts.
1002 termux_step_create_debfile
() {
1003 # Get install size. This will be written as the "Installed-Size" deb field so is measured in 1024-byte blocks:
1004 local TERMUX_PKG_INSTALLSIZE
1005 TERMUX_PKG_INSTALLSIZE
=$
(du
-sk . | cut
-f
1)
1007 # From here on TERMUX_ARCH is set to "all" if TERMUX_PKG_PLATFORM_INDEPENDENT is set by the package
1008 test -n
"$TERMUX_PKG_PLATFORM_INDEPENDENT" && TERMUX_ARCH
=all
1011 cat > DEBIAN
/control
<<-HERE
1012 Package: $TERMUX_PKG_NAME
1013 Architecture: ${TERMUX_ARCH}
1014 Installed-Size: ${TERMUX_PKG_INSTALLSIZE}
1015 Maintainer: $TERMUX_PKG_MAINTAINER
1016 Version: $TERMUX_PKG_FULLVERSION
1017 Description: $TERMUX_PKG_DESCRIPTION
1018 Homepage: $TERMUX_PKG_HOMEPAGE
1020 test ! -z
"$TERMUX_PKG_DEPENDS" && echo "Depends: $TERMUX_PKG_DEPENDS" >> DEBIAN
/control
1021 test ! -z
"$TERMUX_PKG_ESSENTIAL" && echo "Essential: yes" >> DEBIAN
/control
1022 test ! -z
"$TERMUX_PKG_CONFLICTS" && echo "Conflicts: $TERMUX_PKG_CONFLICTS" >> DEBIAN
/control
1023 test ! -z
"$TERMUX_PKG_REPLACES" && echo "Replaces: $TERMUX_PKG_REPLACES" >> DEBIAN
/control
1025 # Create DEBIAN/conffiles (see https://www.debian.org/doc/debian-policy/ap-pkg-conffiles.html):
1026 for f
in $TERMUX_PKG_CONFFILES; do echo "$TERMUX_PREFIX/$f" >> DEBIAN
/conffiles
; done
1028 # Allow packages to create arbitrary control files.
1029 # XXX: Should be done in a better way without a function?
1031 termux_step_create_debscripts
1033 # Create control.tar.xz
1034 $TERMUX_TAR -cJf
"$TERMUX_PKG_PACKAGEDIR/control.tar.xz" .
1036 test ! -f
"$TERMUX_COMMON_CACHEDIR/debian-binary" && echo "2.0" > "$TERMUX_COMMON_CACHEDIR/debian-binary"
1037 TERMUX_PKG_DEBFILE
=$TERMUX_DEBDIR/${TERMUX_PKG_NAME}_
${TERMUX_PKG_FULLVERSION}_
${TERMUX_ARCH}.deb
1038 # Create the actual .deb file:
1039 ar cr
"$TERMUX_PKG_DEBFILE" \
1040 "$TERMUX_COMMON_CACHEDIR/debian-binary" \
1041 "$TERMUX_PKG_PACKAGEDIR/control.tar.xz" \
1042 "$TERMUX_PKG_PACKAGEDIR/data.tar.xz"
1045 # Finish the build. Not to be overridden by package scripts.
1046 termux_step_finish_build
() {
1047 echo "termux - build of '$TERMUX_PKG_NAME' done"
1048 test -t
1 && printf "\033]0;%s - DONE\007" "$TERMUX_PKG_NAME"
1049 mkdir
-p
/data
/data
/.built-packages
1050 echo "$TERMUX_PKG_FULLVERSION" > "/data/data/.built-packages/$TERMUX_PKG_NAME"
1054 termux_step_handle_arguments
"$@"
1055 termux_step_setup_variables
1056 termux_step_handle_buildarch
1057 termux_step_start_build
1058 termux_step_extract_package
1059 cd "$TERMUX_PKG_SRCDIR"
1060 termux_step_post_extract_package
1061 termux_step_handle_hostbuild
1062 termux_step_setup_toolchain
1063 termux_step_patch_package
1064 termux_step_replace_guess_scripts
1065 cd "$TERMUX_PKG_BUILDDIR"
1066 termux_step_pre_configure
1067 cd "$TERMUX_PKG_BUILDDIR"
1068 termux_step_configure
1069 cd "$TERMUX_PKG_BUILDDIR"
1070 termux_step_post_configure
1071 cd "$TERMUX_PKG_BUILDDIR"
1073 cd "$TERMUX_PKG_BUILDDIR"
1074 termux_step_make_install
1075 cd "$TERMUX_PKG_BUILDDIR"
1076 termux_step_post_make_install
1077 cd "$TERMUX_PKG_MASSAGEDIR"
1078 termux_step_extract_into_massagedir
1079 cd "$TERMUX_PKG_MASSAGEDIR"
1081 cd "$TERMUX_PKG_MASSAGEDIR/$TERMUX_PREFIX"
1082 termux_step_post_massage
1083 termux_step_create_datatar
1084 termux_step_create_debfile
1085 termux_step_finish_build