Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 # Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 # Copyright (c) 2012 The Chromium Authors. All rights reserved. |
| 2 # Use of this source code is governed by a BSD-style license that can be | 2 # Use of this source code is governed by a BSD-style license that can be |
| 3 # found in the LICENSE file. | 3 # found in the LICENSE file. |
| 4 | 4 |
| 5 # This file is meant to be included into a target to provide a rule | 5 # This file is meant to be included into a target to provide a rule |
| 6 # to build Android APKs in a consistent manner. | 6 # to build Android APKs in a consistent manner. |
| 7 # | 7 # |
| 8 # To use this, create a gyp target with the following form: | 8 # To use this, create a gyp target with the following form: |
| 9 # { | 9 # { |
| 10 # 'target_name': 'my_package_apk', | 10 # 'target_name': 'my_package_apk', |
| (...skipping 190 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 201 'unsigned_standalone_apk_path': '<(unsigned_standalone_apk_path)', | 201 'unsigned_standalone_apk_path': '<(unsigned_standalone_apk_path)', |
| 202 'unsigned_apk_path': '<(unsigned_apk_path)', | 202 'unsigned_apk_path': '<(unsigned_apk_path)', |
| 203 'unsigned_abi_split_apk_path': '<(unsigned_abi_split_apk_path)', | 203 'unsigned_abi_split_apk_path': '<(unsigned_abi_split_apk_path)', |
| 204 'create_abi_split%': '<(create_abi_split)', | 204 'create_abi_split%': '<(create_abi_split)', |
| 205 'managed_input_apk_path': '<(managed_input_apk_path)', | 205 'managed_input_apk_path': '<(managed_input_apk_path)', |
| 206 'libchromium_android_linker': 'libchromium_android_linker.>(android_product_ extension)', | 206 'libchromium_android_linker': 'libchromium_android_linker.>(android_product_ extension)', |
| 207 'extra_native_libs': [], | 207 'extra_native_libs': [], |
| 208 'native_lib_placeholder_stamp': '<(apk_package_native_libs_dir)/<(android_ap p_abi)/native_lib_placeholder.stamp', | 208 'native_lib_placeholder_stamp': '<(apk_package_native_libs_dir)/<(android_ap p_abi)/native_lib_placeholder.stamp', |
| 209 'native_lib_placeholders': [], | 209 'native_lib_placeholders': [], |
| 210 'main_apk_name': '<(apk_name)', | 210 'main_apk_name': '<(apk_name)', |
| 211 'enable_errorprone%': '1', | |
| 212 'errorprone_exe_path': '<(PRODUCT_DIR)/bin.java/chromium_errorprone', | |
| 211 }, | 213 }, |
| 212 # Pass the jar path to the apk's "fake" jar target. This would be better as | 214 # Pass the jar path to the apk's "fake" jar target. This would be better as |
| 213 # direct_dependent_settings, but a variable set by a direct_dependent_settings | 215 # direct_dependent_settings, but a variable set by a direct_dependent_settings |
| 214 # cannot be lifted in a dependent to all_dependent_settings. | 216 # cannot be lifted in a dependent to all_dependent_settings. |
| 215 'all_dependent_settings': { | 217 'all_dependent_settings': { |
| 216 'conditions': [ | 218 'conditions': [ |
| 217 ['proguard_enabled == "true"', { | 219 ['proguard_enabled == "true"', { |
| 218 'variables': { | 220 'variables': { |
| 219 'proguard_enabled': 'true', | 221 'proguard_enabled': 'true', |
| 220 } | 222 } |
| (...skipping 22 matching lines...) Expand all Loading... | |
| 243 ['native_lib_target != "" and component == "shared_library"', { | 245 ['native_lib_target != "" and component == "shared_library"', { |
| 244 'dependencies': [ | 246 'dependencies': [ |
| 245 '<(DEPTH)/build/android/setup.gyp:copy_system_libraries', | 247 '<(DEPTH)/build/android/setup.gyp:copy_system_libraries', |
| 246 ], | 248 ], |
| 247 }], | 249 }], |
| 248 ['use_chromium_linker == 1', { | 250 ['use_chromium_linker == 1', { |
| 249 'dependencies': [ | 251 'dependencies': [ |
| 250 '<(DEPTH)/base/base.gyp:chromium_android_linker', | 252 '<(DEPTH)/base/base.gyp:chromium_android_linker', |
| 251 ], | 253 ], |
| 252 }], | 254 }], |
| 255 ['enable_errorprone == 1', { | |
| 256 'dependencies': [ | |
|
jbudorick
2015/05/28 15:38:00
Why is this only added to dependencies here in jav
raywilliams_chromium
2015/05/28 17:59:11
Done.
raywilliams_chromium
2015/05/28 17:59:11
added to conditions in the other two jars
| |
| 257 '<(DEPTH)/third_party/errorprone/errorprone.gyp:chromium_errorprone', | |
| 258 ], | |
| 259 }], | |
| 253 ['native_lib_target != ""', { | 260 ['native_lib_target != ""', { |
| 254 'variables': { | 261 'variables': { |
| 255 'conditions': [ | 262 'conditions': [ |
| 256 ['use_chromium_linker == 1', { | 263 ['use_chromium_linker == 1', { |
| 257 'variables': { | 264 'variables': { |
| 258 'chromium_linker_path': [ | 265 'chromium_linker_path': [ |
| 259 '<(SHARED_LIB_DIR)/<(libchromium_android_linker)', | 266 '<(SHARED_LIB_DIR)/<(libchromium_android_linker)', |
| 260 ], | 267 ], |
| 261 } | 268 } |
| 262 }, { | 269 }, { |
| (...skipping 537 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 800 # wrong .java files when additional_src_dirs is empty. | 807 # wrong .java files when additional_src_dirs is empty. |
| 801 # TODO(thakis): Gyp caches >! evaluation by command. Both java.gypi and | 808 # TODO(thakis): Gyp caches >! evaluation by command. Both java.gypi and |
| 802 # java_apk.gypi evaluate the same command, and at the moment two targets | 809 # java_apk.gypi evaluate the same command, and at the moment two targets |
| 803 # set java_in_dir to "java". Add a dummy comment here to make sure | 810 # set java_in_dir to "java". Add a dummy comment here to make sure |
| 804 # that the two targets (one uses java.gypi, the other java_apk.gypi) | 811 # that the two targets (one uses java.gypi, the other java_apk.gypi) |
| 805 # get distinct source lists. Medium-term, make targets list all their | 812 # get distinct source lists. Medium-term, make targets list all their |
| 806 # Java files instead of using find. (As is, this will be broken if two | 813 # Java files instead of using find. (As is, this will be broken if two |
| 807 # targets use the same java_in_dir and both use java_apk.gypi or | 814 # targets use the same java_in_dir and both use java_apk.gypi or |
| 808 # both use java.gypi.) | 815 # both use java.gypi.) |
| 809 'java_sources': ['>!@(find >(java_in_dir)>(java_in_dir_suffix) >(additio nal_src_dirs) -name "*.java" # apk)'], | 816 'java_sources': ['>!@(find >(java_in_dir)>(java_in_dir_suffix) >(additio nal_src_dirs) -name "*.java" # apk)'], |
| 810 | 817 'conditions': [ |
| 818 ['enable_errorprone == 1', { | |
| 819 'extra_inputs': [ | |
| 820 '<(errorprone_exe_path)', | |
| 821 ], | |
| 822 'extra_args': [ '--use-errorprone-path=<(errorprone_exe_path)' ], | |
| 823 }], | |
| 824 ], | |
| 811 }, | 825 }, |
| 812 'inputs': [ | 826 'inputs': [ |
| 813 '<(DEPTH)/build/android/gyp/util/build_utils.py', | 827 '<(DEPTH)/build/android/gyp/util/build_utils.py', |
| 814 '<(DEPTH)/build/android/gyp/javac.py', | 828 '<(DEPTH)/build/android/gyp/javac.py', |
| 815 '>@(java_sources)', | 829 '>@(java_sources)', |
| 816 '>@(input_jars_paths)', | 830 '>@(input_jars_paths)', |
| 817 '<(codegen_stamp)', | 831 '<(codegen_stamp)', |
| 832 '<@(extra_inputs)', | |
| 818 ], | 833 ], |
| 819 'conditions': [ | 834 'conditions': [ |
| 820 ['native_lib_target != ""', { | 835 ['native_lib_target != ""', { |
| 821 'inputs': [ '<(native_libraries_java_stamp)' ], | 836 'inputs': [ '<(native_libraries_java_stamp)' ], |
| 822 }], | 837 }], |
| 823 ], | 838 ], |
| 824 'outputs': [ | 839 'outputs': [ |
| 825 '<(compile_stamp)', | 840 '<(compile_stamp)', |
| 826 '<(javac_jar_path)', | 841 '<(javac_jar_path)', |
| 827 ], | 842 ], |
| 828 'action': [ | 843 'action': [ |
| 829 'python', '<(DEPTH)/build/android/gyp/javac.py', | 844 'python', '<(DEPTH)/build/android/gyp/javac.py', |
| 830 '--classpath=>(input_jars_paths) <(android_sdk_jar)', | 845 '--classpath=>(input_jars_paths) <(android_sdk_jar)', |
| 831 '--src-gendirs=>(gen_src_dirs)', | 846 '--src-gendirs=>(gen_src_dirs)', |
| 832 '--javac-includes=<(javac_includes)', | 847 '--javac-includes=<(javac_includes)', |
| 833 '--chromium-code=<(chromium_code)', | 848 '--chromium-code=<(chromium_code)', |
| 834 '--jar-path=<(javac_jar_path)', | 849 '--jar-path=<(javac_jar_path)', |
| 835 '--jar-excluded-classes=<(jar_excluded_classes)', | 850 '--jar-excluded-classes=<(jar_excluded_classes)', |
| 836 '--stamp=<(compile_stamp)', | 851 '--stamp=<(compile_stamp)', |
| 852 '<@(extra_args)', | |
| 837 '>@(java_sources)', | 853 '>@(java_sources)', |
| 838 ], | 854 ], |
| 839 }, | 855 }, |
| 840 { | 856 { |
| 841 'action_name': 'instr_jar_<(_target_name)', | 857 'action_name': 'instr_jar_<(_target_name)', |
| 842 'message': 'Instrumenting <(_target_name) jar', | 858 'message': 'Instrumenting <(_target_name) jar', |
| 843 'variables': { | 859 'variables': { |
| 844 'input_path': '<(javac_jar_path)', | 860 'input_path': '<(javac_jar_path)', |
| 845 'output_path': '<(jar_path)', | 861 'output_path': '<(jar_path)', |
| 846 'stamp_path': '<(instr_stamp)', | 862 'stamp_path': '<(instr_stamp)', |
| (...skipping 172 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1019 'native_libs_dir': '<(apk_package_native_libs_dir)', | 1035 'native_libs_dir': '<(apk_package_native_libs_dir)', |
| 1020 }, { | 1036 }, { |
| 1021 'native_libs_dir': '<(DEPTH)/build/android/ant/empty/res', | 1037 'native_libs_dir': '<(DEPTH)/build/android/ant/empty/res', |
| 1022 }], | 1038 }], |
| 1023 ], | 1039 ], |
| 1024 }, | 1040 }, |
| 1025 'includes': ['android/apkbuilder_action.gypi'], | 1041 'includes': ['android/apkbuilder_action.gypi'], |
| 1026 }, | 1042 }, |
| 1027 ], | 1043 ], |
| 1028 } | 1044 } |
| OLD | NEW |