1 # FIXME: We would like to enable checksums when downloading
2 # tar files, but they change each time as the tar metadata
3 # differs: https://github.com/google/gitiles/issues/84
4 TERMUX_PKG_HOMEPAGE
=http
://elinux.org
/Android_aapt
5 TERMUX_PKG_DESCRIPTION
="Android Asset Packaging Tool"
8 TERMUX_PKG_VERSION
=${_TAG_VERSION}.
${_TAG_REVISION}
10 TERMUX_PKG_BUILD_IN_SRC
=yes
11 TERMUX_PKG_DEPENDS
="libexpat, libpng, libzopfli"
13 termux_step_make_install
() {
14 local _TAGNAME
=${_TAG_VERSION}_r
${_TAG_REVISION}
16 SYSTEM_CORE_INCLUDE_TARFILE
=$TERMUX_PKG_CACHEDIR/system_core_include_
${_TAGNAME}.
tar.gz
17 test ! -f
$SYSTEM_CORE_INCLUDE_TARFILE && termux_download \
18 "https://android.googlesource.com/platform/system/core/+archive/android-$_TAGNAME/include.tar.gz" \
19 $SYSTEM_CORE_INCLUDE_TARFILE
21 ANDROIDFW_INCLUDE_TARFILE
=$TERMUX_PKG_CACHEDIR/androidfw_include_
${_TAGNAME}.
tar.gz
22 test ! -f
$ANDROIDFW_INCLUDE_TARFILE && termux_download \
23 "https://android.googlesource.com/platform/frameworks/base/+archive/android-$_TAGNAME/include/androidfw.tar.gz" \
24 $ANDROIDFW_INCLUDE_TARFILE
26 ANDROID_BASE_INCLUDE_TARFILE
=$TERMUX_PKG_CACHEDIR/android_base_include_
${_TAGNAME}.
tar.gz
27 test ! -f
$ANDROID_BASE_INCLUDE_TARFILE && termux_download \
28 "https://android.googlesource.com/platform/system/core/+archive/android-$_TAGNAME/base/include/android-base.tar.gz" \
29 $ANDROID_BASE_INCLUDE_TARFILE
31 local AOSP_INCLUDE_DIR
=$TERMUX_PREFIX/include
/aosp
32 mkdir
-p
$AOSP_INCLUDE_DIR
35 tar xf
$SYSTEM_CORE_INCLUDE_TARFILE
38 tar xf
$ANDROIDFW_INCLUDE_TARFILE
42 tar xf
$ANDROID_BASE_INCLUDE_TARFILE
44 patch -p0
< $TERMUX_PKG_BUILDER_DIR/log.h.
patch.txt
47 mkdir
-p
$TERMUX_PKG_SRCDIR/{libcutils
,androidfw
}
48 cd $TERMUX_PKG_SRCDIR/libcutils
49 LIBCUTILS_TARFILE
=$TERMUX_PKG_CACHEDIR/libcutils_
${_TAGNAME}.
tar.gz
50 test ! -f
$LIBCUTILS_TARFILE && termux_download \
51 "https://android.googlesource.com/platform/system/core/+archive/android-$_TAGNAME/libcutils.tar.gz" \
53 tar xf
$LIBCUTILS_TARFILE
54 patch -p0
< $TERMUX_PKG_BUILDER_DIR/libcutils-patch.txt
55 $CXX $CXXFLAGS -isystem
$AOSP_INCLUDE_DIR -c
-o sockets.o sockets.cpp
56 $CXX $CXXFLAGS -isystem
$AOSP_INCLUDE_DIR -c
-o sockets_unix.o sockets_unix.cpp
57 sed -i
's%include <sys/_system_properties.h>%include <sys/system_properties.h>%' properties.c
59 libcutils_common_sources
="\
76 libcutils_nonwindows_sources
="\
79 socket_inaddr_any_server_unix.c \
80 socket_local_client_unix.c \
81 socket_local_server_unix.c \
82 socket_loopback_client_unix.c \
83 socket_loopback_server_unix.c \
84 socket_network_client_unix.c \
90 -isystem
$AOSP_INCLUDE_DIR \
91 $libcutils_common_sources \
92 $libcutils_nonwindows_sources \
97 -o
$TERMUX_PREFIX/lib
/libandroid-cutils.so
102 local LIBUTILS_TARFILE
=$TERMUX_PKG_CACHEDIR/libutils_
${_TAGNAME}.
tar.gz
103 test ! -f
$LIBUTILS_TARFILE && termux_download \
104 "https://android.googlesource.com/platform/system/core/+archive/android-$_TAGNAME/libutils.tar.gz" \
107 local SAFE_IOP_TARFILE
=$TERMUX_PKG_CACHEDIR/safe_iop.
tar.gz
108 test ! -f
$SAFE_IOP_TARFILE && termux_download \
109 https
://android.googlesource.com
/platform
/external
/safe-iop
/+archive
/cd76f998688d145235de78ecd5b340d0eac9239d.
tar.gz \
111 local SAFE_IOP_DIR
=$TERMUX_PKG_TMPDIR/safe-iop
112 mkdir
-p
$SAFE_IOP_DIR
114 tar xf
$SAFE_IOP_TARFILE
115 mv src
/safe_iop.c src
/safe_iop.cpp
117 mkdir
$TERMUX_PKG_SRCDIR/libutils
118 cd $TERMUX_PKG_SRCDIR/libutils
119 tar xf
$LIBUTILS_TARFILE
126 LinearTransform.cpp \
143 $CXX $CXXFLAGS $CPPFLAGS $LDFLAGS \
145 '-DALOG_ASSERT(a,...)=' \
147 -isystem
$TERMUX_PREFIX/include
/aosp \
148 -isystem
$SAFE_IOP_DIR/include \
149 $SAFE_IOP_DIR/src
/safe_iop.cpp \
154 -o
$TERMUX_PREFIX/lib
/libandroid-utils.so
159 local LIBBASE_TARFILE
=$TERMUX_PKG_CACHEDIR/libbase_
${_TAGNAME}.
tar.gz
160 test ! -f
$LIBBASE_TARFILE && termux_download \
161 "https://android.googlesource.com/platform/system/core/+archive/android-${_TAGNAME}/base.tar.gz" \
163 mkdir
-p
$TERMUX_PKG_SRCDIR/libbase
164 cd $TERMUX_PKG_SRCDIR/libbase
165 tar xf
$LIBBASE_TARFILE
166 rm -Rf
$TERMUX_PREFIX/include
/aosp
/android-base
167 mv include
/android-base
$TERMUX_PREFIX/include
/aosp
168 patch -p1
< $TERMUX_PKG_BUILDER_DIR/libbase-patch.txt
172 parsenetaddress.cpp \
176 libbase_linux_src_files
="\
178 # __USE_BSD for DEFFILEMODE to be defined by <sys/stat.h>.
179 $CXX $CXXFLAGS $CPPFLAGS \
183 -isystem
$AOSP_INCLUDE_DIR \
184 $libbase_src_files $libbase_linux_src_files \
187 -o
$TERMUX_PREFIX/lib
/libandroid-base.so
190 # Build libziparchive:
191 LIBZIPARCHIVE_TARFILE
=$TERMUX_PKG_CACHEDIR/libziparchive_
${_TAGNAME}.
tar.gz
192 test ! -f
$LIBZIPARCHIVE_TARFILE && termux_download \
193 "https://android.googlesource.com/platform/system/core/+archive/android-$_TAGNAME/libziparchive.tar.gz" \
194 $LIBZIPARCHIVE_TARFILE
195 mkdir
-p
$TERMUX_PKG_SRCDIR/libziparchive
196 cd $TERMUX_PKG_SRCDIR/libziparchive
197 tar xf
$LIBZIPARCHIVE_TARFILE
198 libziparchive_source_files
="\
200 zip_archive_stream_entry.cc \
202 sed -i
's%next_in = reinterpret_cast<const uint8_t\*>(data)%next_in = const_cast<uint8_t\*>(reinterpret_cast<const uint8_t\*>(data))%' zip_writer.cc
203 $CXX $CXXFLAGS $LDFLAGS -std
=c
++11 \
205 -isystem
$AOSP_INCLUDE_DIR \
206 $libziparchive_source_files \
212 -o
$TERMUX_PREFIX/lib
/libandroid-ziparchive.so
216 # Build libandroidfw:
217 ANDROIDFW_TARFILE
=$TERMUX_PKG_CACHEDIR/androidfw_
${_TAGNAME}.
tar.gz
218 test ! -f
$ANDROIDFW_TARFILE && termux_download \
219 https
://android.googlesource.com
/platform
/frameworks
/base
/+archive
/android-
$_TAGNAME/libs
/androidfw.
tar.gz \
221 mkdir
-p
$TERMUX_PKG_SRCDIR/androidfw
222 cd $TERMUX_PKG_SRCDIR/androidfw
223 tar xf
$ANDROIDFW_TARFILE
232 StreamingZipInflater.cpp \
236 sed -i
's%#include <binder/TextOutput.h>%%' ResourceTypes.cpp
237 $CXX $CXXFLAGS $CPPFLAGS $LDFLAGS -isystem
$AOSP_INCLUDE_DIR \
243 -landroid-ziparchive \
247 -o
$TERMUX_PREFIX/lib
/libandroid-fw.so
250 AAPT_TARFILE
=$TERMUX_PKG_CACHEDIR/aapt_
${_TAGNAME}.
tar.gz
251 test ! -f
$AAPT_TARFILE && termux_download \
252 "https://android.googlesource.com/platform/frameworks/base/+archive/android-$_TAGNAME/tools/aapt.tar.gz" \
254 mkdir
$TERMUX_PKG_SRCDIR/aapt
255 cd $TERMUX_PKG_SRCDIR/aapt
257 sed "s%\@TERMUX_PREFIX\@%${TERMUX_PREFIX}%g" $TERMUX_PKG_BUILDER_DIR/aapt-Main.cpp.
patch.txt |
patch -p1
258 $CXX $CXXFLAGS $CPPFLAGS $LDFLAGS \
263 -DHAVE_ENDIAN_H
=1 -DHAVE_POSIX_FILEMAP
=1 -DHAVE_OFF64_T
=1 -DHAVE_SYS_SOCKET_H
=1 -DHAVE_PTHREADS
=1 \
264 -isystem
$AOSP_INCLUDE_DIR \
266 -landroid-cutils
-landroid-utils
-landroid-fw
-landroid-ziparchive \
268 -lm
-lz
-lpng
-lexpat \
270 -o
$TERMUX_PREFIX/bin
/aapt
275 ZIPALIGN_TARFILE
=$TERMUX_PKG_CACHEDIR/zipalign_
${_TAGNAME}.
tar.gz
276 test ! -f
$ZIPALIGN_TARFILE && termux_download \
277 "https://android.googlesource.com/platform/build.git/+archive/android-$_TAGNAME/tools/zipalign.tar.gz" \
279 mkdir
$TERMUX_PKG_SRCDIR/zipalign
280 cd $TERMUX_PKG_SRCDIR/zipalign
281 tar xf
$ZIPALIGN_TARFILE
282 $CXX $CXXFLAGS $CPPFLAGS $LDFLAGS \
283 -isystem
$AOSP_INCLUDE_DIR \
285 ZipAlign.cpp ZipEntry.cpp ZipFile.cpp \
286 -landroid-cutils
-landroid-utils
-landroid-fw \
290 -o
$TERMUX_PREFIX/bin
/zipalign
293 # Remove this one for now:
294 rm -Rf
$AOSP_INCLUDE_DIR
296 # Create an android.jar with AndroidManifest.xml and resources.arsc:
297 cd $TERMUX_PKG_TMPDIR
301 cp $ANDROID_HOME/platforms
/android-25
/android.jar .
303 mkdir
-p
$TERMUX_PREFIX/share
/aapt
304 zip -q
$TERMUX_PREFIX/share
/aapt
/android.jar AndroidManifest.xml resources.arsc