| // Copyright (C) 2007 The Android Open Source Project |
| // |
| // Licensed under the Apache License, Version 2.0 (the "License"); |
| // you may not use this file except in compliance with the License. |
| // You may obtain a copy of the License at |
| // |
| // http://www.apache.org/licenses/LICENSE-2.0 |
| // |
| // Unless required by applicable law or agreed to in writing, software |
| // distributed under the License is distributed on an "AS IS" BASIS, |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
| // See the License for the specific language governing permissions and |
| // limitations under the License. |
| |
| // |
| // Definitions for building the Android core library and associated tests. |
| // |
| |
| // The Android core library provides low-level APIs for use by the rest of the |
| // Android software stack. It is made up of various parts, some of which can be |
| // found in libcore/ and other parts that can be found in various external/ |
| // directories. See the "core-system-modules" definition for the parts. |
| |
| // libcore has some sub-directories that follow a common structure: |
| // e.g. dalvik, dom, harmony-tests, json, jsr166-tests, luni, libart, ojluni, |
| // support, xml, xmlpull. |
| // |
| // The structure of these is generally: |
| // |
| // src/ |
| // main/ # To be shipped on every device. |
| // java/ # Java source for library code. |
| // native/ # C/C++ source for library code. |
| // resources/ # Support files. |
| // test/ # Built only on demand, for testing. |
| // java/ # Java source for tests. |
| // native/ # C/C++ source for tests (rare). |
| // resources/ # Support files. |
| // |
| // All subdirectories are optional. |
| |
| build = [ |
| "openjdk_java_files.bp", |
| "non_openjdk_java_files.bp", |
| ] |
| |
| // The Java files and their associated resources. |
| core_resource_dirs = [ |
| "luni/src/main/java", |
| "ojluni/src/main/resources/", |
| ] |
| |
| // The source files that go into core-oj. |
| filegroup { |
| name: "core_oj_java_files", |
| srcs: [":openjdk_java_files"], |
| } |
| |
| // OpenJDK source is not annotated with @hide so we need a separate |
| // filegroup for just the parts that contribute to the API. |
| filegroup { |
| name: "core_oj_api_files", |
| srcs: [":openjdk_javadoc_files"], |
| } |
| |
| // The source files that go into core-libart. |
| filegroup { |
| name: "core_libart_java_files", |
| srcs: [ |
| ":non_openjdk_java_files", |
| ":android_icu4j_src_files", |
| ], |
| } |
| |
| // Some parts of libart are not annotated with @hide so we need a separate |
| // filegroup for just the parts that contribute to the API. |
| filegroup { |
| name: "core_libart_api_files", |
| srcs: [ |
| ":non_openjdk_javadoc_files", |
| ":android_icu4j_src_files", |
| ], |
| } |
| |
| // The set of files for the core library that have been marked up with @hide and |
| // API-related annotations. Note that this includes the intra-core and |
| // core-platform APIs as well as the public APIs. |
| // |
| // Some source files in :openjdk_mmodule_extra_files are annotated by applying |
| // annotations to the .annotated.java stubs files in ojluni/annotated/mmodules |
| // and rather than in the original source. See the comments in |
| // openjdk_java_files.bp for more details. |
| filegroup { |
| name: "core_api_files", |
| srcs: [ |
| ":apache-xml_api_files", |
| ":bouncycastle_java_files", |
| ":conscrypt_java_files", |
| ":core_oj_api_files", |
| ":core_libart_api_files", |
| ":okhttp_api_files", |
| ":openjdk_mmodule_extra_files", |
| ], |
| } |
| |
| java_defaults { |
| name: "libcore_java_defaults", |
| javacflags: [ |
| //"-Xlint:all", |
| //"-Xlint:-serial,-deprecation,-unchecked", |
| ], |
| dxflags: ["--core-library"], |
| errorprone: { |
| javacflags: [ |
| "-Xep:MissingOverride:OFF", // Ignore missing @Override. |
| "-Xep:ConstantOverflow:WARN", // Known constant overflow in SplittableRandom |
| ], |
| }, |
| } |
| |
| // |
| // Build for the target (device). |
| // |
| |
| // Rule generating resource lib for android_icu4j. |
| // In the downstream branch master-icu-dev, the resource files are generated. |
| // This rule can't be moved external/icu because soong enforces that no_standard_libs:true can only |
| // be used in libcore/ or development/ |
| java_library { |
| name: "android_icu4j_resources_lib", |
| java_resources: [":android_icu4j_resources"], |
| no_standard_libs: true, |
| system_modules: "none", |
| } |
| |
| // A target used to bootstrap compilation for the core library. |
| // See core-all-system-modules for more details. |
| java_library { |
| name: "core-all", |
| defaults: ["libcore_java_defaults"], |
| |
| srcs: [ |
| ":core_oj_java_files", |
| ":core_libart_java_files", |
| ":openjdk_lambda_stub_files", |
| ], |
| |
| no_standard_libs: true, |
| system_modules: "none", |
| openjdk9: { |
| srcs: ["luni/src/module/java/module-info.java"], |
| javacflags: ["--patch-module=java.base=."], |
| }, |
| |
| java_resource_dirs: core_resource_dirs, |
| static_libs: ["android_icu4j_resources_lib"], |
| java_version: "1.9", |
| |
| installable: false, |
| } |
| |
| // A system modules definition for use by core library targets only. It only |
| // contains the core-all jar, which contains the classes that end up in core-oj, |
| // core-libart as well as the lambda stubs needed to compile Java lambda code. |
| // It does not contain other parts of core library like conscrypt, bouncycastle, |
| // etc. This system_modules definition is used to bootstrap compilation for |
| // other parts of the core library like core-oj, core-libart, conscrypt, |
| // bouncycastle, etc. |
| // |
| // If you want to compile against the entire core library implementation, for |
| // example to build core library tests, see "core-system-modules" instead. |
| java_system_modules { |
| name: "core-all-system-modules", |
| libs: ["core-all"], |
| } |
| |
| // Contains the parts of core library associated with OpenJDK. |
| java_library { |
| name: "core-oj", |
| defaults: ["libcore_java_defaults"], |
| installable: true, |
| hostdex: true, |
| |
| srcs: [":core_oj_java_files"], |
| java_resource_dirs: core_resource_dirs, |
| |
| no_standard_libs: true, |
| libs: ["core-all"], |
| system_modules: "core-all-system-modules", |
| openjdk9: { |
| javacflags: ["--patch-module=java.base=."], |
| }, |
| |
| jacoco: { |
| exclude_filter: [ |
| "java.lang.Class", |
| "java.lang.Long", |
| "java.lang.Number", |
| "java.lang.Object", |
| "java.lang.String", |
| "java.lang.invoke.MethodHandle", |
| "java.lang.ref.Reference", |
| "java.lang.reflect.Proxy", |
| "java.util.AbstractMap", |
| "java.util.HashMap", |
| "java.util.HashMap$Node", |
| "java.util.Map", |
| ], |
| }, |
| |
| notice: "ojluni/NOTICE", |
| |
| } |
| |
| // Contains parts of core library not associated with OpenJDK. Contains not |
| // just java.*, javax.* code but also android.icu.*, android.system.* and |
| // various internal libcore.* packages. |
| java_library { |
| name: "core-libart", |
| defaults: ["libcore_java_defaults"], |
| installable: true, |
| hostdex: true, |
| |
| srcs: [":core_libart_java_files"], |
| static_libs: ["android_icu4j_resources_lib"], |
| java_version: "1.9", |
| |
| no_standard_libs: true, |
| libs: ["core-all"], |
| system_modules: "core-all-system-modules", |
| openjdk9: { |
| javacflags: ["--patch-module=java.base=."], |
| }, |
| |
| jacoco: { |
| exclude_filter: [ |
| "java.lang.DexCache", |
| "dalvik.system.ClassExt", |
| ], |
| }, |
| |
| required: [ |
| // Device files put in /system. |
| "tzdata", |
| "tz_version", |
| // Files used to simulate the /system and runtime APEX dir |
| // structure on host. |
| "tzdata_host", |
| "tzdata_host_runtime_apex", |
| "tzlookup.xml_host_runtime_apex", |
| "tz_version_host", |
| "tz_version_host_runtime_apex", |
| ], |
| } |
| |
| // Provided solely to contribute information about which hidden parts of the |
| // core-oj API are used by apps. |
| java_library { |
| name: "core-oj-hiddenapi", |
| defaults: ["libcore_java_defaults"], |
| compile_dex: true, |
| |
| srcs: [":openjdk_hiddenapi_javadoc_files"], |
| |
| no_standard_libs: true, |
| libs: ["core-all"], |
| system_modules: "core-all-system-modules", |
| openjdk9: { |
| javacflags: ["--patch-module=java.base=."], |
| }, |
| } |
| |
| // |
| // Guaranteed unstripped versions of core-oj and core-libart. |
| // |
| // The build system may or may not strip the core-oj and core-libart jars, |
| // but these will not be stripped. See b/24535627. |
| // |
| |
| java_library { |
| name: "core-oj-testdex", |
| installable: true, |
| static_libs: ["core-oj"], |
| no_standard_libs: true, |
| libs: ["core-all"], |
| system_modules: "core-all-system-modules", |
| dxflags: ["--core-library"], |
| dex_preopt: { |
| enabled: false, |
| }, |
| java_version: "1.9", |
| notice: "ojluni/NOTICE", |
| } |
| |
| java_library { |
| name: "core-libart-testdex", |
| installable: true, |
| static_libs: ["core-libart"], |
| no_standard_libs: true, |
| libs: ["core-all"], |
| system_modules: "core-all-system-modules", |
| dxflags: ["--core-library"], |
| dex_preopt: { |
| enabled: false, |
| }, |
| notice: "ojluni/NOTICE", |
| } |
| |
| |
| java_defaults { |
| name: "core_lambda_stubs_defaults", |
| defaults: ["libcore_java_defaults"], |
| hostdex: true, |
| |
| no_standard_libs: true, |
| libs: ["core-all"], |
| system_modules: "core-all-system-modules", |
| openjdk9: { |
| javacflags: ["--patch-module=java.base=."], |
| }, |
| |
| notice: "ojluni/NOTICE", |
| |
| installable: false, |
| include_srcs: true, |
| } |
| |
| // Creates a jar that exists to satisfy javac when compiling source code that |
| // contains lambdas. This contains all classes / methods required by javac |
| // when generating invoke-dynamic lambda implementation code, even those that |
| // are also in the public SDK API from API level 26 onwards. |
| java_library { |
| name: "core-lambda-stubs", |
| defaults: ["core_lambda_stubs_defaults"], |
| srcs: [ |
| ":openjdk_lambda_stub_files", |
| ":openjdk_lambda_duplicate_stub_files", |
| ], |
| } |
| |
| // An alternative to core-lambda-stubs that omits openjdk_lambda_duplicate_stub_files |
| // because those classes are also part of the core library public SDK API |
| // (since API level 26). |
| java_library { |
| name: "core-lambda-stubs-for-system-modules", |
| defaults: ["core_lambda_stubs_defaults"], |
| srcs: [ |
| ":openjdk_lambda_stub_files", |
| ], |
| } |
| |
| // A system modules definition containing the implementations for the various |
| // parts that make up the core library. |
| // |
| // This system module is intended for use by tests that may need access to |
| // core library internals. It should not be generally used; most of the |
| // platform build should build against API stubs instead. See |
| // "core-platform-api-stubs-system-modules", which is the default used by the |
| // Android build. |
| // |
| // This module also includes lambda stubs for compiling source containing |
| // Java lambdas. |
| java_system_modules { |
| name: "core-system-modules", |
| libs: [ |
| "core-oj", |
| "core-libart", |
| "bouncycastle", |
| "conscrypt", |
| "okhttp", |
| "apache-xml", |
| // This one is not on device but it's needed when javac compiles code |
| // containing lambdas. |
| "core-lambda-stubs-for-system-modules", |
| ], |
| } |
| |
| // Builds libcore test rules |
| java_library_static { |
| name: "core-test-rules", |
| hostdex: true, |
| srcs: [ |
| "dalvik/test-rules/src/main/**/*.java", |
| "test-rules/src/main/**/*.java", |
| ], |
| static_libs: ["junit"], |
| |
| no_standard_libs: true, |
| libs: ["core-all"], |
| system_modules: "core-all-system-modules", |
| } |
| |
| // Builds the core-tests-support library used by various tests. |
| java_library_static { |
| name: "core-tests-support", |
| hostdex: true, |
| srcs: ["support/src/test/java/**/*.java"], |
| |
| no_framework_libs: true, |
| libs: ["junit"], |
| static_libs: [ |
| "bouncycastle-unbundled", |
| "bouncycastle-bcpkix-unbundled", |
| "bouncycastle-ocsp-unbundled", |
| ], |
| } |
| |
| // Builds the jsr166-tests library. |
| java_test { |
| name: "jsr166-tests", |
| srcs: ["jsr166-tests/src/test/java/**/*.java"], |
| no_standard_libs: true, |
| libs: [ |
| "core-all", |
| "junit", |
| ], |
| system_modules: "core-all-system-modules", |
| } |
| |
| // Builds a library just containing files from luni/src/test/filesystems |
| // for use in tests. |
| java_library { |
| name: "filesystemstest", |
| compile_dex: true, |
| srcs: ["luni/src/test/filesystems/src/**/*.java"], |
| java_resource_dirs: ["luni/src/test/filesystems/resources"], |
| no_framework_libs: true, |
| errorprone: { |
| javacflags: ["-Xep:MissingOverride:OFF"], |
| }, |
| } |
| |
| // Builds a library just containing files from luni/src/test/parameter_metadata |
| // for use in tests. |
| java_library { |
| name: "parameter-metadata-test", |
| compile_dex: true, |
| srcs: ["luni/src/test/parameter_metadata/src/**/*.java"], |
| no_framework_libs: true, |
| javacflags: ["-parameters"], |
| errorprone: { |
| javacflags: ["-Xep:MissingOverride:OFF"], |
| }, |
| } |
| |
| // Builds the core-tests library. |
| java_test { |
| name: "core-tests", |
| defaults: ["libcore_java_defaults"], |
| hostdex: true, |
| srcs: [ |
| "dalvik/src/test/java/**/*.java", |
| "dalvik/test-rules/src/test/java/**/*.java", |
| "dom/src/test/java/**/*.java", |
| "harmony-tests/src/test/java/**/*.java", |
| "json/src/test/java/**/*.java", |
| "luni/src/test/java/**/*.java", |
| "xml/src/test/java/**/*.java", |
| ], |
| exclude_srcs: [ |
| "luni/src/test/java/libcore/java/util/zip/Zip64Test.java", |
| "luni/src/test/java/libcore/java/util/zip/Zip64FileTest.java", |
| ], |
| |
| java_resource_dirs: [ |
| "*/src/test/java", |
| "*/src/test/resources", |
| ], |
| exclude_java_resource_dirs: [ |
| "ojluni/src/test/java", |
| "ojluni/src/test/resources", |
| ], |
| |
| java_resources: [ |
| ":filesystemstest", |
| ":parameter-metadata-test", |
| ], |
| |
| no_standard_libs: true, |
| libs: [ |
| "core-all", |
| "okhttp", |
| "bouncycastle", |
| ], |
| system_modules: "core-all-system-modules", |
| |
| static_libs: [ |
| "archive-patcher", |
| "core-test-rules", |
| "core-tests-support", |
| "junit-params", |
| "mockftpserver", |
| "mockito-target", |
| "mockwebserver", |
| "nist-pkix-tests", |
| "slf4j-jdk14", |
| "sqlite-jdbc", |
| "tzdata-testing", |
| "truth-prebuilt", |
| ], |
| |
| errorprone: { |
| javacflags: [ |
| "-Xep:TryFailThrowable:ERROR", |
| "-Xep:ComparisonOutOfRange:ERROR", |
| ], |
| }, |
| |
| test_config: "AndroidTest-core-tests.xml", |
| } |
| |
| // Builds the core-ojtests library that contains test code from OpenJDK. |
| java_test { |
| name: "core-ojtests", |
| defaults: ["libcore_java_defaults"], |
| hostdex: true, |
| |
| srcs: [ |
| "ojluni/src/test/java/**/*.java", |
| ], |
| java_resource_dirs: [ |
| "ojluni/src/test/java", |
| "ojluni/src/test/resources", |
| ], |
| |
| no_standard_libs: true, |
| libs: [ |
| "core-all", |
| "okhttp", |
| "bouncycastle", |
| ], |
| system_modules: "core-all-system-modules", |
| |
| static_libs: ["testng"], |
| |
| // ojluni/src/test/java/util/stream/{bootlib,boottest} |
| // contains tests that are in packages from java.base; |
| // By default, OpenJDK 9's javac will only compile such |
| // code if it's declared to also be in java.base at |
| // compile time. |
| // |
| // For now, we use --patch-module to put all sources |
| // and dependencies from this make target into java.base; |
| // other source directories in this make target are in |
| // packages not from java.base; if this becomes a problem |
| // in future, this could be addressed eg. by splitting |
| // boot{lib,test} out into a separate make target, |
| // deleting those tests or moving them to a different |
| // package. |
| patch_module: "java.base", |
| } |
| |
| // Builds the core-ojtests-public library. Excludes any private API tests. |
| // Like core-ojtests but smaller. |
| java_test { |
| name: "core-ojtests-public", |
| defaults: ["libcore_java_defaults"], |
| srcs: [ |
| "ojluni/src/test/java/**/*.java", |
| ], |
| // Filter out the following: |
| // 1.) DeserializeMethodTest and SerializedLambdaTest, because they depends on stub classes |
| // and won't actually run, and |
| // 2.) util/stream/boot*. Those directories contain classes in the package java.util.stream; |
| // excluding them means we don't need patch_module: "java.base" |
| exclude_srcs: [ |
| "**/DeserializeMethodTest.java", |
| "**/SerializedLambdaTest.java", |
| "ojluni/src/test/java/util/stream/boot*/**/*", |
| ], |
| java_resource_dirs: [ |
| "ojluni/src/test/java", |
| "ojluni/src/test/resources", |
| // Include source code as part of JAR |
| "ojluni/src/test/dist", |
| ], |
| |
| no_standard_libs: true, |
| libs: [ |
| "core-all", |
| "bouncycastle", |
| "okhttp", |
| "testng", |
| ], |
| system_modules: "core-all-system-modules", |
| } |
| |
| // Exports annotated stubs source files in ojluni/annotations/sdk to make them |
| // available to metalava. Used for nullability annotations in OpenJDK source. |
| droiddoc_exported_dir { |
| name: "ojluni-annotated-sdk-stubs", |
| path: "ojluni/annotations/sdk", |
| } |
| droiddoc_exported_dir { |
| name: "ojluni-annotated-nullability-stubs", |
| path: "ojluni/annotations/sdk/nullability", |
| } |
| |
| // Exports annotated stubs source files in ojluni/annotations/mmodules to make |
| // them available to metalava. Used for core platform API and intra-code API |
| // annotations in OpenJDK source. |
| droiddoc_exported_dir { |
| name: "ojluni-annotated-mmodule-stubs", |
| path: "ojluni/annotations/mmodule", |
| } |
| |
| // A file containing the list of tags that are "known" to us from the OpenJdk |
| // source code and so should not cause an error or warning. |
| filegroup { |
| name: "known-oj-tags", |
| srcs: [ |
| "known_oj_tags.txt", |
| ], |
| } |
| |
| // Generates stubs for the parts of the public SDK API provided by the core |
| // library. |
| droidstubs { |
| name: "core-current-stubs-gen", |
| srcs: [":core_api_files"], |
| java_version: "1.9", |
| installable: false, |
| no_framework_libs: true, |
| args: " --exclude-annotations " |
| + "--hide-annotation libcore.api.Hide", |
| merge_inclusion_annotations_dirs: ["ojluni-annotated-mmodule-stubs"], |
| } |
| |
| // Target for validating nullability annotations for correctness and |
| // completeness. To check that there are no nullability errors: |
| // make core-current-stubs-nullability-validation |
| // To check that there are only the expected nullability warnings: |
| // make core-current-stubs-nullability-validation-check-nullability-warnings |
| // To update the the list of known expected nullability warnings: |
| // make core-current-stubs-nullability-validation-update-nullability-warnings |
| droidstubs { |
| name: "core-current-stubs-nullability-validation", |
| srcs: [":core_api_files"], |
| installable: false, |
| no_framework_libs: true, |
| annotations_enabled: true, |
| args: "--hide-annotation libcore.api.Hide " + |
| "--validate-nullability-from-merged-stubs ", |
| merge_inclusion_annotations_dirs: ["ojluni-annotated-mmodule-stubs"], |
| merge_annotations_dirs: [ |
| "metalava-manual", |
| // N.B. Stubs in this filegroup will be validated: |
| "ojluni-annotated-nullability-stubs", |
| ], |
| // The list of classes which have nullability annotations included in the source. |
| // (This is in addition to those which have annotations in the merged stubs.) |
| validate_nullability_from_list: "nullability_annotated_classes.txt", |
| // The expected set of warnings about missing annotations: |
| check_nullability_warnings: "nullability_warnings.txt", |
| } |
| |
| // A stubs target containing the parts of the public SDK API provided by the |
| // core library. |
| // |
| // Don't use this directly, use "sdk_version: core_current". |
| java_library { |
| name: "core.current.stubs", |
| srcs: [":core-current-stubs-gen"], |
| errorprone: { |
| javacflags: [ |
| "-Xep:MissingOverride:OFF", |
| ], |
| }, |
| openjdk9: { |
| javacflags: ["--patch-module=java.base=."], |
| }, |
| no_standard_libs: true, |
| system_modules: "none", |
| } |
| |
| // A host library containing time zone related classes. Used for |
| // host-side tools and tests that have to deal with Android |
| // time zone data. |
| java_library_host { |
| name: "timezone-host", |
| srcs: [":timezone_host_files"], |
| } |