libgc: Remove useless build step
[termux-packages] / build-package.sh
CommitLineData
59f0d218
FF
1#!/bin/bash
2
59f0d218
FF
3set -e -o pipefail -u
4
a0057943 5# Read settings from .termuxrc if existing:
59f0d218
FF
6test -f $HOME/.termuxrc && . $HOME/.termuxrc
7
a0057943
FF
8# Handle command-line arguments:
9show_usage () {
a5b4ca0c 10 echo "Usage: ./build-package.sh [-a ARCH] [-d] [-D] PACKAGE"
a3abe928
FF
11 echo "Build a package by creating a .deb file in the debs/ folder."
12 echo " -a The architecture to build for: aarch64(default), arm, i686, x86_64 or all."
13 echo " -d Build with debug symbols."
14 echo " -D Build a disabled package in disabled-packages/."
fc89df4d 15 echo " -s Skip dependency check."
a0057943
FF
16 exit 1
17}
fc89df4d 18while getopts :a:hdDs option
a0057943
FF
19do
20 case "$option" in
21 a) TERMUX_ARCH="$OPTARG";;
22 h) show_usage;;
a5b4ca0c
VB
23 d) TERMUX_DEBUG=true;;
24 D) TERMUX_IS_DISABLED=true;;
fc89df4d 25 s) export TERMUX_SKIP_DEPCHECK=true;;
a0057943
FF
26 ?) echo "./build-package.sh: illegal option -$OPTARG"; exit 1;;
27 esac
28done
29shift $(($OPTIND-1))
30if [ "$#" -ne 1 ]; then show_usage; fi
31
c629f2b1
FF
32# Configurable settings:
33: ${ANDROID_HOME:="${HOME}/lib/android-sdk"}
34: ${NDK:="${HOME}/lib/android-ndk"}
35: ${TERMUX_MAKE_PROCESSES:='4'}
36: ${TERMUX_TOPDIR:="$HOME/.termux-build"}
37: ${TERMUX_ARCH:="aarch64"} # arm, aarch64, i686 or x86_64.
38if [ "x86_64" = $TERMUX_ARCH -o "aarch64" = $TERMUX_ARCH ]; then
39 TERMUX_ARCH_BITS=64
40else
41 TERMUX_ARCH_BITS=32
42fi
43TERMUX_HOST_PLATFORM="${TERMUX_ARCH}-linux-android"
44if [ $TERMUX_ARCH = "arm" ]; then TERMUX_HOST_PLATFORM="${TERMUX_HOST_PLATFORM}eabi"; fi
45: ${TERMUX_PREFIX:='/data/data/com.termux/files/usr'}
46: ${TERMUX_ANDROID_HOME:='/data/data/com.termux/files/home'}
47: ${TERMUX_DEBUG:=""}
48: ${TERMUX_PROCESS_DEB:=""}
49: ${TERMUX_API_LEVEL:="21"}
50: ${TERMUX_ANDROID_BUILD_TOOLS_VERSION:="24.0.1"}
51: ${TERMUX_NDK_VERSION:="13"}
52: ${TERMUX_IS_DISABLED:=""}
53
a0057943
FF
54# Check the NDK:
55if [ ! -d "$NDK" ]; then
56 echo 'ERROR: $NDK not defined as pointing at a directory - define it pointing at a android NDK installation!'
57 exit 1
58fi
59if grep -s -q "Pkg.Revision = $TERMUX_NDK_VERSION" $NDK/source.properties; then
60 :
61else
62 echo "Wrong NDK version - we need $TERMUX_NDK_VERSION"
63 exit 1
64fi
65
a0057943
FF
66# Check the package to build:
67TERMUX_PKG_NAME=`basename $1`
68export TERMUX_SCRIPTDIR=`cd $(dirname $0); pwd`
69if [[ $1 == *"/"* ]]; then
70 # Path to directory which may be outside this repo:
71 if [ ! -d $1 ]; then echo "ERROR: '$1' seems to be a path but is not a directory"; exit 1; fi
72 export TERMUX_PKG_BUILDER_DIR=`realpath $1`
73else
74 # Package name:
a3abe928 75 if [ -n "$TERMUX_IS_DISABLED" ]; then
a5b4ca0c
VB
76 export TERMUX_PKG_BUILDER_DIR=$TERMUX_SCRIPTDIR/disabled-packages/$TERMUX_PKG_NAME
77 else
78 export TERMUX_PKG_BUILDER_DIR=$TERMUX_SCRIPTDIR/packages/$TERMUX_PKG_NAME
79 fi
a0057943
FF
80fi
81TERMUX_PKG_BUILDER_SCRIPT=$TERMUX_PKG_BUILDER_DIR/build.sh
82if test ! -f $TERMUX_PKG_BUILDER_SCRIPT; then
83 echo "ERROR: No build.sh script at supposed package dir $TERMUX_PKG_BUILDER_DIR!"
84 exit 1
85fi
86
87# Handle 'all' arch:
88if [ $TERMUX_ARCH = 'all' ]; then
a3d36771 89 for arch in 'arm' 'i686' 'aarch64' 'x86_64'; do
a0057943
FF
90 ./build-package.sh -a $arch $1
91 done
92 exit
93fi
94
59f0d218
FF
95# We do not put all of build-tools/$TERMUX_ANDROID_BUILD_TOOLS_VERSION/ into PATH
96# to avoid stuff like arm-linux-androideabi-ld there to conflict with ones from
97# the standalone toolchain.
98TERMUX_DX=$ANDROID_HOME/build-tools/$TERMUX_ANDROID_BUILD_TOOLS_VERSION/dx
382cfb78
FF
99TERMUX_JACK=$ANDROID_HOME/build-tools/$TERMUX_ANDROID_BUILD_TOOLS_VERSION/jack.jar
100TERMUX_JILL=$ANDROID_HOME/build-tools/$TERMUX_ANDROID_BUILD_TOOLS_VERSION/jill.jar
59f0d218
FF
101# Make $TERMUX_TAR and $TERMUX_TOUCH point at gnu versions:
102export TERMUX_TAR="tar"
ed021630 103test `uname` = "Darwin" && TERMUX_TAR=gtar
59f0d218
FF
104export TERMUX_TOUCH="touch"
105test `uname` = "Darwin" && TERMUX_TOUCH=gtouch
106
59f0d218 107export prefix=${TERMUX_PREFIX} # prefix is used by some makefiles
be0684c0 108export PREFIX=${TERMUX_PREFIX} # PREFIX is used by some makefiles
59f0d218 109export TERMUX_COMMON_CACHEDIR="$TERMUX_TOPDIR/_cache"
a0057943 110export TERMUX_DEBDIR="$TERMUX_SCRIPTDIR/debs"
b1d8dacd 111export PKG_CONFIG_LIBDIR=$TERMUX_PREFIX/lib/pkgconfig
a0057943 112mkdir -p $TERMUX_COMMON_CACHEDIR $TERMUX_DEBDIR
59f0d218 113
59f0d218
FF
114TERMUX_PKG_BUILDDIR=$TERMUX_TOPDIR/$TERMUX_PKG_NAME/build
115TERMUX_PKG_CACHEDIR=$TERMUX_TOPDIR/$TERMUX_PKG_NAME/cache
116TERMUX_PKG_MASSAGEDIR=$TERMUX_TOPDIR/$TERMUX_PKG_NAME/massage
117TERMUX_PKG_PACKAGEDIR=$TERMUX_TOPDIR/$TERMUX_PKG_NAME/package
118TERMUX_PKG_SRCDIR=$TERMUX_TOPDIR/$TERMUX_PKG_NAME/src
e239964b 119TERMUX_PKG_SHA256=""
59f0d218
FF
120TERMUX_PKG_TMPDIR=$TERMUX_TOPDIR/$TERMUX_PKG_NAME/tmp
121TERMUX_PKG_HOSTBUILD_DIR=$TERMUX_TOPDIR/$TERMUX_PKG_NAME/host-build
122TERMUX_PKG_PLATFORM_INDEPENDENT=""
123TERMUX_PKG_NO_DEVELSPLIT=""
124TERMUX_PKG_BUILD_REVISION="0" # http://www.debian.org/doc/debian-policy/ch-controlfields.html#s-f-Version
125TERMUX_PKG_EXTRA_CONFIGURE_ARGS=""
126TERMUX_PKG_EXTRA_HOSTBUILD_CONFIGURE_ARGS=""
127TERMUX_PKG_EXTRA_MAKE_ARGS=""
128TERMUX_PKG_BUILD_IN_SRC=""
129TERMUX_PKG_RM_AFTER_INSTALL=""
130TERMUX_PKG_DEPENDS=""
131TERMUX_PKG_HOMEPAGE=""
132TERMUX_PKG_DESCRIPTION="FIXME:Add description"
133TERMUX_PKG_FOLDERNAME=""
134TERMUX_PKG_KEEP_STATIC_LIBRARIES="false"
59f0d218 135TERMUX_PKG_ESSENTIAL=""
a8c61c7d 136TERMUX_PKG_CONFLICTS="" # https://www.debian.org/doc/debian-policy/ch-relationships.html#s-conflicts
768ce14e 137TERMUX_PKG_REPLACES=""
59f0d218 138TERMUX_PKG_CONFFILES=""
7ad25005 139TERMUX_PKG_INCLUDE_IN_DEVPACKAGE=""
28dc0ace 140TERMUX_PKG_DEVPACKAGE_DEPENDS=""
59f0d218
FF
141# Set if a host build should be done in TERMUX_PKG_HOSTBUILD_DIR:
142TERMUX_PKG_HOSTBUILD=""
48670d1b 143TERMUX_PKG_MAINTAINER="Fredrik Fornwall @fornwall"
b1d8dacd 144TERMUX_PKG_CLANG=no
59f0d218
FF
145
146# Cleanup old state
a1a58436 147rm -Rf $TERMUX_PKG_BUILDDIR $TERMUX_PKG_PACKAGEDIR $TERMUX_PKG_SRCDIR $TERMUX_PKG_TMPDIR $TERMUX_PKG_MASSAGEDIR
5822f920 148
59f0d218
FF
149# If $TERMUX_PREFIX already exists, it may have been built for a different arch
150TERMUX_ARCH_FILE=/data/TERMUX_ARCH
151if [ -f "${TERMUX_ARCH_FILE}" ]; then
152 TERMUX_PREVIOUS_ARCH=`cat $TERMUX_ARCH_FILE`
153 if [ $TERMUX_PREVIOUS_ARCH != $TERMUX_ARCH ]; then
154 TERMUX_DATA_BACKUPDIRS=$TERMUX_TOPDIR/_databackups
155 mkdir -p $TERMUX_DATA_BACKUPDIRS
156 TERMUX_DATA_PREVIOUS_BACKUPDIR=$TERMUX_DATA_BACKUPDIRS/$TERMUX_PREVIOUS_ARCH
157 TERMUX_DATA_CURRENT_BACKUPDIR=$TERMUX_DATA_BACKUPDIRS/$TERMUX_ARCH
59f0d218
FF
158 # Save current /data (removing old backup if any)
159 if test -e $TERMUX_DATA_PREVIOUS_BACKUPDIR; then
160 echo "ERROR: Directory already exists"
161 exit 1
162 fi
163 mv /data/data $TERMUX_DATA_PREVIOUS_BACKUPDIR
164 # Restore new one (if any)
165 if [ -d $TERMUX_DATA_CURRENT_BACKUPDIR ]; then
59f0d218
FF
166 mv $TERMUX_DATA_CURRENT_BACKUPDIR /data/data
167 fi
168 fi
169fi
170echo $TERMUX_ARCH > $TERMUX_ARCH_FILE
171
2c1aa558 172# Ensure folders present (but not $TERMUX_PKG_SRCDIR, it will be created in build)
fb45772b 173mkdir -p $TERMUX_PKG_BUILDDIR $TERMUX_PKG_PACKAGEDIR $TERMUX_PKG_TMPDIR $TERMUX_PKG_CACHEDIR $TERMUX_PKG_MASSAGEDIR $PKG_CONFIG_LIBDIR $TERMUX_PREFIX/{bin,etc,lib,libexec,share,tmp,include}
2c1aa558 174
19fb617a 175termux_download() {
e239964b
FF
176 URL="$1"
177 DESTINATION="$2"
178
179 TMPFILE=`mktemp $TERMUX_PKG_TMPDIR/download.$TERMUX_PKG_NAME.XXXXXXXXX`
180 echo "Downloading ${URL}"
6ad2991c
M
181 TRYMAX=6
182 for try in $(seq 1 $TRYMAX); do
e239964b 183 if curl -L --fail --retry 2 -o "$TMPFILE" "$URL"; then
aea30235 184 local ACTUAL_CHECKSUM=`sha256sum $TMPFILE | cut -f 1 -d ' '`
e239964b
FF
185 if [ $# = 3 ]; then
186 # Optional checksum argument:
aea30235
FF
187 local EXPECTED=$3
188 if [ $EXPECTED != $ACTUAL_CHECKSUM ]; then
a75313ee
FF
189 >&2 printf "Wrong checksum for %s:\nExpected: %s\nActual: %s\n" \
190 "$URL" "$EXPECTED" "$ACTUAL_CHECKSUM"
aea30235
FF
191 exit 1
192 fi
e239964b 193 else
a75313ee
FF
194 printf "No validation of checksum for %s:\nActual: %s\n" \
195 "$URL" "$ACTUAL_CHECKSUM"
e239964b
FF
196 fi
197 mv "$TMPFILE" "$DESTINATION"
198 return
199 else
6ad2991c 200 echo "Download of $1 failed (attempt $try/$TRYMAX)" 1>&2
e239964b
FF
201 sleep 45
202 fi
203 done
204
205 echo "Failed to download $1 - exiting" 1>&2
206 exit 1
19fb617a
FF
207}
208
19fb617a
FF
209# Have a debian-binary file ready for deb packaging:
210test ! -f $TERMUX_COMMON_CACHEDIR/debian-binary && echo "2.0" > $TERMUX_COMMON_CACHEDIR/debian-binary
211# The host tuple that may be given to --host configure flag, but normally autodetected so not needed explicitly
bb97a729 212TERMUX_HOST_TUPLE=`sh $TERMUX_SCRIPTDIR/scripts/config.guess`
19fb617a 213
2c1aa558
FF
214# Make $TERMUX_PREFIX/bin/sh executable on the builder, so that build script can assume that it works
215# on both builder and host later on:
216ln -f -s /bin/sh $TERMUX_PREFIX/bin/sh
217
59f0d218 218TERMUX_ELF_CLEANER=$TERMUX_COMMON_CACHEDIR/termux-elf-cleaner
0ae97c5e 219TERMUX_ELF_CLEANER_SRC=$TERMUX_SCRIPTDIR/packages/termux-elf-cleaner/termux-elf-cleaner.cpp
637f22d1
FF
220if [ $TERMUX_ELF_CLEANER_SRC -nt $TERMUX_ELF_CLEANER ]; then
221 g++ -std=c++11 -Wall -Wextra -pedantic -Os $TERMUX_ELF_CLEANER_SRC -o $TERMUX_ELF_CLEANER
59f0d218
FF
222fi
223
59f0d218
FF
224# Run just after sourcing $TERMUX_PKG_BUILDER_SCRIPT
225termux_step_extract_package () {
226 if [ -z "${TERMUX_PKG_SRCURL:=""}" ]; then
227 mkdir -p $TERMUX_PKG_SRCDIR
228 return
229 fi
230 cd $TERMUX_PKG_TMPDIR
231 filename=`basename $TERMUX_PKG_SRCURL`
232 file=$TERMUX_PKG_CACHEDIR/$filename
e239964b
FF
233 test ! -f $file && termux_download $TERMUX_PKG_SRCURL $file $TERMUX_PKG_SHA256
234
59f0d218
FF
235 if [ "x$TERMUX_PKG_FOLDERNAME" = "x" ]; then
236 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`
237 folder=`echo $folder | sed 's/_/-/'` # dpkg uses _ in tar filename, but - in folder
238 else
239 folder=$TERMUX_PKG_FOLDERNAME
240 fi
241 rm -Rf $folder
242 if [ ${file##*.} = zip ]; then
200e43d4 243 unzip -q $file
59f0d218
FF
244 else
245 $TERMUX_TAR xf $file
246 fi
247 mv $folder $TERMUX_PKG_SRCDIR
248}
249
250termux_step_post_extract_package () {
251 return
252}
253
254# Perform a host build. Will be called in $TERMUX_PKG_HOSTBUILD_DIR.
255# After termux_step_post_extract_package() and before termux_step_patch_package()
256termux_step_host_build () {
257 $TERMUX_PKG_SRCDIR/configure ${TERMUX_PKG_EXTRA_HOSTBUILD_CONFIGURE_ARGS}
4663ac70 258 make -j $TERMUX_MAKE_PROCESSES
59f0d218
FF
259}
260
261# This should not be overridden
262termux_step_patch_package () {
263 cd $TERMUX_PKG_SRCDIR
8f7dda83
FF
264 # Suffix patch with ".patch32" or ".patch64" to only apply for these bitnesses:
265 for patch in $TERMUX_PKG_BUILDER_DIR/*.patch{$TERMUX_ARCH_BITS,}; do
dc6476e9
FF
266 test -f $patch && sed "s%\@TERMUX_PREFIX\@%${TERMUX_PREFIX}%g" $patch | \
267 sed "s%\@TERMUX_HOME\@%${TERMUX_ANDROID_HOME}%g" | \
a0057943 268 patch --silent -p1
59f0d218
FF
269 done
270
bb97a729
FF
271 find . -name config.sub -exec chmod u+w '{}' \; -exec cp $TERMUX_SCRIPTDIR/scripts/config.sub '{}' \;
272 find . -name config.guess -exec chmod u+w '{}' \; -exec cp $TERMUX_SCRIPTDIR/scripts/config.guess '{}' \;
59f0d218
FF
273}
274
275termux_step_pre_configure () {
276 return
277}
278
279termux_step_configure () {
280 if [ ! -e $TERMUX_PKG_SRCDIR/configure ]; then
281 return
282 fi
283
284 DISABLE_STATIC="--disable-static"
285 if [ "$TERMUX_PKG_EXTRA_CONFIGURE_ARGS" != "${TERMUX_PKG_EXTRA_CONFIGURE_ARGS/--enable-static/}" ]; then
286 # Do not --disable-static if package explicitly enables it (e.g. gdb needs enable-static to build)
287 DISABLE_STATIC=""
288 fi
289
290 DISABLE_NLS="--disable-nls"
291 if [ "$TERMUX_PKG_EXTRA_CONFIGURE_ARGS" != "${TERMUX_PKG_EXTRA_CONFIGURE_ARGS/--enable-nls/}" ]; then
292 # Do not --disable-nls if package explicitly enables it (for gettext itself)
293 DISABLE_NLS=""
294 fi
295
296 ENABLE_SHARED="--enable-shared"
297 if [ "$TERMUX_PKG_EXTRA_CONFIGURE_ARGS" != "${TERMUX_PKG_EXTRA_CONFIGURE_ARGS/--disable-shared/}" ]; then
298 ENABLE_SHARED=""
299 fi
300 HOST_FLAG="--host=$TERMUX_HOST_PLATFORM"
301 if [ "$TERMUX_PKG_EXTRA_CONFIGURE_ARGS" != "${TERMUX_PKG_EXTRA_CONFIGURE_ARGS/--host=/}" ]; then
302 HOST_FLAG=""
303 fi
304
305 # Some packages provides a $PKG-config script which some configure scripts pickup instead of pkg-config:
306 mkdir $TERMUX_PKG_TMPDIR/config-scripts
307 for f in $TERMUX_PREFIX/bin/*config; do
308 test -f $f && cp $f $TERMUX_PKG_TMPDIR/config-scripts
309 done
59f0d218
FF
310 export PATH=$TERMUX_PKG_TMPDIR/config-scripts:$PATH
311
150f95af
FF
312 # See http://wiki.buici.com/xwiki/bin/view/Programing+C+and+C%2B%2B/Autoconf+and+RPL_MALLOC
313 # about this problem which may cause linker errors in test scripts not undef:ing malloc and
314 # also cause problems with e.g. malloc interceptors such as libgc:
315 local AVOID_AUTOCONF_WRAPPERS="ac_cv_func_malloc_0_nonnull=yes ac_cv_func_realloc_0_nonnull=yes"
d2dfadf1
IN
316 # Similarly, disable gnulib's rpl_getcwd(). It returns the wrong value, affecting zile. See
317 # <https://github.com/termux/termux-packages/issues/76>.
d6fcd836
FF
318 AVOID_AUTOCONF_WRAPPERS+=" gl_cv_func_getcwd_null=yes gl_cv_func_getcwd_posix_signature=yes gl_cv_func_getcwd_path_max=yes gl_cv_func_getcwd_abort_bug=no"
319 AVOID_AUTOCONF_WRAPPERS+=" gl_cv_header_working_fcntl_h=yes gl_cv_func_fcntl_f_dupfd_cloexec=yes gl_cv_func_fcntl_f_dupfd_works=yes"
d6012486
FF
320 # Remove rpl_gettimeofday reference when building at least coreutils:
321 AVOID_AUTOCONF_WRAPPERS+=" gl_cv_func_tzset_clobber=no gl_cv_func_gettimeofday_clobber=no gl_cv_func_gettimeofday_posix_signature=yes"
150f95af 322
6c269245 323 env $AVOID_AUTOCONF_WRAPPERS $TERMUX_PKG_SRCDIR/configure \
59f0d218
FF
324 --disable-dependency-tracking \
325 --prefix=$TERMUX_PREFIX \
326 --disable-rpath --disable-rpath-hack \
327 $HOST_FLAG \
328 $TERMUX_PKG_EXTRA_CONFIGURE_ARGS \
329 $DISABLE_NLS \
330 $ENABLE_SHARED \
331 $DISABLE_STATIC \
332 --libexecdir=$TERMUX_PREFIX/libexec
333}
334
335termux_step_post_configure () {
336 return
337}
338
339termux_step_pre_make () {
340 return
341}
342
343termux_step_make () {
344 if ls *akefile &> /dev/null; then
345 if [ -z "$TERMUX_PKG_EXTRA_MAKE_ARGS" ]; then
346 make -j $TERMUX_MAKE_PROCESSES
347 else
348 make -j $TERMUX_MAKE_PROCESSES ${TERMUX_PKG_EXTRA_MAKE_ARGS}
349 fi
350 fi
351}
352
353termux_step_make_install () {
354 if ls *akefile &> /dev/null; then
355 : ${TERMUX_PKG_MAKE_INSTALL_TARGET:="install"}:
356 # Some packages have problem with parallell install, and it does not buy much, so use -j 1.
357 if [ -z "$TERMUX_PKG_EXTRA_MAKE_ARGS" ]; then
358 make -j 1 ${TERMUX_PKG_MAKE_INSTALL_TARGET}
359 else
360 make -j 1 ${TERMUX_PKG_EXTRA_MAKE_ARGS} ${TERMUX_PKG_MAKE_INSTALL_TARGET}
361 fi
362 fi
363}
364
365termux_step_post_make_install () {
366 return
367}
368
369termux_step_extract_into_massagedir () {
370 TARBALL_ORIG=$TERMUX_PKG_PACKAGEDIR/${TERMUX_PKG_NAME}_orig.tar.gz
371
372 # Build diff tar with what has changed during the build:
373 cd $TERMUX_PREFIX
374 $TERMUX_TAR -N $TERMUX_BUILD_TS_FILE -czf $TARBALL_ORIG .
375
376 # Extract tar in order to massage it
377 mkdir -p $TERMUX_PKG_MASSAGEDIR/$TERMUX_PREFIX
378 cd $TERMUX_PKG_MASSAGEDIR/$TERMUX_PREFIX
379 $TERMUX_TAR xf $TARBALL_ORIG
380}
381
382termux_step_massage () {
383 cd $TERMUX_PKG_MASSAGEDIR/$TERMUX_PREFIX
384
385 # Remove lib/charset.alias which is installed by gettext-using packages:
386 rm -f lib/charset.alias
a0c80d57 387
59f0d218
FF
388 # Remove non-english man pages:
389 test -d share/man && (cd share/man; for f in `ls | grep -v man`; do rm -Rf $f; done )
a0c80d57
FF
390
391 if [ -z ${TERMUX_PKG_KEEP_INFOPAGES+x} ]; then
392 # Remove info pages:
393 rm -Rf share/info
394 fi
395
9db621c0
FF
396 # Remove locale files we're not interested in::
397 rm -Rf share/locale
398 if [ -z ${TERMUX_PKG_KEEP_SHARE_DOC+x} ]; then
399 # Remove info pages:
400 rm -Rf share/doc
401 fi
a0c80d57 402
59f0d218
FF
403 # Remove old kept libraries (readline):
404 find . -name '*.old' -delete
a0c80d57
FF
405
406 # Remove static libraries:
59f0d218
FF
407 if [ $TERMUX_PKG_KEEP_STATIC_LIBRARIES = "false" ]; then
408 find . -name '*.a' -delete
409 find . -name '*.la' -delete
410 fi
411
1d678bce 412 # Move over sbin to bin:
59f0d218
FF
413 for file in sbin/*; do if test -f $file; then mv $file bin/; fi; done
414
40534bae
FF
415 # Remove world permissions and add write permissions.
416 # The -f flag is used to suppress warnings about dangling symlinks (such
417 # as ones to /system/... which may not exist on the build machine):
418 find . -exec chmod -f u+w,o-rwx \{\} \;
59f0d218 419 if [ "$TERMUX_DEBUG" = "" ]; then
e5b151a0
FF
420 # Strip binaries. file(1) may fail for certain unusual files, so disable pipefail.
421 set +e +o pipefail
422 find . -type f | xargs -r file | grep -E "(executable|shared object)" | grep ELF | cut -f 1 -d : | \
2497d957 423 xargs -r $STRIP --strip-unneeded --preserve-dates
e5b151a0 424 set -e -o pipefail
59f0d218 425 fi
1d678bce
FF
426 # Remove DT_ entries which the android 5.1 linker warns about:
427 find . -type f -print0 | xargs -r -0 $TERMUX_ELF_CLEANER
428
429 # Fix shebang paths:
430 for file in `find -L . -type f`; do
431 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
432 done
59f0d218
FF
433
434 test ! -z "$TERMUX_PKG_RM_AFTER_INSTALL" && rm -Rf $TERMUX_PKG_RM_AFTER_INSTALL
435
436 find . -type d -empty -delete # Remove empty directories
437
438 # Sub packages:
439 if [ -d include -a -z "${TERMUX_PKG_NO_DEVELSPLIT}" ]; then
440 # Add virtual -dev sub package if there are include files:
441 _DEVEL_SUBPACKAGE_FILE=$TERMUX_PKG_TMPDIR/${TERMUX_PKG_NAME}-dev.subpackage.sh
7ad25005 442 echo TERMUX_SUBPKG_INCLUDE=\"include share/man/man3 lib/pkgconfig share/aclocal $TERMUX_PKG_INCLUDE_IN_DEVPACKAGE\" > $_DEVEL_SUBPACKAGE_FILE
59f0d218 443 echo TERMUX_SUBPKG_DESCRIPTION=\"Development files for ${TERMUX_PKG_NAME}\" >> $_DEVEL_SUBPACKAGE_FILE
28dc0ace
FF
444 if [ -n "$TERMUX_PKG_DEVPACKAGE_DEPENDS" ]; then
445 echo TERMUX_SUBPKG_DEPENDS=\"$TERMUX_PKG_NAME,$TERMUX_PKG_DEVPACKAGE_DEPENDS\" >> $_DEVEL_SUBPACKAGE_FILE
446 else
447 echo TERMUX_SUBPKG_DEPENDS=\"$TERMUX_PKG_NAME\" >> $_DEVEL_SUBPACKAGE_FILE
448 fi
ad04b25a
FF
449 if [ x$TERMUX_PKG_CONFLICTS != x ]; then
450 # Assume that dev packages conflicts as well.
451 echo "TERMUX_SUBPKG_CONFLICTS=${TERMUX_PKG_CONFLICTS}-dev" >> $_DEVEL_SUBPACKAGE_FILE
452 fi
59f0d218
FF
453 fi
454 # Now build all sub packages
455 rm -Rf $TERMUX_TOPDIR/$TERMUX_PKG_NAME/subpackages
456 for subpackage in $TERMUX_PKG_BUILDER_DIR/*.subpackage.sh $TERMUX_PKG_TMPDIR/*subpackage.sh; do
457 test ! -f $subpackage && continue
458 SUB_PKG_NAME=`basename $subpackage .subpackage.sh`
459 # Default value is same as main package, but sub package may override:
460 TERMUX_SUBPKG_PLATFORM_INDEPENDENT=$TERMUX_PKG_PLATFORM_INDEPENDENT
59f0d218
FF
461 SUB_PKG_DIR=$TERMUX_TOPDIR/$TERMUX_PKG_NAME/subpackages/$SUB_PKG_NAME
462 TERMUX_SUBPKG_DEPENDS=""
ad04b25a 463 TERMUX_SUBPKG_CONFLICTS=""
59f0d218
FF
464 SUB_PKG_MASSAGE_DIR=$SUB_PKG_DIR/massage/$TERMUX_PREFIX
465 SUB_PKG_PACKAGE_DIR=$SUB_PKG_DIR/package
466 mkdir -p $SUB_PKG_MASSAGE_DIR $SUB_PKG_PACKAGE_DIR
467
468 . $subpackage
469
470 for includeset in $TERMUX_SUBPKG_INCLUDE; do
471 _INCLUDE_DIRSET=`dirname $includeset`
472 test "$_INCLUDE_DIRSET" = "." && _INCLUDE_DIRSET=""
4432ca97
FF
473 if [ -e $includeset -o -L $includeset ]; then
474 # Add the -L clause to handle relative symbolic links:
59f0d218
FF
475 mkdir -p $SUB_PKG_MASSAGE_DIR/$_INCLUDE_DIRSET
476 mv $includeset $SUB_PKG_MASSAGE_DIR/$_INCLUDE_DIRSET
477 fi
478 done
479
480 SUB_PKG_ARCH=$TERMUX_ARCH
481 test -n "$TERMUX_SUBPKG_PLATFORM_INDEPENDENT" && SUB_PKG_ARCH=all
482
483 cd $SUB_PKG_DIR/massage
484 SUB_PKG_INSTALLSIZE=`du -sk . | cut -f 1`
b96b5b14 485 $TERMUX_TAR -cJf $SUB_PKG_PACKAGE_DIR/data.tar.xz .
59f0d218
FF
486
487 mkdir -p DEBIAN
488 cd DEBIAN
489 cat > control <<HERE
490Package: $SUB_PKG_NAME
491Architecture: ${SUB_PKG_ARCH}
492Installed-Size: ${SUB_PKG_INSTALLSIZE}
493Maintainer: $TERMUX_PKG_MAINTAINER
494Version: $TERMUX_PKG_FULLVERSION
495Description: $TERMUX_SUBPKG_DESCRIPTION
496Homepage: $TERMUX_PKG_HOMEPAGE
497HERE
498 test ! -z "$TERMUX_SUBPKG_DEPENDS" && echo "Depends: $TERMUX_SUBPKG_DEPENDS" >> control
ad04b25a 499 test ! -z "$TERMUX_SUBPKG_CONFLICTS" && echo "Conflicts: $TERMUX_SUBPKG_CONFLICTS" >> control
b96b5b14 500 $TERMUX_TAR -cJf $SUB_PKG_PACKAGE_DIR/control.tar.xz .
59f0d218
FF
501
502 # Create the actual .deb file:
a0057943 503 TERMUX_SUBPKG_DEBFILE=$TERMUX_DEBDIR/${SUB_PKG_NAME}_${TERMUX_PKG_FULLVERSION}_${SUB_PKG_ARCH}.deb
59f0d218
FF
504 ar cr $TERMUX_SUBPKG_DEBFILE \
505 $TERMUX_COMMON_CACHEDIR/debian-binary \
b96b5b14 506 $SUB_PKG_PACKAGE_DIR/control.tar.xz \
59f0d218
FF
507 $SUB_PKG_PACKAGE_DIR/data.tar.xz
508 if [ "$TERMUX_PROCESS_DEB" != "" ]; then
509 $TERMUX_PROCESS_DEB $TERMUX_SUBPKG_DEBFILE
510 fi
511
512 # Go back to main package:
513 cd $TERMUX_PKG_MASSAGEDIR/$TERMUX_PREFIX
514 done
515
516 # .. remove empty directories (NOTE: keep this last):
517 find . -type d -empty -delete
518 # Make sure user can read and write all files (problem with dpkg otherwise):
519 chmod -R u+rw .
520}
521
522termux_step_post_massage () {
523 return
524}
525
526termux_step_create_debscripts () {
527 return
528}
529
3a189d89 530termux_setup_golang () {
f6a56287
FF
531 export GOOS=android
532 export CGO_ENABLED=1
533 export GO_LDFLAGS="-extldflags=-pie"
534 if [ "$TERMUX_ARCH" = "arm" ]; then
535 export GOARCH=arm
536 export GOARM=7
537 elif [ "$TERMUX_ARCH" = "i686" ]; then
538 export GOARCH=386
539 export GO386=sse2
540 elif [ "$TERMUX_ARCH" = "aarch64" ]; then
541 export GOARCH=arm64
542 elif [ "$TERMUX_ARCH" = "x86_64" ]; then
543 export GOARCH=amd64
544 else
545 echo "ERROR: Unsupported arch: $TERMUX_ARCH"
546 exit 1
547 fi
548
a8dcbfb6 549 local TERMUX_GO_VERSION=go1.7.4
3a189d89
FF
550 local TERMUX_GO_PLATFORM=linux-amd64
551 test `uname` = "Darwin" && TERMUX_GO_PLATFORM=darwin-amd64
552
553 export TERMUX_BUILDGO_FOLDER=$TERMUX_COMMON_CACHEDIR/${TERMUX_GO_VERSION}.${TERMUX_GO_PLATFORM}
554 export GOROOT=$TERMUX_BUILDGO_FOLDER
555 export PATH=$GOROOT/bin:$PATH
556
557 if [ -d $TERMUX_BUILDGO_FOLDER ]; then return; fi
558
559 local TERMUX_BUILDGO_TAR=$TERMUX_COMMON_CACHEDIR/${TERMUX_GO_VERSION}.${TERMUX_GO_PLATFORM}.tar.gz
560 rm -Rf $TERMUX_COMMON_CACHEDIR/go $TERMUX_BUILDGO_FOLDER
32db9f33 561 termux_download https://storage.googleapis.com/golang/${TERMUX_GO_VERSION}.${TERMUX_GO_PLATFORM}.tar.gz $TERMUX_BUILDGO_TAR
3a189d89
FF
562 ( cd $TERMUX_COMMON_CACHEDIR; tar xf $TERMUX_BUILDGO_TAR; mv go $TERMUX_BUILDGO_FOLDER; rm $TERMUX_BUILDGO_TAR )
563}
564
59f0d218
FF
565source $TERMUX_PKG_BUILDER_SCRIPT
566
b0c46014 567if [ -n "${TERMUX_PKG_BLACKLISTED_ARCHES:=""}" -a "$TERMUX_PKG_BLACKLISTED_ARCHES" != "${TERMUX_PKG_BLACKLISTED_ARCHES/$TERMUX_ARCH/}" ]; then
9a104bda
FF
568 echo "Skipping building $TERMUX_PKG_NAME for arch $TERMUX_ARCH"
569 exit 0
570fi
571
fc89df4d
FF
572if [ -z "${TERMUX_SKIP_DEPCHECK:=""}" ]; then
573 for p in `./scripts/buildorder.py $TERMUX_PKG_NAME`; do
574 if [ "$p" != "$TERMUX_PKG_NAME" ]; then
575 echo "Building dependency $p if necessary..."
576 ./build-package.sh -s $p
577 fi
578 done
579fi
580
9247ce47
FF
581# Compute full version:
582TERMUX_PKG_FULLVERSION=$TERMUX_PKG_VERSION
583if [ "$TERMUX_PKG_BUILD_REVISION" != "0" -o "$TERMUX_PKG_FULLVERSION" != "${TERMUX_PKG_FULLVERSION/-/}" ]; then
584 # "0" is the default revision, so only include it if the upstream versions contains "-" itself
585 TERMUX_PKG_FULLVERSION+="-$TERMUX_PKG_BUILD_REVISION"
586fi
587
9b741f49 588if [ -z "$TERMUX_DEBUG" -a -e "/data/data/.built-packages/$TERMUX_PKG_NAME" ]; then
9247ce47
FF
589 if [ "`cat /data/data/.built-packages/$TERMUX_PKG_NAME`" = "$TERMUX_PKG_FULLVERSION" ]; then
590 echo "$TERMUX_PKG_NAME@$TERMUX_PKG_FULLVERSION built - skipping (rm /data/data/.built-packages/$TERMUX_PKG_NAME to force rebuild)"
ff7aaad1
FF
591 exit 0
592 fi
593fi
594
9a104bda 595echo "termux - building $1 for arch $TERMUX_ARCH..."
a75313ee 596test -t 1 && printf "\033]0;%s...\007" "$1"
9a104bda 597
b1d8dacd 598# Compute standalone toolchain dir, bitness of arch and name of host platform:
fa05ce46
FF
599TERMUX_STANDALONE_TOOLCHAIN="$TERMUX_TOPDIR/_lib/toolchain-${TERMUX_ARCH}-ndk${TERMUX_NDK_VERSION}-api${TERMUX_API_LEVEL}"
600# Bump the below version if a change is made in toolchain setup to ensure
b1d8dacd 601# that everyone gets an updated toolchain:
66f3991f 602TERMUX_STANDALONE_TOOLCHAIN+="-v3"
b1d8dacd
FF
603
604# We put this after system PATH to avoid picking up toolchain stripped python
605export PATH=$PATH:$TERMUX_STANDALONE_TOOLCHAIN/bin
606
b1d8dacd
FF
607export AR=$TERMUX_HOST_PLATFORM-ar
608if [ "$TERMUX_PKG_CLANG" = "no" ]; then
609 export AS=${TERMUX_HOST_PLATFORM}-gcc
610 export CC=$TERMUX_HOST_PLATFORM-gcc
611 export CXX=$TERMUX_HOST_PLATFORM-g++
15963528 612 _SPECSFLAG=" -specs=$TERMUX_SCRIPTDIR/termux.spec"
b1d8dacd
FF
613else
614 export AS=${TERMUX_HOST_PLATFORM}-gcc
615 export CC=$TERMUX_HOST_PLATFORM-clang
616 export CXX=$TERMUX_HOST_PLATFORM-clang++
617 # TODO: clang does not have specs file, how to ensure pie
618 # binaries gets built?
619 _SPECSFLAG=""
620fi
621export CPP=${TERMUX_HOST_PLATFORM}-cpp
622export CC_FOR_BUILD=gcc
623export LD=$TERMUX_HOST_PLATFORM-ld
624export OBJDUMP=$TERMUX_HOST_PLATFORM-objdump
625# Setup pkg-config for cross-compiling:
626export PKG_CONFIG=$TERMUX_STANDALONE_TOOLCHAIN/bin/${TERMUX_HOST_PLATFORM}-pkg-config
627export RANLIB=$TERMUX_HOST_PLATFORM-ranlib
628export READELF=$TERMUX_HOST_PLATFORM-readelf
629export STRIP=$TERMUX_HOST_PLATFORM-strip
630
631export CFLAGS="$_SPECSFLAG"
632export LDFLAGS="$_SPECSFLAG -L${TERMUX_PREFIX}/lib"
34317fac 633# Android 7 started to support DT_RUNPATH (but not DT_RPATH), so we may want
1a8d12c2
FF
634# LDFLAGS+="-Wl,-rpath=$TERMUX_PREFIX/lib -Wl,--enable-new-dtags"
635# and no longer remove DT_RUNPATH in termux-elf-cleaner.
b1d8dacd
FF
636
637if [ "$TERMUX_ARCH" = "arm" ]; then
638 CFLAGS+=" -march=armv7-a -mfpu=neon -mfloat-abi=softfp"
639 # "first flag instructs the linker to pick libgcc.a, libgcov.a, and
640 # crt*.o, which are tailored for armv7-a"
641 # - https://developer.android.com/ndk/guides/standalone_toolchain.html
642 LDFLAGS+=" -march=armv7-a -Wl,--fix-cortex-a8"
643elif [ $TERMUX_ARCH = "i686" ]; then
644 # From $NDK/docs/CPU-ARCH-ABIS.html:
645 CFLAGS+=" -march=i686 -msse3 -mstackrealign -mfpmath=sse"
646elif [ $TERMUX_ARCH = "aarch64" ]; then
647 LDFLAGS+=" -Wl,-rpath-link,$TERMUX_PREFIX/lib"
648 LDFLAGS+=" -Wl,-rpath-link,$TERMUX_STANDALONE_TOOLCHAIN/sysroot/usr/lib"
649elif [ $TERMUX_ARCH = "x86_64" ]; then
650 :
651else
652 echo "Error: Invalid arch '$TERMUX_ARCH' - support arches are 'arm', 'i686', 'aarch64', 'x86_64'"
653 exit 1
654fi
655
656if [ -n "$TERMUX_DEBUG" ]; then
1d678bce 657 CFLAGS+=" -g3 -O1 -fstack-protector --param ssp-buffer-size=4 -D_FORTIFY_SOURCE=2"
b1d8dacd
FF
658else
659 CFLAGS+=" -Os"
660fi
661
662export CXXFLAGS="$CFLAGS"
663export CPPFLAGS="-I${TERMUX_PREFIX}/include"
664
665export ac_cv_func_getpwent=no
666export ac_cv_func_getpwnam=no
667export ac_cv_func_getpwuid=no
668
669if [ ! -d $TERMUX_STANDALONE_TOOLCHAIN ]; then
b1d8dacd
FF
670 # Do not put toolchain in place until we are done with setup, to avoid having a half setup
671 # toolchain left in place if something goes wrong (or process is just aborted):
672 _TERMUX_TOOLCHAIN_TMPDIR=${TERMUX_STANDALONE_TOOLCHAIN}-tmp
673 rm -Rf $_TERMUX_TOOLCHAIN_TMPDIR
674
fa05ce46
FF
675 _NDK_ARCHNAME=$TERMUX_ARCH
676 if [ $TERMUX_ARCH = "aarch64" ]; then
677 _NDK_ARCHNAME=arm64
678 elif [ $TERMUX_ARCH = "i686" ]; then
679 _NDK_ARCHNAME=x86
680 fi
681 $NDK/build/tools/make_standalone_toolchain.py \
682 --api $TERMUX_API_LEVEL \
683 --arch $_NDK_ARCHNAME \
684 --install-dir $_TERMUX_TOOLCHAIN_TMPDIR
2497d957 685
fa05ce46
FF
686 if [ "arm" = $TERMUX_ARCH ]; then
687 # Fix to allow e.g. <bits/c++config.h> to be included:
688 cp $_TERMUX_TOOLCHAIN_TMPDIR/include/c++/4.9.x/arm-linux-androideabi/armv7-a/bits/* \
689 $_TERMUX_TOOLCHAIN_TMPDIR/include/c++/4.9.x/bits
690 fi
2497d957 691
b1d8dacd 692 cd $_TERMUX_TOOLCHAIN_TMPDIR/sysroot
2497d957 693
b1d8dacd
FF
694 for f in $TERMUX_SCRIPTDIR/ndk_patches/*.patch; do
695 sed "s%\@TERMUX_PREFIX\@%${TERMUX_PREFIX}%g" $f | \
696 sed "s%\@TERMUX_HOME\@%${TERMUX_ANDROID_HOME}%g" | \
697 patch --silent -p1;
698 done
2497d957 699 # elf.h is taken from glibc since the elf.h in the NDK is lacking.
b1d8dacd
FF
700 # sysexits.h is header-only and used by a few programs.
701 cp $TERMUX_SCRIPTDIR/ndk_patches/{elf.h,sysexits.h} $_TERMUX_TOOLCHAIN_TMPDIR/sysroot/usr/include
2497d957 702
0c3f2697 703 $TERMUX_ELF_CLEANER usr/lib/*.so
2497d957 704
66f3991f
FF
705 # zlib is really version 1.2.8 in the Android platform (at least
706 # starting from Android 5), not older as the NDK headers claim.
707 for file in zconf.h zlib.h; do
708 curl -o $_TERMUX_TOOLCHAIN_TMPDIR/sysroot/usr/include/$file \
709 https://raw.githubusercontent.com/madler/zlib/v1.2.8/$file
710 done
711 unset file
712
b1d8dacd
FF
713 mv $_TERMUX_TOOLCHAIN_TMPDIR $TERMUX_STANDALONE_TOOLCHAIN
714fi
715
716if [ ! -f $TERMUX_PREFIX/lib/libstdc++.so ]; then
717 # Setup libgnustl_shared.so in $PREFIX/lib and libstdc++.so as a symlink to it,
718 # so that other C++ using packages links to it instead of the default android
719 # C++ library which does not support exceptions or STL:
720 # https://developer.android.com/ndk/guides/cpp-support.html
721 # We do however want to avoid installing this, to avoid problems # where e.g.
722 # libm.so on some i686 devices links against libstdc++.so.
723 # The libgnustl_shared.so library will be packaged in the libgnustl package
724 # which is part of the base Termux installation.
725 mkdir -p $TERMUX_PREFIX/lib
726 cd $TERMUX_PREFIX/lib
727 _STL_LIBFILE=$TERMUX_STANDALONE_TOOLCHAIN/${TERMUX_HOST_PLATFORM}/lib/libgnustl_shared.so
728 if [ $TERMUX_ARCH = arm ]; then
729 _STL_LIBFILE=$TERMUX_STANDALONE_TOOLCHAIN/${TERMUX_HOST_PLATFORM}/lib/armv7-a/libgnustl_shared.so
730 elif [ $TERMUX_ARCH = x86_64 ]; then
731 _STL_LIBFILE=$TERMUX_STANDALONE_TOOLCHAIN/${TERMUX_HOST_PLATFORM}/lib64/libgnustl_shared.so
732 fi
733 cp $_STL_LIBFILE .
734 ln -f -s libgnustl_shared.so libstdc++.so
735fi
736
204bde80
FF
737# Create pkg-config wrapper. We use path to host pkg-config to
738# avoid picking up a cross-compiled pkg-config later on.
739_HOST_PKGCONFIG=`which pkg-config`
740mkdir -p $TERMUX_STANDALONE_TOOLCHAIN/bin $PKG_CONFIG_LIBDIR
741cat > $PKG_CONFIG <<HERE
b1d8dacd
FF
742#!/bin/sh
743export PKG_CONFIG_DIR=
744export PKG_CONFIG_LIBDIR=$PKG_CONFIG_LIBDIR
b1d8dacd
FF
745exec $_HOST_PKGCONFIG "\$@"
746HERE
204bde80
FF
747chmod +x $PKG_CONFIG
748# Add a pkg-config file for the system zlib
749cat > $PKG_CONFIG_LIBDIR/zlib.pc <<HERE
b1d8dacd
FF
750Name: zlib
751Description: zlib compression library
66f3991f 752Version: 1.2.8
b1d8dacd
FF
753
754Requires:
204bde80 755Libs: -lz
b1d8dacd 756HERE
b1d8dacd 757
ab5f5c60
FF
758# Keep track of when build started so we can see what files have been created.
759# We start by sleeping so that any generated files above (such as zlib.pc) get
760# an older timestamp than the TERMUX_BUILD_TS_FILE.
761sleep 1
762TERMUX_BUILD_TS_FILE=$TERMUX_PKG_TMPDIR/timestamp_$TERMUX_PKG_NAME
763touch $TERMUX_BUILD_TS_FILE
b1d8dacd 764
59f0d218
FF
765# Start by extracting the package src into $TERMUX_PKG_SRCURL:
766termux_step_extract_package
767# Optional post processing:
768termux_step_post_extract_package
769
770# Optional host build:
771if [ "x$TERMUX_PKG_HOSTBUILD" != "x" ]; then
772 cd $TERMUX_PKG_SRCDIR
773 for patch in $TERMUX_PKG_BUILDER_DIR/*.patch.beforehostbuild; do
a0057943 774 test -f $patch && sed "s%\@TERMUX_PREFIX\@%${TERMUX_PREFIX}%g" $patch | patch --silent -p1
59f0d218
FF
775 done
776
777 if [ -f "$TERMUX_PKG_HOSTBUILD_DIR/TERMUX_BUILT_FOR_$TERMUX_PKG_VERSION" ]; then
778 echo "Using already built host build"
779 else
780 mkdir -p $TERMUX_PKG_HOSTBUILD_DIR
781 cd $TERMUX_PKG_HOSTBUILD_DIR
782
783 ORIG_AR=$AR; unset AR
784 ORIG_AS=$AS; unset AS
785 ORIG_CC=$CC; unset CC
786 ORIG_CXX=$CXX; unset CXX
787 ORIG_CPP=$CPP; unset CPP
788 ORIG_CFLAGS=$CFLAGS; unset CFLAGS
789 ORIG_CPPFLAGS=$CPPFLAGS; unset CPPFLAGS
790 ORIG_CXXFLAGS=$CXXFLAGS; unset CXXFLAGS
791 ORIG_LDFLAGS=$LDFLAGS; unset LDFLAGS
792 ORIG_RANLIB=$RANLIB; unset RANLIB
793 ORIG_LD=$LD; unset LD
794 ORIG_PKG_CONFIG=$PKG_CONFIG; unset PKG_CONFIG
795 ORIG_PKG_CONFIG_LIBDIR=$PKG_CONFIG_LIBDIR; unset PKG_CONFIG_LIBDIR
796 ORIG_STRIP=$STRIP; unset STRIP
797
798 termux_step_host_build
799 touch $TERMUX_PKG_HOSTBUILD_DIR/TERMUX_BUILT_FOR_$TERMUX_PKG_VERSION
800
801 export AR=$ORIG_AR
802 export AS=$ORIG_AS
803 export CC=$ORIG_CC
804 export CXX=$ORIG_CXX
805 export CPP=$ORIG_CPP
806 export CFLAGS=$ORIG_CFLAGS
807 export CPPFLAGS=$ORIG_CPPFLAGS
808 export CXXFLAGS=$ORIG_CXXFLAGS
809 export LDFLAGS=$ORIG_LDFLAGS
810 export RANLIB=$ORIG_RANLIB
811 export LD=$ORIG_LD
812 export PKG_CONFIG=$ORIG_PKG_CONFIG
813 export PKG_CONFIG_LIBDIR=$ORIG_PKG_CONFIG_LIBDIR
814 export STRIP=$ORIG_STRIP
815 fi
816fi
817
818if [ "$TERMUX_PKG_DEPENDS" != "${TERMUX_PKG_DEPENDS/libandroid-support/}" ]; then
819 # If using the android support library, link to it and include its headers as system headers:
820 export CPPFLAGS="$CPPFLAGS -isystem $TERMUX_PREFIX/include/libandroid-support"
821 export LDFLAGS="$LDFLAGS -landroid-support"
822fi
823
824if [ -n "$TERMUX_PKG_BUILD_IN_SRC" ]; then
825 echo "Building in src due to TERMUX_PKG_BUILD_IN_SRC being set" >> $TERMUX_PKG_BUILDDIR/BUILDING_IN_SRC.txt
826 TERMUX_PKG_BUILDDIR=$TERMUX_PKG_SRCDIR
827fi
828
829cd $TERMUX_PKG_BUILDDIR
830termux_step_patch_package
831cd $TERMUX_PKG_BUILDDIR
832termux_step_pre_configure
833cd $TERMUX_PKG_BUILDDIR
834termux_step_configure
835cd $TERMUX_PKG_BUILDDIR
836termux_step_post_configure
837cd $TERMUX_PKG_BUILDDIR
838termux_step_pre_make
839cd $TERMUX_PKG_BUILDDIR
840termux_step_make
841cd $TERMUX_PKG_BUILDDIR
842termux_step_make_install
843cd $TERMUX_PKG_BUILDDIR
844termux_step_post_make_install
845cd $TERMUX_PKG_MASSAGEDIR
846termux_step_extract_into_massagedir
58235144 847cd $TERMUX_PKG_MASSAGEDIR
59f0d218 848termux_step_massage
f1cb02a4 849cd $TERMUX_PKG_MASSAGEDIR/$TERMUX_PREFIX
59f0d218
FF
850termux_step_post_massage
851
852# Create data tarball containing files to package:
853cd $TERMUX_PKG_MASSAGEDIR
23d4b8b5 854if [ -z "${TERMUX_PKG_METAPACKAGE+x}" -a "`find . -type f`" = "" ]; then
59f0d218
FF
855 echo "ERROR: No files in package"
856 exit 1
857fi
b96b5b14 858$TERMUX_TAR -cJf $TERMUX_PKG_PACKAGEDIR/data.tar.xz .
59f0d218
FF
859
860# Get install size. This will be written as the "Installed-Size" deb field so is measured in 1024-byte blocks:
861TERMUX_PKG_INSTALLSIZE=`du -sk . | cut -f 1`
862
863# Create deb package:
864# NOTE: From here on TERMUX_ARCH is set to "all" if TERMUX_PKG_PLATFORM_INDEPENDENT is set by the package
865test -n "$TERMUX_PKG_PLATFORM_INDEPENDENT" && TERMUX_ARCH=all
866
867cd $TERMUX_PKG_MASSAGEDIR
868
869mkdir -p DEBIAN
870cat > DEBIAN/control <<HERE
871Package: $TERMUX_PKG_NAME
872Architecture: ${TERMUX_ARCH}
873Installed-Size: ${TERMUX_PKG_INSTALLSIZE}
874Maintainer: $TERMUX_PKG_MAINTAINER
875Version: $TERMUX_PKG_FULLVERSION
876Description: $TERMUX_PKG_DESCRIPTION
877Homepage: $TERMUX_PKG_HOMEPAGE
878HERE
879test ! -z "$TERMUX_PKG_DEPENDS" && echo "Depends: $TERMUX_PKG_DEPENDS" >> DEBIAN/control
880test ! -z "$TERMUX_PKG_ESSENTIAL" && echo "Essential: yes" >> DEBIAN/control
a8c61c7d 881test ! -z "$TERMUX_PKG_CONFLICTS" && echo "Conflicts: $TERMUX_PKG_CONFLICTS" >> DEBIAN/control
768ce14e 882test ! -z "$TERMUX_PKG_REPLACES" && echo "Replaces: $TERMUX_PKG_REPLACES" >> DEBIAN/control
59f0d218
FF
883
884# Create DEBIAN/conffiles (see https://www.debian.org/doc/debian-policy/ap-pkg-conffiles.html):
885for f in $TERMUX_PKG_CONFFILES; do echo $TERMUX_PREFIX/$f >> DEBIAN/conffiles; done
886# Allow packages to create arbitrary control files:
887cd DEBIAN
888termux_step_create_debscripts
889
b96b5b14
FF
890# Create control.tar.xz
891$TERMUX_TAR -cJf $TERMUX_PKG_PACKAGEDIR/control.tar.xz .
59f0d218 892# In the .deb ar file there should be a file "debian-binary" with "2.0" as the content:
a0057943 893TERMUX_PKG_DEBFILE=$TERMUX_DEBDIR/${TERMUX_PKG_NAME}_${TERMUX_PKG_FULLVERSION}_${TERMUX_ARCH}.deb
59f0d218 894# Create the actual .deb file:
a75313ee
FF
895ar cr "$TERMUX_PKG_DEBFILE" \
896 "$TERMUX_COMMON_CACHEDIR/debian-binary" \
897 "$TERMUX_PKG_PACKAGEDIR/control.tar.xz" \
898 "$TERMUX_PKG_PACKAGEDIR/data.tar.xz"
59f0d218
FF
899
900if [ "$TERMUX_PROCESS_DEB" != "" ]; then
a75313ee 901 $TERMUX_PROCESS_DEB "$TERMUX_PKG_DEBFILE"
59f0d218
FF
902fi
903
904echo "termux - build of '$1' done"
a75313ee 905test -t 1 && printf "\033]0;%s - DONE\007" "$1"
ff7aaad1
FF
906
907mkdir -p /data/data/.built-packages
9247ce47 908echo "$TERMUX_PKG_FULLVERSION" > "/data/data/.built-packages/$TERMUX_PKG_NAME"
59f0d218 909exit 0