diff options
author | Colin Cross <ccross@android.com> | 2019-10-18 20:09:34 -0700 |
---|---|---|
committer | Kimberly Kreider <kkreider@google.com> | 2019-12-17 22:23:23 +0000 |
commit | 4ba82c94824137acae8ed1c69db6d1c151b155ee (patch) | |
tree | 340466216de6672de0dffec7c2ec7a8dea017f54 | |
parent | 438f8347e87ebaad8605bfc7f2d125a503151570 (diff) | |
download | build_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.bp | 1 | ||||
-rw-r--r-- | java/java.go | 8 | ||||
-rw-r--r-- | java/tradefed.go | 37 |
3 files changed, 45 insertions, 1 deletions
@@ -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} +} |