Switch over to building with unified headers
[termux-packages] / packages / aapt / build.sh
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"
6 _TAG_VERSION=7.0.0
7 _TAG_REVISION=14
8 TERMUX_PKG_VERSION=${_TAG_VERSION}.${_TAG_REVISION}
9 TERMUX_PKG_REVISION=1
10 TERMUX_PKG_BUILD_IN_SRC=yes
11 TERMUX_PKG_DEPENDS="libexpat, libpng, libzopfli"
12
13 termux_step_make_install () {
14 local _TAGNAME=${_TAG_VERSION}_r${_TAG_REVISION}
15
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
20
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
25
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
30
31 local AOSP_INCLUDE_DIR=$TERMUX_PREFIX/include/aosp
32 mkdir -p $AOSP_INCLUDE_DIR
33 cd $AOSP_INCLUDE_DIR
34 rm -Rf *
35 tar xf $SYSTEM_CORE_INCLUDE_TARFILE
36 mkdir -p androidfw
37 cd androidfw
38 tar xf $ANDROIDFW_INCLUDE_TARFILE
39 cd ..
40 mkdir -p android-base
41 cd android-base
42 tar xf $ANDROID_BASE_INCLUDE_TARFILE
43 cd ../log
44 patch -p0 < $TERMUX_PKG_BUILDER_DIR/log.h.patch.txt
45
46 # Build libcutils:
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" \
52 $LIBCUTILS_TARFILE
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
58 # From Android.mk:
59 libcutils_common_sources="\
60 config_utils.c \
61 fs_config.c \
62 canned_fs_config.c \
63 hashmap.c \
64 iosched_policy.c \
65 load_file.c \
66 native_handle.c \
67 open_memstream.c \
68 process_name.c \
69 record_stream.c \
70 sched_policy.c \
71 sockets.o \
72 strdup16to8.c \
73 strdup8to16.c \
74 strlcpy.c \
75 threads.c"
76 libcutils_nonwindows_sources="\
77 fs.c \
78 multiuser.c \
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 \
85 sockets_unix.o \
86 str_parms.c"
87 $CC $CFLAGS \
88 -Dchar16_t=uint16_t \
89 -std=c11 \
90 -isystem $AOSP_INCLUDE_DIR \
91 $libcutils_common_sources \
92 $libcutils_nonwindows_sources \
93 trace-host.c \
94 properties.c \
95 -llog \
96 -shared \
97 -o $TERMUX_PREFIX/lib/libandroid-cutils.so
98
99
100
101 # Build libutil:
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" \
105 $LIBUTILS_TARFILE
106
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 \
110 $SAFE_IOP_TARFILE
111 local SAFE_IOP_DIR=$TERMUX_PKG_TMPDIR/safe-iop
112 mkdir -p $SAFE_IOP_DIR
113 cd $SAFE_IOP_DIR
114 tar xf $SAFE_IOP_TARFILE
115 mv src/safe_iop.c src/safe_iop.cpp
116
117 mkdir $TERMUX_PKG_SRCDIR/libutils
118 cd $TERMUX_PKG_SRCDIR/libutils
119 tar xf $LIBUTILS_TARFILE
120 # From Android.mk:
121 #CallStack.cpp \
122 #SystemClock.cpp \
123 commonSources="\
124 FileMap.cpp \
125 JenkinsHash.cpp \
126 LinearTransform.cpp \
127 Log.cpp \
128 NativeHandle.cpp \
129 Printer.cpp \
130 PropertyMap.cpp \
131 RefBase.cpp \
132 SharedBuffer.cpp \
133 Static.cpp \
134 StopWatch.cpp \
135 String8.cpp \
136 String16.cpp \
137 Threads.cpp \
138 Timers.cpp \
139 Tokenizer.cpp \
140 Unicode.cpp \
141 VectorImpl.cpp \
142 misc.cpp"
143 $CXX $CXXFLAGS $CPPFLAGS $LDFLAGS \
144 -std=c++11 \
145 '-DALOG_ASSERT(a,...)=' \
146 -Dtypeof=decltype \
147 -isystem $TERMUX_PREFIX/include/aosp \
148 -isystem $SAFE_IOP_DIR/include \
149 $SAFE_IOP_DIR/src/safe_iop.cpp \
150 $commonSources \
151 -landroid-cutils \
152 -llog \
153 -shared \
154 -o $TERMUX_PREFIX/lib/libandroid-utils.so
155
156
157
158 # Build libbase:
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" \
162 $LIBBASE_TARFILE
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
169 #logging.cpp \
170 libbase_src_files="\
171 file.cpp \
172 parsenetaddress.cpp \
173 stringprintf.cpp \
174 strings.cpp \
175 test_utils.cpp"
176 libbase_linux_src_files="\
177 errors_unix.cpp"
178 # __USE_BSD for DEFFILEMODE to be defined by <sys/stat.h>.
179 $CXX $CXXFLAGS $CPPFLAGS -std=c++11 \
180 -D__USE_BSD \
181 -isystem $AOSP_INCLUDE_DIR \
182 $libbase_src_files $libbase_linux_src_files \
183 -llog \
184 -shared \
185 -o $TERMUX_PREFIX/lib/libandroid-base.so
186
187
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="\
197 zip_archive.cc \
198 zip_archive_stream_entry.cc \
199 zip_writer.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 \
202 -DZLIB_CONST \
203 -isystem $AOSP_INCLUDE_DIR \
204 $libziparchive_source_files \
205 -landroid-base \
206 -landroid-utils \
207 -lz \
208 -llog \
209 -shared \
210 -o $TERMUX_PREFIX/lib/libandroid-ziparchive.so
211
212
213
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 \
218 $ANDROIDFW_TARFILE
219 mkdir -p $TERMUX_PKG_SRCDIR/androidfw
220 cd $TERMUX_PKG_SRCDIR/androidfw
221 tar xf $ANDROIDFW_TARFILE
222 commonSources="\
223 Asset.cpp \
224 AssetDir.cpp \
225 AssetManager.cpp \
226 LocaleData.cpp \
227 misc.cpp \
228 ObbFile.cpp \
229 ResourceTypes.cpp \
230 StreamingZipInflater.cpp \
231 TypeWrappers.cpp \
232 ZipFileRO.cpp \
233 ZipUtils.cpp"
234 sed -i 's%#include <binder/TextOutput.h>%%' ResourceTypes.cpp
235 $CXX $CXXFLAGS $CPPFLAGS $LDFLAGS -isystem $AOSP_INCLUDE_DIR \
236 -std=c++11 \
237 $commonSources \
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 # Build aapt:
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" \
250 $AAPT_TARFILE
251 mkdir $TERMUX_PKG_SRCDIR/aapt
252 cd $TERMUX_PKG_SRCDIR/aapt
253 tar xf $AAPT_TARFILE
254 sed "s%\@TERMUX_PREFIX\@%${TERMUX_PREFIX}%g" $TERMUX_PKG_BUILDER_DIR/aapt-Main.cpp.patch.txt | patch -p1
255 $CXX $CXXFLAGS $CPPFLAGS $LDFLAGS \
256 -std=c++11 \
257 -DANDROID_SMP=1 \
258 -DNDEBUG=1 \
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 \
261 *.cpp \
262 -landroid-cutils -landroid-utils -landroid-fw -landroid-ziparchive \
263 -llog \
264 -lm -lz -lpng -lexpat \
265 -pie \
266 -o $TERMUX_PREFIX/bin/aapt
267
268
269
270 # Build zipalign:
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" \
274 $ZIPALIGN_TARFILE
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 \
280 -std=c++11 \
281 ZipAlign.cpp ZipEntry.cpp ZipFile.cpp \
282 -landroid-cutils -landroid-utils -landroid-fw \
283 -lm -lz -llog \
284 -lzopfli \
285 -pie \
286 -o $TERMUX_PREFIX/bin/zipalign
287
288
289 # Remove this one for now:
290 rm -Rf $AOSP_INCLUDE_DIR
291
292 # Create an android.jar with AndroidManifest.xml and resources.arsc:
293 cd $TERMUX_PKG_TMPDIR
294 rm -rf android-jar
295 mkdir android-jar
296 cd android-jar
297 cp $ANDROID_HOME/platforms/android-25/android.jar .
298 unzip -q android.jar
299 mkdir -p $TERMUX_PREFIX/share/aapt
300 zip -q $TERMUX_PREFIX/share/aapt/android.jar AndroidManifest.xml resources.arsc
301 }