2012-09-19 08:16:27 +04:00
|
|
|
# Copyright (c) 2012 The Chromium Authors. All rights reserved.
|
|
|
|
# Use of this source code is governed by a BSD-style license that can be
|
|
|
|
# found in the LICENSE file.
|
|
|
|
|
|
|
|
# This file is meant to be included into a target to provide a rule
|
|
|
|
# to build Android APKs in a consistent manner.
|
|
|
|
#
|
|
|
|
# To use this, create a gyp target with the following form:
|
|
|
|
# {
|
|
|
|
# 'target_name': 'my_package_apk',
|
|
|
|
# 'type': 'none',
|
|
|
|
# 'variables': {
|
|
|
|
# 'package_name': 'my_package',
|
|
|
|
# 'apk_name': 'MyPackage',
|
|
|
|
# 'java_in_dir': 'path/to/package/root',
|
|
|
|
# 'resource_dir': 'res',
|
|
|
|
# },
|
|
|
|
# 'includes': ['path/to/this/gypi/file'],
|
|
|
|
# }
|
|
|
|
#
|
|
|
|
# Note that this assumes that there's an ant buildfile <package_name>_apk.xml in
|
|
|
|
# java_in_dir. So, if you have package_name="content_shell" and
|
|
|
|
# java_in_dir="content/shell/android/java" you should have a directory structure
|
|
|
|
# like:
|
|
|
|
#
|
|
|
|
# content/shell/android/java/content_shell_apk.xml
|
|
|
|
# content/shell/android/java/src/chromium/base/Foo.java
|
|
|
|
# content/shell/android/java/src/chromium/base/Bar.java
|
2012-09-28 22:22:29 +04:00
|
|
|
#
|
|
|
|
# Required variables:
|
|
|
|
# package_name - Used to name the intermediate output directory and in the
|
|
|
|
# names of some output files.
|
|
|
|
# apk_name - The final apk will be named <apk_name>-debug.apk (or -release)
|
|
|
|
# java_in_dir - The top-level java directory. The src should be in
|
|
|
|
# <java_in_dir>/src.
|
|
|
|
# resource_dir - The directory for resources.
|
|
|
|
# Optional/automatic variables:
|
|
|
|
# additional_input_paths - These paths will be included in the 'inputs' list to
|
|
|
|
# ensure that this target is rebuilt when one of these paths changes.
|
|
|
|
# additional_src_dirs - Additional directories with .java files to be compiled
|
|
|
|
# and included in the output of this target.
|
2012-10-05 20:51:32 +04:00
|
|
|
# asset_location - The directory where assets are located (default:
|
|
|
|
# <PRODUCT_DIR>/<package_name>/assets).
|
2012-09-28 22:22:29 +04:00
|
|
|
# generated_src_dirs - Same as additional_src_dirs except used for .java files
|
|
|
|
# that are generated at build time. This should be set automatically by a
|
|
|
|
# target's dependencies. The .java files in these directories are not
|
|
|
|
# included in the 'inputs' list (unlike additional_src_dirs).
|
|
|
|
# input_jars_paths - The path to jars to be included in the classpath. This
|
|
|
|
# should be filled automatically by depending on the appropriate targets.
|
|
|
|
# native_libs_paths - The path to any native library to be included in this
|
2012-10-12 03:23:49 +04:00
|
|
|
# target. This should be a path in <(SHARED_LIB_DIR). A stripped copy of
|
|
|
|
# the library will be included in the apk and symbolic links to the
|
|
|
|
# unstripped copy will be added to <(android_product_out) to enable native
|
|
|
|
# debugging.
|
2012-09-19 08:16:27 +04:00
|
|
|
|
|
|
|
{
|
|
|
|
'variables': {
|
2012-10-10 02:40:39 +04:00
|
|
|
'asset_location%': '',
|
2012-10-05 20:51:32 +04:00
|
|
|
'additional_input_paths': [],
|
2012-09-19 08:16:27 +04:00
|
|
|
'input_jars_paths': [],
|
2012-09-28 22:22:29 +04:00
|
|
|
'additional_src_dirs': [],
|
|
|
|
'generated_src_dirs': [],
|
2012-10-10 05:29:46 +04:00
|
|
|
'app_manifest_version_name%': '<(android_app_version_name)',
|
|
|
|
'app_manifest_version_code%': '<(android_app_version_code)',
|
|
|
|
'proguard_enabled%': 'false',
|
2012-10-12 03:23:49 +04:00
|
|
|
'proguard_flags%': '',
|
|
|
|
'native_libs_paths': [],
|
|
|
|
'manifest_package_name%': 'unknown.package.name',
|
2012-09-19 08:16:27 +04:00
|
|
|
},
|
2012-10-12 03:23:49 +04:00
|
|
|
'sources': [
|
|
|
|
'<@(native_libs_paths)'
|
|
|
|
],
|
|
|
|
'rules': [
|
|
|
|
{
|
|
|
|
'rule_name': 'copy_and_strip_native_libraries',
|
|
|
|
'extension': 'so',
|
|
|
|
'variables': {
|
|
|
|
'stripped_library_path': '<(PRODUCT_DIR)/<(package_name)/libs/<(android_app_abi)/<(RULE_INPUT_ROOT).so',
|
|
|
|
'link_dir': '<(android_product_out)/symbols/data/data/<(manifest_package_name)/lib/',
|
|
|
|
},
|
|
|
|
'outputs': [
|
|
|
|
'<(stripped_library_path)',
|
|
|
|
'<(link_dir)/<(RULE_INPUT_ROOT).so',
|
|
|
|
],
|
|
|
|
# There is no way to do 2 actions for each source library in gyp. So to
|
|
|
|
# both strip the library and create the link in <(link_dir) a separate
|
|
|
|
# script is required.
|
|
|
|
'action': [
|
|
|
|
'<(DEPTH)/build/android/prepare_library_for_apk',
|
|
|
|
'<(android_strip)',
|
|
|
|
'<(RULE_INPUT_PATH)',
|
|
|
|
'<(stripped_library_path)',
|
|
|
|
'<(link_dir)',
|
|
|
|
],
|
|
|
|
},
|
|
|
|
],
|
2012-09-19 08:16:27 +04:00
|
|
|
'actions': [
|
|
|
|
{
|
|
|
|
'action_name': 'ant_<(package_name)_apk',
|
|
|
|
'message': 'Building <(package_name) apk.',
|
|
|
|
'inputs': [
|
|
|
|
'<(java_in_dir)/AndroidManifest.xml',
|
2012-10-05 20:51:32 +04:00
|
|
|
'<(DEPTH)/build/android/ant/chromium-apk.xml',
|
2012-09-19 08:16:27 +04:00
|
|
|
'<(DEPTH)/build/android/ant/common.xml',
|
|
|
|
'<(DEPTH)/build/android/ant/sdk-targets.xml',
|
2012-10-12 03:23:49 +04:00
|
|
|
# If there is a separate find for additional_src_dirs, it will find the
|
2012-09-28 22:22:29 +04:00
|
|
|
# wrong .java files when additional_src_dirs is empty.
|
|
|
|
'>!@(find >(java_in_dir) >(additional_src_dirs) -name "*.java")',
|
2012-09-19 08:16:27 +04:00
|
|
|
'<!@(find <(java_in_dir)/<(resource_dir) -name "*")',
|
|
|
|
'>@(input_jars_paths)',
|
|
|
|
'>@(native_libs_paths)',
|
|
|
|
'>@(additional_input_paths)',
|
|
|
|
],
|
|
|
|
'outputs': [
|
2012-10-10 00:17:56 +04:00
|
|
|
# TODO(cjhopman): Apks are built with a -debug suffix even when they are
|
|
|
|
# built in release. This should be fixed.
|
2012-09-19 22:19:18 +04:00
|
|
|
'<(PRODUCT_DIR)/apks/<(apk_name)-debug.apk',
|
2012-09-19 08:16:27 +04:00
|
|
|
],
|
|
|
|
'action': [
|
|
|
|
'ant',
|
|
|
|
'-DAPP_ABI=<(android_app_abi)',
|
|
|
|
'-DANDROID_GDBSERVER=<(android_gdbserver)',
|
|
|
|
'-DANDROID_SDK=<(android_sdk)',
|
|
|
|
'-DANDROID_SDK_ROOT=<(android_sdk_root)',
|
|
|
|
'-DANDROID_SDK_TOOLS=<(android_sdk_tools)',
|
|
|
|
'-DANDROID_SDK_VERSION=<(android_sdk_version)',
|
|
|
|
'-DANDROID_TOOLCHAIN=<(android_toolchain)',
|
2012-09-28 22:22:29 +04:00
|
|
|
'-DCHROMIUM_SRC=<(ant_build_out)/../..',
|
2012-09-19 08:16:27 +04:00
|
|
|
'-DCONFIGURATION_NAME=<(CONFIGURATION_NAME)',
|
2012-09-28 22:22:29 +04:00
|
|
|
'-DPRODUCT_DIR=<(ant_build_out)',
|
|
|
|
|
2012-10-05 20:51:32 +04:00
|
|
|
'-DAPK_NAME=<(apk_name)',
|
|
|
|
'-DASSET_DIR=<(asset_location)',
|
2012-09-19 08:16:27 +04:00
|
|
|
'-DADDITIONAL_SRC_DIRS=>(additional_src_dirs)',
|
2012-09-28 22:22:29 +04:00
|
|
|
'-DGENERATED_SRC_DIRS=>(generated_src_dirs)',
|
2012-10-05 20:51:32 +04:00
|
|
|
'-DINPUT_JARS_PATHS=>(input_jars_paths)',
|
2012-09-28 22:22:29 +04:00
|
|
|
'-DPACKAGE_NAME=<(package_name)',
|
2012-09-19 08:16:27 +04:00
|
|
|
'-DRESOURCE_DIR=<(resource_dir)',
|
2012-10-10 05:29:46 +04:00
|
|
|
'-DAPP_MANIFEST_VERSION_NAME=<(app_manifest_version_name)',
|
|
|
|
'-DAPP_MANIFEST_VERSION_CODE=<(app_manifest_version_code)',
|
|
|
|
'-DPROGUARD_FLAGS=>(proguard_flags)',
|
|
|
|
'-DPROGUARD_ENABLED=>(proguard_enabled)',
|
2012-09-28 22:22:29 +04:00
|
|
|
|
2012-10-05 20:51:32 +04:00
|
|
|
'-Dbasedir=<(java_in_dir)',
|
2012-09-19 08:16:27 +04:00
|
|
|
'-buildfile',
|
2012-10-10 00:17:56 +04:00
|
|
|
'<(DEPTH)/build/android/ant/chromium-apk.xml',
|
|
|
|
|
|
|
|
# Specify CONFIGURATION_NAME as the target for ant to build. The
|
|
|
|
# buildfile will then build the appropriate SDK tools target.
|
|
|
|
'<(CONFIGURATION_NAME)',
|
2012-09-19 08:16:27 +04:00
|
|
|
]
|
|
|
|
},
|
|
|
|
],
|
|
|
|
}
|