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 -std
=c
++11 \
181 -isystem
$AOSP_INCLUDE_DIR \
182 $libbase_src_files $libbase_linux_src_files \
185 -o
$TERMUX_PREFIX/lib
/libandroid-base.so
188 # Build libziparchive:
189 LIBZIPARCHIVE_TARFILE
=$TERMUX_PKG_CACHEDIR/libziparchive_
${_TAGNAME}.
tar.gz
190 test ! -f
$LIBZIPARCHIVE_TARFILE && termux_download \
191 "https://android.googlesource.com/platform/system/core/+archive/android-$_TAGNAME/libziparchive.tar.gz" \
192 $LIBZIPARCHIVE_TARFILE
193 mkdir
-p
$TERMUX_PKG_SRCDIR/libziparchive
194 cd $TERMUX_PKG_SRCDIR/libziparchive
195 tar xf
$LIBZIPARCHIVE_TARFILE
196 libziparchive_source_files
="\
198 zip_archive_stream_entry.cc \
200 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
201 $CXX $CXXFLAGS $LDFLAGS -std
=c
++11 \
203 -isystem
$AOSP_INCLUDE_DIR \
204 $libziparchive_source_files \
210 -o
$TERMUX_PREFIX/lib
/libandroid-ziparchive.so
214 # Build libandroidfw:
215 ANDROIDFW_TARFILE
=$TERMUX_PKG_CACHEDIR/androidfw_
${_TAGNAME}.
tar.gz
216 test ! -f
$ANDROIDFW_TARFILE && termux_download \
217 https
://android.googlesource.com
/platform
/frameworks
/base
/+archive
/android-
$_TAGNAME/libs
/androidfw.
tar.gz \
219 mkdir
-p
$TERMUX_PKG_SRCDIR/androidfw
220 cd $TERMUX_PKG_SRCDIR/androidfw
221 tar xf
$ANDROIDFW_TARFILE
230 StreamingZipInflater.cpp \
234 sed -i
's%#include <binder/TextOutput.h>%%' ResourceTypes.cpp
235 $CXX $CXXFLAGS $CPPFLAGS $LDFLAGS -isystem
$AOSP_INCLUDE_DIR \
240 -landroid-ziparchive \
244 -o
$TERMUX_PREFIX/lib
/libandroid-fw.so
247 AAPT_TARFILE
=$TERMUX_PKG_CACHEDIR/aapt_
${_TAGNAME}.
tar.gz
248 test ! -f
$AAPT_TARFILE && termux_download \
249 "https://android.googlesource.com/platform/frameworks/base/+archive/android-$_TAGNAME/tools/aapt.tar.gz" \
251 mkdir
$TERMUX_PKG_SRCDIR/aapt
252 cd $TERMUX_PKG_SRCDIR/aapt
254 sed "s%\@TERMUX_PREFIX\@%${TERMUX_PREFIX}%g" $TERMUX_PKG_BUILDER_DIR/aapt-Main.cpp.
patch.txt |
patch -p1
255 $CXX $CXXFLAGS $CPPFLAGS $LDFLAGS \
259 -DHAVE_ENDIAN_H
=1 -DHAVE_POSIX_FILEMAP
=1 -DHAVE_OFF64_T
=1 -DHAVE_SYS_SOCKET_H
=1 -DHAVE_PTHREADS
=1 \
260 -isystem
$AOSP_INCLUDE_DIR \
262 -landroid-cutils
-landroid-utils
-landroid-fw
-landroid-ziparchive \
264 -lm
-lz
-lpng
-lexpat \
266 -o
$TERMUX_PREFIX/bin
/aapt
271 ZIPALIGN_TARFILE
=$TERMUX_PKG_CACHEDIR/zipalign_
${_TAGNAME}.
tar.gz
272 test ! -f
$ZIPALIGN_TARFILE && termux_download \
273 "https://android.googlesource.com/platform/build.git/+archive/android-$_TAGNAME/tools/zipalign.tar.gz" \
275 mkdir
$TERMUX_PKG_SRCDIR/zipalign
276 cd $TERMUX_PKG_SRCDIR/zipalign
277 tar xf
$ZIPALIGN_TARFILE
278 $CXX $CXXFLAGS $CPPFLAGS $LDFLAGS \
279 -isystem
$AOSP_INCLUDE_DIR \
281 ZipAlign.cpp ZipEntry.cpp ZipFile.cpp \
282 -landroid-cutils
-landroid-utils
-landroid-fw \
286 -o
$TERMUX_PREFIX/bin
/zipalign
289 # Remove this one for now:
290 rm -Rf
$AOSP_INCLUDE_DIR
292 # Create an android.jar with AndroidManifest.xml and resources.arsc:
293 cd $TERMUX_PKG_TMPDIR
297 cp $ANDROID_HOME/platforms
/android-25
/android.jar .
299 mkdir
-p
$TERMUX_PREFIX/share
/aapt
300 zip -q
$TERMUX_PREFIX/share
/aapt
/android.jar AndroidManifest.xml resources.arsc