blob: ffe7dbd330bd140592bcfc0e23d2ac04e5a909b1 [file] [log] [blame]
#! /usr/bin/env python
# Copyright 2018 Google LLC.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
'''
This script can be run with no arguments, in which case it will produce an
APK with native libraries for all four architectures: arm, arm64, x86, and
x64. You can instead list the architectures you want as arguments to this
script. For example:
python make_universal_apk.py arm x86
The environment variables ANDROID_NDK_HOME and ANDROID_HOME must be set to the
locations of the Android NDK and SDK.
Additionally, `ninja` should be in your path.
It assumes that the source tree is in the desired state, e.g. by having
run 'python tools/git-sync-deps' in the root of the skia checkout.
Also:
* If the environment variable SKQP_BUILD_DIR is set, many of the
intermediate build objects will be placed here.
* If the environment variable SKQP_OUTPUT_DIR is set, the final APK
will be placed in this directory.
* If the environment variable SKQP_DEBUG is set, Skia will be compiled
in debug mode.
'''
import os
import sys
import create_apk
def make_apk(opts):
assert '/' in [os.sep, os.altsep] # 'a/b' over os.path.join('a', 'b')
skia_dir = os.path.dirname(__file__) + '/../..'
create_apk.makedirs(opts.build_dir)
assets_dir = skia_dir + '/platform_tools/android/apps/skqp/src/main/assets'
resources_path = assets_dir + '/resources'
with create_apk.RemoveFiles(resources_path): # always clean up
create_apk.remove(resources_path)
os.symlink('../../../../../../../resources', resources_path)
create_apk.create_apk(opts)
def main():
options = create_apk.SkQP_Build_Options()
if options.error:
sys.stderr.write(options.error + __doc__)
sys.exit(1)
options.write(sys.stdout)
make_apk(options)
if __name__ == '__main__':
main()