aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorColin Cross <ccross@android.com>2019-10-18 20:09:34 -0700
committerKimberly Kreider <kkreider@google.com>2019-12-17 22:23:23 +0000
commit4ba82c94824137acae8ed1c69db6d1c151b155ee (patch)
tree340466216de6672de0dffec7c2ec7a8dea017f54
parent438f8347e87ebaad8605bfc7f2d125a503151570 (diff)
downloadbuild_soong-4ba82c94824137acae8ed1c69db6d1c151b155ee.tar.gz
build_soong-4ba82c94824137acae8ed1c69db6d1c151b155ee.tar.bz2
build_soong-4ba82c94824137acae8ed1c69db6d1c151b155ee.zip
DO NOT MERGE: Add tradefed_java_library_host
Add a module type for tradefed libraries that causes an additional copy to be installed at out/host/linux-x86/tradefed. Bug: 143908003 Exclude merging into *-plus-aosp branches, since they already include the change. Merged-In: I670345494abbad80dacab54471e635abfae3b3b3 Merged-In: I1cb25bbd5823a14f1a9428d58827677eff22ec7e Change-Id: I55bca53e02588827374896ef87d58f3f4bdc48c7 (cherry picked from commit f0f2e2cf79558569c227e8d96a784d9c0679814a) (cherry picked from commit cba45b28925b2fb3ebbd9e281a185de0d2b8b0c7)
-rw-r--r--Android.bp1
-rw-r--r--java/java.go8
-rw-r--r--java/tradefed.go37
3 files changed, 45 insertions, 1 deletions
diff --git a/Android.bp b/Android.bp
index 2692b1be..2f5343e4 100644
--- a/Android.bp
+++ b/Android.bp
@@ -281,6 +281,7 @@ bootstrap_go_package {
"java/support_libraries.go",
"java/system_modules.go",
"java/testing.go",
+ "java/tradefed.go",
],
testSrcs: [
"java/app_test.go",
diff --git a/java/java.go b/java/java.go
index 9ac38c92..6bfdfeee 100644
--- a/java/java.go
+++ b/java/java.go
@@ -1453,6 +1453,8 @@ func (j *Module) CompilerDeps() []string {
type Library struct {
Module
+
+ InstallMixin func(ctx android.ModuleContext, installPath android.Path) (extraInstallDeps android.Paths)
}
func shouldUncompressDex(ctx android.ModuleContext, dexpreopter *dexpreopter) bool {
@@ -1482,8 +1484,12 @@ func (j *Library) GenerateAndroidBuildActions(ctx android.ModuleContext) {
j.compile(ctx)
if (Bool(j.properties.Installable) || ctx.Host()) && !android.DirectlyInAnyApex(ctx, ctx.ModuleName()) {
+ var extraInstallDeps android.Paths
+ if j.InstallMixin != nil {
+ extraInstallDeps = j.InstallMixin(ctx, j.outputFile)
+ }
j.installFile = ctx.InstallFile(android.PathForModuleInstall(ctx, "framework"),
- ctx.ModuleName()+".jar", j.outputFile)
+ ctx.ModuleName()+".jar", j.outputFile, extraInstallDeps...)
}
}
diff --git a/java/tradefed.go b/java/tradefed.go
new file mode 100644
index 00000000..ebbdec13
--- /dev/null
+++ b/java/tradefed.go
@@ -0,0 +1,37 @@
+// Copyright 2019 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 java
+
+import (
+ "android/soong/android"
+)
+
+func init() {
+ android.RegisterModuleType("tradefed_java_library_host", tradefedJavaLibraryFactory)
+}
+
+// tradefed_java_library_factory wraps java_library and installs an additional
+// copy of the output jar to $HOST_OUT/tradefed.
+func tradefedJavaLibraryFactory() android.Module {
+ module := LibraryHostFactory().(*Library)
+ module.InstallMixin = tradefedJavaLibraryInstall
+ return module
+}
+
+func tradefedJavaLibraryInstall(ctx android.ModuleContext, path android.Path) android.Paths {
+ installedPath := ctx.InstallFile(android.PathForModuleInstall(ctx, "tradefed"),
+ ctx.ModuleName()+".jar", path)
+ return android.Paths{installedPath}
+}