This CL adds a genrule that generates a text file that contains all of the normal / non-signature permissions formatted with one permission per line. This can be used by tools that require a list of permissions known as part of their build. Without this support, it would be difficult to write the build rules for such tools as it is not possible to access the frameworks/base/core/res/AndroidManifest.xml from Android.bp files in other directories. Test: Built locally and manually verified the file Change-Id: I01046e5faa1f0a81c3d2ee82643094d4cf82f221
76 lines
2.5 KiB
Plaintext
76 lines
2.5 KiB
Plaintext
//
|
|
// Copyright (C) 2008 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.
|
|
//
|
|
|
|
android_app {
|
|
name: "framework-res",
|
|
sdk_version: "core_platform",
|
|
certificate: "platform",
|
|
|
|
// Soong special-cases framework-res to install this alongside
|
|
// the libraries at /system/framework/framework-res.apk.
|
|
|
|
// Generate private symbols into the com.android.internal.R class
|
|
// so they are not accessible to 3rd party apps.
|
|
aaptflags: [
|
|
"--private-symbols",
|
|
"com.android.internal",
|
|
|
|
// Framework doesn't need versioning since it IS the platform.
|
|
"--no-auto-version",
|
|
|
|
// Allow overlay to add resource
|
|
"--auto-add-overlay",
|
|
],
|
|
|
|
// Create package-export.apk, which other packages can use to get
|
|
// PRODUCT-agnostic resource data like IDs and type definitions.
|
|
export_package_resources: true,
|
|
|
|
dist: {
|
|
targets: [
|
|
"simulated_device_launcher",
|
|
],
|
|
},
|
|
}
|
|
|
|
// This logic can be removed once robolectric's transition to binary resources is complete
|
|
filegroup {
|
|
name: "robolectric_framework_raw_res_files",
|
|
srcs: [
|
|
"assets/**/*",
|
|
"res/**/*",
|
|
],
|
|
}
|
|
|
|
// Generate a text file containing a list of permissions that non-system apps
|
|
// are allowed to obtain.
|
|
genrule {
|
|
name: "permission-list-normal",
|
|
out: ["permission-list-normal.txt"],
|
|
srcs: ["AndroidManifest.xml"],
|
|
cmd: "cat $(in) " +
|
|
// xmllint has trouble accessing attributes under the android namespace.
|
|
// Strip these prefixes prior to processing with xmllint.
|
|
" | sed -r 's/android:(name|protectionLevel)/\\1/g' " +
|
|
" | $(location xmllint) /dev/stdin --xpath " +
|
|
" '//permission[not(contains(@protectionLevel, \"signature\"))]/@name'" +
|
|
// The result of xmllint is name="value" pairs. Format these to just the
|
|
// permission name, one per-line.
|
|
" | sed -r 's/\\s*name=\\s*//g' | tr -d '\"'" +
|
|
" > $(out)",
|
|
tools: ["xmllint"]
|
|
}
|