Add java config and share it with make

Add a java/config package to hold config information, and share
it with make through makevars.

Test: builds
Change-Id: I46c088bda0fe97a1823bfdd80fa692d0bf61da1b
This commit is contained in:
Colin Cross 2017-06-22 17:20:19 -07:00
parent 540eff8e5f
commit 3e3e72da90
4 changed files with 69 additions and 4 deletions

View File

@ -188,6 +188,7 @@ bootstrap_go_package {
"soong", "soong",
"soong-android", "soong-android",
"soong-genrule", "soong-genrule",
"soong-java-config",
], ],
srcs: [ srcs: [
"java/androidmk.go", "java/androidmk.go",
@ -201,6 +202,19 @@ bootstrap_go_package {
pluginFor: ["soong_build"], pluginFor: ["soong_build"],
} }
bootstrap_go_package {
name: "soong-java-config",
pkgPath: "android/soong/java/config",
deps: [
"blueprint-proptools",
"soong-android",
],
srcs: [
"java/config/config.go",
"java/config/makevars.go",
],
}
bootstrap_go_package { bootstrap_go_package {
name: "soong-python", name: "soong-python",
pkgPath: "android/soong/python", pkgPath: "android/soong/python",

23
java/config/config.go Normal file
View File

@ -0,0 +1,23 @@
// Copyright 2017 Google Inc. All rights reserved.
//
// 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.
package config
import "android/soong/android"
var (
DefaultLibraries = []string{"core-oj", "core-libart", "ext", "framework", "okhttp"}
)
var pctx = android.NewPackageContext("android/soong/java/config")

29
java/config/makevars.go Normal file
View File

@ -0,0 +1,29 @@
// Copyright 2017 Google Inc. All rights reserved.
//
// 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.
package config
import (
"strings"
"android/soong/android"
)
func init() {
android.RegisterMakeVarsProvider(pctx, makeVarsProvider)
}
func makeVarsProvider(ctx android.MakeVarsContext) {
ctx.Strict("TARGET_DEFAULT_JAVA_LIBRARIES", strings.Join(DefaultLibraries, " "))
}

View File

@ -26,6 +26,7 @@ import (
"android/soong/android" "android/soong/android"
"android/soong/genrule" "android/soong/genrule"
"android/soong/java/config"
) )
func init() { func init() {
@ -169,8 +170,6 @@ func (j *Module) BootClasspath(ctx android.BaseContext) string {
} }
} }
var defaultJavaLibraries = []string{"core-libart", "legacy-test", "ext", "framework"}
func (j *Module) deps(ctx android.BottomUpMutatorContext) { func (j *Module) deps(ctx android.BottomUpMutatorContext) {
var deps []string var deps []string
@ -180,7 +179,7 @@ func (j *Module) deps(ctx android.BottomUpMutatorContext) {
deps = append(deps, bootClasspath) deps = append(deps, bootClasspath)
} }
if ctx.Device() && j.deviceProperties.Sdk_version == "" { if ctx.Device() && j.deviceProperties.Sdk_version == "" {
deps = append(deps, defaultJavaLibraries...) deps = append(deps, config.DefaultLibraries...)
} }
} }
deps = append(deps, j.properties.Java_libs...) deps = append(deps, j.properties.Java_libs...)
@ -218,7 +217,7 @@ func (j *Module) collectDeps(ctx android.ModuleContext) (classpath android.Paths
if javaDep, ok := module.(JavaDependency); ok { if javaDep, ok := module.(JavaDependency); ok {
if otherName == j.BootClasspath(ctx) { if otherName == j.BootClasspath(ctx) {
bootClasspath = android.OptionalPathForPath(javaDep.ClasspathFile()) bootClasspath = android.OptionalPathForPath(javaDep.ClasspathFile())
} else if inList(otherName, defaultJavaLibraries) { } else if inList(otherName, config.DefaultLibraries) {
classpath = append(classpath, javaDep.ClasspathFile()) classpath = append(classpath, javaDep.ClasspathFile())
} else if inList(otherName, j.properties.Java_libs) { } else if inList(otherName, j.properties.Java_libs) {
classpath = append(classpath, javaDep.ClasspathFile()) classpath = append(classpath, javaDep.ClasspathFile())