| 1 | TERMUX_PKG_HOMEPAGE=http://elinux.org/Android_aapt |
| 2 | TERMUX_PKG_DESCRIPTION="Android Asset Packaging Tool" |
| 3 | _TAG_VERSION=7.0.0 |
| 4 | _TAG_REVISION=14 |
| 5 | TERMUX_PKG_VERSION=${_TAG_VERSION}.${_TAG_REVISION} |
| 6 | TERMUX_PKG_BUILD_REVISION=1 |
| 7 | TERMUX_PKG_BUILD_IN_SRC=yes |
| 8 | TERMUX_PKG_DEPENDS="libexpat, libpng, libzopfli" |
| 9 | TERMUX_PKG_CLANG=yes |
| 10 | |
| 11 | termux_step_make_install () { |
| 12 | local _TAGNAME=${_TAG_VERSION}_r${_TAG_REVISION} |
| 13 | |
| 14 | SYSTEM_CORE_INCLUDE_TARFILE=$TERMUX_PKG_CACHEDIR/system_core_include_${_TAGNAME}.tar.gz |
| 15 | test ! -f $SYSTEM_CORE_INCLUDE_TARFILE && termux_download \ |
| 16 | "https://android.googlesource.com/platform/system/core/+archive/android-$_TAGNAME/include.tar.gz" \ |
| 17 | $SYSTEM_CORE_INCLUDE_TARFILE |
| 18 | |
| 19 | ANDROIDFW_INCLUDE_TARFILE=$TERMUX_PKG_CACHEDIR/androidfw_include_${_TAGNAME}.tar.gz |
| 20 | test ! -f $ANDROIDFW_INCLUDE_TARFILE && termux_download \ |
| 21 | "https://android.googlesource.com/platform/frameworks/base/+archive/android-$_TAGNAME/include/androidfw.tar.gz" \ |
| 22 | $ANDROIDFW_INCLUDE_TARFILE |
| 23 | |
| 24 | ANDROID_BASE_INCLUDE_TARFILE=$TERMUX_PKG_CACHEDIR/android_base_include_${_TAGNAME}.tar.gz |
| 25 | test ! -f $ANDROID_BASE_INCLUDE_TARFILE && termux_download \ |
| 26 | "https://android.googlesource.com/platform/system/core/+archive/android-$_TAGNAME/base/include/android-base.tar.gz" \ |
| 27 | $ANDROID_BASE_INCLUDE_TARFILE |
| 28 | |
| 29 | local AOSP_INCLUDE_DIR=$TERMUX_PREFIX/include/aosp |
| 30 | mkdir -p $AOSP_INCLUDE_DIR |
| 31 | cd $AOSP_INCLUDE_DIR |
| 32 | rm -Rf * |
| 33 | tar xf $SYSTEM_CORE_INCLUDE_TARFILE |
| 34 | mkdir -p androidfw |
| 35 | cd androidfw |
| 36 | tar xf $ANDROIDFW_INCLUDE_TARFILE |
| 37 | cd .. |
| 38 | mkdir -p android-base |
| 39 | cd android-base |
| 40 | tar xf $ANDROID_BASE_INCLUDE_TARFILE |
| 41 | |
| 42 | |
| 43 | # Build libcutils: |
| 44 | mkdir -p $TERMUX_PKG_SRCDIR/{libcutils,androidfw} |
| 45 | cd $TERMUX_PKG_SRCDIR/libcutils |
| 46 | LIBCUTILS_TARFILE=$TERMUX_PKG_CACHEDIR/libcutils_${_TAGNAME}.tar.gz |
| 47 | test ! -f $LIBCUTILS_TARFILE && termux_download \ |
| 48 | "https://android.googlesource.com/platform/system/core/+archive/android-$_TAGNAME/libcutils.tar.gz" \ |
| 49 | $LIBCUTILS_TARFILE |
| 50 | tar xf $LIBCUTILS_TARFILE |
| 51 | $CXX $CXXFLAGS -isystem $AOSP_INCLUDE_DIR -c -o sockets.o sockets.cpp |
| 52 | $CXX $CXXFLAGS -isystem $AOSP_INCLUDE_DIR -c -o sockets_unix.o sockets_unix.cpp |
| 53 | sed -i 's%include <sys/_system_properties.h>%include <sys/system_properties.h>%' properties.c |
| 54 | # From Android.mk: |
| 55 | libcutils_common_sources="\ |
| 56 | config_utils.c \ |
| 57 | fs_config.c \ |
| 58 | canned_fs_config.c \ |
| 59 | hashmap.c \ |
| 60 | iosched_policy.c \ |
| 61 | load_file.c \ |
| 62 | native_handle.c \ |
| 63 | open_memstream.c \ |
| 64 | process_name.c \ |
| 65 | record_stream.c \ |
| 66 | sched_policy.c \ |
| 67 | sockets.o \ |
| 68 | strdup16to8.c \ |
| 69 | strdup8to16.c \ |
| 70 | strlcpy.c \ |
| 71 | threads.c" |
| 72 | libcutils_nonwindows_sources="\ |
| 73 | fs.c \ |
| 74 | multiuser.c \ |
| 75 | socket_inaddr_any_server_unix.c \ |
| 76 | socket_local_client_unix.c \ |
| 77 | socket_local_server_unix.c \ |
| 78 | socket_loopback_client_unix.c \ |
| 79 | socket_loopback_server_unix.c \ |
| 80 | socket_network_client_unix.c \ |
| 81 | sockets_unix.o \ |
| 82 | str_parms.c" |
| 83 | $CC $CFLAGS \ |
| 84 | -Dchar16_t=uint16_t \ |
| 85 | -std=c11 \ |
| 86 | -isystem $AOSP_INCLUDE_DIR \ |
| 87 | $libcutils_common_sources \ |
| 88 | $libcutils_nonwindows_sources \ |
| 89 | trace-host.c \ |
| 90 | properties.c \ |
| 91 | -llog \ |
| 92 | -shared \ |
| 93 | -o $TERMUX_PREFIX/lib/libandroid-cutils.so |
| 94 | |
| 95 | |
| 96 | |
| 97 | # Build libutil: |
| 98 | local LIBUTILS_TARFILE=$TERMUX_PKG_CACHEDIR/libutils_${_TAGNAME}.tar.gz |
| 99 | test ! -f $LIBUTILS_TARFILE && termux_download \ |
| 100 | "https://android.googlesource.com/platform/system/core/+archive/android-$_TAGNAME/libutils.tar.gz" \ |
| 101 | $LIBUTILS_TARFILE |
| 102 | |
| 103 | local SAFE_IOP_TARFILE=$TERMUX_PKG_CACHEDIR/safe_iop.tar.gz |
| 104 | test ! -f $SAFE_IOP_TARFILE && termux_download \ |
| 105 | https://android.googlesource.com/platform/external/safe-iop/+archive/cd76f998688d145235de78ecd5b340d0eac9239d.tar.gz \ |
| 106 | $SAFE_IOP_TARFILE |
| 107 | local SAFE_IOP_DIR=$TERMUX_PKG_TMPDIR/safe-iop |
| 108 | mkdir -p $SAFE_IOP_DIR |
| 109 | cd $SAFE_IOP_DIR |
| 110 | tar xf $SAFE_IOP_TARFILE |
| 111 | mv src/safe_iop.c src/safe_iop.cpp |
| 112 | |
| 113 | mkdir $TERMUX_PKG_SRCDIR/libutils |
| 114 | cd $TERMUX_PKG_SRCDIR/libutils |
| 115 | tar xf $LIBUTILS_TARFILE |
| 116 | # From Android.mk: |
| 117 | #CallStack.cpp \ |
| 118 | commonSources="\ |
| 119 | FileMap.cpp \ |
| 120 | JenkinsHash.cpp \ |
| 121 | LinearTransform.cpp \ |
| 122 | Log.cpp \ |
| 123 | NativeHandle.cpp \ |
| 124 | Printer.cpp \ |
| 125 | PropertyMap.cpp \ |
| 126 | RefBase.cpp \ |
| 127 | SharedBuffer.cpp \ |
| 128 | Static.cpp \ |
| 129 | StopWatch.cpp \ |
| 130 | String8.cpp \ |
| 131 | String16.cpp \ |
| 132 | SystemClock.cpp \ |
| 133 | Threads.cpp \ |
| 134 | Timers.cpp \ |
| 135 | Tokenizer.cpp \ |
| 136 | Unicode.cpp \ |
| 137 | VectorImpl.cpp \ |
| 138 | misc.cpp" |
| 139 | $CXX $CXXFLAGS $CPPFLAGS $LDFLAGS \ |
| 140 | -std=c++11 \ |
| 141 | '-DALOG_ASSERT(a,...)=' \ |
| 142 | -Dtypeof=decltype \ |
| 143 | -isystem $TERMUX_PREFIX/include/aosp \ |
| 144 | -isystem $SAFE_IOP_DIR/include \ |
| 145 | $SAFE_IOP_DIR/src/safe_iop.cpp \ |
| 146 | $commonSources \ |
| 147 | -landroid-cutils \ |
| 148 | -llog \ |
| 149 | -shared \ |
| 150 | -o $TERMUX_PREFIX/lib/libandroid-utils.so |
| 151 | |
| 152 | |
| 153 | |
| 154 | # Build libbase: |
| 155 | local LIBBASE_TARFILE=$TERMUX_PKG_CACHEDIR/libbase_${_TAGNAME}.tar.gz |
| 156 | test ! -f $LIBBASE_TARFILE && termux_download \ |
| 157 | "https://android.googlesource.com/platform/system/core/+archive/android-${_TAGNAME}/base.tar.gz" \ |
| 158 | $LIBBASE_TARFILE |
| 159 | mkdir -p $TERMUX_PKG_SRCDIR/libbase |
| 160 | cd $TERMUX_PKG_SRCDIR/libbase |
| 161 | tar xf $LIBBASE_TARFILE |
| 162 | rm -Rf $TERMUX_PREFIX/include/aosp/android-base |
| 163 | mv include/android-base $TERMUX_PREFIX/include/aosp |
| 164 | patch -p1 < $TERMUX_PKG_BUILDER_DIR/libbase-patch.txt |
| 165 | libbase_src_files="\ |
| 166 | file.cpp \ |
| 167 | logging.cpp \ |
| 168 | parsenetaddress.cpp \ |
| 169 | stringprintf.cpp \ |
| 170 | strings.cpp \ |
| 171 | test_utils.cpp" |
| 172 | libbase_linux_src_files="\ |
| 173 | errors_unix.cpp" |
| 174 | # __USE_BSD for DEFFILEMODE to be defined by <sys/stat.h>. |
| 175 | $CXX $CXXFLAGS $CPPFLAGS -std=c++11 \ |
| 176 | -D__USE_BSD \ |
| 177 | -isystem $AOSP_INCLUDE_DIR \ |
| 178 | $libbase_src_files $libbase_linux_src_files \ |
| 179 | -llog \ |
| 180 | -shared \ |
| 181 | -o $TERMUX_PREFIX/lib/libandroid-base.so |
| 182 | |
| 183 | |
| 184 | # Build libziparchive: |
| 185 | LIBZIPARCHIVE_TARFILE=$TERMUX_PKG_CACHEDIR/libziparchive_${_TAGNAME}.tar.gz |
| 186 | test ! -f $LIBZIPARCHIVE_TARFILE && termux_download \ |
| 187 | "https://android.googlesource.com/platform/system/core/+archive/android-$_TAGNAME/libziparchive.tar.gz" \ |
| 188 | $LIBZIPARCHIVE_TARFILE |
| 189 | mkdir -p $TERMUX_PKG_SRCDIR/libziparchive |
| 190 | cd $TERMUX_PKG_SRCDIR/libziparchive |
| 191 | tar xf $LIBZIPARCHIVE_TARFILE |
| 192 | libziparchive_source_files="\ |
| 193 | zip_archive.cc \ |
| 194 | zip_archive_stream_entry.cc \ |
| 195 | zip_writer.cc" |
| 196 | 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 |
| 197 | $CXX $CXXFLAGS $LDFLAGS -std=c++11 \ |
| 198 | -DZLIB_CONST \ |
| 199 | -isystem $AOSP_INCLUDE_DIR \ |
| 200 | $libziparchive_source_files \ |
| 201 | -landroid-base \ |
| 202 | -landroid-utils \ |
| 203 | -lz \ |
| 204 | -llog \ |
| 205 | -shared \ |
| 206 | -o $TERMUX_PREFIX/lib/libandroid-ziparchive.so |
| 207 | |
| 208 | |
| 209 | |
| 210 | # Build libandroidfw: |
| 211 | ANDROIDFW_TARFILE=$TERMUX_PKG_CACHEDIR/androidfw_${_TAGNAME}.tar.gz |
| 212 | test ! -f $ANDROIDFW_TARFILE && termux_download \ |
| 213 | https://android.googlesource.com/platform/frameworks/base/+archive/android-$_TAGNAME/libs/androidfw.tar.gz \ |
| 214 | $ANDROIDFW_TARFILE |
| 215 | mkdir -p $TERMUX_PKG_SRCDIR/androidfw |
| 216 | cd $TERMUX_PKG_SRCDIR/androidfw |
| 217 | tar xf $ANDROIDFW_TARFILE |
| 218 | commonSources="\ |
| 219 | Asset.cpp \ |
| 220 | AssetDir.cpp \ |
| 221 | AssetManager.cpp \ |
| 222 | LocaleData.cpp \ |
| 223 | misc.cpp \ |
| 224 | ObbFile.cpp \ |
| 225 | ResourceTypes.cpp \ |
| 226 | StreamingZipInflater.cpp \ |
| 227 | TypeWrappers.cpp \ |
| 228 | ZipFileRO.cpp \ |
| 229 | ZipUtils.cpp" |
| 230 | sed -i 's%#include <binder/TextOutput.h>%%' ResourceTypes.cpp |
| 231 | $CXX $CXXFLAGS $LDFLAGS -isystem $AOSP_INCLUDE_DIR \ |
| 232 | -std=c++11 \ |
| 233 | $commonSources \ |
| 234 | -DACONFIGURATION_SCREENROUND_ANY=0x00 \ |
| 235 | -DACONFIGURATION_SCREENROUND_NO=0x1 \ |
| 236 | -DACONFIGURATION_SCREENROUND_YES=0x2 \ |
| 237 | -DACONFIGURATION_SCREEN_ROUND=0x8000 \ |
| 238 | -landroid-cutils \ |
| 239 | -landroid-utils \ |
| 240 | -landroid-ziparchive \ |
| 241 | -llog \ |
| 242 | -lz \ |
| 243 | -shared \ |
| 244 | -o $TERMUX_PREFIX/lib/libandroid-fw.so |
| 245 | |
| 246 | |
| 247 | |
| 248 | # Build aapt: |
| 249 | AAPT_TARFILE=$TERMUX_PKG_CACHEDIR/aapt_${_TAGNAME}.tar.gz |
| 250 | test ! -f $AAPT_TARFILE && termux_download \ |
| 251 | "https://android.googlesource.com/platform/frameworks/base/+archive/android-$_TAGNAME/tools/aapt.tar.gz" \ |
| 252 | $AAPT_TARFILE |
| 253 | mkdir $TERMUX_PKG_SRCDIR/aapt |
| 254 | cd $TERMUX_PKG_SRCDIR/aapt |
| 255 | tar xf $AAPT_TARFILE |
| 256 | sed "s%\@TERMUX_PREFIX\@%${TERMUX_PREFIX}%g" $TERMUX_PKG_BUILDER_DIR/aapt-Main.cpp.patch.txt | patch -p1 |
| 257 | $CXX $CXXFLAGS $CPPFLAGS $LDFLAGS \ |
| 258 | -std=c++11 \ |
| 259 | -DANDROID_SMP=1 \ |
| 260 | -DNDEBUG=1 \ |
| 261 | -DHAVE_ENDIAN_H=1 -DHAVE_POSIX_FILEMAP=1 -DHAVE_OFF64_T=1 -DHAVE_SYS_SOCKET_H=1 -DHAVE_PTHREADS=1 \ |
| 262 | -DACONFIGURATION_SCREENROUND_ANY=0x00 \ |
| 263 | -DACONFIGURATION_SCREENROUND_NO=0x1 \ |
| 264 | -DACONFIGURATION_SCREENROUND_YES=0x2 \ |
| 265 | -DACONFIGURATION_SCREEN_ROUND=0x8000 \ |
| 266 | -isystem $AOSP_INCLUDE_DIR \ |
| 267 | *.cpp \ |
| 268 | -landroid-cutils -landroid-utils -landroid-fw -landroid-ziparchive \ |
| 269 | -llog \ |
| 270 | -lm -lz -lpng -lexpat \ |
| 271 | -pie \ |
| 272 | -o $TERMUX_PREFIX/bin/aapt |
| 273 | |
| 274 | |
| 275 | |
| 276 | # Build zipalign: |
| 277 | ZIPALIGN_TARFILE=$TERMUX_PKG_CACHEDIR/zipalign_${_TAGNAME}.tar.gz |
| 278 | test ! -f $ZIPALIGN_TARFILE && termux_download \ |
| 279 | "https://android.googlesource.com/platform/build.git/+archive/android-$_TAGNAME/tools/zipalign.tar.gz" \ |
| 280 | $ZIPALIGN_TARFILE |
| 281 | mkdir $TERMUX_PKG_SRCDIR/zipalign |
| 282 | cd $TERMUX_PKG_SRCDIR/zipalign |
| 283 | tar xf $ZIPALIGN_TARFILE |
| 284 | $CXX $CXXFLAGS $CPPFLAGS $LDFLAGS \ |
| 285 | -isystem $AOSP_INCLUDE_DIR \ |
| 286 | -std=c++11 \ |
| 287 | ZipAlign.cpp ZipEntry.cpp ZipFile.cpp \ |
| 288 | -landroid-cutils -landroid-utils -landroid-fw \ |
| 289 | -lm -lz -llog \ |
| 290 | -lzopfli \ |
| 291 | -pie \ |
| 292 | -o $TERMUX_PREFIX/bin/zipalign |
| 293 | |
| 294 | |
| 295 | # Remove this one for now: |
| 296 | rm -Rf $AOSP_INCLUDE_DIR |
| 297 | |
| 298 | # Create an android.jar with AndroidManifest.xml and resources.arsc: |
| 299 | cd $TERMUX_PKG_TMPDIR |
| 300 | rm -rf android-jar |
| 301 | mkdir android-jar |
| 302 | cd android-jar |
| 303 | cp $ANDROID_HOME/platforms/android-24/android.jar . |
| 304 | unzip -q android.jar |
| 305 | mkdir -p $TERMUX_PREFIX/share/aapt |
| 306 | zip -q $TERMUX_PREFIX/share/aapt/android.jar AndroidManifest.xml resources.arsc |
| 307 | } |