| #! /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() |