blob: a1a01a5cf1017c2e5c9916a1bf207a7d6ffb4bbe [file] [log] [blame]
Colin Cross3f40fa42015-01-30 17:27:36 -08001// Copyright 2015 Google Inc. All rights reserved.
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
Colin Cross635c3b02016-05-18 15:37:25 -070015package android
Colin Cross3f40fa42015-01-30 17:27:36 -080016
17import (
Colin Cross6ff51382015-12-17 16:39:19 -080018 "fmt"
Alex Lightfb4353d2019-01-17 13:57:45 -080019 "path"
Colin Cross3f40fa42015-01-30 17:27:36 -080020 "path/filepath"
Colin Cross6ff51382015-12-17 16:39:19 -080021 "strings"
Colin Crossaabf6792017-11-29 00:27:14 -080022 "text/scanner"
Colin Crossf6566ed2015-03-24 11:13:38 -070023
24 "github.com/google/blueprint"
Colin Cross7f19f372016-11-01 11:10:25 -070025 "github.com/google/blueprint/pathtools"
Colin Crossfe4bc362018-09-12 10:02:13 -070026 "github.com/google/blueprint/proptools"
Colin Cross3f40fa42015-01-30 17:27:36 -080027)
28
29var (
30 DeviceSharedLibrary = "shared_library"
31 DeviceStaticLibrary = "static_library"
32 DeviceExecutable = "executable"
33 HostSharedLibrary = "host_shared_library"
34 HostStaticLibrary = "host_static_library"
35 HostExecutable = "host_executable"
36)
37
Colin Crossae887032017-10-23 17:16:14 -070038type BuildParams struct {
Dan Willemsen9f3c5742016-11-03 14:28:31 -070039 Rule blueprint.Rule
Colin Cross33bfb0a2016-11-21 17:23:08 -080040 Deps blueprint.Deps
41 Depfile WritablePath
Colin Cross67a5c132017-05-09 13:45:28 -070042 Description string
Dan Willemsen9f3c5742016-11-03 14:28:31 -070043 Output WritablePath
44 Outputs WritablePaths
45 ImplicitOutput WritablePath
46 ImplicitOutputs WritablePaths
47 Input Path
48 Inputs Paths
49 Implicit Path
50 Implicits Paths
51 OrderOnly Paths
52 Default bool
53 Args map[string]string
Dan Willemsen34cc69e2015-09-23 15:26:20 -070054}
55
Colin Crossae887032017-10-23 17:16:14 -070056type ModuleBuildParams BuildParams
57
Colin Cross0ea8ba82019-06-06 14:33:29 -070058// BaseModuleContext is the same as blueprint.BaseModuleContext except that Config() returns
Colin Crossdc35e212019-06-06 16:13:11 -070059// a Config instead of an interface{}, and some methods have been wrapped to use an android.Module
60// instead of a blueprint.Module, plus some extra methods that return Android-specific information
Colin Cross0ea8ba82019-06-06 14:33:29 -070061// about the current module.
62type BaseModuleContext interface {
Colin Crossdc35e212019-06-06 16:13:11 -070063 Module() Module
Colin Cross0ea8ba82019-06-06 14:33:29 -070064 ModuleName() string
65 ModuleDir() string
66 ModuleType() string
67 Config() Config
68
Colin Crossdc35e212019-06-06 16:13:11 -070069 OtherModuleName(m blueprint.Module) string
70 OtherModuleDir(m blueprint.Module) string
71 OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{})
72 OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag
73 OtherModuleExists(name string) bool
Jiyong Park9e6c2422019-08-09 20:39:45 +090074 OtherModuleType(m blueprint.Module) string
Colin Crossdc35e212019-06-06 16:13:11 -070075
76 GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module
77 GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module
78 GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag)
79
80 VisitDirectDepsBlueprint(visit func(blueprint.Module))
81 VisitDirectDeps(visit func(Module))
82 VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module))
83 VisitDirectDepsIf(pred func(Module) bool, visit func(Module))
84 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
85 VisitDepsDepthFirst(visit func(Module))
86 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
87 VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module))
88 WalkDeps(visit func(Module, Module) bool)
89 WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool)
90 // GetWalkPath is supposed to be called in visit function passed in WalkDeps()
91 // and returns a top-down dependency path from a start module to current child module.
92 GetWalkPath() []Module
93
Colin Cross0ea8ba82019-06-06 14:33:29 -070094 ContainsProperty(name string) bool
95 Errorf(pos scanner.Position, fmt string, args ...interface{})
96 ModuleErrorf(fmt string, args ...interface{})
97 PropertyErrorf(property, fmt string, args ...interface{})
98 Failed() bool
99
100 // GlobWithDeps returns a list of files that match the specified pattern but do not match any
101 // of the patterns in excludes. It also adds efficient dependencies to rerun the primary
102 // builder whenever a file matching the pattern as added or removed, without rerunning if a
103 // file that does not match the pattern is added to a searched directory.
104 GlobWithDeps(pattern string, excludes []string) ([]string, error)
105
Colin Crossdc35e212019-06-06 16:13:11 -0700106 Glob(globPattern string, excludes []string) Paths
107 GlobFiles(globPattern string, excludes []string) Paths
108
Colin Cross0ea8ba82019-06-06 14:33:29 -0700109 Fs() pathtools.FileSystem
110 AddNinjaFileDeps(deps ...string)
111
Colin Crossdc35e212019-06-06 16:13:11 -0700112 AddMissingDependencies(missingDeps []string)
113
Colin Crossa1ad8d12016-06-01 17:09:44 -0700114 Target() Target
Colin Cross8b74d172016-09-13 09:59:14 -0700115 TargetPrimary() bool
Colin Crossee0bc3b2018-10-02 22:01:37 -0700116 MultiTargets() []Target
Colin Crossf6566ed2015-03-24 11:13:38 -0700117 Arch() Arch
Colin Crossa1ad8d12016-06-01 17:09:44 -0700118 Os() OsType
Colin Crossf6566ed2015-03-24 11:13:38 -0700119 Host() bool
120 Device() bool
Colin Cross0af4b842015-04-30 16:36:18 -0700121 Darwin() bool
Doug Horn21b94272019-01-16 12:06:11 -0800122 Fuchsia() bool
Colin Cross3edeee12017-04-04 12:59:48 -0700123 Windows() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700124 Debug() bool
Colin Cross1e7d3702016-08-24 15:25:47 -0700125 PrimaryArch() bool
Jiyong Park2db76922017-11-08 16:03:48 +0900126 Platform() bool
127 DeviceSpecific() bool
128 SocSpecific() bool
129 ProductSpecific() bool
Justin Yund5f6c822019-06-25 16:47:17 +0900130 SystemExtSpecific() bool
Colin Cross1332b002015-04-07 17:11:30 -0700131 AConfig() Config
Colin Cross9272ade2016-08-17 15:24:12 -0700132 DeviceConfig() DeviceConfig
Colin Crossf6566ed2015-03-24 11:13:38 -0700133}
134
Colin Cross0ea8ba82019-06-06 14:33:29 -0700135// Deprecated: use BaseModuleContext instead
Colin Cross635c3b02016-05-18 15:37:25 -0700136type BaseContext interface {
Colin Crossaabf6792017-11-29 00:27:14 -0800137 BaseModuleContext
Colin Crossaabf6792017-11-29 00:27:14 -0800138}
139
Colin Cross635c3b02016-05-18 15:37:25 -0700140type ModuleContext interface {
Colin Crossaabf6792017-11-29 00:27:14 -0800141 BaseModuleContext
Colin Cross3f40fa42015-01-30 17:27:36 -0800142
Colin Crossae887032017-10-23 17:16:14 -0700143 // Deprecated: use ModuleContext.Build instead.
Colin Cross0875c522017-11-28 17:34:01 -0800144 ModuleBuild(pctx PackageContext, params ModuleBuildParams)
Colin Cross8f101b42015-06-17 15:09:06 -0700145
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700146 ExpandSources(srcFiles, excludes []string) Paths
Colin Cross366938f2017-12-11 16:29:02 -0800147 ExpandSource(srcFile, prop string) Path
Colin Cross2383f3b2018-02-06 14:40:13 -0800148 ExpandOptionalSource(srcFile *string, prop string) OptionalPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700149
Colin Cross5c517922017-08-31 12:29:17 -0700150 InstallExecutable(installPath OutputPath, name string, srcPath Path, deps ...Path) OutputPath
151 InstallFile(installPath OutputPath, name string, srcPath Path, deps ...Path) OutputPath
Colin Cross3854a602016-01-11 12:49:11 -0800152 InstallSymlink(installPath OutputPath, name string, srcPath OutputPath) OutputPath
Jiyong Parkf1194352019-02-25 11:05:47 +0900153 InstallAbsoluteSymlink(installPath OutputPath, name string, absPath string) OutputPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700154 CheckbuildFile(srcPath Path)
Dan Willemsen6553f5e2016-03-10 18:14:25 -0800155
Colin Cross8d8f8e22016-08-03 11:57:50 -0700156 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700157 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700158 InstallInSanitizerDir() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900159 InstallInRecovery() bool
Colin Cross607d8582019-07-29 16:44:46 -0700160 InstallBypassMake() bool
Nan Zhang6d34b302017-02-04 17:47:46 -0800161
162 RequiredModuleNames() []string
Sasha Smundakb6d23052019-04-01 18:37:36 -0700163 HostRequiredModuleNames() []string
164 TargetRequiredModuleNames() []string
Colin Cross3f68a132017-10-23 17:10:29 -0700165
Colin Cross3f68a132017-10-23 17:10:29 -0700166 ModuleSubDir() string
167
Colin Cross0875c522017-11-28 17:34:01 -0800168 Variable(pctx PackageContext, name, value string)
169 Rule(pctx PackageContext, name string, params blueprint.RuleParams, argNames ...string) blueprint.Rule
Colin Crossae887032017-10-23 17:16:14 -0700170 // Similar to blueprint.ModuleContext.Build, but takes Paths instead of []string,
171 // and performs more verification.
Colin Cross0875c522017-11-28 17:34:01 -0800172 Build(pctx PackageContext, params BuildParams)
Colin Cross3f68a132017-10-23 17:10:29 -0700173
Colin Cross0875c522017-11-28 17:34:01 -0800174 PrimaryModule() Module
175 FinalModule() Module
176 VisitAllModuleVariants(visit func(Module))
Colin Cross3f68a132017-10-23 17:10:29 -0700177
178 GetMissingDependencies() []string
Jeff Gaston088e29e2017-11-29 16:47:17 -0800179 Namespace() blueprint.Namespace
Colin Cross3f40fa42015-01-30 17:27:36 -0800180}
181
Colin Cross635c3b02016-05-18 15:37:25 -0700182type Module interface {
Colin Cross3f40fa42015-01-30 17:27:36 -0800183 blueprint.Module
184
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700185 // GenerateAndroidBuildActions is analogous to Blueprints' GenerateBuildActions,
186 // but GenerateAndroidBuildActions also has access to Android-specific information.
187 // For more information, see Module.GenerateBuildActions within Blueprint's module_ctx.go
Colin Cross635c3b02016-05-18 15:37:25 -0700188 GenerateAndroidBuildActions(ModuleContext)
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700189
Colin Cross1e676be2016-10-12 14:38:15 -0700190 DepsMutator(BottomUpMutatorContext)
Colin Cross3f40fa42015-01-30 17:27:36 -0800191
Colin Cross635c3b02016-05-18 15:37:25 -0700192 base() *ModuleBase
Dan Willemsen0effe062015-11-30 16:06:01 -0800193 Enabled() bool
Colin Crossa1ad8d12016-06-01 17:09:44 -0700194 Target() Target
Dan Willemsen782a2d12015-12-21 14:55:28 -0800195 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700196 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700197 InstallInSanitizerDir() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900198 InstallInRecovery() bool
Colin Cross607d8582019-07-29 16:44:46 -0700199 InstallBypassMake() bool
Colin Crossa2f296f2016-11-29 15:16:18 -0800200 SkipInstall()
Jiyong Park374510b2018-03-19 18:23:01 +0900201 ExportedToMake() bool
Jiyong Park52818fc2019-03-18 12:01:38 +0900202 NoticeFile() OptionalPath
Colin Cross36242852017-06-23 15:06:31 -0700203
204 AddProperties(props ...interface{})
205 GetProperties() []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700206
Colin Crossae887032017-10-23 17:16:14 -0700207 BuildParamsForTests() []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800208 RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800209 VariablesForTests() map[string]string
Paul Duffine2453c72019-05-31 14:00:04 +0100210
Colin Cross9a362232019-07-01 15:32:45 -0700211 // String returns a string that includes the module name and variants for printing during debugging.
212 String() string
213
Paul Duffine2453c72019-05-31 14:00:04 +0100214 // Get the qualified module id for this module.
215 qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName
216
217 // Get information about the properties that can contain visibility rules.
218 visibilityProperties() []visibilityProperty
Paul Duffin63c6e182019-07-24 14:24:38 +0100219
220 // Get the visibility rules that control the visibility of this module.
221 visibility() []string
Paul Duffine2453c72019-05-31 14:00:04 +0100222}
223
224// Qualified id for a module
225type qualifiedModuleName struct {
226 // The package (i.e. directory) in which the module is defined, without trailing /
227 pkg string
228
229 // The name of the module, empty string if package.
230 name string
231}
232
233func (q qualifiedModuleName) String() string {
234 if q.name == "" {
235 return "//" + q.pkg
236 }
237 return "//" + q.pkg + ":" + q.name
238}
239
Paul Duffine484f472019-06-20 16:38:08 +0100240func (q qualifiedModuleName) isRootPackage() bool {
241 return q.pkg == "" && q.name == ""
242}
243
Paul Duffine2453c72019-05-31 14:00:04 +0100244// Get the id for the package containing this module.
245func (q qualifiedModuleName) getContainingPackageId() qualifiedModuleName {
246 pkg := q.pkg
247 if q.name == "" {
Paul Duffine484f472019-06-20 16:38:08 +0100248 if pkg == "" {
249 panic(fmt.Errorf("Cannot get containing package id of root package"))
250 }
251
252 index := strings.LastIndex(pkg, "/")
253 if index == -1 {
254 pkg = ""
255 } else {
256 pkg = pkg[:index]
257 }
Paul Duffine2453c72019-05-31 14:00:04 +0100258 }
259 return newPackageId(pkg)
260}
261
262func newPackageId(pkg string) qualifiedModuleName {
263 // A qualified id for a package module has no name.
264 return qualifiedModuleName{pkg: pkg, name: ""}
Colin Cross3f40fa42015-01-30 17:27:36 -0800265}
266
Colin Crossfc754582016-05-17 16:34:16 -0700267type nameProperties struct {
268 // The name of the module. Must be unique across all modules.
Nan Zhang0007d812017-11-07 10:57:05 -0800269 Name *string
Colin Crossfc754582016-05-17 16:34:16 -0700270}
271
272type commonProperties struct {
Dan Willemsen0effe062015-11-30 16:06:01 -0800273 // emit build rules for this module
274 Enabled *bool `android:"arch_variant"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800275
Paul Duffin2e61fa62019-03-28 14:10:57 +0000276 // Controls the visibility of this module to other modules. Allowable values are one or more of
277 // these formats:
278 //
279 // ["//visibility:public"]: Anyone can use this module.
280 // ["//visibility:private"]: Only rules in the module's package (not its subpackages) can use
281 // this module.
282 // ["//some/package:__pkg__", "//other/package:__pkg__"]: Only modules in some/package and
283 // other/package (defined in some/package/*.bp and other/package/*.bp) have access to
284 // this module. Note that sub-packages do not have access to the rule; for example,
285 // //some/package/foo:bar or //other/package/testing:bla wouldn't have access. __pkg__
286 // is a special module and must be used verbatim. It represents all of the modules in the
287 // package.
288 // ["//project:__subpackages__", "//other:__subpackages__"]: Only modules in packages project
289 // or other or in one of their sub-packages have access to this module. For example,
290 // //project:rule, //project/library:lib or //other/testing/internal:munge are allowed
291 // to depend on this rule (but not //independent:evil)
292 // ["//project"]: This is shorthand for ["//project:__pkg__"]
293 // [":__subpackages__"]: This is shorthand for ["//project:__subpackages__"] where
294 // //project is the module's package. e.g. using [":__subpackages__"] in
295 // packages/apps/Settings/Android.bp is equivalent to
296 // //packages/apps/Settings:__subpackages__.
297 // ["//visibility:legacy_public"]: The default visibility, behaves as //visibility:public
298 // for now. It is an error if it is used in a module.
Paul Duffine2453c72019-05-31 14:00:04 +0100299 //
300 // If a module does not specify the `visibility` property then it uses the
301 // `default_visibility` property of the `package` module in the module's package.
302 //
Paul Duffine484f472019-06-20 16:38:08 +0100303 // If a module does not specify the `visibility` property then it uses the
304 // `default_visibility` property of the `package` module in the module's package.
305 //
Paul Duffine2453c72019-05-31 14:00:04 +0100306 // If the `default_visibility` property is not set for the module's package then
Paul Duffine484f472019-06-20 16:38:08 +0100307 // it will use the `default_visibility` of its closest ancestor package for which
308 // a `default_visibility` property is specified.
309 //
310 // If no `default_visibility` property can be found then the module uses the
311 // global default of `//visibility:legacy_public`.
Paul Duffine2453c72019-05-31 14:00:04 +0100312 //
Paul Duffin95d53b52019-07-24 13:45:05 +0100313 // The `visibility` property has no effect on a defaults module although it does
314 // apply to any non-defaults module that uses it. To set the visibility of a
315 // defaults module, use the `defaults_visibility` property on the defaults module;
316 // not to be confused with the `default_visibility` property on the package module.
317 //
Paul Duffin2e61fa62019-03-28 14:10:57 +0000318 // See https://android.googlesource.com/platform/build/soong/+/master/README.md#visibility for
319 // more details.
320 Visibility []string
321
Colin Cross7d5136f2015-05-11 13:39:40 -0700322 // control whether this module compiles for 32-bit, 64-bit, or both. Possible values
Colin Cross3f40fa42015-01-30 17:27:36 -0800323 // are "32" (compile for 32-bit only), "64" (compile for 64-bit only), "both" (compile for both
324 // architectures), or "first" (compile for 64-bit on a 64-bit platform, and 32-bit on a 32-bit
325 // platform
Colin Cross7d716ba2017-11-01 10:38:29 -0700326 Compile_multilib *string `android:"arch_variant"`
Colin Cross69617d32016-09-06 10:39:07 -0700327
328 Target struct {
329 Host struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700330 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700331 }
332 Android struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700333 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700334 }
335 }
336
Colin Crossee0bc3b2018-10-02 22:01:37 -0700337 UseTargetVariants bool `blueprint:"mutated"`
338 Default_multilib string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800339
Dan Willemsen782a2d12015-12-21 14:55:28 -0800340 // whether this is a proprietary vendor module, and should be installed into /vendor
Colin Cross7d716ba2017-11-01 10:38:29 -0700341 Proprietary *bool
Dan Willemsen782a2d12015-12-21 14:55:28 -0800342
Colin Cross55708f32017-03-20 13:23:34 -0700343 // vendor who owns this module
Dan Willemsenefac4a82017-07-18 19:42:09 -0700344 Owner *string
Colin Cross55708f32017-03-20 13:23:34 -0700345
Jiyong Park2db76922017-11-08 16:03:48 +0900346 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
347 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
348 // Use `soc_specific` instead for better meaning.
Colin Cross7d716ba2017-11-01 10:38:29 -0700349 Vendor *bool
Dan Willemsenaa118f92017-04-06 12:49:58 -0700350
Jiyong Park2db76922017-11-08 16:03:48 +0900351 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
352 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
353 Soc_specific *bool
354
355 // whether this module is specific to a device, not only for SoC, but also for off-chip
356 // peripherals. When set to true, it is installed into /odm (or /vendor/odm if odm partition
357 // does not exist, or /system/vendor/odm if both odm and vendor partitions do not exist).
358 // This implies `soc_specific:true`.
359 Device_specific *bool
360
361 // whether this module is specific to a software configuration of a product (e.g. country,
Jaekyun Seok5cfbfbb2018-01-10 19:00:15 +0900362 // network operator, etc). When set to true, it is installed into /product (or
363 // /system/product if product partition does not exist).
Jiyong Park2db76922017-11-08 16:03:48 +0900364 Product_specific *bool
365
Justin Yund5f6c822019-06-25 16:47:17 +0900366 // TODO(b/135957588) Product_services_specific will be removed once we clear all Android.bp
367 // files that have 'product_services_specific: true'. This will be converted to
368 // Product_speicific as a workaround.
Dario Freni95cf7672018-08-17 00:57:57 +0100369 Product_services_specific *bool
Dario Frenifd05a742018-05-29 13:28:54 +0100370
Justin Yund5f6c822019-06-25 16:47:17 +0900371 // whether this module extends system. When set to true, it is installed into /system_ext
372 // (or /system/system_ext if system_ext partition does not exist).
373 System_ext_specific *bool
374
Jiyong Parkf9332f12018-02-01 00:54:12 +0900375 // Whether this module is installed to recovery partition
376 Recovery *bool
377
dimitry1f33e402019-03-26 12:39:31 +0100378 // Whether this module is built for non-native architecures (also known as native bridge binary)
379 Native_bridge_supported *bool `android:"arch_variant"`
380
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700381 // init.rc files to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800382 Init_rc []string `android:"path"`
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700383
Steven Moreland57a23d22018-04-04 15:42:19 -0700384 // VINTF manifest fragments to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800385 Vintf_fragments []string `android:"path"`
Steven Moreland57a23d22018-04-04 15:42:19 -0700386
Chris Wolfe998306e2016-08-15 14:47:23 -0400387 // names of other modules to install if this module is installed
Colin Crossc602b7d2017-05-05 13:36:36 -0700388 Required []string `android:"arch_variant"`
Chris Wolfe998306e2016-08-15 14:47:23 -0400389
Sasha Smundakb6d23052019-04-01 18:37:36 -0700390 // names of other modules to install on host if this module is installed
391 Host_required []string `android:"arch_variant"`
392
393 // names of other modules to install on target if this module is installed
394 Target_required []string `android:"arch_variant"`
395
Colin Cross5aac3622017-08-31 15:07:09 -0700396 // relative path to a file to include in the list of notices for the device
Colin Cross27b922f2019-03-04 22:35:41 -0800397 Notice *string `android:"path"`
Colin Cross5aac3622017-08-31 15:07:09 -0700398
Dan Willemsen569edc52018-11-19 09:33:29 -0800399 Dist struct {
400 // copy the output of this module to the $DIST_DIR when `dist` is specified on the
401 // command line and any of these targets are also on the command line, or otherwise
402 // built
403 Targets []string `android:"arch_variant"`
404
405 // The name of the output artifact. This defaults to the basename of the output of
406 // the module.
407 Dest *string `android:"arch_variant"`
408
409 // The directory within the dist directory to store the artifact. Defaults to the
410 // top level directory ("").
411 Dir *string `android:"arch_variant"`
412
413 // A suffix to add to the artifact file name (before any extension).
414 Suffix *string `android:"arch_variant"`
415 } `android:"arch_variant"`
416
Colin Crossa1ad8d12016-06-01 17:09:44 -0700417 // Set by TargetMutator
Colin Crossee0bc3b2018-10-02 22:01:37 -0700418 CompileTarget Target `blueprint:"mutated"`
419 CompileMultiTargets []Target `blueprint:"mutated"`
420 CompilePrimary bool `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800421
422 // Set by InitAndroidModule
423 HostOrDeviceSupported HostOrDeviceSupported `blueprint:"mutated"`
Dan Willemsen0b24c742016-10-04 15:13:37 -0700424 ArchSpecific bool `blueprint:"mutated"`
Colin Crossce75d2c2016-10-06 16:12:58 -0700425
426 SkipInstall bool `blueprint:"mutated"`
Jeff Gaston088e29e2017-11-29 16:47:17 -0800427
428 NamespaceExportedToMake bool `blueprint:"mutated"`
Colin Cross6c4f21f2019-06-06 15:41:36 -0700429
430 MissingDeps []string `blueprint:"mutated"`
Colin Cross9a362232019-07-01 15:32:45 -0700431
432 // Name and variant strings stored by mutators to enable Module.String()
433 DebugName string `blueprint:"mutated"`
434 DebugMutators []string `blueprint:"mutated"`
435 DebugVariations []string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800436}
437
438type hostAndDeviceProperties struct {
Colin Cross4e81d702018-11-09 10:36:55 -0800439 // If set to true, build a variant of the module for the host. Defaults to false.
440 Host_supported *bool
441
442 // If set to true, build a variant of the module for the device. Defaults to true.
Colin Crossa4190c12016-07-12 13:11:25 -0700443 Device_supported *bool
Colin Cross3f40fa42015-01-30 17:27:36 -0800444}
445
Colin Crossc472d572015-03-17 15:06:21 -0700446type Multilib string
447
448const (
Colin Cross6b4a32d2017-12-05 13:42:45 -0800449 MultilibBoth Multilib = "both"
450 MultilibFirst Multilib = "first"
451 MultilibCommon Multilib = "common"
452 MultilibCommonFirst Multilib = "common_first"
453 MultilibDefault Multilib = ""
Colin Crossc472d572015-03-17 15:06:21 -0700454)
455
Colin Crossa1ad8d12016-06-01 17:09:44 -0700456type HostOrDeviceSupported int
457
458const (
459 _ HostOrDeviceSupported = iota
Dan Albert0981b5c2018-08-02 13:46:35 -0700460
461 // Host and HostCross are built by default. Device is not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700462 HostSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700463
464 // Host is built by default. HostCross and Device are not supported.
Dan Albertc6345fb2016-10-20 01:36:11 -0700465 HostSupportedNoCross
Dan Albert0981b5c2018-08-02 13:46:35 -0700466
467 // Device is built by default. Host and HostCross are not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700468 DeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700469
470 // Device is built by default. Host and HostCross are supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700471 HostAndDeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700472
473 // Host, HostCross, and Device are built by default.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700474 HostAndDeviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700475
476 // Nothing is supported. This is not exposed to the user, but used to mark a
477 // host only module as unsupported when the module type is not supported on
478 // the host OS. E.g. benchmarks are supported on Linux but not Darwin.
Dan Willemsen0b24c742016-10-04 15:13:37 -0700479 NeitherHostNorDeviceSupported
Colin Crossa1ad8d12016-06-01 17:09:44 -0700480)
481
Jiyong Park2db76922017-11-08 16:03:48 +0900482type moduleKind int
483
484const (
485 platformModule moduleKind = iota
486 deviceSpecificModule
487 socSpecificModule
488 productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900489 systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900490)
491
492func (k moduleKind) String() string {
493 switch k {
494 case platformModule:
495 return "platform"
496 case deviceSpecificModule:
497 return "device-specific"
498 case socSpecificModule:
499 return "soc-specific"
500 case productSpecificModule:
501 return "product-specific"
Justin Yund5f6c822019-06-25 16:47:17 +0900502 case systemExtSpecificModule:
503 return "systemext-specific"
Jiyong Park2db76922017-11-08 16:03:48 +0900504 default:
505 panic(fmt.Errorf("unknown module kind %d", k))
506 }
507}
508
Colin Cross36242852017-06-23 15:06:31 -0700509func InitAndroidModule(m Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800510 base := m.base()
511 base.module = m
Colin Cross5049f022015-03-18 13:28:46 -0700512
Colin Cross36242852017-06-23 15:06:31 -0700513 m.AddProperties(
Colin Crossfc754582016-05-17 16:34:16 -0700514 &base.nameProperties,
515 &base.commonProperties,
516 &base.variableProperties)
Colin Crossa3a97412019-03-18 12:24:29 -0700517 base.generalProperties = m.GetProperties()
Pirama Arumuga Nainar955dc492018-04-17 14:58:42 -0700518 base.customizableProperties = m.GetProperties()
Paul Duffin63c6e182019-07-24 14:24:38 +0100519
520 // The default_visibility property needs to be checked and parsed by the visibility module during
521 // its checking and parsing phases.
522 base.primaryVisibilityProperty =
523 newVisibilityProperty("visibility", &base.commonProperties.Visibility)
524 base.visibilityPropertyInfo = []visibilityProperty{base.primaryVisibilityProperty}
Colin Cross5049f022015-03-18 13:28:46 -0700525}
526
Colin Cross36242852017-06-23 15:06:31 -0700527func InitAndroidArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
528 InitAndroidModule(m)
Colin Cross5049f022015-03-18 13:28:46 -0700529
530 base := m.base()
Colin Cross3f40fa42015-01-30 17:27:36 -0800531 base.commonProperties.HostOrDeviceSupported = hod
Colin Cross69617d32016-09-06 10:39:07 -0700532 base.commonProperties.Default_multilib = string(defaultMultilib)
Dan Willemsen0b24c742016-10-04 15:13:37 -0700533 base.commonProperties.ArchSpecific = true
Colin Crossee0bc3b2018-10-02 22:01:37 -0700534 base.commonProperties.UseTargetVariants = true
Colin Cross3f40fa42015-01-30 17:27:36 -0800535
Dan Willemsen218f6562015-07-08 18:13:11 -0700536 switch hod {
Nan Zhang1a0f09b2017-07-05 10:35:11 -0700537 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Cross36242852017-06-23 15:06:31 -0700538 m.AddProperties(&base.hostAndDeviceProperties)
Colin Cross3f40fa42015-01-30 17:27:36 -0800539 }
540
Colin Cross36242852017-06-23 15:06:31 -0700541 InitArchModule(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800542}
543
Colin Crossee0bc3b2018-10-02 22:01:37 -0700544func InitAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
545 InitAndroidArchModule(m, hod, defaultMultilib)
546 m.base().commonProperties.UseTargetVariants = false
547}
548
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800549// A ModuleBase object contains the properties that are common to all Android
Colin Cross3f40fa42015-01-30 17:27:36 -0800550// modules. It should be included as an anonymous field in every module
551// struct definition. InitAndroidModule should then be called from the module's
552// factory function, and the return values from InitAndroidModule should be
553// returned from the factory function.
554//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800555// The ModuleBase type is responsible for implementing the GenerateBuildActions
556// method to support the blueprint.Module interface. This method will then call
557// the module's GenerateAndroidBuildActions method once for each build variant
Colin Cross25de6c32019-06-06 14:29:25 -0700558// that is to be built. GenerateAndroidBuildActions is passed a ModuleContext
559// rather than the usual blueprint.ModuleContext.
560// ModuleContext exposes extra functionality specific to the Android build
Colin Cross3f40fa42015-01-30 17:27:36 -0800561// system including details about the particular build variant that is to be
562// generated.
563//
564// For example:
565//
566// import (
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800567// "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -0800568// )
569//
570// type myModule struct {
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800571// android.ModuleBase
Colin Cross3f40fa42015-01-30 17:27:36 -0800572// properties struct {
573// MyProperty string
574// }
575// }
576//
Colin Cross36242852017-06-23 15:06:31 -0700577// func NewMyModule() android.Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800578// m := &myModule{}
Colin Cross36242852017-06-23 15:06:31 -0700579// m.AddProperties(&m.properties)
580// android.InitAndroidModule(m)
581// return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800582// }
583//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800584// func (m *myModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800585// // Get the CPU architecture for the current build variant.
586// variantArch := ctx.Arch()
587//
588// // ...
589// }
Colin Cross635c3b02016-05-18 15:37:25 -0700590type ModuleBase struct {
Colin Cross3f40fa42015-01-30 17:27:36 -0800591 // Putting the curiously recurring thing pointing to the thing that contains
592 // the thing pattern to good use.
Colin Cross36242852017-06-23 15:06:31 -0700593 // TODO: remove this
Colin Cross635c3b02016-05-18 15:37:25 -0700594 module Module
Colin Cross3f40fa42015-01-30 17:27:36 -0800595
Colin Crossfc754582016-05-17 16:34:16 -0700596 nameProperties nameProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800597 commonProperties commonProperties
Colin Cross7f64b6d2015-07-09 13:57:48 -0700598 variableProperties variableProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800599 hostAndDeviceProperties hostAndDeviceProperties
600 generalProperties []interface{}
Colin Crossc17727d2018-10-24 12:42:09 -0700601 archProperties [][]interface{}
Colin Crossa120ec12016-08-19 16:07:38 -0700602 customizableProperties []interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800603
Paul Duffin63c6e182019-07-24 14:24:38 +0100604 // Information about all the properties on the module that contains visibility rules that need
605 // checking.
606 visibilityPropertyInfo []visibilityProperty
607
608 // The primary visibility property, may be nil, that controls access to the module.
609 primaryVisibilityProperty visibilityProperty
610
Colin Cross3f40fa42015-01-30 17:27:36 -0800611 noAddressSanitizer bool
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700612 installFiles Paths
613 checkbuildFiles Paths
Jiyong Park52818fc2019-03-18 12:01:38 +0900614 noticeFile OptionalPath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700615
616 // Used by buildTargetSingleton to create checkbuild and per-directory build targets
617 // Only set on the final variant of each module
Colin Cross0875c522017-11-28 17:34:01 -0800618 installTarget WritablePath
619 checkbuildTarget WritablePath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700620 blueprintDir string
Colin Crossa120ec12016-08-19 16:07:38 -0700621
Colin Cross178a5092016-09-13 13:42:32 -0700622 hooks hooks
Colin Cross36242852017-06-23 15:06:31 -0700623
624 registerProps []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700625
626 // For tests
Colin Crossae887032017-10-23 17:16:14 -0700627 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800628 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800629 variables map[string]string
Colin Crossa9d8bee2018-10-02 13:59:46 -0700630
631 prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool
Colin Cross36242852017-06-23 15:06:31 -0700632}
633
Colin Cross4157e882019-06-06 16:57:04 -0700634func (m *ModuleBase) DepsMutator(BottomUpMutatorContext) {}
Colin Cross5f692ec2019-02-01 16:53:07 -0800635
Colin Cross4157e882019-06-06 16:57:04 -0700636func (m *ModuleBase) AddProperties(props ...interface{}) {
637 m.registerProps = append(m.registerProps, props...)
Colin Cross36242852017-06-23 15:06:31 -0700638}
639
Colin Cross4157e882019-06-06 16:57:04 -0700640func (m *ModuleBase) GetProperties() []interface{} {
641 return m.registerProps
Colin Cross3f40fa42015-01-30 17:27:36 -0800642}
643
Colin Cross4157e882019-06-06 16:57:04 -0700644func (m *ModuleBase) BuildParamsForTests() []BuildParams {
645 return m.buildParams
Colin Crosscec81712017-07-13 14:43:27 -0700646}
647
Colin Cross4157e882019-06-06 16:57:04 -0700648func (m *ModuleBase) RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams {
649 return m.ruleParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800650}
651
Colin Cross4157e882019-06-06 16:57:04 -0700652func (m *ModuleBase) VariablesForTests() map[string]string {
653 return m.variables
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800654}
655
Colin Cross4157e882019-06-06 16:57:04 -0700656func (m *ModuleBase) Prefer32(prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool) {
657 m.prefer32 = prefer32
Colin Crossa9d8bee2018-10-02 13:59:46 -0700658}
659
Colin Crossce75d2c2016-10-06 16:12:58 -0700660// Name returns the name of the module. It may be overridden by individual module types, for
661// example prebuilts will prepend prebuilt_ to the name.
Colin Cross4157e882019-06-06 16:57:04 -0700662func (m *ModuleBase) Name() string {
663 return String(m.nameProperties.Name)
Colin Crossfc754582016-05-17 16:34:16 -0700664}
665
Colin Cross9a362232019-07-01 15:32:45 -0700666// String returns a string that includes the module name and variants for printing during debugging.
667func (m *ModuleBase) String() string {
668 sb := strings.Builder{}
669 sb.WriteString(m.commonProperties.DebugName)
670 sb.WriteString("{")
671 for i := range m.commonProperties.DebugMutators {
672 if i != 0 {
673 sb.WriteString(",")
674 }
675 sb.WriteString(m.commonProperties.DebugMutators[i])
676 sb.WriteString(":")
677 sb.WriteString(m.commonProperties.DebugVariations[i])
678 }
679 sb.WriteString("}")
680 return sb.String()
681}
682
Colin Crossce75d2c2016-10-06 16:12:58 -0700683// BaseModuleName returns the name of the module as specified in the blueprints file.
Colin Cross4157e882019-06-06 16:57:04 -0700684func (m *ModuleBase) BaseModuleName() string {
685 return String(m.nameProperties.Name)
Colin Crossce75d2c2016-10-06 16:12:58 -0700686}
687
Colin Cross4157e882019-06-06 16:57:04 -0700688func (m *ModuleBase) base() *ModuleBase {
689 return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800690}
691
Paul Duffine2453c72019-05-31 14:00:04 +0100692func (m *ModuleBase) qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName {
693 return qualifiedModuleName{pkg: ctx.ModuleDir(), name: ctx.ModuleName()}
694}
695
696func (m *ModuleBase) visibilityProperties() []visibilityProperty {
Paul Duffin63c6e182019-07-24 14:24:38 +0100697 return m.visibilityPropertyInfo
698}
699
700func (m *ModuleBase) visibility() []string {
701 // The soong_namespace module does not initialize the primaryVisibilityProperty.
702 if m.primaryVisibilityProperty != nil {
703 return m.primaryVisibilityProperty.getStrings()
704 } else {
705 return nil
Paul Duffine2453c72019-05-31 14:00:04 +0100706 }
707}
708
Colin Cross4157e882019-06-06 16:57:04 -0700709func (m *ModuleBase) SetTarget(target Target, multiTargets []Target, primary bool) {
710 m.commonProperties.CompileTarget = target
711 m.commonProperties.CompileMultiTargets = multiTargets
712 m.commonProperties.CompilePrimary = primary
Colin Crossd3ba0392015-05-07 14:11:29 -0700713}
714
Colin Cross4157e882019-06-06 16:57:04 -0700715func (m *ModuleBase) Target() Target {
716 return m.commonProperties.CompileTarget
Dan Willemsen490fd492015-11-24 17:53:15 -0800717}
718
Colin Cross4157e882019-06-06 16:57:04 -0700719func (m *ModuleBase) TargetPrimary() bool {
720 return m.commonProperties.CompilePrimary
Colin Cross8b74d172016-09-13 09:59:14 -0700721}
722
Colin Cross4157e882019-06-06 16:57:04 -0700723func (m *ModuleBase) MultiTargets() []Target {
724 return m.commonProperties.CompileMultiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -0700725}
726
Colin Cross4157e882019-06-06 16:57:04 -0700727func (m *ModuleBase) Os() OsType {
728 return m.Target().Os
Dan Willemsen490fd492015-11-24 17:53:15 -0800729}
730
Colin Cross4157e882019-06-06 16:57:04 -0700731func (m *ModuleBase) Host() bool {
732 return m.Os().Class == Host || m.Os().Class == HostCross
Dan Willemsen97750522016-02-09 17:43:51 -0800733}
734
Colin Cross4157e882019-06-06 16:57:04 -0700735func (m *ModuleBase) Arch() Arch {
736 return m.Target().Arch
Dan Willemsen97750522016-02-09 17:43:51 -0800737}
738
Colin Cross4157e882019-06-06 16:57:04 -0700739func (m *ModuleBase) ArchSpecific() bool {
740 return m.commonProperties.ArchSpecific
Dan Willemsen0b24c742016-10-04 15:13:37 -0700741}
742
Colin Cross4157e882019-06-06 16:57:04 -0700743func (m *ModuleBase) OsClassSupported() []OsClass {
744 switch m.commonProperties.HostOrDeviceSupported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700745 case HostSupported:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700746 return []OsClass{Host, HostCross}
Dan Albertc6345fb2016-10-20 01:36:11 -0700747 case HostSupportedNoCross:
748 return []OsClass{Host}
Colin Crossa1ad8d12016-06-01 17:09:44 -0700749 case DeviceSupported:
750 return []OsClass{Device}
Dan Albert0981b5c2018-08-02 13:46:35 -0700751 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700752 var supported []OsClass
Colin Cross4157e882019-06-06 16:57:04 -0700753 if Bool(m.hostAndDeviceProperties.Host_supported) ||
754 (m.commonProperties.HostOrDeviceSupported == HostAndDeviceDefault &&
755 m.hostAndDeviceProperties.Host_supported == nil) {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700756 supported = append(supported, Host, HostCross)
757 }
Colin Cross4157e882019-06-06 16:57:04 -0700758 if m.hostAndDeviceProperties.Device_supported == nil ||
759 *m.hostAndDeviceProperties.Device_supported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700760 supported = append(supported, Device)
761 }
762 return supported
763 default:
764 return nil
765 }
Colin Cross3f40fa42015-01-30 17:27:36 -0800766}
767
Colin Cross4157e882019-06-06 16:57:04 -0700768func (m *ModuleBase) DeviceSupported() bool {
769 return m.commonProperties.HostOrDeviceSupported == DeviceSupported ||
770 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
771 (m.hostAndDeviceProperties.Device_supported == nil ||
772 *m.hostAndDeviceProperties.Device_supported)
Colin Cross3f40fa42015-01-30 17:27:36 -0800773}
774
Colin Cross4157e882019-06-06 16:57:04 -0700775func (m *ModuleBase) Platform() bool {
Justin Yund5f6c822019-06-25 16:47:17 +0900776 return !m.DeviceSpecific() && !m.SocSpecific() && !m.ProductSpecific() && !m.SystemExtSpecific()
Jiyong Parkc678ad32018-04-10 13:07:10 +0900777}
778
Colin Cross4157e882019-06-06 16:57:04 -0700779func (m *ModuleBase) DeviceSpecific() bool {
780 return Bool(m.commonProperties.Device_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900781}
782
Colin Cross4157e882019-06-06 16:57:04 -0700783func (m *ModuleBase) SocSpecific() bool {
784 return Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900785}
786
Colin Cross4157e882019-06-06 16:57:04 -0700787func (m *ModuleBase) ProductSpecific() bool {
788 return Bool(m.commonProperties.Product_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900789}
790
Justin Yund5f6c822019-06-25 16:47:17 +0900791func (m *ModuleBase) SystemExtSpecific() bool {
792 return Bool(m.commonProperties.System_ext_specific)
Dario Frenifd05a742018-05-29 13:28:54 +0100793}
794
Colin Cross4157e882019-06-06 16:57:04 -0700795func (m *ModuleBase) Enabled() bool {
796 if m.commonProperties.Enabled == nil {
797 return !m.Os().DefaultDisabled
Dan Willemsen490fd492015-11-24 17:53:15 -0800798 }
Colin Cross4157e882019-06-06 16:57:04 -0700799 return *m.commonProperties.Enabled
Colin Cross3f40fa42015-01-30 17:27:36 -0800800}
801
Colin Cross4157e882019-06-06 16:57:04 -0700802func (m *ModuleBase) SkipInstall() {
803 m.commonProperties.SkipInstall = true
Colin Crossce75d2c2016-10-06 16:12:58 -0700804}
805
Colin Cross4157e882019-06-06 16:57:04 -0700806func (m *ModuleBase) ExportedToMake() bool {
807 return m.commonProperties.NamespaceExportedToMake
Jiyong Park374510b2018-03-19 18:23:01 +0900808}
809
Colin Cross4157e882019-06-06 16:57:04 -0700810func (m *ModuleBase) computeInstallDeps(
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700811 ctx blueprint.ModuleContext) Paths {
Colin Cross3f40fa42015-01-30 17:27:36 -0800812
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700813 result := Paths{}
Colin Cross6b753602018-06-21 13:03:07 -0700814 // TODO(ccross): we need to use WalkDeps and have some way to know which dependencies require installation
Colin Cross3f40fa42015-01-30 17:27:36 -0800815 ctx.VisitDepsDepthFirstIf(isFileInstaller,
816 func(m blueprint.Module) {
817 fileInstaller := m.(fileInstaller)
818 files := fileInstaller.filesToInstall()
819 result = append(result, files...)
820 })
821
822 return result
823}
824
Colin Cross4157e882019-06-06 16:57:04 -0700825func (m *ModuleBase) filesToInstall() Paths {
826 return m.installFiles
Colin Cross3f40fa42015-01-30 17:27:36 -0800827}
828
Colin Cross4157e882019-06-06 16:57:04 -0700829func (m *ModuleBase) NoAddressSanitizer() bool {
830 return m.noAddressSanitizer
Colin Cross3f40fa42015-01-30 17:27:36 -0800831}
832
Colin Cross4157e882019-06-06 16:57:04 -0700833func (m *ModuleBase) InstallInData() bool {
Dan Willemsen782a2d12015-12-21 14:55:28 -0800834 return false
835}
836
Jaewoong Jung0949f312019-09-11 10:25:18 -0700837func (m *ModuleBase) InstallInTestcases() bool {
838 return false
839}
840
Colin Cross4157e882019-06-06 16:57:04 -0700841func (m *ModuleBase) InstallInSanitizerDir() bool {
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700842 return false
843}
844
Colin Cross4157e882019-06-06 16:57:04 -0700845func (m *ModuleBase) InstallInRecovery() bool {
846 return Bool(m.commonProperties.Recovery)
Jiyong Parkf9332f12018-02-01 00:54:12 +0900847}
848
Colin Cross607d8582019-07-29 16:44:46 -0700849func (m *ModuleBase) InstallBypassMake() bool {
850 return false
851}
852
Colin Cross4157e882019-06-06 16:57:04 -0700853func (m *ModuleBase) Owner() string {
854 return String(m.commonProperties.Owner)
Sundong Ahn4fd04bb2018-08-31 18:01:37 +0900855}
856
Colin Cross4157e882019-06-06 16:57:04 -0700857func (m *ModuleBase) NoticeFile() OptionalPath {
858 return m.noticeFile
Jiyong Park52818fc2019-03-18 12:01:38 +0900859}
860
Colin Cross4157e882019-06-06 16:57:04 -0700861func (m *ModuleBase) generateModuleTarget(ctx ModuleContext) {
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700862 allInstalledFiles := Paths{}
863 allCheckbuildFiles := Paths{}
Colin Cross0875c522017-11-28 17:34:01 -0800864 ctx.VisitAllModuleVariants(func(module Module) {
865 a := module.base()
Colin Crossc9404352015-03-26 16:10:12 -0700866 allInstalledFiles = append(allInstalledFiles, a.installFiles...)
867 allCheckbuildFiles = append(allCheckbuildFiles, a.checkbuildFiles...)
Colin Cross3f40fa42015-01-30 17:27:36 -0800868 })
869
Colin Cross0875c522017-11-28 17:34:01 -0800870 var deps Paths
Colin Cross9454bfa2015-03-17 13:24:18 -0700871
Jeff Gaston088e29e2017-11-29 16:47:17 -0800872 namespacePrefix := ctx.Namespace().(*Namespace).id
873 if namespacePrefix != "" {
874 namespacePrefix = namespacePrefix + "-"
875 }
876
Colin Cross3f40fa42015-01-30 17:27:36 -0800877 if len(allInstalledFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -0800878 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-install")
Colin Cross0875c522017-11-28 17:34:01 -0800879 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -0700880 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -0800881 Output: name,
882 Implicits: allInstalledFiles,
Colin Crossaabf6792017-11-29 00:27:14 -0800883 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross9454bfa2015-03-17 13:24:18 -0700884 })
885 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -0700886 m.installTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -0700887 }
888
889 if len(allCheckbuildFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -0800890 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-checkbuild")
Colin Cross0875c522017-11-28 17:34:01 -0800891 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -0700892 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -0800893 Output: name,
894 Implicits: allCheckbuildFiles,
Colin Cross9454bfa2015-03-17 13:24:18 -0700895 })
896 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -0700897 m.checkbuildTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -0700898 }
899
900 if len(deps) > 0 {
Dan Willemsen5ba07e82015-12-11 13:51:06 -0800901 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -0800902 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -0800903 suffix = "-soong"
904 }
905
Jeff Gaston088e29e2017-11-29 16:47:17 -0800906 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+suffix)
Colin Cross0875c522017-11-28 17:34:01 -0800907 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -0700908 Rule: blueprint.Phony,
Jeff Gaston088e29e2017-11-29 16:47:17 -0800909 Outputs: []WritablePath{name},
Colin Cross9454bfa2015-03-17 13:24:18 -0700910 Implicits: deps,
Colin Cross3f40fa42015-01-30 17:27:36 -0800911 })
Colin Cross1f8c52b2015-06-16 16:38:17 -0700912
Colin Cross4157e882019-06-06 16:57:04 -0700913 m.blueprintDir = ctx.ModuleDir()
Colin Cross3f40fa42015-01-30 17:27:36 -0800914 }
915}
916
Colin Cross4157e882019-06-06 16:57:04 -0700917func determineModuleKind(m *ModuleBase, ctx blueprint.BaseModuleContext) moduleKind {
918 var socSpecific = Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
919 var deviceSpecific = Bool(m.commonProperties.Device_specific)
920 var productSpecific = Bool(m.commonProperties.Product_specific)
Justin Yund5f6c822019-06-25 16:47:17 +0900921 var systemExtSpecific = Bool(m.commonProperties.System_ext_specific)
Jiyong Park2db76922017-11-08 16:03:48 +0900922
Dario Frenifd05a742018-05-29 13:28:54 +0100923 msg := "conflicting value set here"
924 if socSpecific && deviceSpecific {
925 ctx.PropertyErrorf("device_specific", "a module cannot be specific to SoC and device at the same time.")
Colin Cross4157e882019-06-06 16:57:04 -0700926 if Bool(m.commonProperties.Vendor) {
Jiyong Park2db76922017-11-08 16:03:48 +0900927 ctx.PropertyErrorf("vendor", msg)
928 }
Colin Cross4157e882019-06-06 16:57:04 -0700929 if Bool(m.commonProperties.Proprietary) {
Jiyong Park2db76922017-11-08 16:03:48 +0900930 ctx.PropertyErrorf("proprietary", msg)
931 }
Colin Cross4157e882019-06-06 16:57:04 -0700932 if Bool(m.commonProperties.Soc_specific) {
Jiyong Park2db76922017-11-08 16:03:48 +0900933 ctx.PropertyErrorf("soc_specific", msg)
934 }
935 }
936
Justin Yund5f6c822019-06-25 16:47:17 +0900937 if productSpecific && systemExtSpecific {
938 ctx.PropertyErrorf("product_specific", "a module cannot be specific to product and system_ext at the same time.")
939 ctx.PropertyErrorf("system_ext_specific", msg)
Dario Frenifd05a742018-05-29 13:28:54 +0100940 }
941
Justin Yund5f6c822019-06-25 16:47:17 +0900942 if (socSpecific || deviceSpecific) && (productSpecific || systemExtSpecific) {
Dario Frenifd05a742018-05-29 13:28:54 +0100943 if productSpecific {
944 ctx.PropertyErrorf("product_specific", "a module cannot be specific to SoC or device and product at the same time.")
945 } else {
Justin Yund5f6c822019-06-25 16:47:17 +0900946 ctx.PropertyErrorf("system_ext_specific", "a module cannot be specific to SoC or device and system_ext at the same time.")
Dario Frenifd05a742018-05-29 13:28:54 +0100947 }
948 if deviceSpecific {
949 ctx.PropertyErrorf("device_specific", msg)
950 } else {
Colin Cross4157e882019-06-06 16:57:04 -0700951 if Bool(m.commonProperties.Vendor) {
Dario Frenifd05a742018-05-29 13:28:54 +0100952 ctx.PropertyErrorf("vendor", msg)
953 }
Colin Cross4157e882019-06-06 16:57:04 -0700954 if Bool(m.commonProperties.Proprietary) {
Dario Frenifd05a742018-05-29 13:28:54 +0100955 ctx.PropertyErrorf("proprietary", msg)
956 }
Colin Cross4157e882019-06-06 16:57:04 -0700957 if Bool(m.commonProperties.Soc_specific) {
Dario Frenifd05a742018-05-29 13:28:54 +0100958 ctx.PropertyErrorf("soc_specific", msg)
959 }
960 }
961 }
962
Jiyong Park2db76922017-11-08 16:03:48 +0900963 if productSpecific {
964 return productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900965 } else if systemExtSpecific {
966 return systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900967 } else if deviceSpecific {
968 return deviceSpecificModule
969 } else if socSpecific {
970 return socSpecificModule
971 } else {
972 return platformModule
973 }
974}
975
Colin Cross0ea8ba82019-06-06 14:33:29 -0700976func (m *ModuleBase) baseModuleContextFactory(ctx blueprint.BaseModuleContext) baseModuleContext {
977 return baseModuleContext{
978 BaseModuleContext: ctx,
979 target: m.commonProperties.CompileTarget,
980 targetPrimary: m.commonProperties.CompilePrimary,
981 multiTargets: m.commonProperties.CompileMultiTargets,
982 kind: determineModuleKind(m, ctx),
983 config: ctx.Config().(Config),
Colin Cross3f40fa42015-01-30 17:27:36 -0800984 }
Colin Cross3f40fa42015-01-30 17:27:36 -0800985}
986
Colin Cross4157e882019-06-06 16:57:04 -0700987func (m *ModuleBase) GenerateBuildActions(blueprintCtx blueprint.ModuleContext) {
Colin Cross25de6c32019-06-06 14:29:25 -0700988 ctx := &moduleContext{
Colin Cross0ea8ba82019-06-06 14:33:29 -0700989 module: m.module,
Colin Crossdc35e212019-06-06 16:13:11 -0700990 bp: blueprintCtx,
Colin Cross0ea8ba82019-06-06 14:33:29 -0700991 baseModuleContext: m.baseModuleContextFactory(blueprintCtx),
992 installDeps: m.computeInstallDeps(blueprintCtx),
993 installFiles: m.installFiles,
Colin Cross0ea8ba82019-06-06 14:33:29 -0700994 variables: make(map[string]string),
Colin Cross3f40fa42015-01-30 17:27:36 -0800995 }
996
Colin Cross6c4f21f2019-06-06 15:41:36 -0700997 // Temporarily continue to call blueprintCtx.GetMissingDependencies() to maintain the previous behavior of never
998 // reporting missing dependency errors in Blueprint when AllowMissingDependencies == true.
999 // TODO: This will be removed once defaults modules handle missing dependency errors
1000 blueprintCtx.GetMissingDependencies()
1001
Colin Crossdc35e212019-06-06 16:13:11 -07001002 // For the final GenerateAndroidBuildActions pass, require that all visited dependencies Soong modules and
1003 // are enabled.
1004 ctx.baseModuleContext.strictVisitDeps = true
1005
Colin Cross4c83e5c2019-02-25 14:54:28 -08001006 if ctx.config.captureBuild {
1007 ctx.ruleParams = make(map[blueprint.Rule]blueprint.RuleParams)
1008 }
1009
Colin Cross67a5c132017-05-09 13:45:28 -07001010 desc := "//" + ctx.ModuleDir() + ":" + ctx.ModuleName() + " "
1011 var suffix []string
Colin Cross0875c522017-11-28 17:34:01 -08001012 if ctx.Os().Class != Device && ctx.Os().Class != Generic {
1013 suffix = append(suffix, ctx.Os().String())
Colin Cross67a5c132017-05-09 13:45:28 -07001014 }
Colin Cross0875c522017-11-28 17:34:01 -08001015 if !ctx.PrimaryArch() {
1016 suffix = append(suffix, ctx.Arch().ArchType.String())
Colin Cross67a5c132017-05-09 13:45:28 -07001017 }
1018
1019 ctx.Variable(pctx, "moduleDesc", desc)
1020
1021 s := ""
1022 if len(suffix) > 0 {
1023 s = " [" + strings.Join(suffix, " ") + "]"
1024 }
1025 ctx.Variable(pctx, "moduleDescSuffix", s)
1026
Dan Willemsen569edc52018-11-19 09:33:29 -08001027 // Some common property checks for properties that will be used later in androidmk.go
Colin Cross4157e882019-06-06 16:57:04 -07001028 if m.commonProperties.Dist.Dest != nil {
1029 _, err := validateSafePath(*m.commonProperties.Dist.Dest)
Dan Willemsen569edc52018-11-19 09:33:29 -08001030 if err != nil {
1031 ctx.PropertyErrorf("dist.dest", "%s", err.Error())
1032 }
1033 }
Colin Cross4157e882019-06-06 16:57:04 -07001034 if m.commonProperties.Dist.Dir != nil {
1035 _, err := validateSafePath(*m.commonProperties.Dist.Dir)
Dan Willemsen569edc52018-11-19 09:33:29 -08001036 if err != nil {
1037 ctx.PropertyErrorf("dist.dir", "%s", err.Error())
1038 }
1039 }
Colin Cross4157e882019-06-06 16:57:04 -07001040 if m.commonProperties.Dist.Suffix != nil {
1041 if strings.Contains(*m.commonProperties.Dist.Suffix, "/") {
Dan Willemsen569edc52018-11-19 09:33:29 -08001042 ctx.PropertyErrorf("dist.suffix", "Suffix may not contain a '/' character.")
1043 }
1044 }
1045
Colin Cross4157e882019-06-06 16:57:04 -07001046 if m.Enabled() {
Jooyung Hand48f3c32019-08-23 11:18:57 +09001047 // ensure all direct android.Module deps are enabled
1048 ctx.VisitDirectDepsBlueprint(func(bm blueprint.Module) {
1049 if _, ok := bm.(Module); ok {
1050 ctx.validateAndroidModule(bm, ctx.baseModuleContext.strictVisitDeps)
1051 }
1052 })
1053
Colin Cross4157e882019-06-06 16:57:04 -07001054 notice := proptools.StringDefault(m.commonProperties.Notice, "NOTICE")
1055 if module := SrcIsModule(notice); module != "" {
1056 m.noticeFile = ctx.ExpandOptionalSource(&notice, "notice")
Jiyong Park52818fc2019-03-18 12:01:38 +09001057 } else {
1058 noticePath := filepath.Join(ctx.ModuleDir(), notice)
Colin Cross4157e882019-06-06 16:57:04 -07001059 m.noticeFile = ExistentPathForSource(ctx, noticePath)
Jaewoong Jung62707f72018-11-16 13:26:43 -08001060 }
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001061
1062 m.module.GenerateAndroidBuildActions(ctx)
1063 if ctx.Failed() {
1064 return
1065 }
1066
1067 m.installFiles = append(m.installFiles, ctx.installFiles...)
1068 m.checkbuildFiles = append(m.checkbuildFiles, ctx.checkbuildFiles...)
Colin Crossdc35e212019-06-06 16:13:11 -07001069 } else if ctx.Config().AllowMissingDependencies() {
1070 // If the module is not enabled it will not create any build rules, nothing will call
1071 // ctx.GetMissingDependencies(), and blueprint will consider the missing dependencies to be unhandled
1072 // and report them as an error even when AllowMissingDependencies = true. Call
1073 // ctx.GetMissingDependencies() here to tell blueprint not to handle them.
1074 ctx.GetMissingDependencies()
Colin Cross3f40fa42015-01-30 17:27:36 -08001075 }
1076
Colin Cross4157e882019-06-06 16:57:04 -07001077 if m == ctx.FinalModule().(Module).base() {
1078 m.generateModuleTarget(ctx)
Colin Cross9b1d13d2016-09-19 15:18:11 -07001079 if ctx.Failed() {
1080 return
1081 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001082 }
Colin Crosscec81712017-07-13 14:43:27 -07001083
Colin Cross4157e882019-06-06 16:57:04 -07001084 m.buildParams = ctx.buildParams
1085 m.ruleParams = ctx.ruleParams
1086 m.variables = ctx.variables
Colin Cross3f40fa42015-01-30 17:27:36 -08001087}
1088
Colin Cross0ea8ba82019-06-06 14:33:29 -07001089type baseModuleContext struct {
1090 blueprint.BaseModuleContext
Colin Cross8b74d172016-09-13 09:59:14 -07001091 target Target
Colin Crossee0bc3b2018-10-02 22:01:37 -07001092 multiTargets []Target
Colin Cross8b74d172016-09-13 09:59:14 -07001093 targetPrimary bool
1094 debug bool
Jiyong Park2db76922017-11-08 16:03:48 +09001095 kind moduleKind
Colin Cross8b74d172016-09-13 09:59:14 -07001096 config Config
Colin Crossdc35e212019-06-06 16:13:11 -07001097
1098 walkPath []Module
1099
1100 strictVisitDeps bool // If true, enforce that all dependencies are enabled
Colin Crossf6566ed2015-03-24 11:13:38 -07001101}
1102
Colin Cross25de6c32019-06-06 14:29:25 -07001103type moduleContext struct {
Colin Crossdc35e212019-06-06 16:13:11 -07001104 bp blueprint.ModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -07001105 baseModuleContext
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001106 installDeps Paths
1107 installFiles Paths
1108 checkbuildFiles Paths
Colin Cross8d8f8e22016-08-03 11:57:50 -07001109 module Module
Colin Crosscec81712017-07-13 14:43:27 -07001110
1111 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001112 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001113 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001114 variables map[string]string
Colin Cross6ff51382015-12-17 16:39:19 -08001115}
1116
Colin Crossb88b3c52019-06-10 15:15:17 -07001117func (m *moduleContext) ninjaError(params BuildParams, err error) (PackageContext, BuildParams) {
1118 return pctx, BuildParams{
Colin Cross4b69c492019-06-07 13:06:06 -07001119 Rule: ErrorRule,
1120 Description: params.Description,
1121 Output: params.Output,
1122 Outputs: params.Outputs,
1123 ImplicitOutput: params.ImplicitOutput,
1124 ImplicitOutputs: params.ImplicitOutputs,
Colin Cross6ff51382015-12-17 16:39:19 -08001125 Args: map[string]string{
1126 "error": err.Error(),
1127 },
Colin Crossb88b3c52019-06-10 15:15:17 -07001128 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001129}
1130
Colin Cross25de6c32019-06-06 14:29:25 -07001131func (m *moduleContext) ModuleBuild(pctx PackageContext, params ModuleBuildParams) {
1132 m.Build(pctx, BuildParams(params))
Colin Cross3f40fa42015-01-30 17:27:36 -08001133}
1134
Colin Cross0875c522017-11-28 17:34:01 -08001135func convertBuildParams(params BuildParams) blueprint.BuildParams {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001136 bparams := blueprint.BuildParams{
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001137 Rule: params.Rule,
Colin Cross0875c522017-11-28 17:34:01 -08001138 Description: params.Description,
Colin Cross33bfb0a2016-11-21 17:23:08 -08001139 Deps: params.Deps,
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001140 Outputs: params.Outputs.Strings(),
1141 ImplicitOutputs: params.ImplicitOutputs.Strings(),
1142 Inputs: params.Inputs.Strings(),
1143 Implicits: params.Implicits.Strings(),
1144 OrderOnly: params.OrderOnly.Strings(),
1145 Args: params.Args,
1146 Optional: !params.Default,
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001147 }
1148
Colin Cross33bfb0a2016-11-21 17:23:08 -08001149 if params.Depfile != nil {
1150 bparams.Depfile = params.Depfile.String()
1151 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001152 if params.Output != nil {
1153 bparams.Outputs = append(bparams.Outputs, params.Output.String())
1154 }
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001155 if params.ImplicitOutput != nil {
1156 bparams.ImplicitOutputs = append(bparams.ImplicitOutputs, params.ImplicitOutput.String())
1157 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001158 if params.Input != nil {
1159 bparams.Inputs = append(bparams.Inputs, params.Input.String())
1160 }
1161 if params.Implicit != nil {
1162 bparams.Implicits = append(bparams.Implicits, params.Implicit.String())
1163 }
1164
Colin Cross0b9f31f2019-02-28 11:00:01 -08001165 bparams.Outputs = proptools.NinjaEscapeList(bparams.Outputs)
1166 bparams.ImplicitOutputs = proptools.NinjaEscapeList(bparams.ImplicitOutputs)
1167 bparams.Inputs = proptools.NinjaEscapeList(bparams.Inputs)
1168 bparams.Implicits = proptools.NinjaEscapeList(bparams.Implicits)
1169 bparams.OrderOnly = proptools.NinjaEscapeList(bparams.OrderOnly)
1170 bparams.Depfile = proptools.NinjaEscapeList([]string{bparams.Depfile})[0]
Colin Crossfe4bc362018-09-12 10:02:13 -07001171
Colin Cross0875c522017-11-28 17:34:01 -08001172 return bparams
1173}
1174
Colin Cross25de6c32019-06-06 14:29:25 -07001175func (m *moduleContext) Variable(pctx PackageContext, name, value string) {
1176 if m.config.captureBuild {
1177 m.variables[name] = value
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001178 }
1179
Colin Crossdc35e212019-06-06 16:13:11 -07001180 m.bp.Variable(pctx.PackageContext, name, value)
Colin Cross0875c522017-11-28 17:34:01 -08001181}
1182
Colin Cross25de6c32019-06-06 14:29:25 -07001183func (m *moduleContext) Rule(pctx PackageContext, name string, params blueprint.RuleParams,
Colin Cross0875c522017-11-28 17:34:01 -08001184 argNames ...string) blueprint.Rule {
1185
Colin Crossdc35e212019-06-06 16:13:11 -07001186 rule := m.bp.Rule(pctx.PackageContext, name, params, argNames...)
Colin Cross4c83e5c2019-02-25 14:54:28 -08001187
Colin Cross25de6c32019-06-06 14:29:25 -07001188 if m.config.captureBuild {
1189 m.ruleParams[rule] = params
Colin Cross4c83e5c2019-02-25 14:54:28 -08001190 }
1191
1192 return rule
Colin Cross0875c522017-11-28 17:34:01 -08001193}
1194
Colin Cross25de6c32019-06-06 14:29:25 -07001195func (m *moduleContext) Build(pctx PackageContext, params BuildParams) {
Colin Crossb88b3c52019-06-10 15:15:17 -07001196 if params.Description != "" {
1197 params.Description = "${moduleDesc}" + params.Description + "${moduleDescSuffix}"
1198 }
1199
1200 if missingDeps := m.GetMissingDependencies(); len(missingDeps) > 0 {
1201 pctx, params = m.ninjaError(params, fmt.Errorf("module %s missing dependencies: %s\n",
1202 m.ModuleName(), strings.Join(missingDeps, ", ")))
1203 }
1204
Colin Cross25de6c32019-06-06 14:29:25 -07001205 if m.config.captureBuild {
1206 m.buildParams = append(m.buildParams, params)
Colin Cross0875c522017-11-28 17:34:01 -08001207 }
1208
Colin Crossdc35e212019-06-06 16:13:11 -07001209 m.bp.Build(pctx.PackageContext, convertBuildParams(params))
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001210}
1211
Colin Crossdc35e212019-06-06 16:13:11 -07001212func (b *baseModuleContext) Module() Module {
1213 module, _ := b.BaseModuleContext.Module().(Module)
1214 return module
1215}
1216
1217func (b *baseModuleContext) Config() Config {
1218 return b.BaseModuleContext.Config().(Config)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001219}
1220
Colin Cross25de6c32019-06-06 14:29:25 -07001221func (m *moduleContext) GetMissingDependencies() []string {
Colin Cross6c4f21f2019-06-06 15:41:36 -07001222 var missingDeps []string
1223 missingDeps = append(missingDeps, m.Module().base().commonProperties.MissingDeps...)
Colin Crossdc35e212019-06-06 16:13:11 -07001224 missingDeps = append(missingDeps, m.bp.GetMissingDependencies()...)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001225 missingDeps = FirstUniqueStrings(missingDeps)
1226 return missingDeps
Colin Cross6ff51382015-12-17 16:39:19 -08001227}
1228
Colin Crossdc35e212019-06-06 16:13:11 -07001229func (b *baseModuleContext) AddMissingDependencies(deps []string) {
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001230 if deps != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001231 missingDeps := &b.Module().base().commonProperties.MissingDeps
Colin Cross6c4f21f2019-06-06 15:41:36 -07001232 *missingDeps = append(*missingDeps, deps...)
1233 *missingDeps = FirstUniqueStrings(*missingDeps)
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001234 }
1235}
1236
Colin Crossdc35e212019-06-06 16:13:11 -07001237func (b *baseModuleContext) validateAndroidModule(module blueprint.Module, strict bool) Module {
Colin Crossd11fcda2017-10-23 17:59:01 -07001238 aModule, _ := module.(Module)
Colin Crossdc35e212019-06-06 16:13:11 -07001239
1240 if !strict {
1241 return aModule
1242 }
1243
Colin Cross380c69a2019-06-10 17:49:58 +00001244 if aModule == nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001245 b.ModuleErrorf("module %q not an android module", b.OtherModuleName(module))
Colin Cross380c69a2019-06-10 17:49:58 +00001246 return nil
1247 }
1248
1249 if !aModule.Enabled() {
Colin Crossdc35e212019-06-06 16:13:11 -07001250 if b.Config().AllowMissingDependencies() {
1251 b.AddMissingDependencies([]string{b.OtherModuleName(aModule)})
Colin Cross380c69a2019-06-10 17:49:58 +00001252 } else {
Colin Crossdc35e212019-06-06 16:13:11 -07001253 b.ModuleErrorf("depends on disabled module %q", b.OtherModuleName(aModule))
Colin Cross380c69a2019-06-10 17:49:58 +00001254 }
1255 return nil
1256 }
Colin Crossd11fcda2017-10-23 17:59:01 -07001257 return aModule
1258}
1259
Colin Crossdc35e212019-06-06 16:13:11 -07001260func (b *baseModuleContext) getDirectDepInternal(name string, tag blueprint.DependencyTag) (blueprint.Module, blueprint.DependencyTag) {
Jiyong Parkf2976302019-04-17 21:47:37 +09001261 type dep struct {
1262 mod blueprint.Module
1263 tag blueprint.DependencyTag
1264 }
1265 var deps []dep
Colin Crossdc35e212019-06-06 16:13:11 -07001266 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001267 if aModule, _ := module.(Module); aModule != nil && aModule.base().BaseModuleName() == name {
Colin Crossdc35e212019-06-06 16:13:11 -07001268 returnedTag := b.BaseModuleContext.OtherModuleDependencyTag(aModule)
Jiyong Parkf2976302019-04-17 21:47:37 +09001269 if tag == nil || returnedTag == tag {
1270 deps = append(deps, dep{aModule, returnedTag})
1271 }
1272 }
1273 })
1274 if len(deps) == 1 {
1275 return deps[0].mod, deps[0].tag
1276 } else if len(deps) >= 2 {
1277 panic(fmt.Errorf("Multiple dependencies having same BaseModuleName() %q found from %q",
Colin Crossdc35e212019-06-06 16:13:11 -07001278 name, b.ModuleName()))
Jiyong Parkf2976302019-04-17 21:47:37 +09001279 } else {
1280 return nil, nil
1281 }
1282}
1283
Colin Crossdc35e212019-06-06 16:13:11 -07001284func (b *baseModuleContext) GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module {
Colin Cross0ef08162019-05-01 15:50:51 -07001285 var deps []Module
Colin Crossdc35e212019-06-06 16:13:11 -07001286 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001287 if aModule, _ := module.(Module); aModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001288 if b.BaseModuleContext.OtherModuleDependencyTag(aModule) == tag {
Colin Cross0ef08162019-05-01 15:50:51 -07001289 deps = append(deps, aModule)
1290 }
1291 }
1292 })
1293 return deps
1294}
1295
Colin Cross25de6c32019-06-06 14:29:25 -07001296func (m *moduleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1297 module, _ := m.getDirectDepInternal(name, tag)
1298 return module
Jiyong Parkf2976302019-04-17 21:47:37 +09001299}
1300
Colin Crossdc35e212019-06-06 16:13:11 -07001301func (b *baseModuleContext) GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag) {
1302 return b.getDirectDepInternal(name, nil)
Jiyong Parkf2976302019-04-17 21:47:37 +09001303}
1304
Colin Crossdc35e212019-06-06 16:13:11 -07001305func (b *baseModuleContext) VisitDirectDepsBlueprint(visit func(blueprint.Module)) {
1306 b.BaseModuleContext.VisitDirectDeps(visit)
Colin Cross35143d02017-11-16 00:11:20 -08001307}
1308
Colin Crossdc35e212019-06-06 16:13:11 -07001309func (b *baseModuleContext) VisitDirectDeps(visit func(Module)) {
1310 b.BaseModuleContext.VisitDirectDeps(func(module blueprint.Module) {
1311 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001312 visit(aModule)
1313 }
1314 })
1315}
1316
Colin Crossdc35e212019-06-06 16:13:11 -07001317func (b *baseModuleContext) VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module)) {
1318 b.BaseModuleContext.VisitDirectDeps(func(module blueprint.Module) {
1319 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
1320 if b.BaseModuleContext.OtherModuleDependencyTag(aModule) == tag {
Colin Crossee6143c2017-12-30 17:54:27 -08001321 visit(aModule)
1322 }
1323 }
1324 })
1325}
1326
Colin Crossdc35e212019-06-06 16:13:11 -07001327func (b *baseModuleContext) VisitDirectDepsIf(pred func(Module) bool, visit func(Module)) {
1328 b.BaseModuleContext.VisitDirectDepsIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001329 // pred
1330 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001331 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001332 return pred(aModule)
1333 } else {
1334 return false
1335 }
1336 },
1337 // visit
1338 func(module blueprint.Module) {
1339 visit(module.(Module))
1340 })
1341}
1342
Colin Crossdc35e212019-06-06 16:13:11 -07001343func (b *baseModuleContext) VisitDepsDepthFirst(visit func(Module)) {
1344 b.BaseModuleContext.VisitDepsDepthFirst(func(module blueprint.Module) {
1345 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001346 visit(aModule)
1347 }
1348 })
1349}
1350
Colin Crossdc35e212019-06-06 16:13:11 -07001351func (b *baseModuleContext) VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module)) {
1352 b.BaseModuleContext.VisitDepsDepthFirstIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001353 // pred
1354 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001355 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001356 return pred(aModule)
1357 } else {
1358 return false
1359 }
1360 },
1361 // visit
1362 func(module blueprint.Module) {
1363 visit(module.(Module))
1364 })
1365}
1366
Colin Crossdc35e212019-06-06 16:13:11 -07001367func (b *baseModuleContext) WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool) {
1368 b.BaseModuleContext.WalkDeps(visit)
Alex Light778127a2019-02-27 14:19:50 -08001369}
1370
Colin Crossdc35e212019-06-06 16:13:11 -07001371func (b *baseModuleContext) WalkDeps(visit func(Module, Module) bool) {
1372 b.walkPath = []Module{b.Module()}
1373 b.BaseModuleContext.WalkDeps(func(child, parent blueprint.Module) bool {
1374 childAndroidModule, _ := child.(Module)
1375 parentAndroidModule, _ := parent.(Module)
Colin Crossd11fcda2017-10-23 17:59:01 -07001376 if childAndroidModule != nil && parentAndroidModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001377 // record walkPath before visit
1378 for b.walkPath[len(b.walkPath)-1] != parentAndroidModule {
1379 b.walkPath = b.walkPath[0 : len(b.walkPath)-1]
1380 }
1381 b.walkPath = append(b.walkPath, childAndroidModule)
Colin Crossd11fcda2017-10-23 17:59:01 -07001382 return visit(childAndroidModule, parentAndroidModule)
1383 } else {
1384 return false
1385 }
1386 })
1387}
1388
Colin Crossdc35e212019-06-06 16:13:11 -07001389func (b *baseModuleContext) GetWalkPath() []Module {
1390 return b.walkPath
1391}
1392
Colin Cross25de6c32019-06-06 14:29:25 -07001393func (m *moduleContext) VisitAllModuleVariants(visit func(Module)) {
Colin Crossdc35e212019-06-06 16:13:11 -07001394 m.bp.VisitAllModuleVariants(func(module blueprint.Module) {
Colin Cross0875c522017-11-28 17:34:01 -08001395 visit(module.(Module))
1396 })
1397}
1398
Colin Cross25de6c32019-06-06 14:29:25 -07001399func (m *moduleContext) PrimaryModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001400 return m.bp.PrimaryModule().(Module)
Colin Cross0875c522017-11-28 17:34:01 -08001401}
1402
Colin Cross25de6c32019-06-06 14:29:25 -07001403func (m *moduleContext) FinalModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001404 return m.bp.FinalModule().(Module)
1405}
1406
1407func (m *moduleContext) ModuleSubDir() string {
1408 return m.bp.ModuleSubDir()
Colin Cross0875c522017-11-28 17:34:01 -08001409}
1410
Colin Cross0ea8ba82019-06-06 14:33:29 -07001411func (b *baseModuleContext) Target() Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001412 return b.target
Colin Crossa1ad8d12016-06-01 17:09:44 -07001413}
1414
Colin Cross0ea8ba82019-06-06 14:33:29 -07001415func (b *baseModuleContext) TargetPrimary() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001416 return b.targetPrimary
Colin Cross8b74d172016-09-13 09:59:14 -07001417}
1418
Colin Cross0ea8ba82019-06-06 14:33:29 -07001419func (b *baseModuleContext) MultiTargets() []Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001420 return b.multiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07001421}
1422
Colin Cross0ea8ba82019-06-06 14:33:29 -07001423func (b *baseModuleContext) Arch() Arch {
Colin Cross25de6c32019-06-06 14:29:25 -07001424 return b.target.Arch
Colin Cross3f40fa42015-01-30 17:27:36 -08001425}
1426
Colin Cross0ea8ba82019-06-06 14:33:29 -07001427func (b *baseModuleContext) Os() OsType {
Colin Cross25de6c32019-06-06 14:29:25 -07001428 return b.target.Os
Dan Willemsen490fd492015-11-24 17:53:15 -08001429}
1430
Colin Cross0ea8ba82019-06-06 14:33:29 -07001431func (b *baseModuleContext) Host() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001432 return b.target.Os.Class == Host || b.target.Os.Class == HostCross
Colin Crossf6566ed2015-03-24 11:13:38 -07001433}
1434
Colin Cross0ea8ba82019-06-06 14:33:29 -07001435func (b *baseModuleContext) Device() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001436 return b.target.Os.Class == Device
Colin Crossf6566ed2015-03-24 11:13:38 -07001437}
1438
Colin Cross0ea8ba82019-06-06 14:33:29 -07001439func (b *baseModuleContext) Darwin() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001440 return b.target.Os == Darwin
Colin Cross0af4b842015-04-30 16:36:18 -07001441}
1442
Colin Cross0ea8ba82019-06-06 14:33:29 -07001443func (b *baseModuleContext) Fuchsia() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001444 return b.target.Os == Fuchsia
Doug Horn21b94272019-01-16 12:06:11 -08001445}
1446
Colin Cross0ea8ba82019-06-06 14:33:29 -07001447func (b *baseModuleContext) Windows() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001448 return b.target.Os == Windows
Colin Cross3edeee12017-04-04 12:59:48 -07001449}
1450
Colin Cross0ea8ba82019-06-06 14:33:29 -07001451func (b *baseModuleContext) Debug() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001452 return b.debug
Colin Crossf6566ed2015-03-24 11:13:38 -07001453}
1454
Colin Cross0ea8ba82019-06-06 14:33:29 -07001455func (b *baseModuleContext) PrimaryArch() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001456 if len(b.config.Targets[b.target.Os]) <= 1 {
Colin Cross67a5c132017-05-09 13:45:28 -07001457 return true
1458 }
Colin Cross25de6c32019-06-06 14:29:25 -07001459 return b.target.Arch.ArchType == b.config.Targets[b.target.Os][0].Arch.ArchType
Colin Cross1e7d3702016-08-24 15:25:47 -07001460}
1461
Colin Cross0ea8ba82019-06-06 14:33:29 -07001462func (b *baseModuleContext) AConfig() Config {
Colin Cross25de6c32019-06-06 14:29:25 -07001463 return b.config
Colin Cross1332b002015-04-07 17:11:30 -07001464}
1465
Colin Cross0ea8ba82019-06-06 14:33:29 -07001466func (b *baseModuleContext) DeviceConfig() DeviceConfig {
Colin Cross25de6c32019-06-06 14:29:25 -07001467 return DeviceConfig{b.config.deviceConfig}
Colin Cross9272ade2016-08-17 15:24:12 -07001468}
1469
Colin Cross0ea8ba82019-06-06 14:33:29 -07001470func (b *baseModuleContext) Platform() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001471 return b.kind == platformModule
Jiyong Park2db76922017-11-08 16:03:48 +09001472}
1473
Colin Cross0ea8ba82019-06-06 14:33:29 -07001474func (b *baseModuleContext) DeviceSpecific() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001475 return b.kind == deviceSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001476}
1477
Colin Cross0ea8ba82019-06-06 14:33:29 -07001478func (b *baseModuleContext) SocSpecific() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001479 return b.kind == socSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001480}
1481
Colin Cross0ea8ba82019-06-06 14:33:29 -07001482func (b *baseModuleContext) ProductSpecific() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001483 return b.kind == productSpecificModule
Dan Willemsen782a2d12015-12-21 14:55:28 -08001484}
1485
Justin Yund5f6c822019-06-25 16:47:17 +09001486func (b *baseModuleContext) SystemExtSpecific() bool {
1487 return b.kind == systemExtSpecificModule
Dario Frenifd05a742018-05-29 13:28:54 +01001488}
1489
Jiyong Park5baac542018-08-28 09:55:37 +09001490// Makes this module a platform module, i.e. not specific to soc, device,
Justin Yund5f6c822019-06-25 16:47:17 +09001491// product, or system_ext.
Colin Cross4157e882019-06-06 16:57:04 -07001492func (m *ModuleBase) MakeAsPlatform() {
1493 m.commonProperties.Vendor = boolPtr(false)
1494 m.commonProperties.Proprietary = boolPtr(false)
1495 m.commonProperties.Soc_specific = boolPtr(false)
1496 m.commonProperties.Product_specific = boolPtr(false)
Justin Yund5f6c822019-06-25 16:47:17 +09001497 m.commonProperties.System_ext_specific = boolPtr(false)
Jiyong Park5baac542018-08-28 09:55:37 +09001498}
1499
Colin Cross4157e882019-06-06 16:57:04 -07001500func (m *ModuleBase) EnableNativeBridgeSupportByDefault() {
1501 m.commonProperties.Native_bridge_supported = boolPtr(true)
dimitry03dc3f62019-05-09 14:07:34 +02001502}
1503
Jooyung Han344d5432019-08-23 11:17:39 +09001504// IsNativeBridgeSupported returns true if "native_bridge_supported" is explicitly set as "true"
1505func (m *ModuleBase) IsNativeBridgeSupported() bool {
1506 return proptools.Bool(m.commonProperties.Native_bridge_supported)
1507}
1508
Colin Cross25de6c32019-06-06 14:29:25 -07001509func (m *moduleContext) InstallInData() bool {
1510 return m.module.InstallInData()
Dan Willemsen782a2d12015-12-21 14:55:28 -08001511}
1512
Jaewoong Jung0949f312019-09-11 10:25:18 -07001513func (m *moduleContext) InstallInTestcases() bool {
1514 return m.module.InstallInTestcases()
1515}
1516
Colin Cross25de6c32019-06-06 14:29:25 -07001517func (m *moduleContext) InstallInSanitizerDir() bool {
1518 return m.module.InstallInSanitizerDir()
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001519}
1520
Colin Cross25de6c32019-06-06 14:29:25 -07001521func (m *moduleContext) InstallInRecovery() bool {
1522 return m.module.InstallInRecovery()
Jiyong Parkf9332f12018-02-01 00:54:12 +09001523}
1524
Colin Cross607d8582019-07-29 16:44:46 -07001525func (m *moduleContext) InstallBypassMake() bool {
1526 return m.module.InstallBypassMake()
1527}
1528
Colin Cross25de6c32019-06-06 14:29:25 -07001529func (m *moduleContext) skipInstall(fullInstallPath OutputPath) bool {
1530 if m.module.base().commonProperties.SkipInstall {
Colin Cross893d8162017-04-26 17:34:03 -07001531 return true
1532 }
1533
Colin Cross3607f212018-05-07 15:28:05 -07001534 // We'll need a solution for choosing which of modules with the same name in different
1535 // namespaces to install. For now, reuse the list of namespaces exported to Make as the
1536 // list of namespaces to install in a Soong-only build.
Colin Cross25de6c32019-06-06 14:29:25 -07001537 if !m.module.base().commonProperties.NamespaceExportedToMake {
Colin Cross3607f212018-05-07 15:28:05 -07001538 return true
1539 }
1540
Colin Cross25de6c32019-06-06 14:29:25 -07001541 if m.Device() {
Colin Cross607d8582019-07-29 16:44:46 -07001542 if m.Config().EmbeddedInMake() && !m.InstallBypassMake() {
Colin Cross893d8162017-04-26 17:34:03 -07001543 return true
1544 }
1545
Colin Cross25de6c32019-06-06 14:29:25 -07001546 if m.Config().SkipMegaDeviceInstall(fullInstallPath.String()) {
Colin Cross893d8162017-04-26 17:34:03 -07001547 return true
1548 }
1549 }
1550
1551 return false
1552}
1553
Colin Cross25de6c32019-06-06 14:29:25 -07001554func (m *moduleContext) InstallFile(installPath OutputPath, name string, srcPath Path,
Colin Crossa2344662016-03-24 13:14:12 -07001555 deps ...Path) OutputPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001556 return m.installFile(installPath, name, srcPath, Cp, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001557}
1558
Colin Cross25de6c32019-06-06 14:29:25 -07001559func (m *moduleContext) InstallExecutable(installPath OutputPath, name string, srcPath Path,
Colin Cross5c517922017-08-31 12:29:17 -07001560 deps ...Path) OutputPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001561 return m.installFile(installPath, name, srcPath, CpExecutable, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001562}
1563
Colin Cross25de6c32019-06-06 14:29:25 -07001564func (m *moduleContext) installFile(installPath OutputPath, name string, srcPath Path,
Colin Cross5c517922017-08-31 12:29:17 -07001565 rule blueprint.Rule, deps []Path) OutputPath {
Colin Cross35cec122015-04-02 14:37:16 -07001566
Colin Cross25de6c32019-06-06 14:29:25 -07001567 fullInstallPath := installPath.Join(m, name)
1568 m.module.base().hooks.runInstallHooks(m, fullInstallPath, false)
Colin Cross3f40fa42015-01-30 17:27:36 -08001569
Colin Cross25de6c32019-06-06 14:29:25 -07001570 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001571
Colin Cross25de6c32019-06-06 14:29:25 -07001572 deps = append(deps, m.installDeps...)
Colin Cross35cec122015-04-02 14:37:16 -07001573
Colin Cross89562dc2016-10-03 17:47:19 -07001574 var implicitDeps, orderOnlyDeps Paths
1575
Colin Cross25de6c32019-06-06 14:29:25 -07001576 if m.Host() {
Colin Cross89562dc2016-10-03 17:47:19 -07001577 // Installed host modules might be used during the build, depend directly on their
1578 // dependencies so their timestamp is updated whenever their dependency is updated
1579 implicitDeps = deps
1580 } else {
1581 orderOnlyDeps = deps
1582 }
1583
Colin Cross25de6c32019-06-06 14:29:25 -07001584 m.Build(pctx, BuildParams{
Colin Cross5c517922017-08-31 12:29:17 -07001585 Rule: rule,
Colin Cross67a5c132017-05-09 13:45:28 -07001586 Description: "install " + fullInstallPath.Base(),
1587 Output: fullInstallPath,
1588 Input: srcPath,
1589 Implicits: implicitDeps,
1590 OrderOnly: orderOnlyDeps,
Colin Cross25de6c32019-06-06 14:29:25 -07001591 Default: !m.Config().EmbeddedInMake(),
Dan Willemsen322acaf2016-01-12 23:07:05 -08001592 })
Colin Cross3f40fa42015-01-30 17:27:36 -08001593
Colin Cross25de6c32019-06-06 14:29:25 -07001594 m.installFiles = append(m.installFiles, fullInstallPath)
Dan Willemsen322acaf2016-01-12 23:07:05 -08001595 }
Colin Cross25de6c32019-06-06 14:29:25 -07001596 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross35cec122015-04-02 14:37:16 -07001597 return fullInstallPath
1598}
1599
Colin Cross25de6c32019-06-06 14:29:25 -07001600func (m *moduleContext) InstallSymlink(installPath OutputPath, name string, srcPath OutputPath) OutputPath {
1601 fullInstallPath := installPath.Join(m, name)
1602 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Colin Cross3854a602016-01-11 12:49:11 -08001603
Colin Cross25de6c32019-06-06 14:29:25 -07001604 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001605
Alex Lightfb4353d2019-01-17 13:57:45 -08001606 relPath, err := filepath.Rel(path.Dir(fullInstallPath.String()), srcPath.String())
1607 if err != nil {
1608 panic(fmt.Sprintf("Unable to generate symlink between %q and %q: %s", fullInstallPath.Base(), srcPath.Base(), err))
1609 }
Colin Cross25de6c32019-06-06 14:29:25 -07001610 m.Build(pctx, BuildParams{
Colin Cross67a5c132017-05-09 13:45:28 -07001611 Rule: Symlink,
1612 Description: "install symlink " + fullInstallPath.Base(),
1613 Output: fullInstallPath,
1614 OrderOnly: Paths{srcPath},
Colin Cross25de6c32019-06-06 14:29:25 -07001615 Default: !m.Config().EmbeddedInMake(),
Colin Cross12fc4972016-01-11 12:49:11 -08001616 Args: map[string]string{
Alex Lightfb4353d2019-01-17 13:57:45 -08001617 "fromPath": relPath,
Colin Cross12fc4972016-01-11 12:49:11 -08001618 },
1619 })
Colin Cross3854a602016-01-11 12:49:11 -08001620
Colin Cross25de6c32019-06-06 14:29:25 -07001621 m.installFiles = append(m.installFiles, fullInstallPath)
1622 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross12fc4972016-01-11 12:49:11 -08001623 }
Colin Cross3854a602016-01-11 12:49:11 -08001624 return fullInstallPath
1625}
1626
Jiyong Parkf1194352019-02-25 11:05:47 +09001627// installPath/name -> absPath where absPath might be a path that is available only at runtime
1628// (e.g. /apex/...)
Colin Cross25de6c32019-06-06 14:29:25 -07001629func (m *moduleContext) InstallAbsoluteSymlink(installPath OutputPath, name string, absPath string) OutputPath {
1630 fullInstallPath := installPath.Join(m, name)
1631 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Jiyong Parkf1194352019-02-25 11:05:47 +09001632
Colin Cross25de6c32019-06-06 14:29:25 -07001633 if !m.skipInstall(fullInstallPath) {
1634 m.Build(pctx, BuildParams{
Jiyong Parkf1194352019-02-25 11:05:47 +09001635 Rule: Symlink,
1636 Description: "install symlink " + fullInstallPath.Base() + " -> " + absPath,
1637 Output: fullInstallPath,
Colin Cross25de6c32019-06-06 14:29:25 -07001638 Default: !m.Config().EmbeddedInMake(),
Jiyong Parkf1194352019-02-25 11:05:47 +09001639 Args: map[string]string{
1640 "fromPath": absPath,
1641 },
1642 })
1643
Colin Cross25de6c32019-06-06 14:29:25 -07001644 m.installFiles = append(m.installFiles, fullInstallPath)
Jiyong Parkf1194352019-02-25 11:05:47 +09001645 }
1646 return fullInstallPath
1647}
1648
Colin Cross25de6c32019-06-06 14:29:25 -07001649func (m *moduleContext) CheckbuildFile(srcPath Path) {
1650 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross3f40fa42015-01-30 17:27:36 -08001651}
1652
Colin Cross3f40fa42015-01-30 17:27:36 -08001653type fileInstaller interface {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001654 filesToInstall() Paths
Colin Cross3f40fa42015-01-30 17:27:36 -08001655}
1656
1657func isFileInstaller(m blueprint.Module) bool {
1658 _, ok := m.(fileInstaller)
1659 return ok
1660}
1661
1662func isAndroidModule(m blueprint.Module) bool {
Colin Cross635c3b02016-05-18 15:37:25 -07001663 _, ok := m.(Module)
Colin Cross3f40fa42015-01-30 17:27:36 -08001664 return ok
1665}
Colin Crossfce53272015-04-08 11:21:40 -07001666
Dan Willemsen2ef08f42015-06-30 18:15:24 -07001667func findStringInSlice(str string, slice []string) int {
1668 for i, s := range slice {
1669 if s == str {
1670 return i
Colin Crossfce53272015-04-08 11:21:40 -07001671 }
1672 }
Dan Willemsen2ef08f42015-06-30 18:15:24 -07001673 return -1
1674}
1675
Colin Cross41955e82019-05-29 14:40:35 -07001676// SrcIsModule decodes module references in the format ":name" into the module name, or empty string if the input
1677// was not a module reference.
1678func SrcIsModule(s string) (module string) {
Colin Cross068e0fe2016-12-13 15:23:47 -08001679 if len(s) > 1 && s[0] == ':' {
1680 return s[1:]
1681 }
1682 return ""
1683}
1684
Colin Cross41955e82019-05-29 14:40:35 -07001685// SrcIsModule decodes module references in the format ":name{.tag}" into the module name and tag, ":name" into the
1686// module name and an empty string for the tag, or empty strings if the input was not a module reference.
1687func SrcIsModuleWithTag(s string) (module, tag string) {
1688 if len(s) > 1 && s[0] == ':' {
1689 module = s[1:]
1690 if tagStart := strings.IndexByte(module, '{'); tagStart > 0 {
1691 if module[len(module)-1] == '}' {
1692 tag = module[tagStart+1 : len(module)-1]
1693 module = module[:tagStart]
1694 return module, tag
1695 }
1696 }
1697 return module, ""
1698 }
1699 return "", ""
Colin Cross068e0fe2016-12-13 15:23:47 -08001700}
1701
Colin Cross41955e82019-05-29 14:40:35 -07001702type sourceOrOutputDependencyTag struct {
1703 blueprint.BaseDependencyTag
1704 tag string
1705}
1706
1707func sourceOrOutputDepTag(tag string) blueprint.DependencyTag {
1708 return sourceOrOutputDependencyTag{tag: tag}
1709}
1710
1711var SourceDepTag = sourceOrOutputDepTag("")
Colin Cross068e0fe2016-12-13 15:23:47 -08001712
Colin Cross366938f2017-12-11 16:29:02 -08001713// Adds necessary dependencies to satisfy filegroup or generated sources modules listed in srcFiles
1714// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08001715//
1716// Deprecated: tag the property with `android:"path"` instead.
Colin Cross068e0fe2016-12-13 15:23:47 -08001717func ExtractSourcesDeps(ctx BottomUpMutatorContext, srcFiles []string) {
Nan Zhang2439eb72017-04-10 11:27:50 -07001718 set := make(map[string]bool)
1719
Colin Cross068e0fe2016-12-13 15:23:47 -08001720 for _, s := range srcFiles {
Colin Cross41955e82019-05-29 14:40:35 -07001721 if m, t := SrcIsModuleWithTag(s); m != "" {
1722 if _, found := set[s]; found {
1723 ctx.ModuleErrorf("found source dependency duplicate: %q!", s)
Nan Zhang2439eb72017-04-10 11:27:50 -07001724 } else {
Colin Cross41955e82019-05-29 14:40:35 -07001725 set[s] = true
1726 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Nan Zhang2439eb72017-04-10 11:27:50 -07001727 }
Colin Cross068e0fe2016-12-13 15:23:47 -08001728 }
1729 }
Colin Cross068e0fe2016-12-13 15:23:47 -08001730}
1731
Colin Cross366938f2017-12-11 16:29:02 -08001732// Adds necessary dependencies to satisfy filegroup or generated sources modules specified in s
1733// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08001734//
1735// Deprecated: tag the property with `android:"path"` instead.
Colin Cross366938f2017-12-11 16:29:02 -08001736func ExtractSourceDeps(ctx BottomUpMutatorContext, s *string) {
1737 if s != nil {
Colin Cross41955e82019-05-29 14:40:35 -07001738 if m, t := SrcIsModuleWithTag(*s); m != "" {
1739 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Colin Cross366938f2017-12-11 16:29:02 -08001740 }
1741 }
1742}
1743
Colin Cross41955e82019-05-29 14:40:35 -07001744// A module that implements SourceFileProducer can be referenced from any property that is tagged with `android:"path"`
1745// using the ":module" syntax and provides a list of paths to be used as if they were listed in the property.
Colin Cross068e0fe2016-12-13 15:23:47 -08001746type SourceFileProducer interface {
1747 Srcs() Paths
1748}
1749
Colin Cross41955e82019-05-29 14:40:35 -07001750// A module that implements OutputFileProducer can be referenced from any property that is tagged with `android:"path"`
1751// using the ":module" syntax or ":module{.tag}" syntax and provides a list of otuput files to be used as if they were
1752// listed in the property.
1753type OutputFileProducer interface {
1754 OutputFiles(tag string) (Paths, error)
1755}
1756
Colin Crossfe17f6f2019-03-28 19:30:56 -07001757type HostToolProvider interface {
1758 HostToolPath() OptionalPath
1759}
1760
Colin Cross27b922f2019-03-04 22:35:41 -08001761// Returns a list of paths expanded from globs and modules referenced using ":module" syntax. The property must
1762// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08001763//
1764// Deprecated: use PathsForModuleSrc or PathsForModuleSrcExcludes instead.
Colin Cross25de6c32019-06-06 14:29:25 -07001765func (m *moduleContext) ExpandSources(srcFiles, excludes []string) Paths {
1766 return PathsForModuleSrcExcludes(m, srcFiles, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07001767}
1768
Colin Cross2fafa3e2019-03-05 12:39:51 -08001769// Returns a single path expanded from globs and modules referenced using ":module" syntax. The property must
1770// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08001771//
1772// Deprecated: use PathForModuleSrc instead.
Colin Cross25de6c32019-06-06 14:29:25 -07001773func (m *moduleContext) ExpandSource(srcFile, prop string) Path {
1774 return PathForModuleSrc(m, srcFile)
Colin Cross2fafa3e2019-03-05 12:39:51 -08001775}
1776
1777// Returns an optional single path expanded from globs and modules referenced using ":module" syntax if
1778// the srcFile is non-nil. The property must be tagged with `android:"path" to support automatic source module
1779// dependency resolution.
Colin Cross25de6c32019-06-06 14:29:25 -07001780func (m *moduleContext) ExpandOptionalSource(srcFile *string, prop string) OptionalPath {
Colin Cross2fafa3e2019-03-05 12:39:51 -08001781 if srcFile != nil {
Colin Cross25de6c32019-06-06 14:29:25 -07001782 return OptionalPathForPath(PathForModuleSrc(m, *srcFile))
Colin Cross2fafa3e2019-03-05 12:39:51 -08001783 }
1784 return OptionalPath{}
1785}
1786
Colin Cross25de6c32019-06-06 14:29:25 -07001787func (m *moduleContext) RequiredModuleNames() []string {
1788 return m.module.base().commonProperties.Required
Nan Zhang6d34b302017-02-04 17:47:46 -08001789}
1790
Colin Cross25de6c32019-06-06 14:29:25 -07001791func (m *moduleContext) HostRequiredModuleNames() []string {
1792 return m.module.base().commonProperties.Host_required
Sasha Smundakb6d23052019-04-01 18:37:36 -07001793}
1794
Colin Cross25de6c32019-06-06 14:29:25 -07001795func (m *moduleContext) TargetRequiredModuleNames() []string {
1796 return m.module.base().commonProperties.Target_required
Sasha Smundakb6d23052019-04-01 18:37:36 -07001797}
1798
Colin Crossdc35e212019-06-06 16:13:11 -07001799func (b *baseModuleContext) Glob(globPattern string, excludes []string) Paths {
1800 ret, err := b.GlobWithDeps(globPattern, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07001801 if err != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001802 b.ModuleErrorf("glob: %s", err.Error())
Colin Cross8f101b42015-06-17 15:09:06 -07001803 }
Colin Crossdc35e212019-06-06 16:13:11 -07001804 return pathsForModuleSrcFromFullPath(b, ret, true)
Colin Crossfce53272015-04-08 11:21:40 -07001805}
Colin Cross1f8c52b2015-06-16 16:38:17 -07001806
Colin Crossdc35e212019-06-06 16:13:11 -07001807func (b *baseModuleContext) GlobFiles(globPattern string, excludes []string) Paths {
1808 ret, err := b.GlobWithDeps(globPattern, excludes)
Nan Zhang581fd212018-01-10 16:06:12 -08001809 if err != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001810 b.ModuleErrorf("glob: %s", err.Error())
Nan Zhang581fd212018-01-10 16:06:12 -08001811 }
Colin Crossdc35e212019-06-06 16:13:11 -07001812 return pathsForModuleSrcFromFullPath(b, ret, false)
Nan Zhang581fd212018-01-10 16:06:12 -08001813}
1814
Colin Cross463a90e2015-06-17 14:20:06 -07001815func init() {
Colin Cross798bfce2016-10-12 14:28:16 -07001816 RegisterSingletonType("buildtarget", BuildTargetSingleton)
Colin Cross463a90e2015-06-17 14:20:06 -07001817}
1818
Colin Cross0875c522017-11-28 17:34:01 -08001819func BuildTargetSingleton() Singleton {
Colin Cross1f8c52b2015-06-16 16:38:17 -07001820 return &buildTargetSingleton{}
1821}
1822
Colin Cross87d8b562017-04-25 10:01:55 -07001823func parentDir(dir string) string {
1824 dir, _ = filepath.Split(dir)
1825 return filepath.Clean(dir)
1826}
1827
Colin Cross1f8c52b2015-06-16 16:38:17 -07001828type buildTargetSingleton struct{}
1829
Colin Cross0875c522017-11-28 17:34:01 -08001830func (c *buildTargetSingleton) GenerateBuildActions(ctx SingletonContext) {
1831 var checkbuildDeps Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07001832
Colin Cross0875c522017-11-28 17:34:01 -08001833 mmTarget := func(dir string) WritablePath {
1834 return PathForPhony(ctx,
1835 "MODULES-IN-"+strings.Replace(filepath.Clean(dir), "/", "-", -1))
Colin Cross87d8b562017-04-25 10:01:55 -07001836 }
1837
Colin Cross0875c522017-11-28 17:34:01 -08001838 modulesInDir := make(map[string]Paths)
Colin Cross1f8c52b2015-06-16 16:38:17 -07001839
Colin Cross0875c522017-11-28 17:34:01 -08001840 ctx.VisitAllModules(func(module Module) {
1841 blueprintDir := module.base().blueprintDir
1842 installTarget := module.base().installTarget
1843 checkbuildTarget := module.base().checkbuildTarget
Colin Cross1f8c52b2015-06-16 16:38:17 -07001844
Colin Cross0875c522017-11-28 17:34:01 -08001845 if checkbuildTarget != nil {
1846 checkbuildDeps = append(checkbuildDeps, checkbuildTarget)
1847 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], checkbuildTarget)
1848 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07001849
Colin Cross0875c522017-11-28 17:34:01 -08001850 if installTarget != nil {
1851 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], installTarget)
Colin Cross1f8c52b2015-06-16 16:38:17 -07001852 }
1853 })
1854
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001855 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08001856 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001857 suffix = "-soong"
1858 }
1859
Colin Cross1f8c52b2015-06-16 16:38:17 -07001860 // Create a top-level checkbuild target that depends on all modules
Colin Cross0875c522017-11-28 17:34:01 -08001861 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07001862 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001863 Output: PathForPhony(ctx, "checkbuild"+suffix),
Colin Cross1f8c52b2015-06-16 16:38:17 -07001864 Implicits: checkbuildDeps,
Colin Cross1f8c52b2015-06-16 16:38:17 -07001865 })
1866
Dan Willemsend2e95fb2017-09-20 14:30:50 -07001867 // Make will generate the MODULES-IN-* targets
Colin Crossaabf6792017-11-29 00:27:14 -08001868 if ctx.Config().EmbeddedInMake() {
Dan Willemsend2e95fb2017-09-20 14:30:50 -07001869 return
1870 }
1871
Colin Cross87d8b562017-04-25 10:01:55 -07001872 // Ensure ancestor directories are in modulesInDir
Inseob Kim1a365c62019-06-08 15:47:51 +09001873 dirs := SortedStringKeys(modulesInDir)
Colin Cross87d8b562017-04-25 10:01:55 -07001874 for _, dir := range dirs {
1875 dir := parentDir(dir)
1876 for dir != "." && dir != "/" {
1877 if _, exists := modulesInDir[dir]; exists {
1878 break
1879 }
1880 modulesInDir[dir] = nil
1881 dir = parentDir(dir)
1882 }
1883 }
1884
1885 // Make directories build their direct subdirectories
Colin Cross87d8b562017-04-25 10:01:55 -07001886 for _, dir := range dirs {
1887 p := parentDir(dir)
1888 if p != "." && p != "/" {
1889 modulesInDir[p] = append(modulesInDir[p], mmTarget(dir))
1890 }
1891 }
1892
Dan Willemsend2e95fb2017-09-20 14:30:50 -07001893 // Create a MODULES-IN-<directory> target that depends on all modules in a directory, and
1894 // depends on the MODULES-IN-* targets of all of its subdirectories that contain Android.bp
1895 // files.
Colin Cross1f8c52b2015-06-16 16:38:17 -07001896 for _, dir := range dirs {
Colin Cross0875c522017-11-28 17:34:01 -08001897 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07001898 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001899 Output: mmTarget(dir),
Colin Cross87d8b562017-04-25 10:01:55 -07001900 Implicits: modulesInDir[dir],
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001901 // HACK: checkbuild should be an optional build, but force it
1902 // enabled for now in standalone builds
Colin Crossaabf6792017-11-29 00:27:14 -08001903 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross1f8c52b2015-06-16 16:38:17 -07001904 })
1905 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07001906
1907 // Create (host|host-cross|target)-<OS> phony rules to build a reduced checkbuild.
1908 osDeps := map[OsType]Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08001909 ctx.VisitAllModules(func(module Module) {
1910 if module.Enabled() {
1911 os := module.Target().Os
1912 osDeps[os] = append(osDeps[os], module.base().checkbuildFiles...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07001913 }
1914 })
1915
Colin Cross0875c522017-11-28 17:34:01 -08001916 osClass := make(map[string]Paths)
Dan Willemsen61d88b82017-09-20 17:29:08 -07001917 for os, deps := range osDeps {
1918 var className string
1919
1920 switch os.Class {
1921 case Host:
1922 className = "host"
1923 case HostCross:
1924 className = "host-cross"
1925 case Device:
1926 className = "target"
1927 default:
1928 continue
1929 }
1930
Colin Cross0875c522017-11-28 17:34:01 -08001931 name := PathForPhony(ctx, className+"-"+os.Name)
Dan Willemsen61d88b82017-09-20 17:29:08 -07001932 osClass[className] = append(osClass[className], name)
1933
Colin Cross0875c522017-11-28 17:34:01 -08001934 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07001935 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001936 Output: name,
1937 Implicits: deps,
Dan Willemsen61d88b82017-09-20 17:29:08 -07001938 })
1939 }
1940
1941 // Wrap those into host|host-cross|target phony rules
Inseob Kim1a365c62019-06-08 15:47:51 +09001942 for _, class := range SortedStringKeys(osClass) {
Colin Cross0875c522017-11-28 17:34:01 -08001943 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07001944 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001945 Output: PathForPhony(ctx, class),
Dan Willemsen61d88b82017-09-20 17:29:08 -07001946 Implicits: osClass[class],
Dan Willemsen61d88b82017-09-20 17:29:08 -07001947 })
1948 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07001949}
Colin Crossd779da42015-12-17 18:00:23 -08001950
Brandon Lee5d45c6f2018-08-15 15:35:38 -07001951// Collect information for opening IDE project files in java/jdeps.go.
1952type IDEInfo interface {
1953 IDEInfo(ideInfo *IdeInfo)
1954 BaseModuleName() string
1955}
1956
1957// Extract the base module name from the Import name.
1958// Often the Import name has a prefix "prebuilt_".
1959// Remove the prefix explicitly if needed
1960// until we find a better solution to get the Import name.
1961type IDECustomizedModuleName interface {
1962 IDECustomizedModuleName() string
1963}
1964
1965type IdeInfo struct {
1966 Deps []string `json:"dependencies,omitempty"`
1967 Srcs []string `json:"srcs,omitempty"`
1968 Aidl_include_dirs []string `json:"aidl_include_dirs,omitempty"`
1969 Jarjar_rules []string `json:"jarjar_rules,omitempty"`
1970 Jars []string `json:"jars,omitempty"`
1971 Classes []string `json:"class,omitempty"`
1972 Installed_paths []string `json:"installed,omitempty"`
patricktu18c82ff2019-05-10 15:48:50 +08001973 SrcJars []string `json:"srcjars,omitempty"`
Brandon Lee5d45c6f2018-08-15 15:35:38 -07001974}