| // Copyright (C) 2019 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. |
| |
| mainline_stubs_args = |
| "--error UnhiddenSystemApi " + |
| "--hide BroadcastBehavior " + |
| "--hide DeprecationMismatch " + |
| "--hide HiddenSuperclass " + |
| "--hide HiddenTypedefConstant " + |
| "--hide HiddenTypeParameter " + |
| "--hide MissingPermission " + |
| "--hide RequiresPermission " + |
| "--hide SdkConstant " + |
| "--hide Todo " + |
| "--hide Typo " + |
| "--hide UnavailableSymbol " |
| |
| // TODO: modularize this so not every module has the same whitelist |
| framework_packages_to_document = [ |
| "android", |
| "dalvik", |
| "java", |
| "javax", |
| "junit", |
| "org.apache.http", |
| "org.json", |
| "org.w3c.dom", |
| "org.xml.sax", |
| "org.xmlpull", |
| ] |
| |
| // TODO: remove the hiding when server classes are cleaned up. |
| mainline_framework_stubs_args = |
| mainline_stubs_args + |
| "--hide-package com.android.server " |
| |
| priv_apps = " " + |
| "--show-annotation android.annotation.SystemApi\\(" + |
| "client=android.annotation.SystemApi.Client.PRIVILEGED_APPS" + |
| "\\) " |
| |
| module_libs = " " + |
| " --show-annotation android.annotation.SystemApi\\(" + |
| "client=android.annotation.SystemApi.Client.MODULE_LIBRARIES" + |
| "\\) " |
| |
| mainline_service_stubs_args = |
| mainline_stubs_args + |
| "--show-annotation android.annotation.SystemApi\\(" + |
| "client=android.annotation.SystemApi.Client.SYSTEM_SERVER" + |
| "\\) " + |
| "--hide-annotation android.annotation.Hide " + |
| "--hide InternalClasses " // com.android.* classes are okay in this interface |
| |
| // Defaults common to all mainline module java_sdk_library instances. |
| java_defaults { |
| name: "framework-module-common-defaults", |
| |
| // Additional annotations used for compiling both the implementation and the |
| // stubs libraries. |
| libs: ["framework-annotations-lib"], |
| |
| // Framework modules are not generally shared libraries, i.e. they are not |
| // intended, and must not be allowed, to be used in a <uses-library> manifest |
| // entry. |
| shared_library: false, |
| |
| // Enable api lint. This will eventually become the default for java_sdk_library |
| // but it cannot yet be turned on because some usages have not been cleaned up. |
| // TODO(b/156126315) - Remove when no longer needed. |
| api_lint: { |
| enabled: true, |
| }, |
| |
| // The API scope specific properties. |
| public: { |
| enabled: true, |
| sdk_version: "module_current", |
| }, |
| |
| // Configure framework module specific metalava options. |
| droiddoc_options: [mainline_stubs_args], |
| |
| annotations_enabled: true, |
| |
| // The stub libraries must be visible to frameworks/base so they can be combined |
| // into API specific libraries. |
| stubs_library_visibility: [ |
| "//frameworks/base", // Framework |
| ], |
| |
| // Set the visibility of the modules creating the stubs source. |
| stubs_source_visibility: [ |
| // Ignore any visibility rules specified on the java_sdk_library when |
| // setting the visibility of the stubs source modules. |
| "//visibility:override", |
| |
| // Currently, the stub source is not required for anything other than building |
| // the stubs library so is private to avoid misuse. |
| "//visibility:private", |
| ], |
| |
| // Collates API usages from each module for further analysis. |
| plugins: ["java_api_finder"], |
| |
| // Mainline modules should only rely on 'module_lib' APIs provided by other modules |
| // and the non updatable parts of the platform. |
| sdk_version: "module_current", |
| } |
| |
| // Defaults for mainline module provided java_sdk_library instances. |
| java_defaults { |
| name: "framework-module-defaults", |
| defaults: ["framework-module-common-defaults"], |
| |
| system: { |
| enabled: true, |
| sdk_version: "module_current", |
| }, |
| module_lib: { |
| enabled: true, |
| sdk_version: "module_current", |
| }, |
| } |
| |
| // Defaults for mainline module system server provided java_sdk_library instances. |
| java_defaults { |
| name: "framework-system-server-module-defaults", |
| defaults: ["framework-module-common-defaults"], |
| |
| system_server: { |
| enabled: true, |
| sdk_version: "module_current", |
| }, |
| } |
| |
| stubs_defaults { |
| name: "framework-module-stubs-defaults-publicapi", |
| args: mainline_framework_stubs_args, |
| installable: false, |
| sdk_version: "module_current", |
| annotations_enabled: true, |
| merge_annotations_dirs: [ |
| "metalava-manual", |
| ], |
| filter_packages: framework_packages_to_document, |
| check_api: { |
| current: { |
| api_file: "api/current.txt", |
| removed_api_file: "api/removed.txt", |
| }, |
| api_lint: { |
| enabled: true, |
| }, |
| }, |
| dist: { |
| targets: ["sdk", "win_sdk"], |
| dir: "apistubs/android/public/api", |
| }, |
| } |
| |
| stubs_defaults { |
| name: "framework-module-stubs-defaults-systemapi", |
| args: mainline_framework_stubs_args + priv_apps, |
| libs: ["framework-annotations-lib"], |
| installable: false, |
| sdk_version: "module_current", |
| annotations_enabled: true, |
| merge_annotations_dirs: [ |
| "metalava-manual", |
| ], |
| filter_packages: framework_packages_to_document, |
| check_api: { |
| current: { |
| api_file: "api/system-current.txt", |
| removed_api_file: "api/system-removed.txt", |
| }, |
| api_lint: { |
| enabled: true, |
| }, |
| }, |
| dist: { |
| targets: ["sdk", "win_sdk"], |
| dir: "apistubs/android/system/api", |
| }, |
| } |
| |
| java_defaults { |
| name: "framework-module-stubs-lib-defaults-publicapi", |
| installable: false, |
| sdk_version: "module_current", |
| libs: [ "stub-annotations" ], |
| java_version: "1.8", |
| dist: { |
| targets: ["sdk", "win_sdk"], |
| dir: "apistubs/android/public", |
| }, |
| } |
| |
| java_defaults { |
| name: "framework-module-stubs-lib-defaults-systemapi", |
| installable: false, |
| sdk_version: "module_current", |
| libs: [ "stub-annotations" ], |
| java_version: "1.8", |
| dist: { |
| targets: ["sdk", "win_sdk"], |
| dir: "apistubs/android/system", |
| }, |
| } |
| |
| java_defaults { |
| name: "framework-module-stubs-lib-defaults-module_libs_api", |
| installable: false, |
| sdk_version: "module_current", |
| libs: [ "stub-annotations" ], |
| java_version: "1.8", |
| dist: { |
| targets: ["sdk", "win_sdk"], |
| dir: "apistubs/android/module-lib", |
| }, |
| } |
| |
| // The defaults for module_libs comes in two parts - defaults for API checks |
| // and defaults for stub generation. This is because we want the API txt |
| // files to *only* include the module_libs_api, but the stubs to include |
| // module_libs_api as well as priv_apps. |
| |
| stubs_defaults { |
| name: "framework-module-api-defaults-module_libs_api", |
| args: mainline_framework_stubs_args + module_libs, |
| libs: ["framework-annotations-lib"], |
| installable: false, |
| sdk_version: "module_current", |
| annotations_enabled: true, |
| merge_annotations_dirs: [ |
| "metalava-manual", |
| ], |
| filter_packages: framework_packages_to_document, |
| check_api: { |
| current: { |
| api_file: "api/module-lib-current.txt", |
| removed_api_file: "api/module-lib-removed.txt", |
| }, |
| api_lint: { |
| enabled: true, |
| }, |
| }, |
| dist: { |
| targets: ["sdk", "win_sdk"], |
| dir: "apistubs/android/module-lib/api", |
| }, |
| } |
| |
| stubs_defaults { |
| name: "framework-module-stubs-defaults-module_libs_api", |
| args: mainline_framework_stubs_args + module_libs + priv_apps, |
| libs: ["framework-annotations-lib"], |
| installable: false, |
| sdk_version: "module_current", |
| annotations_enabled: true, |
| merge_annotations_dirs: [ |
| "metalava-manual", |
| ], |
| filter_packages: framework_packages_to_document, |
| } |
| |
| stubs_defaults { |
| name: "service-module-stubs-srcs-defaults", |
| args: mainline_service_stubs_args, |
| installable: false, |
| annotations_enabled: true, |
| merge_annotations_dirs: [ |
| "metalava-manual", |
| ], |
| filter_packages: ["com.android."], |
| check_api: { |
| current: { |
| api_file: "api/current.txt", |
| removed_api_file: "api/removed.txt", |
| }, |
| api_lint: { |
| enabled: true, |
| }, |
| }, |
| dist: { |
| targets: ["sdk", "win_sdk"], |
| dir: "apistubs/android/system-server/api", |
| }, |
| } |
| |
| // Empty for now, but a convenient place to add rules for all |
| // module java_library system_server stub libs. |
| java_defaults { |
| name: "service-module-stubs-defaults", |
| dist: { |
| targets: ["sdk", "win_sdk"], |
| dir: "apistubs/android/system-server", |
| }, |
| } |