blob: b858564232bee2e7407f05466530fc2a7f7acd69 [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 Cross70dda7e2019-10-01 22:05:35 -0700150 InstallExecutable(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
151 InstallFile(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
152 InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath
153 InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath
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 Cross90ba5f42019-10-02 11:10:58 -0700160 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700161 InstallBypassMake() bool
Nan Zhang6d34b302017-02-04 17:47:46 -0800162
163 RequiredModuleNames() []string
Sasha Smundakb6d23052019-04-01 18:37:36 -0700164 HostRequiredModuleNames() []string
165 TargetRequiredModuleNames() []string
Colin Cross3f68a132017-10-23 17:10:29 -0700166
Colin Cross3f68a132017-10-23 17:10:29 -0700167 ModuleSubDir() string
168
Colin Cross0875c522017-11-28 17:34:01 -0800169 Variable(pctx PackageContext, name, value string)
170 Rule(pctx PackageContext, name string, params blueprint.RuleParams, argNames ...string) blueprint.Rule
Colin Crossae887032017-10-23 17:16:14 -0700171 // Similar to blueprint.ModuleContext.Build, but takes Paths instead of []string,
172 // and performs more verification.
Colin Cross0875c522017-11-28 17:34:01 -0800173 Build(pctx PackageContext, params BuildParams)
Colin Cross3f68a132017-10-23 17:10:29 -0700174
Colin Cross0875c522017-11-28 17:34:01 -0800175 PrimaryModule() Module
176 FinalModule() Module
177 VisitAllModuleVariants(visit func(Module))
Colin Cross3f68a132017-10-23 17:10:29 -0700178
179 GetMissingDependencies() []string
Jeff Gaston088e29e2017-11-29 16:47:17 -0800180 Namespace() blueprint.Namespace
Colin Cross3f40fa42015-01-30 17:27:36 -0800181}
182
Colin Cross635c3b02016-05-18 15:37:25 -0700183type Module interface {
Colin Cross3f40fa42015-01-30 17:27:36 -0800184 blueprint.Module
185
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700186 // GenerateAndroidBuildActions is analogous to Blueprints' GenerateBuildActions,
187 // but GenerateAndroidBuildActions also has access to Android-specific information.
188 // For more information, see Module.GenerateBuildActions within Blueprint's module_ctx.go
Colin Cross635c3b02016-05-18 15:37:25 -0700189 GenerateAndroidBuildActions(ModuleContext)
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700190
Colin Cross1e676be2016-10-12 14:38:15 -0700191 DepsMutator(BottomUpMutatorContext)
Colin Cross3f40fa42015-01-30 17:27:36 -0800192
Colin Cross635c3b02016-05-18 15:37:25 -0700193 base() *ModuleBase
Dan Willemsen0effe062015-11-30 16:06:01 -0800194 Enabled() bool
Colin Crossa1ad8d12016-06-01 17:09:44 -0700195 Target() Target
Dan Willemsen782a2d12015-12-21 14:55:28 -0800196 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700197 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700198 InstallInSanitizerDir() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900199 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700200 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700201 InstallBypassMake() bool
Colin Crossa2f296f2016-11-29 15:16:18 -0800202 SkipInstall()
Jiyong Park374510b2018-03-19 18:23:01 +0900203 ExportedToMake() bool
Jiyong Park52818fc2019-03-18 12:01:38 +0900204 NoticeFile() OptionalPath
Colin Cross36242852017-06-23 15:06:31 -0700205
206 AddProperties(props ...interface{})
207 GetProperties() []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700208
Colin Crossae887032017-10-23 17:16:14 -0700209 BuildParamsForTests() []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800210 RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800211 VariablesForTests() map[string]string
Paul Duffine2453c72019-05-31 14:00:04 +0100212
Colin Cross9a362232019-07-01 15:32:45 -0700213 // String returns a string that includes the module name and variants for printing during debugging.
214 String() string
215
Paul Duffine2453c72019-05-31 14:00:04 +0100216 // Get the qualified module id for this module.
217 qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName
218
219 // Get information about the properties that can contain visibility rules.
220 visibilityProperties() []visibilityProperty
Paul Duffin63c6e182019-07-24 14:24:38 +0100221
222 // Get the visibility rules that control the visibility of this module.
223 visibility() []string
Paul Duffine2453c72019-05-31 14:00:04 +0100224}
225
226// Qualified id for a module
227type qualifiedModuleName struct {
228 // The package (i.e. directory) in which the module is defined, without trailing /
229 pkg string
230
231 // The name of the module, empty string if package.
232 name string
233}
234
235func (q qualifiedModuleName) String() string {
236 if q.name == "" {
237 return "//" + q.pkg
238 }
239 return "//" + q.pkg + ":" + q.name
240}
241
Paul Duffine484f472019-06-20 16:38:08 +0100242func (q qualifiedModuleName) isRootPackage() bool {
243 return q.pkg == "" && q.name == ""
244}
245
Paul Duffine2453c72019-05-31 14:00:04 +0100246// Get the id for the package containing this module.
247func (q qualifiedModuleName) getContainingPackageId() qualifiedModuleName {
248 pkg := q.pkg
249 if q.name == "" {
Paul Duffine484f472019-06-20 16:38:08 +0100250 if pkg == "" {
251 panic(fmt.Errorf("Cannot get containing package id of root package"))
252 }
253
254 index := strings.LastIndex(pkg, "/")
255 if index == -1 {
256 pkg = ""
257 } else {
258 pkg = pkg[:index]
259 }
Paul Duffine2453c72019-05-31 14:00:04 +0100260 }
261 return newPackageId(pkg)
262}
263
264func newPackageId(pkg string) qualifiedModuleName {
265 // A qualified id for a package module has no name.
266 return qualifiedModuleName{pkg: pkg, name: ""}
Colin Cross3f40fa42015-01-30 17:27:36 -0800267}
268
Colin Crossfc754582016-05-17 16:34:16 -0700269type nameProperties struct {
270 // The name of the module. Must be unique across all modules.
Nan Zhang0007d812017-11-07 10:57:05 -0800271 Name *string
Colin Crossfc754582016-05-17 16:34:16 -0700272}
273
274type commonProperties struct {
Dan Willemsen0effe062015-11-30 16:06:01 -0800275 // emit build rules for this module
276 Enabled *bool `android:"arch_variant"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800277
Paul Duffin2e61fa62019-03-28 14:10:57 +0000278 // Controls the visibility of this module to other modules. Allowable values are one or more of
279 // these formats:
280 //
281 // ["//visibility:public"]: Anyone can use this module.
282 // ["//visibility:private"]: Only rules in the module's package (not its subpackages) can use
283 // this module.
284 // ["//some/package:__pkg__", "//other/package:__pkg__"]: Only modules in some/package and
285 // other/package (defined in some/package/*.bp and other/package/*.bp) have access to
286 // this module. Note that sub-packages do not have access to the rule; for example,
287 // //some/package/foo:bar or //other/package/testing:bla wouldn't have access. __pkg__
288 // is a special module and must be used verbatim. It represents all of the modules in the
289 // package.
290 // ["//project:__subpackages__", "//other:__subpackages__"]: Only modules in packages project
291 // or other or in one of their sub-packages have access to this module. For example,
292 // //project:rule, //project/library:lib or //other/testing/internal:munge are allowed
293 // to depend on this rule (but not //independent:evil)
294 // ["//project"]: This is shorthand for ["//project:__pkg__"]
295 // [":__subpackages__"]: This is shorthand for ["//project:__subpackages__"] where
296 // //project is the module's package. e.g. using [":__subpackages__"] in
297 // packages/apps/Settings/Android.bp is equivalent to
298 // //packages/apps/Settings:__subpackages__.
299 // ["//visibility:legacy_public"]: The default visibility, behaves as //visibility:public
300 // for now. It is an error if it is used in a module.
Paul Duffine2453c72019-05-31 14:00:04 +0100301 //
302 // If a module does not specify the `visibility` property then it uses the
303 // `default_visibility` property of the `package` module in the module's package.
304 //
305 // If the `default_visibility` property is not set for the module's package then
Paul Duffine484f472019-06-20 16:38:08 +0100306 // it will use the `default_visibility` of its closest ancestor package for which
307 // a `default_visibility` property is specified.
308 //
309 // If no `default_visibility` property can be found then the module uses the
310 // global default of `//visibility:legacy_public`.
Paul Duffine2453c72019-05-31 14:00:04 +0100311 //
Paul Duffin95d53b52019-07-24 13:45:05 +0100312 // The `visibility` property has no effect on a defaults module although it does
313 // apply to any non-defaults module that uses it. To set the visibility of a
314 // defaults module, use the `defaults_visibility` property on the defaults module;
315 // not to be confused with the `default_visibility` property on the package module.
316 //
Paul Duffin2e61fa62019-03-28 14:10:57 +0000317 // See https://android.googlesource.com/platform/build/soong/+/master/README.md#visibility for
318 // more details.
319 Visibility []string
320
Colin Cross7d5136f2015-05-11 13:39:40 -0700321 // control whether this module compiles for 32-bit, 64-bit, or both. Possible values
Colin Cross3f40fa42015-01-30 17:27:36 -0800322 // are "32" (compile for 32-bit only), "64" (compile for 64-bit only), "both" (compile for both
323 // architectures), or "first" (compile for 64-bit on a 64-bit platform, and 32-bit on a 32-bit
324 // platform
Colin Cross7d716ba2017-11-01 10:38:29 -0700325 Compile_multilib *string `android:"arch_variant"`
Colin Cross69617d32016-09-06 10:39:07 -0700326
327 Target struct {
328 Host struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700329 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700330 }
331 Android struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700332 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700333 }
334 }
335
Colin Crossee0bc3b2018-10-02 22:01:37 -0700336 UseTargetVariants bool `blueprint:"mutated"`
337 Default_multilib string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800338
Dan Willemsen782a2d12015-12-21 14:55:28 -0800339 // whether this is a proprietary vendor module, and should be installed into /vendor
Colin Cross7d716ba2017-11-01 10:38:29 -0700340 Proprietary *bool
Dan Willemsen782a2d12015-12-21 14:55:28 -0800341
Colin Cross55708f32017-03-20 13:23:34 -0700342 // vendor who owns this module
Dan Willemsenefac4a82017-07-18 19:42:09 -0700343 Owner *string
Colin Cross55708f32017-03-20 13:23:34 -0700344
Jiyong Park2db76922017-11-08 16:03:48 +0900345 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
346 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
347 // Use `soc_specific` instead for better meaning.
Colin Cross7d716ba2017-11-01 10:38:29 -0700348 Vendor *bool
Dan Willemsenaa118f92017-04-06 12:49:58 -0700349
Jiyong Park2db76922017-11-08 16:03:48 +0900350 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
351 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
352 Soc_specific *bool
353
354 // whether this module is specific to a device, not only for SoC, but also for off-chip
355 // peripherals. When set to true, it is installed into /odm (or /vendor/odm if odm partition
356 // does not exist, or /system/vendor/odm if both odm and vendor partitions do not exist).
357 // This implies `soc_specific:true`.
358 Device_specific *bool
359
360 // whether this module is specific to a software configuration of a product (e.g. country,
Jaekyun Seok5cfbfbb2018-01-10 19:00:15 +0900361 // network operator, etc). When set to true, it is installed into /product (or
362 // /system/product if product partition does not exist).
Jiyong Park2db76922017-11-08 16:03:48 +0900363 Product_specific *bool
364
Justin Yund5f6c822019-06-25 16:47:17 +0900365 // whether this module extends system. When set to true, it is installed into /system_ext
366 // (or /system/system_ext if system_ext partition does not exist).
367 System_ext_specific *bool
368
Jiyong Parkf9332f12018-02-01 00:54:12 +0900369 // Whether this module is installed to recovery partition
370 Recovery *bool
371
dimitry1f33e402019-03-26 12:39:31 +0100372 // Whether this module is built for non-native architecures (also known as native bridge binary)
373 Native_bridge_supported *bool `android:"arch_variant"`
374
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700375 // init.rc files to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800376 Init_rc []string `android:"path"`
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700377
Steven Moreland57a23d22018-04-04 15:42:19 -0700378 // VINTF manifest fragments to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800379 Vintf_fragments []string `android:"path"`
Steven Moreland57a23d22018-04-04 15:42:19 -0700380
Chris Wolfe998306e2016-08-15 14:47:23 -0400381 // names of other modules to install if this module is installed
Colin Crossc602b7d2017-05-05 13:36:36 -0700382 Required []string `android:"arch_variant"`
Chris Wolfe998306e2016-08-15 14:47:23 -0400383
Sasha Smundakb6d23052019-04-01 18:37:36 -0700384 // names of other modules to install on host if this module is installed
385 Host_required []string `android:"arch_variant"`
386
387 // names of other modules to install on target if this module is installed
388 Target_required []string `android:"arch_variant"`
389
Colin Cross5aac3622017-08-31 15:07:09 -0700390 // relative path to a file to include in the list of notices for the device
Colin Cross27b922f2019-03-04 22:35:41 -0800391 Notice *string `android:"path"`
Colin Cross5aac3622017-08-31 15:07:09 -0700392
Dan Willemsen569edc52018-11-19 09:33:29 -0800393 Dist struct {
394 // copy the output of this module to the $DIST_DIR when `dist` is specified on the
395 // command line and any of these targets are also on the command line, or otherwise
396 // built
397 Targets []string `android:"arch_variant"`
398
399 // The name of the output artifact. This defaults to the basename of the output of
400 // the module.
401 Dest *string `android:"arch_variant"`
402
403 // The directory within the dist directory to store the artifact. Defaults to the
404 // top level directory ("").
405 Dir *string `android:"arch_variant"`
406
407 // A suffix to add to the artifact file name (before any extension).
408 Suffix *string `android:"arch_variant"`
409 } `android:"arch_variant"`
410
Colin Crossa1ad8d12016-06-01 17:09:44 -0700411 // Set by TargetMutator
Colin Crossa195f912019-10-16 11:07:20 -0700412 CompileOS OsType `blueprint:"mutated"`
Colin Crossee0bc3b2018-10-02 22:01:37 -0700413 CompileTarget Target `blueprint:"mutated"`
414 CompileMultiTargets []Target `blueprint:"mutated"`
415 CompilePrimary bool `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800416
417 // Set by InitAndroidModule
418 HostOrDeviceSupported HostOrDeviceSupported `blueprint:"mutated"`
Dan Willemsen0b24c742016-10-04 15:13:37 -0700419 ArchSpecific bool `blueprint:"mutated"`
Colin Crossce75d2c2016-10-06 16:12:58 -0700420
421 SkipInstall bool `blueprint:"mutated"`
Jeff Gaston088e29e2017-11-29 16:47:17 -0800422
423 NamespaceExportedToMake bool `blueprint:"mutated"`
Colin Cross6c4f21f2019-06-06 15:41:36 -0700424
425 MissingDeps []string `blueprint:"mutated"`
Colin Cross9a362232019-07-01 15:32:45 -0700426
427 // Name and variant strings stored by mutators to enable Module.String()
428 DebugName string `blueprint:"mutated"`
429 DebugMutators []string `blueprint:"mutated"`
430 DebugVariations []string `blueprint:"mutated"`
Colin Cross7228ecd2019-11-18 16:00:16 -0800431
432 // set by ImageMutator
433 ImageVariation string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800434}
435
436type hostAndDeviceProperties struct {
Colin Cross4e81d702018-11-09 10:36:55 -0800437 // If set to true, build a variant of the module for the host. Defaults to false.
438 Host_supported *bool
439
440 // If set to true, build a variant of the module for the device. Defaults to true.
Colin Crossa4190c12016-07-12 13:11:25 -0700441 Device_supported *bool
Colin Cross3f40fa42015-01-30 17:27:36 -0800442}
443
Colin Crossc472d572015-03-17 15:06:21 -0700444type Multilib string
445
446const (
Colin Cross6b4a32d2017-12-05 13:42:45 -0800447 MultilibBoth Multilib = "both"
448 MultilibFirst Multilib = "first"
449 MultilibCommon Multilib = "common"
450 MultilibCommonFirst Multilib = "common_first"
451 MultilibDefault Multilib = ""
Colin Crossc472d572015-03-17 15:06:21 -0700452)
453
Colin Crossa1ad8d12016-06-01 17:09:44 -0700454type HostOrDeviceSupported int
455
456const (
457 _ HostOrDeviceSupported = iota
Dan Albert0981b5c2018-08-02 13:46:35 -0700458
459 // Host and HostCross are built by default. Device is not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700460 HostSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700461
462 // Host is built by default. HostCross and Device are not supported.
Dan Albertc6345fb2016-10-20 01:36:11 -0700463 HostSupportedNoCross
Dan Albert0981b5c2018-08-02 13:46:35 -0700464
465 // Device is built by default. Host and HostCross are not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700466 DeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700467
468 // Device is built by default. Host and HostCross are supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700469 HostAndDeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700470
471 // Host, HostCross, and Device are built by default.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700472 HostAndDeviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700473
474 // Nothing is supported. This is not exposed to the user, but used to mark a
475 // host only module as unsupported when the module type is not supported on
476 // the host OS. E.g. benchmarks are supported on Linux but not Darwin.
Dan Willemsen0b24c742016-10-04 15:13:37 -0700477 NeitherHostNorDeviceSupported
Colin Crossa1ad8d12016-06-01 17:09:44 -0700478)
479
Jiyong Park2db76922017-11-08 16:03:48 +0900480type moduleKind int
481
482const (
483 platformModule moduleKind = iota
484 deviceSpecificModule
485 socSpecificModule
486 productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900487 systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900488)
489
490func (k moduleKind) String() string {
491 switch k {
492 case platformModule:
493 return "platform"
494 case deviceSpecificModule:
495 return "device-specific"
496 case socSpecificModule:
497 return "soc-specific"
498 case productSpecificModule:
499 return "product-specific"
Justin Yund5f6c822019-06-25 16:47:17 +0900500 case systemExtSpecificModule:
501 return "systemext-specific"
Jiyong Park2db76922017-11-08 16:03:48 +0900502 default:
503 panic(fmt.Errorf("unknown module kind %d", k))
504 }
505}
506
Colin Cross36242852017-06-23 15:06:31 -0700507func InitAndroidModule(m Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800508 base := m.base()
509 base.module = m
Colin Cross5049f022015-03-18 13:28:46 -0700510
Colin Cross36242852017-06-23 15:06:31 -0700511 m.AddProperties(
Colin Crossfc754582016-05-17 16:34:16 -0700512 &base.nameProperties,
Colin Cross18c46802019-09-24 22:19:02 -0700513 &base.commonProperties)
514
515 // Allow tests to override the default product variables
516 if base.variableProperties == nil {
517 base.variableProperties = zeroProductVariables
518 }
519
520 // Filter the product variables properties to the ones that exist on this module
521 base.variableProperties = createVariableProperties(m.GetProperties(), base.variableProperties)
522 if base.variableProperties != nil {
523 m.AddProperties(base.variableProperties)
524 }
525
Colin Crossa3a97412019-03-18 12:24:29 -0700526 base.generalProperties = m.GetProperties()
Pirama Arumuga Nainar955dc492018-04-17 14:58:42 -0700527 base.customizableProperties = m.GetProperties()
Paul Duffin63c6e182019-07-24 14:24:38 +0100528
529 // The default_visibility property needs to be checked and parsed by the visibility module during
530 // its checking and parsing phases.
531 base.primaryVisibilityProperty =
532 newVisibilityProperty("visibility", &base.commonProperties.Visibility)
533 base.visibilityPropertyInfo = []visibilityProperty{base.primaryVisibilityProperty}
Colin Cross5049f022015-03-18 13:28:46 -0700534}
535
Colin Cross36242852017-06-23 15:06:31 -0700536func InitAndroidArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
537 InitAndroidModule(m)
Colin Cross5049f022015-03-18 13:28:46 -0700538
539 base := m.base()
Colin Cross3f40fa42015-01-30 17:27:36 -0800540 base.commonProperties.HostOrDeviceSupported = hod
Colin Cross69617d32016-09-06 10:39:07 -0700541 base.commonProperties.Default_multilib = string(defaultMultilib)
Dan Willemsen0b24c742016-10-04 15:13:37 -0700542 base.commonProperties.ArchSpecific = true
Colin Crossee0bc3b2018-10-02 22:01:37 -0700543 base.commonProperties.UseTargetVariants = true
Colin Cross3f40fa42015-01-30 17:27:36 -0800544
Dan Willemsen218f6562015-07-08 18:13:11 -0700545 switch hod {
Nan Zhang1a0f09b2017-07-05 10:35:11 -0700546 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Cross36242852017-06-23 15:06:31 -0700547 m.AddProperties(&base.hostAndDeviceProperties)
Colin Cross3f40fa42015-01-30 17:27:36 -0800548 }
549
Colin Cross36242852017-06-23 15:06:31 -0700550 InitArchModule(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800551}
552
Colin Crossee0bc3b2018-10-02 22:01:37 -0700553func InitAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
554 InitAndroidArchModule(m, hod, defaultMultilib)
555 m.base().commonProperties.UseTargetVariants = false
556}
557
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800558// A ModuleBase object contains the properties that are common to all Android
Colin Cross3f40fa42015-01-30 17:27:36 -0800559// modules. It should be included as an anonymous field in every module
560// struct definition. InitAndroidModule should then be called from the module's
561// factory function, and the return values from InitAndroidModule should be
562// returned from the factory function.
563//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800564// The ModuleBase type is responsible for implementing the GenerateBuildActions
565// method to support the blueprint.Module interface. This method will then call
566// the module's GenerateAndroidBuildActions method once for each build variant
Colin Cross25de6c32019-06-06 14:29:25 -0700567// that is to be built. GenerateAndroidBuildActions is passed a ModuleContext
568// rather than the usual blueprint.ModuleContext.
569// ModuleContext exposes extra functionality specific to the Android build
Colin Cross3f40fa42015-01-30 17:27:36 -0800570// system including details about the particular build variant that is to be
571// generated.
572//
573// For example:
574//
575// import (
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800576// "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -0800577// )
578//
579// type myModule struct {
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800580// android.ModuleBase
Colin Cross3f40fa42015-01-30 17:27:36 -0800581// properties struct {
582// MyProperty string
583// }
584// }
585//
Colin Cross36242852017-06-23 15:06:31 -0700586// func NewMyModule() android.Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800587// m := &myModule{}
Colin Cross36242852017-06-23 15:06:31 -0700588// m.AddProperties(&m.properties)
589// android.InitAndroidModule(m)
590// return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800591// }
592//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800593// func (m *myModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800594// // Get the CPU architecture for the current build variant.
595// variantArch := ctx.Arch()
596//
597// // ...
598// }
Colin Cross635c3b02016-05-18 15:37:25 -0700599type ModuleBase struct {
Colin Cross3f40fa42015-01-30 17:27:36 -0800600 // Putting the curiously recurring thing pointing to the thing that contains
601 // the thing pattern to good use.
Colin Cross36242852017-06-23 15:06:31 -0700602 // TODO: remove this
Colin Cross635c3b02016-05-18 15:37:25 -0700603 module Module
Colin Cross3f40fa42015-01-30 17:27:36 -0800604
Colin Crossfc754582016-05-17 16:34:16 -0700605 nameProperties nameProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800606 commonProperties commonProperties
Colin Cross18c46802019-09-24 22:19:02 -0700607 variableProperties interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800608 hostAndDeviceProperties hostAndDeviceProperties
609 generalProperties []interface{}
Colin Crossc17727d2018-10-24 12:42:09 -0700610 archProperties [][]interface{}
Colin Crossa120ec12016-08-19 16:07:38 -0700611 customizableProperties []interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800612
Paul Duffin63c6e182019-07-24 14:24:38 +0100613 // Information about all the properties on the module that contains visibility rules that need
614 // checking.
615 visibilityPropertyInfo []visibilityProperty
616
617 // The primary visibility property, may be nil, that controls access to the module.
618 primaryVisibilityProperty visibilityProperty
619
Colin Cross3f40fa42015-01-30 17:27:36 -0800620 noAddressSanitizer bool
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700621 installFiles Paths
622 checkbuildFiles Paths
Jiyong Park52818fc2019-03-18 12:01:38 +0900623 noticeFile OptionalPath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700624
625 // Used by buildTargetSingleton to create checkbuild and per-directory build targets
626 // Only set on the final variant of each module
Colin Cross0875c522017-11-28 17:34:01 -0800627 installTarget WritablePath
628 checkbuildTarget WritablePath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700629 blueprintDir string
Colin Crossa120ec12016-08-19 16:07:38 -0700630
Colin Cross178a5092016-09-13 13:42:32 -0700631 hooks hooks
Colin Cross36242852017-06-23 15:06:31 -0700632
633 registerProps []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700634
635 // For tests
Colin Crossae887032017-10-23 17:16:14 -0700636 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800637 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800638 variables map[string]string
Colin Crossa9d8bee2018-10-02 13:59:46 -0700639
640 prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool
Colin Cross36242852017-06-23 15:06:31 -0700641}
642
Colin Cross4157e882019-06-06 16:57:04 -0700643func (m *ModuleBase) DepsMutator(BottomUpMutatorContext) {}
Colin Cross5f692ec2019-02-01 16:53:07 -0800644
Colin Cross4157e882019-06-06 16:57:04 -0700645func (m *ModuleBase) AddProperties(props ...interface{}) {
646 m.registerProps = append(m.registerProps, props...)
Colin Cross36242852017-06-23 15:06:31 -0700647}
648
Colin Cross4157e882019-06-06 16:57:04 -0700649func (m *ModuleBase) GetProperties() []interface{} {
650 return m.registerProps
Colin Cross3f40fa42015-01-30 17:27:36 -0800651}
652
Colin Cross4157e882019-06-06 16:57:04 -0700653func (m *ModuleBase) BuildParamsForTests() []BuildParams {
654 return m.buildParams
Colin Crosscec81712017-07-13 14:43:27 -0700655}
656
Colin Cross4157e882019-06-06 16:57:04 -0700657func (m *ModuleBase) RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams {
658 return m.ruleParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800659}
660
Colin Cross4157e882019-06-06 16:57:04 -0700661func (m *ModuleBase) VariablesForTests() map[string]string {
662 return m.variables
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800663}
664
Colin Cross4157e882019-06-06 16:57:04 -0700665func (m *ModuleBase) Prefer32(prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool) {
666 m.prefer32 = prefer32
Colin Crossa9d8bee2018-10-02 13:59:46 -0700667}
668
Colin Crossce75d2c2016-10-06 16:12:58 -0700669// Name returns the name of the module. It may be overridden by individual module types, for
670// example prebuilts will prepend prebuilt_ to the name.
Colin Cross4157e882019-06-06 16:57:04 -0700671func (m *ModuleBase) Name() string {
672 return String(m.nameProperties.Name)
Colin Crossfc754582016-05-17 16:34:16 -0700673}
674
Colin Cross9a362232019-07-01 15:32:45 -0700675// String returns a string that includes the module name and variants for printing during debugging.
676func (m *ModuleBase) String() string {
677 sb := strings.Builder{}
678 sb.WriteString(m.commonProperties.DebugName)
679 sb.WriteString("{")
680 for i := range m.commonProperties.DebugMutators {
681 if i != 0 {
682 sb.WriteString(",")
683 }
684 sb.WriteString(m.commonProperties.DebugMutators[i])
685 sb.WriteString(":")
686 sb.WriteString(m.commonProperties.DebugVariations[i])
687 }
688 sb.WriteString("}")
689 return sb.String()
690}
691
Colin Crossce75d2c2016-10-06 16:12:58 -0700692// BaseModuleName returns the name of the module as specified in the blueprints file.
Colin Cross4157e882019-06-06 16:57:04 -0700693func (m *ModuleBase) BaseModuleName() string {
694 return String(m.nameProperties.Name)
Colin Crossce75d2c2016-10-06 16:12:58 -0700695}
696
Colin Cross4157e882019-06-06 16:57:04 -0700697func (m *ModuleBase) base() *ModuleBase {
698 return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800699}
700
Paul Duffine2453c72019-05-31 14:00:04 +0100701func (m *ModuleBase) qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName {
702 return qualifiedModuleName{pkg: ctx.ModuleDir(), name: ctx.ModuleName()}
703}
704
705func (m *ModuleBase) visibilityProperties() []visibilityProperty {
Paul Duffin63c6e182019-07-24 14:24:38 +0100706 return m.visibilityPropertyInfo
707}
708
709func (m *ModuleBase) visibility() []string {
710 // The soong_namespace module does not initialize the primaryVisibilityProperty.
711 if m.primaryVisibilityProperty != nil {
712 return m.primaryVisibilityProperty.getStrings()
713 } else {
714 return nil
Paul Duffine2453c72019-05-31 14:00:04 +0100715 }
716}
717
Colin Cross4157e882019-06-06 16:57:04 -0700718func (m *ModuleBase) Target() Target {
719 return m.commonProperties.CompileTarget
Dan Willemsen490fd492015-11-24 17:53:15 -0800720}
721
Colin Cross4157e882019-06-06 16:57:04 -0700722func (m *ModuleBase) TargetPrimary() bool {
723 return m.commonProperties.CompilePrimary
Colin Cross8b74d172016-09-13 09:59:14 -0700724}
725
Colin Cross4157e882019-06-06 16:57:04 -0700726func (m *ModuleBase) MultiTargets() []Target {
727 return m.commonProperties.CompileMultiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -0700728}
729
Colin Cross4157e882019-06-06 16:57:04 -0700730func (m *ModuleBase) Os() OsType {
731 return m.Target().Os
Dan Willemsen490fd492015-11-24 17:53:15 -0800732}
733
Colin Cross4157e882019-06-06 16:57:04 -0700734func (m *ModuleBase) Host() bool {
735 return m.Os().Class == Host || m.Os().Class == HostCross
Dan Willemsen97750522016-02-09 17:43:51 -0800736}
737
Colin Cross4157e882019-06-06 16:57:04 -0700738func (m *ModuleBase) Arch() Arch {
739 return m.Target().Arch
Dan Willemsen97750522016-02-09 17:43:51 -0800740}
741
Colin Cross4157e882019-06-06 16:57:04 -0700742func (m *ModuleBase) ArchSpecific() bool {
743 return m.commonProperties.ArchSpecific
Dan Willemsen0b24c742016-10-04 15:13:37 -0700744}
745
Colin Cross4157e882019-06-06 16:57:04 -0700746func (m *ModuleBase) OsClassSupported() []OsClass {
747 switch m.commonProperties.HostOrDeviceSupported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700748 case HostSupported:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700749 return []OsClass{Host, HostCross}
Dan Albertc6345fb2016-10-20 01:36:11 -0700750 case HostSupportedNoCross:
751 return []OsClass{Host}
Colin Crossa1ad8d12016-06-01 17:09:44 -0700752 case DeviceSupported:
753 return []OsClass{Device}
Dan Albert0981b5c2018-08-02 13:46:35 -0700754 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700755 var supported []OsClass
Colin Cross4157e882019-06-06 16:57:04 -0700756 if Bool(m.hostAndDeviceProperties.Host_supported) ||
757 (m.commonProperties.HostOrDeviceSupported == HostAndDeviceDefault &&
758 m.hostAndDeviceProperties.Host_supported == nil) {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700759 supported = append(supported, Host, HostCross)
760 }
Colin Cross4157e882019-06-06 16:57:04 -0700761 if m.hostAndDeviceProperties.Device_supported == nil ||
762 *m.hostAndDeviceProperties.Device_supported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700763 supported = append(supported, Device)
764 }
765 return supported
766 default:
767 return nil
768 }
Colin Cross3f40fa42015-01-30 17:27:36 -0800769}
770
Colin Cross4157e882019-06-06 16:57:04 -0700771func (m *ModuleBase) DeviceSupported() bool {
772 return m.commonProperties.HostOrDeviceSupported == DeviceSupported ||
773 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
774 (m.hostAndDeviceProperties.Device_supported == nil ||
775 *m.hostAndDeviceProperties.Device_supported)
Colin Cross3f40fa42015-01-30 17:27:36 -0800776}
777
Paul Duffine44358f2019-11-26 18:04:12 +0000778func (m *ModuleBase) HostSupported() bool {
779 return m.commonProperties.HostOrDeviceSupported == HostSupported ||
780 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
781 (m.hostAndDeviceProperties.Host_supported != nil &&
782 *m.hostAndDeviceProperties.Host_supported)
783}
784
Colin Cross4157e882019-06-06 16:57:04 -0700785func (m *ModuleBase) Platform() bool {
Justin Yund5f6c822019-06-25 16:47:17 +0900786 return !m.DeviceSpecific() && !m.SocSpecific() && !m.ProductSpecific() && !m.SystemExtSpecific()
Jiyong Parkc678ad32018-04-10 13:07:10 +0900787}
788
Colin Cross4157e882019-06-06 16:57:04 -0700789func (m *ModuleBase) DeviceSpecific() bool {
790 return Bool(m.commonProperties.Device_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900791}
792
Colin Cross4157e882019-06-06 16:57:04 -0700793func (m *ModuleBase) SocSpecific() bool {
794 return Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900795}
796
Colin Cross4157e882019-06-06 16:57:04 -0700797func (m *ModuleBase) ProductSpecific() bool {
798 return Bool(m.commonProperties.Product_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900799}
800
Justin Yund5f6c822019-06-25 16:47:17 +0900801func (m *ModuleBase) SystemExtSpecific() bool {
802 return Bool(m.commonProperties.System_ext_specific)
Dario Frenifd05a742018-05-29 13:28:54 +0100803}
804
Colin Cross4157e882019-06-06 16:57:04 -0700805func (m *ModuleBase) Enabled() bool {
806 if m.commonProperties.Enabled == nil {
807 return !m.Os().DefaultDisabled
Dan Willemsen490fd492015-11-24 17:53:15 -0800808 }
Colin Cross4157e882019-06-06 16:57:04 -0700809 return *m.commonProperties.Enabled
Colin Cross3f40fa42015-01-30 17:27:36 -0800810}
811
Colin Cross4157e882019-06-06 16:57:04 -0700812func (m *ModuleBase) SkipInstall() {
813 m.commonProperties.SkipInstall = true
Colin Crossce75d2c2016-10-06 16:12:58 -0700814}
815
Colin Cross4157e882019-06-06 16:57:04 -0700816func (m *ModuleBase) ExportedToMake() bool {
817 return m.commonProperties.NamespaceExportedToMake
Jiyong Park374510b2018-03-19 18:23:01 +0900818}
819
Colin Cross4157e882019-06-06 16:57:04 -0700820func (m *ModuleBase) computeInstallDeps(
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700821 ctx blueprint.ModuleContext) Paths {
Colin Cross3f40fa42015-01-30 17:27:36 -0800822
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700823 result := Paths{}
Colin Cross6b753602018-06-21 13:03:07 -0700824 // TODO(ccross): we need to use WalkDeps and have some way to know which dependencies require installation
Colin Cross3f40fa42015-01-30 17:27:36 -0800825 ctx.VisitDepsDepthFirstIf(isFileInstaller,
826 func(m blueprint.Module) {
827 fileInstaller := m.(fileInstaller)
828 files := fileInstaller.filesToInstall()
829 result = append(result, files...)
830 })
831
832 return result
833}
834
Colin Cross4157e882019-06-06 16:57:04 -0700835func (m *ModuleBase) filesToInstall() Paths {
836 return m.installFiles
Colin Cross3f40fa42015-01-30 17:27:36 -0800837}
838
Colin Cross4157e882019-06-06 16:57:04 -0700839func (m *ModuleBase) NoAddressSanitizer() bool {
840 return m.noAddressSanitizer
Colin Cross3f40fa42015-01-30 17:27:36 -0800841}
842
Colin Cross4157e882019-06-06 16:57:04 -0700843func (m *ModuleBase) InstallInData() bool {
Dan Willemsen782a2d12015-12-21 14:55:28 -0800844 return false
845}
846
Jaewoong Jung0949f312019-09-11 10:25:18 -0700847func (m *ModuleBase) InstallInTestcases() bool {
848 return false
849}
850
Colin Cross4157e882019-06-06 16:57:04 -0700851func (m *ModuleBase) InstallInSanitizerDir() bool {
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700852 return false
853}
854
Colin Cross4157e882019-06-06 16:57:04 -0700855func (m *ModuleBase) InstallInRecovery() bool {
856 return Bool(m.commonProperties.Recovery)
Jiyong Parkf9332f12018-02-01 00:54:12 +0900857}
858
Colin Cross90ba5f42019-10-02 11:10:58 -0700859func (m *ModuleBase) InstallInRoot() bool {
860 return false
861}
862
Colin Cross607d8582019-07-29 16:44:46 -0700863func (m *ModuleBase) InstallBypassMake() bool {
864 return false
865}
866
Colin Cross4157e882019-06-06 16:57:04 -0700867func (m *ModuleBase) Owner() string {
868 return String(m.commonProperties.Owner)
Sundong Ahn4fd04bb2018-08-31 18:01:37 +0900869}
870
Colin Cross4157e882019-06-06 16:57:04 -0700871func (m *ModuleBase) NoticeFile() OptionalPath {
872 return m.noticeFile
Jiyong Park52818fc2019-03-18 12:01:38 +0900873}
874
Colin Cross7228ecd2019-11-18 16:00:16 -0800875func (m *ModuleBase) setImageVariation(variant string) {
876 m.commonProperties.ImageVariation = variant
877}
878
879func (m *ModuleBase) ImageVariation() blueprint.Variation {
880 return blueprint.Variation{
881 Mutator: "image",
882 Variation: m.base().commonProperties.ImageVariation,
883 }
884}
885
886func (m *ModuleBase) InRecovery() bool {
887 return m.base().commonProperties.ImageVariation == RecoveryVariation
888}
889
Colin Cross4157e882019-06-06 16:57:04 -0700890func (m *ModuleBase) generateModuleTarget(ctx ModuleContext) {
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700891 allInstalledFiles := Paths{}
892 allCheckbuildFiles := Paths{}
Colin Cross0875c522017-11-28 17:34:01 -0800893 ctx.VisitAllModuleVariants(func(module Module) {
894 a := module.base()
Colin Crossc9404352015-03-26 16:10:12 -0700895 allInstalledFiles = append(allInstalledFiles, a.installFiles...)
896 allCheckbuildFiles = append(allCheckbuildFiles, a.checkbuildFiles...)
Colin Cross3f40fa42015-01-30 17:27:36 -0800897 })
898
Colin Cross0875c522017-11-28 17:34:01 -0800899 var deps Paths
Colin Cross9454bfa2015-03-17 13:24:18 -0700900
Jeff Gaston088e29e2017-11-29 16:47:17 -0800901 namespacePrefix := ctx.Namespace().(*Namespace).id
902 if namespacePrefix != "" {
903 namespacePrefix = namespacePrefix + "-"
904 }
905
Colin Cross3f40fa42015-01-30 17:27:36 -0800906 if len(allInstalledFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -0800907 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-install")
Colin Cross0875c522017-11-28 17:34:01 -0800908 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -0700909 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -0800910 Output: name,
911 Implicits: allInstalledFiles,
Colin Crossaabf6792017-11-29 00:27:14 -0800912 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross9454bfa2015-03-17 13:24:18 -0700913 })
914 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -0700915 m.installTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -0700916 }
917
918 if len(allCheckbuildFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -0800919 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-checkbuild")
Colin Cross0875c522017-11-28 17:34:01 -0800920 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -0700921 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -0800922 Output: name,
923 Implicits: allCheckbuildFiles,
Colin Cross9454bfa2015-03-17 13:24:18 -0700924 })
925 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -0700926 m.checkbuildTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -0700927 }
928
929 if len(deps) > 0 {
Dan Willemsen5ba07e82015-12-11 13:51:06 -0800930 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -0800931 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -0800932 suffix = "-soong"
933 }
934
Jeff Gaston088e29e2017-11-29 16:47:17 -0800935 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+suffix)
Colin Cross0875c522017-11-28 17:34:01 -0800936 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -0700937 Rule: blueprint.Phony,
Jeff Gaston088e29e2017-11-29 16:47:17 -0800938 Outputs: []WritablePath{name},
Colin Cross9454bfa2015-03-17 13:24:18 -0700939 Implicits: deps,
Colin Cross3f40fa42015-01-30 17:27:36 -0800940 })
Colin Cross1f8c52b2015-06-16 16:38:17 -0700941
Colin Cross4157e882019-06-06 16:57:04 -0700942 m.blueprintDir = ctx.ModuleDir()
Colin Cross3f40fa42015-01-30 17:27:36 -0800943 }
944}
945
Colin Cross4157e882019-06-06 16:57:04 -0700946func determineModuleKind(m *ModuleBase, ctx blueprint.BaseModuleContext) moduleKind {
947 var socSpecific = Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
948 var deviceSpecific = Bool(m.commonProperties.Device_specific)
949 var productSpecific = Bool(m.commonProperties.Product_specific)
Justin Yund5f6c822019-06-25 16:47:17 +0900950 var systemExtSpecific = Bool(m.commonProperties.System_ext_specific)
Jiyong Park2db76922017-11-08 16:03:48 +0900951
Dario Frenifd05a742018-05-29 13:28:54 +0100952 msg := "conflicting value set here"
953 if socSpecific && deviceSpecific {
954 ctx.PropertyErrorf("device_specific", "a module cannot be specific to SoC and device at the same time.")
Colin Cross4157e882019-06-06 16:57:04 -0700955 if Bool(m.commonProperties.Vendor) {
Jiyong Park2db76922017-11-08 16:03:48 +0900956 ctx.PropertyErrorf("vendor", msg)
957 }
Colin Cross4157e882019-06-06 16:57:04 -0700958 if Bool(m.commonProperties.Proprietary) {
Jiyong Park2db76922017-11-08 16:03:48 +0900959 ctx.PropertyErrorf("proprietary", msg)
960 }
Colin Cross4157e882019-06-06 16:57:04 -0700961 if Bool(m.commonProperties.Soc_specific) {
Jiyong Park2db76922017-11-08 16:03:48 +0900962 ctx.PropertyErrorf("soc_specific", msg)
963 }
964 }
965
Justin Yund5f6c822019-06-25 16:47:17 +0900966 if productSpecific && systemExtSpecific {
967 ctx.PropertyErrorf("product_specific", "a module cannot be specific to product and system_ext at the same time.")
968 ctx.PropertyErrorf("system_ext_specific", msg)
Dario Frenifd05a742018-05-29 13:28:54 +0100969 }
970
Justin Yund5f6c822019-06-25 16:47:17 +0900971 if (socSpecific || deviceSpecific) && (productSpecific || systemExtSpecific) {
Dario Frenifd05a742018-05-29 13:28:54 +0100972 if productSpecific {
973 ctx.PropertyErrorf("product_specific", "a module cannot be specific to SoC or device and product at the same time.")
974 } else {
Justin Yund5f6c822019-06-25 16:47:17 +0900975 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 +0100976 }
977 if deviceSpecific {
978 ctx.PropertyErrorf("device_specific", msg)
979 } else {
Colin Cross4157e882019-06-06 16:57:04 -0700980 if Bool(m.commonProperties.Vendor) {
Dario Frenifd05a742018-05-29 13:28:54 +0100981 ctx.PropertyErrorf("vendor", msg)
982 }
Colin Cross4157e882019-06-06 16:57:04 -0700983 if Bool(m.commonProperties.Proprietary) {
Dario Frenifd05a742018-05-29 13:28:54 +0100984 ctx.PropertyErrorf("proprietary", msg)
985 }
Colin Cross4157e882019-06-06 16:57:04 -0700986 if Bool(m.commonProperties.Soc_specific) {
Dario Frenifd05a742018-05-29 13:28:54 +0100987 ctx.PropertyErrorf("soc_specific", msg)
988 }
989 }
990 }
991
Jiyong Park2db76922017-11-08 16:03:48 +0900992 if productSpecific {
993 return productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900994 } else if systemExtSpecific {
995 return systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900996 } else if deviceSpecific {
997 return deviceSpecificModule
998 } else if socSpecific {
999 return socSpecificModule
1000 } else {
1001 return platformModule
1002 }
1003}
1004
Colin Cross0ea8ba82019-06-06 14:33:29 -07001005func (m *ModuleBase) baseModuleContextFactory(ctx blueprint.BaseModuleContext) baseModuleContext {
1006 return baseModuleContext{
1007 BaseModuleContext: ctx,
1008 target: m.commonProperties.CompileTarget,
1009 targetPrimary: m.commonProperties.CompilePrimary,
1010 multiTargets: m.commonProperties.CompileMultiTargets,
1011 kind: determineModuleKind(m, ctx),
1012 config: ctx.Config().(Config),
Colin Cross3f40fa42015-01-30 17:27:36 -08001013 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001014}
1015
Colin Cross4157e882019-06-06 16:57:04 -07001016func (m *ModuleBase) GenerateBuildActions(blueprintCtx blueprint.ModuleContext) {
Colin Cross25de6c32019-06-06 14:29:25 -07001017 ctx := &moduleContext{
Colin Cross0ea8ba82019-06-06 14:33:29 -07001018 module: m.module,
Colin Crossdc35e212019-06-06 16:13:11 -07001019 bp: blueprintCtx,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001020 baseModuleContext: m.baseModuleContextFactory(blueprintCtx),
1021 installDeps: m.computeInstallDeps(blueprintCtx),
1022 installFiles: m.installFiles,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001023 variables: make(map[string]string),
Colin Cross3f40fa42015-01-30 17:27:36 -08001024 }
1025
Colin Cross6c4f21f2019-06-06 15:41:36 -07001026 // Temporarily continue to call blueprintCtx.GetMissingDependencies() to maintain the previous behavior of never
1027 // reporting missing dependency errors in Blueprint when AllowMissingDependencies == true.
1028 // TODO: This will be removed once defaults modules handle missing dependency errors
1029 blueprintCtx.GetMissingDependencies()
1030
Colin Crossdc35e212019-06-06 16:13:11 -07001031 // For the final GenerateAndroidBuildActions pass, require that all visited dependencies Soong modules and
1032 // are enabled.
1033 ctx.baseModuleContext.strictVisitDeps = true
1034
Colin Cross4c83e5c2019-02-25 14:54:28 -08001035 if ctx.config.captureBuild {
1036 ctx.ruleParams = make(map[blueprint.Rule]blueprint.RuleParams)
1037 }
1038
Colin Cross67a5c132017-05-09 13:45:28 -07001039 desc := "//" + ctx.ModuleDir() + ":" + ctx.ModuleName() + " "
1040 var suffix []string
Colin Cross0875c522017-11-28 17:34:01 -08001041 if ctx.Os().Class != Device && ctx.Os().Class != Generic {
1042 suffix = append(suffix, ctx.Os().String())
Colin Cross67a5c132017-05-09 13:45:28 -07001043 }
Colin Cross0875c522017-11-28 17:34:01 -08001044 if !ctx.PrimaryArch() {
1045 suffix = append(suffix, ctx.Arch().ArchType.String())
Colin Cross67a5c132017-05-09 13:45:28 -07001046 }
1047
1048 ctx.Variable(pctx, "moduleDesc", desc)
1049
1050 s := ""
1051 if len(suffix) > 0 {
1052 s = " [" + strings.Join(suffix, " ") + "]"
1053 }
1054 ctx.Variable(pctx, "moduleDescSuffix", s)
1055
Dan Willemsen569edc52018-11-19 09:33:29 -08001056 // Some common property checks for properties that will be used later in androidmk.go
Colin Cross4157e882019-06-06 16:57:04 -07001057 if m.commonProperties.Dist.Dest != nil {
1058 _, err := validateSafePath(*m.commonProperties.Dist.Dest)
Dan Willemsen569edc52018-11-19 09:33:29 -08001059 if err != nil {
1060 ctx.PropertyErrorf("dist.dest", "%s", err.Error())
1061 }
1062 }
Colin Cross4157e882019-06-06 16:57:04 -07001063 if m.commonProperties.Dist.Dir != nil {
1064 _, err := validateSafePath(*m.commonProperties.Dist.Dir)
Dan Willemsen569edc52018-11-19 09:33:29 -08001065 if err != nil {
1066 ctx.PropertyErrorf("dist.dir", "%s", err.Error())
1067 }
1068 }
Colin Cross4157e882019-06-06 16:57:04 -07001069 if m.commonProperties.Dist.Suffix != nil {
1070 if strings.Contains(*m.commonProperties.Dist.Suffix, "/") {
Dan Willemsen569edc52018-11-19 09:33:29 -08001071 ctx.PropertyErrorf("dist.suffix", "Suffix may not contain a '/' character.")
1072 }
1073 }
1074
Colin Cross4157e882019-06-06 16:57:04 -07001075 if m.Enabled() {
Jooyung Hand48f3c32019-08-23 11:18:57 +09001076 // ensure all direct android.Module deps are enabled
1077 ctx.VisitDirectDepsBlueprint(func(bm blueprint.Module) {
1078 if _, ok := bm.(Module); ok {
1079 ctx.validateAndroidModule(bm, ctx.baseModuleContext.strictVisitDeps)
1080 }
1081 })
1082
Colin Cross4157e882019-06-06 16:57:04 -07001083 notice := proptools.StringDefault(m.commonProperties.Notice, "NOTICE")
1084 if module := SrcIsModule(notice); module != "" {
1085 m.noticeFile = ctx.ExpandOptionalSource(&notice, "notice")
Jiyong Park52818fc2019-03-18 12:01:38 +09001086 } else {
1087 noticePath := filepath.Join(ctx.ModuleDir(), notice)
Colin Cross4157e882019-06-06 16:57:04 -07001088 m.noticeFile = ExistentPathForSource(ctx, noticePath)
Jaewoong Jung62707f72018-11-16 13:26:43 -08001089 }
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001090
1091 m.module.GenerateAndroidBuildActions(ctx)
1092 if ctx.Failed() {
1093 return
1094 }
1095
1096 m.installFiles = append(m.installFiles, ctx.installFiles...)
1097 m.checkbuildFiles = append(m.checkbuildFiles, ctx.checkbuildFiles...)
Colin Crossdc35e212019-06-06 16:13:11 -07001098 } else if ctx.Config().AllowMissingDependencies() {
1099 // If the module is not enabled it will not create any build rules, nothing will call
1100 // ctx.GetMissingDependencies(), and blueprint will consider the missing dependencies to be unhandled
1101 // and report them as an error even when AllowMissingDependencies = true. Call
1102 // ctx.GetMissingDependencies() here to tell blueprint not to handle them.
1103 ctx.GetMissingDependencies()
Colin Cross3f40fa42015-01-30 17:27:36 -08001104 }
1105
Colin Cross4157e882019-06-06 16:57:04 -07001106 if m == ctx.FinalModule().(Module).base() {
1107 m.generateModuleTarget(ctx)
Colin Cross9b1d13d2016-09-19 15:18:11 -07001108 if ctx.Failed() {
1109 return
1110 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001111 }
Colin Crosscec81712017-07-13 14:43:27 -07001112
Colin Cross4157e882019-06-06 16:57:04 -07001113 m.buildParams = ctx.buildParams
1114 m.ruleParams = ctx.ruleParams
1115 m.variables = ctx.variables
Colin Cross3f40fa42015-01-30 17:27:36 -08001116}
1117
Colin Cross0ea8ba82019-06-06 14:33:29 -07001118type baseModuleContext struct {
1119 blueprint.BaseModuleContext
Colin Cross8b74d172016-09-13 09:59:14 -07001120 target Target
Colin Crossee0bc3b2018-10-02 22:01:37 -07001121 multiTargets []Target
Colin Cross8b74d172016-09-13 09:59:14 -07001122 targetPrimary bool
1123 debug bool
Jiyong Park2db76922017-11-08 16:03:48 +09001124 kind moduleKind
Colin Cross8b74d172016-09-13 09:59:14 -07001125 config Config
Colin Crossdc35e212019-06-06 16:13:11 -07001126
1127 walkPath []Module
1128
1129 strictVisitDeps bool // If true, enforce that all dependencies are enabled
Colin Crossf6566ed2015-03-24 11:13:38 -07001130}
1131
Colin Cross25de6c32019-06-06 14:29:25 -07001132type moduleContext struct {
Colin Crossdc35e212019-06-06 16:13:11 -07001133 bp blueprint.ModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -07001134 baseModuleContext
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001135 installDeps Paths
1136 installFiles Paths
1137 checkbuildFiles Paths
Colin Cross8d8f8e22016-08-03 11:57:50 -07001138 module Module
Colin Crosscec81712017-07-13 14:43:27 -07001139
1140 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001141 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001142 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001143 variables map[string]string
Colin Cross6ff51382015-12-17 16:39:19 -08001144}
1145
Colin Crossb88b3c52019-06-10 15:15:17 -07001146func (m *moduleContext) ninjaError(params BuildParams, err error) (PackageContext, BuildParams) {
1147 return pctx, BuildParams{
Colin Cross4b69c492019-06-07 13:06:06 -07001148 Rule: ErrorRule,
1149 Description: params.Description,
1150 Output: params.Output,
1151 Outputs: params.Outputs,
1152 ImplicitOutput: params.ImplicitOutput,
1153 ImplicitOutputs: params.ImplicitOutputs,
Colin Cross6ff51382015-12-17 16:39:19 -08001154 Args: map[string]string{
1155 "error": err.Error(),
1156 },
Colin Crossb88b3c52019-06-10 15:15:17 -07001157 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001158}
1159
Colin Cross25de6c32019-06-06 14:29:25 -07001160func (m *moduleContext) ModuleBuild(pctx PackageContext, params ModuleBuildParams) {
1161 m.Build(pctx, BuildParams(params))
Colin Cross3f40fa42015-01-30 17:27:36 -08001162}
1163
Colin Cross0875c522017-11-28 17:34:01 -08001164func convertBuildParams(params BuildParams) blueprint.BuildParams {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001165 bparams := blueprint.BuildParams{
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001166 Rule: params.Rule,
Colin Cross0875c522017-11-28 17:34:01 -08001167 Description: params.Description,
Colin Cross33bfb0a2016-11-21 17:23:08 -08001168 Deps: params.Deps,
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001169 Outputs: params.Outputs.Strings(),
1170 ImplicitOutputs: params.ImplicitOutputs.Strings(),
1171 Inputs: params.Inputs.Strings(),
1172 Implicits: params.Implicits.Strings(),
1173 OrderOnly: params.OrderOnly.Strings(),
1174 Args: params.Args,
1175 Optional: !params.Default,
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001176 }
1177
Colin Cross33bfb0a2016-11-21 17:23:08 -08001178 if params.Depfile != nil {
1179 bparams.Depfile = params.Depfile.String()
1180 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001181 if params.Output != nil {
1182 bparams.Outputs = append(bparams.Outputs, params.Output.String())
1183 }
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001184 if params.ImplicitOutput != nil {
1185 bparams.ImplicitOutputs = append(bparams.ImplicitOutputs, params.ImplicitOutput.String())
1186 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001187 if params.Input != nil {
1188 bparams.Inputs = append(bparams.Inputs, params.Input.String())
1189 }
1190 if params.Implicit != nil {
1191 bparams.Implicits = append(bparams.Implicits, params.Implicit.String())
1192 }
1193
Colin Cross0b9f31f2019-02-28 11:00:01 -08001194 bparams.Outputs = proptools.NinjaEscapeList(bparams.Outputs)
1195 bparams.ImplicitOutputs = proptools.NinjaEscapeList(bparams.ImplicitOutputs)
1196 bparams.Inputs = proptools.NinjaEscapeList(bparams.Inputs)
1197 bparams.Implicits = proptools.NinjaEscapeList(bparams.Implicits)
1198 bparams.OrderOnly = proptools.NinjaEscapeList(bparams.OrderOnly)
1199 bparams.Depfile = proptools.NinjaEscapeList([]string{bparams.Depfile})[0]
Colin Crossfe4bc362018-09-12 10:02:13 -07001200
Colin Cross0875c522017-11-28 17:34:01 -08001201 return bparams
1202}
1203
Colin Cross25de6c32019-06-06 14:29:25 -07001204func (m *moduleContext) Variable(pctx PackageContext, name, value string) {
1205 if m.config.captureBuild {
1206 m.variables[name] = value
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001207 }
1208
Colin Crossdc35e212019-06-06 16:13:11 -07001209 m.bp.Variable(pctx.PackageContext, name, value)
Colin Cross0875c522017-11-28 17:34:01 -08001210}
1211
Colin Cross25de6c32019-06-06 14:29:25 -07001212func (m *moduleContext) Rule(pctx PackageContext, name string, params blueprint.RuleParams,
Colin Cross0875c522017-11-28 17:34:01 -08001213 argNames ...string) blueprint.Rule {
1214
Ramy Medhatdd0418a2019-11-04 18:16:11 -05001215 if (m.config.UseGoma() || m.config.UseRBE()) && params.Pool == nil {
1216 // When USE_GOMA=true or USE_RBE=true are set and the rule is not supported by goma/RBE, restrict
1217 // jobs to the local parallelism value
Colin Cross2e2dbc22019-09-25 13:31:46 -07001218 params.Pool = localPool
1219 }
1220
Colin Crossdc35e212019-06-06 16:13:11 -07001221 rule := m.bp.Rule(pctx.PackageContext, name, params, argNames...)
Colin Cross4c83e5c2019-02-25 14:54:28 -08001222
Colin Cross25de6c32019-06-06 14:29:25 -07001223 if m.config.captureBuild {
1224 m.ruleParams[rule] = params
Colin Cross4c83e5c2019-02-25 14:54:28 -08001225 }
1226
1227 return rule
Colin Cross0875c522017-11-28 17:34:01 -08001228}
1229
Colin Cross25de6c32019-06-06 14:29:25 -07001230func (m *moduleContext) Build(pctx PackageContext, params BuildParams) {
Colin Crossb88b3c52019-06-10 15:15:17 -07001231 if params.Description != "" {
1232 params.Description = "${moduleDesc}" + params.Description + "${moduleDescSuffix}"
1233 }
1234
1235 if missingDeps := m.GetMissingDependencies(); len(missingDeps) > 0 {
1236 pctx, params = m.ninjaError(params, fmt.Errorf("module %s missing dependencies: %s\n",
1237 m.ModuleName(), strings.Join(missingDeps, ", ")))
1238 }
1239
Colin Cross25de6c32019-06-06 14:29:25 -07001240 if m.config.captureBuild {
1241 m.buildParams = append(m.buildParams, params)
Colin Cross0875c522017-11-28 17:34:01 -08001242 }
1243
Colin Crossdc35e212019-06-06 16:13:11 -07001244 m.bp.Build(pctx.PackageContext, convertBuildParams(params))
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001245}
1246
Colin Crossdc35e212019-06-06 16:13:11 -07001247func (b *baseModuleContext) Module() Module {
1248 module, _ := b.BaseModuleContext.Module().(Module)
1249 return module
1250}
1251
1252func (b *baseModuleContext) Config() Config {
1253 return b.BaseModuleContext.Config().(Config)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001254}
1255
Colin Cross25de6c32019-06-06 14:29:25 -07001256func (m *moduleContext) GetMissingDependencies() []string {
Colin Cross6c4f21f2019-06-06 15:41:36 -07001257 var missingDeps []string
1258 missingDeps = append(missingDeps, m.Module().base().commonProperties.MissingDeps...)
Colin Crossdc35e212019-06-06 16:13:11 -07001259 missingDeps = append(missingDeps, m.bp.GetMissingDependencies()...)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001260 missingDeps = FirstUniqueStrings(missingDeps)
1261 return missingDeps
Colin Cross6ff51382015-12-17 16:39:19 -08001262}
1263
Colin Crossdc35e212019-06-06 16:13:11 -07001264func (b *baseModuleContext) AddMissingDependencies(deps []string) {
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001265 if deps != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001266 missingDeps := &b.Module().base().commonProperties.MissingDeps
Colin Cross6c4f21f2019-06-06 15:41:36 -07001267 *missingDeps = append(*missingDeps, deps...)
1268 *missingDeps = FirstUniqueStrings(*missingDeps)
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001269 }
1270}
1271
Colin Crossdc35e212019-06-06 16:13:11 -07001272func (b *baseModuleContext) validateAndroidModule(module blueprint.Module, strict bool) Module {
Colin Crossd11fcda2017-10-23 17:59:01 -07001273 aModule, _ := module.(Module)
Colin Crossdc35e212019-06-06 16:13:11 -07001274
1275 if !strict {
1276 return aModule
1277 }
1278
Colin Cross380c69a2019-06-10 17:49:58 +00001279 if aModule == nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001280 b.ModuleErrorf("module %q not an android module", b.OtherModuleName(module))
Colin Cross380c69a2019-06-10 17:49:58 +00001281 return nil
1282 }
1283
1284 if !aModule.Enabled() {
Colin Crossdc35e212019-06-06 16:13:11 -07001285 if b.Config().AllowMissingDependencies() {
1286 b.AddMissingDependencies([]string{b.OtherModuleName(aModule)})
Colin Cross380c69a2019-06-10 17:49:58 +00001287 } else {
Colin Crossdc35e212019-06-06 16:13:11 -07001288 b.ModuleErrorf("depends on disabled module %q", b.OtherModuleName(aModule))
Colin Cross380c69a2019-06-10 17:49:58 +00001289 }
1290 return nil
1291 }
Colin Crossd11fcda2017-10-23 17:59:01 -07001292 return aModule
1293}
1294
Colin Crossdc35e212019-06-06 16:13:11 -07001295func (b *baseModuleContext) getDirectDepInternal(name string, tag blueprint.DependencyTag) (blueprint.Module, blueprint.DependencyTag) {
Jiyong Parkf2976302019-04-17 21:47:37 +09001296 type dep struct {
1297 mod blueprint.Module
1298 tag blueprint.DependencyTag
1299 }
1300 var deps []dep
Colin Crossdc35e212019-06-06 16:13:11 -07001301 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001302 if aModule, _ := module.(Module); aModule != nil && aModule.base().BaseModuleName() == name {
Colin Crossdc35e212019-06-06 16:13:11 -07001303 returnedTag := b.BaseModuleContext.OtherModuleDependencyTag(aModule)
Jiyong Parkf2976302019-04-17 21:47:37 +09001304 if tag == nil || returnedTag == tag {
1305 deps = append(deps, dep{aModule, returnedTag})
1306 }
1307 }
1308 })
1309 if len(deps) == 1 {
1310 return deps[0].mod, deps[0].tag
1311 } else if len(deps) >= 2 {
1312 panic(fmt.Errorf("Multiple dependencies having same BaseModuleName() %q found from %q",
Colin Crossdc35e212019-06-06 16:13:11 -07001313 name, b.ModuleName()))
Jiyong Parkf2976302019-04-17 21:47:37 +09001314 } else {
1315 return nil, nil
1316 }
1317}
1318
Colin Crossdc35e212019-06-06 16:13:11 -07001319func (b *baseModuleContext) GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module {
Colin Cross0ef08162019-05-01 15:50:51 -07001320 var deps []Module
Colin Crossdc35e212019-06-06 16:13:11 -07001321 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001322 if aModule, _ := module.(Module); aModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001323 if b.BaseModuleContext.OtherModuleDependencyTag(aModule) == tag {
Colin Cross0ef08162019-05-01 15:50:51 -07001324 deps = append(deps, aModule)
1325 }
1326 }
1327 })
1328 return deps
1329}
1330
Colin Cross25de6c32019-06-06 14:29:25 -07001331func (m *moduleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1332 module, _ := m.getDirectDepInternal(name, tag)
1333 return module
Jiyong Parkf2976302019-04-17 21:47:37 +09001334}
1335
Colin Crossdc35e212019-06-06 16:13:11 -07001336func (b *baseModuleContext) GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag) {
1337 return b.getDirectDepInternal(name, nil)
Jiyong Parkf2976302019-04-17 21:47:37 +09001338}
1339
Colin Crossdc35e212019-06-06 16:13:11 -07001340func (b *baseModuleContext) VisitDirectDepsBlueprint(visit func(blueprint.Module)) {
1341 b.BaseModuleContext.VisitDirectDeps(visit)
Colin Cross35143d02017-11-16 00:11:20 -08001342}
1343
Colin Crossdc35e212019-06-06 16:13:11 -07001344func (b *baseModuleContext) VisitDirectDeps(visit func(Module)) {
1345 b.BaseModuleContext.VisitDirectDeps(func(module blueprint.Module) {
1346 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001347 visit(aModule)
1348 }
1349 })
1350}
1351
Colin Crossdc35e212019-06-06 16:13:11 -07001352func (b *baseModuleContext) VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module)) {
1353 b.BaseModuleContext.VisitDirectDeps(func(module blueprint.Module) {
1354 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
1355 if b.BaseModuleContext.OtherModuleDependencyTag(aModule) == tag {
Colin Crossee6143c2017-12-30 17:54:27 -08001356 visit(aModule)
1357 }
1358 }
1359 })
1360}
1361
Colin Crossdc35e212019-06-06 16:13:11 -07001362func (b *baseModuleContext) VisitDirectDepsIf(pred func(Module) bool, visit func(Module)) {
1363 b.BaseModuleContext.VisitDirectDepsIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001364 // pred
1365 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001366 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001367 return pred(aModule)
1368 } else {
1369 return false
1370 }
1371 },
1372 // visit
1373 func(module blueprint.Module) {
1374 visit(module.(Module))
1375 })
1376}
1377
Colin Crossdc35e212019-06-06 16:13:11 -07001378func (b *baseModuleContext) VisitDepsDepthFirst(visit func(Module)) {
1379 b.BaseModuleContext.VisitDepsDepthFirst(func(module blueprint.Module) {
1380 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001381 visit(aModule)
1382 }
1383 })
1384}
1385
Colin Crossdc35e212019-06-06 16:13:11 -07001386func (b *baseModuleContext) VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module)) {
1387 b.BaseModuleContext.VisitDepsDepthFirstIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001388 // pred
1389 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001390 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001391 return pred(aModule)
1392 } else {
1393 return false
1394 }
1395 },
1396 // visit
1397 func(module blueprint.Module) {
1398 visit(module.(Module))
1399 })
1400}
1401
Colin Crossdc35e212019-06-06 16:13:11 -07001402func (b *baseModuleContext) WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool) {
1403 b.BaseModuleContext.WalkDeps(visit)
Alex Light778127a2019-02-27 14:19:50 -08001404}
1405
Colin Crossdc35e212019-06-06 16:13:11 -07001406func (b *baseModuleContext) WalkDeps(visit func(Module, Module) bool) {
1407 b.walkPath = []Module{b.Module()}
1408 b.BaseModuleContext.WalkDeps(func(child, parent blueprint.Module) bool {
1409 childAndroidModule, _ := child.(Module)
1410 parentAndroidModule, _ := parent.(Module)
Colin Crossd11fcda2017-10-23 17:59:01 -07001411 if childAndroidModule != nil && parentAndroidModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001412 // record walkPath before visit
1413 for b.walkPath[len(b.walkPath)-1] != parentAndroidModule {
1414 b.walkPath = b.walkPath[0 : len(b.walkPath)-1]
1415 }
1416 b.walkPath = append(b.walkPath, childAndroidModule)
Colin Crossd11fcda2017-10-23 17:59:01 -07001417 return visit(childAndroidModule, parentAndroidModule)
1418 } else {
1419 return false
1420 }
1421 })
1422}
1423
Colin Crossdc35e212019-06-06 16:13:11 -07001424func (b *baseModuleContext) GetWalkPath() []Module {
1425 return b.walkPath
1426}
1427
Colin Cross25de6c32019-06-06 14:29:25 -07001428func (m *moduleContext) VisitAllModuleVariants(visit func(Module)) {
Colin Crossdc35e212019-06-06 16:13:11 -07001429 m.bp.VisitAllModuleVariants(func(module blueprint.Module) {
Colin Cross0875c522017-11-28 17:34:01 -08001430 visit(module.(Module))
1431 })
1432}
1433
Colin Cross25de6c32019-06-06 14:29:25 -07001434func (m *moduleContext) PrimaryModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001435 return m.bp.PrimaryModule().(Module)
Colin Cross0875c522017-11-28 17:34:01 -08001436}
1437
Colin Cross25de6c32019-06-06 14:29:25 -07001438func (m *moduleContext) FinalModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001439 return m.bp.FinalModule().(Module)
1440}
1441
1442func (m *moduleContext) ModuleSubDir() string {
1443 return m.bp.ModuleSubDir()
Colin Cross0875c522017-11-28 17:34:01 -08001444}
1445
Colin Cross0ea8ba82019-06-06 14:33:29 -07001446func (b *baseModuleContext) Target() Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001447 return b.target
Colin Crossa1ad8d12016-06-01 17:09:44 -07001448}
1449
Colin Cross0ea8ba82019-06-06 14:33:29 -07001450func (b *baseModuleContext) TargetPrimary() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001451 return b.targetPrimary
Colin Cross8b74d172016-09-13 09:59:14 -07001452}
1453
Colin Cross0ea8ba82019-06-06 14:33:29 -07001454func (b *baseModuleContext) MultiTargets() []Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001455 return b.multiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07001456}
1457
Colin Cross0ea8ba82019-06-06 14:33:29 -07001458func (b *baseModuleContext) Arch() Arch {
Colin Cross25de6c32019-06-06 14:29:25 -07001459 return b.target.Arch
Colin Cross3f40fa42015-01-30 17:27:36 -08001460}
1461
Colin Cross0ea8ba82019-06-06 14:33:29 -07001462func (b *baseModuleContext) Os() OsType {
Colin Cross25de6c32019-06-06 14:29:25 -07001463 return b.target.Os
Dan Willemsen490fd492015-11-24 17:53:15 -08001464}
1465
Colin Cross0ea8ba82019-06-06 14:33:29 -07001466func (b *baseModuleContext) Host() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001467 return b.target.Os.Class == Host || b.target.Os.Class == HostCross
Colin Crossf6566ed2015-03-24 11:13:38 -07001468}
1469
Colin Cross0ea8ba82019-06-06 14:33:29 -07001470func (b *baseModuleContext) Device() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001471 return b.target.Os.Class == Device
Colin Crossf6566ed2015-03-24 11:13:38 -07001472}
1473
Colin Cross0ea8ba82019-06-06 14:33:29 -07001474func (b *baseModuleContext) Darwin() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001475 return b.target.Os == Darwin
Colin Cross0af4b842015-04-30 16:36:18 -07001476}
1477
Colin Cross0ea8ba82019-06-06 14:33:29 -07001478func (b *baseModuleContext) Fuchsia() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001479 return b.target.Os == Fuchsia
Doug Horn21b94272019-01-16 12:06:11 -08001480}
1481
Colin Cross0ea8ba82019-06-06 14:33:29 -07001482func (b *baseModuleContext) Windows() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001483 return b.target.Os == Windows
Colin Cross3edeee12017-04-04 12:59:48 -07001484}
1485
Colin Cross0ea8ba82019-06-06 14:33:29 -07001486func (b *baseModuleContext) Debug() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001487 return b.debug
Colin Crossf6566ed2015-03-24 11:13:38 -07001488}
1489
Colin Cross0ea8ba82019-06-06 14:33:29 -07001490func (b *baseModuleContext) PrimaryArch() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001491 if len(b.config.Targets[b.target.Os]) <= 1 {
Colin Cross67a5c132017-05-09 13:45:28 -07001492 return true
1493 }
Colin Cross25de6c32019-06-06 14:29:25 -07001494 return b.target.Arch.ArchType == b.config.Targets[b.target.Os][0].Arch.ArchType
Colin Cross1e7d3702016-08-24 15:25:47 -07001495}
1496
Colin Cross0ea8ba82019-06-06 14:33:29 -07001497func (b *baseModuleContext) AConfig() Config {
Colin Cross25de6c32019-06-06 14:29:25 -07001498 return b.config
Colin Cross1332b002015-04-07 17:11:30 -07001499}
1500
Colin Cross0ea8ba82019-06-06 14:33:29 -07001501func (b *baseModuleContext) DeviceConfig() DeviceConfig {
Colin Cross25de6c32019-06-06 14:29:25 -07001502 return DeviceConfig{b.config.deviceConfig}
Colin Cross9272ade2016-08-17 15:24:12 -07001503}
1504
Colin Cross0ea8ba82019-06-06 14:33:29 -07001505func (b *baseModuleContext) Platform() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001506 return b.kind == platformModule
Jiyong Park2db76922017-11-08 16:03:48 +09001507}
1508
Colin Cross0ea8ba82019-06-06 14:33:29 -07001509func (b *baseModuleContext) DeviceSpecific() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001510 return b.kind == deviceSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001511}
1512
Colin Cross0ea8ba82019-06-06 14:33:29 -07001513func (b *baseModuleContext) SocSpecific() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001514 return b.kind == socSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001515}
1516
Colin Cross0ea8ba82019-06-06 14:33:29 -07001517func (b *baseModuleContext) ProductSpecific() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001518 return b.kind == productSpecificModule
Dan Willemsen782a2d12015-12-21 14:55:28 -08001519}
1520
Justin Yund5f6c822019-06-25 16:47:17 +09001521func (b *baseModuleContext) SystemExtSpecific() bool {
1522 return b.kind == systemExtSpecificModule
Dario Frenifd05a742018-05-29 13:28:54 +01001523}
1524
Jiyong Park5baac542018-08-28 09:55:37 +09001525// Makes this module a platform module, i.e. not specific to soc, device,
Justin Yund5f6c822019-06-25 16:47:17 +09001526// product, or system_ext.
Colin Cross4157e882019-06-06 16:57:04 -07001527func (m *ModuleBase) MakeAsPlatform() {
1528 m.commonProperties.Vendor = boolPtr(false)
1529 m.commonProperties.Proprietary = boolPtr(false)
1530 m.commonProperties.Soc_specific = boolPtr(false)
1531 m.commonProperties.Product_specific = boolPtr(false)
Justin Yund5f6c822019-06-25 16:47:17 +09001532 m.commonProperties.System_ext_specific = boolPtr(false)
Jiyong Park5baac542018-08-28 09:55:37 +09001533}
1534
Colin Cross4157e882019-06-06 16:57:04 -07001535func (m *ModuleBase) EnableNativeBridgeSupportByDefault() {
1536 m.commonProperties.Native_bridge_supported = boolPtr(true)
dimitry03dc3f62019-05-09 14:07:34 +02001537}
1538
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001539func (m *ModuleBase) MakeAsSystemExt() {
Jooyung Han91df2082019-11-20 01:49:42 +09001540 m.commonProperties.Vendor = boolPtr(false)
1541 m.commonProperties.Proprietary = boolPtr(false)
1542 m.commonProperties.Soc_specific = boolPtr(false)
1543 m.commonProperties.Product_specific = boolPtr(false)
1544 m.commonProperties.System_ext_specific = boolPtr(true)
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001545}
1546
Jooyung Han344d5432019-08-23 11:17:39 +09001547// IsNativeBridgeSupported returns true if "native_bridge_supported" is explicitly set as "true"
1548func (m *ModuleBase) IsNativeBridgeSupported() bool {
1549 return proptools.Bool(m.commonProperties.Native_bridge_supported)
1550}
1551
Colin Cross25de6c32019-06-06 14:29:25 -07001552func (m *moduleContext) InstallInData() bool {
1553 return m.module.InstallInData()
Dan Willemsen782a2d12015-12-21 14:55:28 -08001554}
1555
Jaewoong Jung0949f312019-09-11 10:25:18 -07001556func (m *moduleContext) InstallInTestcases() bool {
1557 return m.module.InstallInTestcases()
1558}
1559
Colin Cross25de6c32019-06-06 14:29:25 -07001560func (m *moduleContext) InstallInSanitizerDir() bool {
1561 return m.module.InstallInSanitizerDir()
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001562}
1563
Colin Cross25de6c32019-06-06 14:29:25 -07001564func (m *moduleContext) InstallInRecovery() bool {
1565 return m.module.InstallInRecovery()
Jiyong Parkf9332f12018-02-01 00:54:12 +09001566}
1567
Colin Cross90ba5f42019-10-02 11:10:58 -07001568func (m *moduleContext) InstallInRoot() bool {
1569 return m.module.InstallInRoot()
1570}
1571
Colin Cross607d8582019-07-29 16:44:46 -07001572func (m *moduleContext) InstallBypassMake() bool {
1573 return m.module.InstallBypassMake()
1574}
1575
Colin Cross70dda7e2019-10-01 22:05:35 -07001576func (m *moduleContext) skipInstall(fullInstallPath InstallPath) bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001577 if m.module.base().commonProperties.SkipInstall {
Colin Cross893d8162017-04-26 17:34:03 -07001578 return true
1579 }
1580
Colin Cross3607f212018-05-07 15:28:05 -07001581 // We'll need a solution for choosing which of modules with the same name in different
1582 // namespaces to install. For now, reuse the list of namespaces exported to Make as the
1583 // list of namespaces to install in a Soong-only build.
Colin Cross25de6c32019-06-06 14:29:25 -07001584 if !m.module.base().commonProperties.NamespaceExportedToMake {
Colin Cross3607f212018-05-07 15:28:05 -07001585 return true
1586 }
1587
Colin Cross25de6c32019-06-06 14:29:25 -07001588 if m.Device() {
Colin Cross607d8582019-07-29 16:44:46 -07001589 if m.Config().EmbeddedInMake() && !m.InstallBypassMake() {
Colin Cross893d8162017-04-26 17:34:03 -07001590 return true
1591 }
1592
Colin Cross25de6c32019-06-06 14:29:25 -07001593 if m.Config().SkipMegaDeviceInstall(fullInstallPath.String()) {
Colin Cross893d8162017-04-26 17:34:03 -07001594 return true
1595 }
1596 }
1597
1598 return false
1599}
1600
Colin Cross70dda7e2019-10-01 22:05:35 -07001601func (m *moduleContext) InstallFile(installPath InstallPath, name string, srcPath Path,
1602 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001603 return m.installFile(installPath, name, srcPath, Cp, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001604}
1605
Colin Cross70dda7e2019-10-01 22:05:35 -07001606func (m *moduleContext) InstallExecutable(installPath InstallPath, name string, srcPath Path,
1607 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001608 return m.installFile(installPath, name, srcPath, CpExecutable, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001609}
1610
Colin Cross70dda7e2019-10-01 22:05:35 -07001611func (m *moduleContext) installFile(installPath InstallPath, name string, srcPath Path,
1612 rule blueprint.Rule, deps []Path) InstallPath {
Colin Cross35cec122015-04-02 14:37:16 -07001613
Colin Cross25de6c32019-06-06 14:29:25 -07001614 fullInstallPath := installPath.Join(m, name)
1615 m.module.base().hooks.runInstallHooks(m, fullInstallPath, false)
Colin Cross3f40fa42015-01-30 17:27:36 -08001616
Colin Cross25de6c32019-06-06 14:29:25 -07001617 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001618
Colin Cross25de6c32019-06-06 14:29:25 -07001619 deps = append(deps, m.installDeps...)
Colin Cross35cec122015-04-02 14:37:16 -07001620
Colin Cross89562dc2016-10-03 17:47:19 -07001621 var implicitDeps, orderOnlyDeps Paths
1622
Colin Cross25de6c32019-06-06 14:29:25 -07001623 if m.Host() {
Colin Cross89562dc2016-10-03 17:47:19 -07001624 // Installed host modules might be used during the build, depend directly on their
1625 // dependencies so their timestamp is updated whenever their dependency is updated
1626 implicitDeps = deps
1627 } else {
1628 orderOnlyDeps = deps
1629 }
1630
Colin Cross25de6c32019-06-06 14:29:25 -07001631 m.Build(pctx, BuildParams{
Colin Cross5c517922017-08-31 12:29:17 -07001632 Rule: rule,
Colin Cross67a5c132017-05-09 13:45:28 -07001633 Description: "install " + fullInstallPath.Base(),
1634 Output: fullInstallPath,
1635 Input: srcPath,
1636 Implicits: implicitDeps,
1637 OrderOnly: orderOnlyDeps,
Colin Cross25de6c32019-06-06 14:29:25 -07001638 Default: !m.Config().EmbeddedInMake(),
Dan Willemsen322acaf2016-01-12 23:07:05 -08001639 })
Colin Cross3f40fa42015-01-30 17:27:36 -08001640
Colin Cross25de6c32019-06-06 14:29:25 -07001641 m.installFiles = append(m.installFiles, fullInstallPath)
Dan Willemsen322acaf2016-01-12 23:07:05 -08001642 }
Colin Cross25de6c32019-06-06 14:29:25 -07001643 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross35cec122015-04-02 14:37:16 -07001644 return fullInstallPath
1645}
1646
Colin Cross70dda7e2019-10-01 22:05:35 -07001647func (m *moduleContext) InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001648 fullInstallPath := installPath.Join(m, name)
1649 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Colin Cross3854a602016-01-11 12:49:11 -08001650
Colin Cross25de6c32019-06-06 14:29:25 -07001651 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001652
Alex Lightfb4353d2019-01-17 13:57:45 -08001653 relPath, err := filepath.Rel(path.Dir(fullInstallPath.String()), srcPath.String())
1654 if err != nil {
1655 panic(fmt.Sprintf("Unable to generate symlink between %q and %q: %s", fullInstallPath.Base(), srcPath.Base(), err))
1656 }
Colin Cross25de6c32019-06-06 14:29:25 -07001657 m.Build(pctx, BuildParams{
Colin Cross67a5c132017-05-09 13:45:28 -07001658 Rule: Symlink,
1659 Description: "install symlink " + fullInstallPath.Base(),
1660 Output: fullInstallPath,
1661 OrderOnly: Paths{srcPath},
Colin Cross25de6c32019-06-06 14:29:25 -07001662 Default: !m.Config().EmbeddedInMake(),
Colin Cross12fc4972016-01-11 12:49:11 -08001663 Args: map[string]string{
Alex Lightfb4353d2019-01-17 13:57:45 -08001664 "fromPath": relPath,
Colin Cross12fc4972016-01-11 12:49:11 -08001665 },
1666 })
Colin Cross3854a602016-01-11 12:49:11 -08001667
Colin Cross25de6c32019-06-06 14:29:25 -07001668 m.installFiles = append(m.installFiles, fullInstallPath)
1669 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross12fc4972016-01-11 12:49:11 -08001670 }
Colin Cross3854a602016-01-11 12:49:11 -08001671 return fullInstallPath
1672}
1673
Jiyong Parkf1194352019-02-25 11:05:47 +09001674// installPath/name -> absPath where absPath might be a path that is available only at runtime
1675// (e.g. /apex/...)
Colin Cross70dda7e2019-10-01 22:05:35 -07001676func (m *moduleContext) InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001677 fullInstallPath := installPath.Join(m, name)
1678 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Jiyong Parkf1194352019-02-25 11:05:47 +09001679
Colin Cross25de6c32019-06-06 14:29:25 -07001680 if !m.skipInstall(fullInstallPath) {
1681 m.Build(pctx, BuildParams{
Jiyong Parkf1194352019-02-25 11:05:47 +09001682 Rule: Symlink,
1683 Description: "install symlink " + fullInstallPath.Base() + " -> " + absPath,
1684 Output: fullInstallPath,
Colin Cross25de6c32019-06-06 14:29:25 -07001685 Default: !m.Config().EmbeddedInMake(),
Jiyong Parkf1194352019-02-25 11:05:47 +09001686 Args: map[string]string{
1687 "fromPath": absPath,
1688 },
1689 })
1690
Colin Cross25de6c32019-06-06 14:29:25 -07001691 m.installFiles = append(m.installFiles, fullInstallPath)
Jiyong Parkf1194352019-02-25 11:05:47 +09001692 }
1693 return fullInstallPath
1694}
1695
Colin Cross25de6c32019-06-06 14:29:25 -07001696func (m *moduleContext) CheckbuildFile(srcPath Path) {
1697 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross3f40fa42015-01-30 17:27:36 -08001698}
1699
Colin Cross3f40fa42015-01-30 17:27:36 -08001700type fileInstaller interface {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001701 filesToInstall() Paths
Colin Cross3f40fa42015-01-30 17:27:36 -08001702}
1703
1704func isFileInstaller(m blueprint.Module) bool {
1705 _, ok := m.(fileInstaller)
1706 return ok
1707}
1708
1709func isAndroidModule(m blueprint.Module) bool {
Colin Cross635c3b02016-05-18 15:37:25 -07001710 _, ok := m.(Module)
Colin Cross3f40fa42015-01-30 17:27:36 -08001711 return ok
1712}
Colin Crossfce53272015-04-08 11:21:40 -07001713
Dan Willemsen2ef08f42015-06-30 18:15:24 -07001714func findStringInSlice(str string, slice []string) int {
1715 for i, s := range slice {
1716 if s == str {
1717 return i
Colin Crossfce53272015-04-08 11:21:40 -07001718 }
1719 }
Dan Willemsen2ef08f42015-06-30 18:15:24 -07001720 return -1
1721}
1722
Colin Cross41955e82019-05-29 14:40:35 -07001723// SrcIsModule decodes module references in the format ":name" into the module name, or empty string if the input
1724// was not a module reference.
1725func SrcIsModule(s string) (module string) {
Colin Cross068e0fe2016-12-13 15:23:47 -08001726 if len(s) > 1 && s[0] == ':' {
1727 return s[1:]
1728 }
1729 return ""
1730}
1731
Colin Cross41955e82019-05-29 14:40:35 -07001732// SrcIsModule decodes module references in the format ":name{.tag}" into the module name and tag, ":name" into the
1733// module name and an empty string for the tag, or empty strings if the input was not a module reference.
1734func SrcIsModuleWithTag(s string) (module, tag string) {
1735 if len(s) > 1 && s[0] == ':' {
1736 module = s[1:]
1737 if tagStart := strings.IndexByte(module, '{'); tagStart > 0 {
1738 if module[len(module)-1] == '}' {
1739 tag = module[tagStart+1 : len(module)-1]
1740 module = module[:tagStart]
1741 return module, tag
1742 }
1743 }
1744 return module, ""
1745 }
1746 return "", ""
Colin Cross068e0fe2016-12-13 15:23:47 -08001747}
1748
Colin Cross41955e82019-05-29 14:40:35 -07001749type sourceOrOutputDependencyTag struct {
1750 blueprint.BaseDependencyTag
1751 tag string
1752}
1753
1754func sourceOrOutputDepTag(tag string) blueprint.DependencyTag {
1755 return sourceOrOutputDependencyTag{tag: tag}
1756}
1757
1758var SourceDepTag = sourceOrOutputDepTag("")
Colin Cross068e0fe2016-12-13 15:23:47 -08001759
Colin Cross366938f2017-12-11 16:29:02 -08001760// Adds necessary dependencies to satisfy filegroup or generated sources modules listed in srcFiles
1761// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08001762//
1763// Deprecated: tag the property with `android:"path"` instead.
Colin Cross068e0fe2016-12-13 15:23:47 -08001764func ExtractSourcesDeps(ctx BottomUpMutatorContext, srcFiles []string) {
Nan Zhang2439eb72017-04-10 11:27:50 -07001765 set := make(map[string]bool)
1766
Colin Cross068e0fe2016-12-13 15:23:47 -08001767 for _, s := range srcFiles {
Colin Cross41955e82019-05-29 14:40:35 -07001768 if m, t := SrcIsModuleWithTag(s); m != "" {
1769 if _, found := set[s]; found {
1770 ctx.ModuleErrorf("found source dependency duplicate: %q!", s)
Nan Zhang2439eb72017-04-10 11:27:50 -07001771 } else {
Colin Cross41955e82019-05-29 14:40:35 -07001772 set[s] = true
1773 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Nan Zhang2439eb72017-04-10 11:27:50 -07001774 }
Colin Cross068e0fe2016-12-13 15:23:47 -08001775 }
1776 }
Colin Cross068e0fe2016-12-13 15:23:47 -08001777}
1778
Colin Cross366938f2017-12-11 16:29:02 -08001779// Adds necessary dependencies to satisfy filegroup or generated sources modules specified in s
1780// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08001781//
1782// Deprecated: tag the property with `android:"path"` instead.
Colin Cross366938f2017-12-11 16:29:02 -08001783func ExtractSourceDeps(ctx BottomUpMutatorContext, s *string) {
1784 if s != nil {
Colin Cross41955e82019-05-29 14:40:35 -07001785 if m, t := SrcIsModuleWithTag(*s); m != "" {
1786 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Colin Cross366938f2017-12-11 16:29:02 -08001787 }
1788 }
1789}
1790
Colin Cross41955e82019-05-29 14:40:35 -07001791// A module that implements SourceFileProducer can be referenced from any property that is tagged with `android:"path"`
1792// 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 -08001793type SourceFileProducer interface {
1794 Srcs() Paths
1795}
1796
Colin Cross41955e82019-05-29 14:40:35 -07001797// A module that implements OutputFileProducer can be referenced from any property that is tagged with `android:"path"`
Roland Levillain97c1f342019-11-22 14:20:54 +00001798// using the ":module" syntax or ":module{.tag}" syntax and provides a list of output files to be used as if they were
Colin Cross41955e82019-05-29 14:40:35 -07001799// listed in the property.
1800type OutputFileProducer interface {
1801 OutputFiles(tag string) (Paths, error)
1802}
1803
Colin Crossfe17f6f2019-03-28 19:30:56 -07001804type HostToolProvider interface {
1805 HostToolPath() OptionalPath
1806}
1807
Colin Cross27b922f2019-03-04 22:35:41 -08001808// Returns a list of paths expanded from globs and modules referenced using ":module" syntax. The property must
1809// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08001810//
1811// Deprecated: use PathsForModuleSrc or PathsForModuleSrcExcludes instead.
Colin Cross25de6c32019-06-06 14:29:25 -07001812func (m *moduleContext) ExpandSources(srcFiles, excludes []string) Paths {
1813 return PathsForModuleSrcExcludes(m, srcFiles, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07001814}
1815
Colin Cross2fafa3e2019-03-05 12:39:51 -08001816// Returns a single path expanded from globs and modules referenced using ":module" syntax. The property must
1817// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08001818//
1819// Deprecated: use PathForModuleSrc instead.
Colin Cross25de6c32019-06-06 14:29:25 -07001820func (m *moduleContext) ExpandSource(srcFile, prop string) Path {
1821 return PathForModuleSrc(m, srcFile)
Colin Cross2fafa3e2019-03-05 12:39:51 -08001822}
1823
1824// Returns an optional single path expanded from globs and modules referenced using ":module" syntax if
1825// the srcFile is non-nil. The property must be tagged with `android:"path" to support automatic source module
1826// dependency resolution.
Colin Cross25de6c32019-06-06 14:29:25 -07001827func (m *moduleContext) ExpandOptionalSource(srcFile *string, prop string) OptionalPath {
Colin Cross2fafa3e2019-03-05 12:39:51 -08001828 if srcFile != nil {
Colin Cross25de6c32019-06-06 14:29:25 -07001829 return OptionalPathForPath(PathForModuleSrc(m, *srcFile))
Colin Cross2fafa3e2019-03-05 12:39:51 -08001830 }
1831 return OptionalPath{}
1832}
1833
Colin Cross25de6c32019-06-06 14:29:25 -07001834func (m *moduleContext) RequiredModuleNames() []string {
1835 return m.module.base().commonProperties.Required
Nan Zhang6d34b302017-02-04 17:47:46 -08001836}
1837
Colin Cross25de6c32019-06-06 14:29:25 -07001838func (m *moduleContext) HostRequiredModuleNames() []string {
1839 return m.module.base().commonProperties.Host_required
Sasha Smundakb6d23052019-04-01 18:37:36 -07001840}
1841
Colin Cross25de6c32019-06-06 14:29:25 -07001842func (m *moduleContext) TargetRequiredModuleNames() []string {
1843 return m.module.base().commonProperties.Target_required
Sasha Smundakb6d23052019-04-01 18:37:36 -07001844}
1845
Colin Crossdc35e212019-06-06 16:13:11 -07001846func (b *baseModuleContext) Glob(globPattern string, excludes []string) Paths {
1847 ret, err := b.GlobWithDeps(globPattern, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07001848 if err != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001849 b.ModuleErrorf("glob: %s", err.Error())
Colin Cross8f101b42015-06-17 15:09:06 -07001850 }
Colin Crossdc35e212019-06-06 16:13:11 -07001851 return pathsForModuleSrcFromFullPath(b, ret, true)
Colin Crossfce53272015-04-08 11:21:40 -07001852}
Colin Cross1f8c52b2015-06-16 16:38:17 -07001853
Colin Crossdc35e212019-06-06 16:13:11 -07001854func (b *baseModuleContext) GlobFiles(globPattern string, excludes []string) Paths {
1855 ret, err := b.GlobWithDeps(globPattern, excludes)
Nan Zhang581fd212018-01-10 16:06:12 -08001856 if err != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001857 b.ModuleErrorf("glob: %s", err.Error())
Nan Zhang581fd212018-01-10 16:06:12 -08001858 }
Colin Crossdc35e212019-06-06 16:13:11 -07001859 return pathsForModuleSrcFromFullPath(b, ret, false)
Nan Zhang581fd212018-01-10 16:06:12 -08001860}
1861
Colin Cross463a90e2015-06-17 14:20:06 -07001862func init() {
Colin Cross798bfce2016-10-12 14:28:16 -07001863 RegisterSingletonType("buildtarget", BuildTargetSingleton)
Colin Cross463a90e2015-06-17 14:20:06 -07001864}
1865
Colin Cross0875c522017-11-28 17:34:01 -08001866func BuildTargetSingleton() Singleton {
Colin Cross1f8c52b2015-06-16 16:38:17 -07001867 return &buildTargetSingleton{}
1868}
1869
Colin Cross87d8b562017-04-25 10:01:55 -07001870func parentDir(dir string) string {
1871 dir, _ = filepath.Split(dir)
1872 return filepath.Clean(dir)
1873}
1874
Colin Cross1f8c52b2015-06-16 16:38:17 -07001875type buildTargetSingleton struct{}
1876
Colin Cross0875c522017-11-28 17:34:01 -08001877func (c *buildTargetSingleton) GenerateBuildActions(ctx SingletonContext) {
1878 var checkbuildDeps Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07001879
Colin Cross0875c522017-11-28 17:34:01 -08001880 mmTarget := func(dir string) WritablePath {
1881 return PathForPhony(ctx,
1882 "MODULES-IN-"+strings.Replace(filepath.Clean(dir), "/", "-", -1))
Colin Cross87d8b562017-04-25 10:01:55 -07001883 }
1884
Colin Cross0875c522017-11-28 17:34:01 -08001885 modulesInDir := make(map[string]Paths)
Colin Cross1f8c52b2015-06-16 16:38:17 -07001886
Colin Cross0875c522017-11-28 17:34:01 -08001887 ctx.VisitAllModules(func(module Module) {
1888 blueprintDir := module.base().blueprintDir
1889 installTarget := module.base().installTarget
1890 checkbuildTarget := module.base().checkbuildTarget
Colin Cross1f8c52b2015-06-16 16:38:17 -07001891
Colin Cross0875c522017-11-28 17:34:01 -08001892 if checkbuildTarget != nil {
1893 checkbuildDeps = append(checkbuildDeps, checkbuildTarget)
1894 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], checkbuildTarget)
1895 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07001896
Colin Cross0875c522017-11-28 17:34:01 -08001897 if installTarget != nil {
1898 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], installTarget)
Colin Cross1f8c52b2015-06-16 16:38:17 -07001899 }
1900 })
1901
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001902 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08001903 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001904 suffix = "-soong"
1905 }
1906
Colin Cross1f8c52b2015-06-16 16:38:17 -07001907 // Create a top-level checkbuild target that depends on all modules
Colin Cross0875c522017-11-28 17:34:01 -08001908 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07001909 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001910 Output: PathForPhony(ctx, "checkbuild"+suffix),
Colin Cross1f8c52b2015-06-16 16:38:17 -07001911 Implicits: checkbuildDeps,
Colin Cross1f8c52b2015-06-16 16:38:17 -07001912 })
1913
Dan Willemsend2e95fb2017-09-20 14:30:50 -07001914 // Make will generate the MODULES-IN-* targets
Colin Crossaabf6792017-11-29 00:27:14 -08001915 if ctx.Config().EmbeddedInMake() {
Dan Willemsend2e95fb2017-09-20 14:30:50 -07001916 return
1917 }
1918
Colin Cross87d8b562017-04-25 10:01:55 -07001919 // Ensure ancestor directories are in modulesInDir
Inseob Kim1a365c62019-06-08 15:47:51 +09001920 dirs := SortedStringKeys(modulesInDir)
Colin Cross87d8b562017-04-25 10:01:55 -07001921 for _, dir := range dirs {
1922 dir := parentDir(dir)
1923 for dir != "." && dir != "/" {
1924 if _, exists := modulesInDir[dir]; exists {
1925 break
1926 }
1927 modulesInDir[dir] = nil
1928 dir = parentDir(dir)
1929 }
1930 }
1931
1932 // Make directories build their direct subdirectories
Colin Cross87d8b562017-04-25 10:01:55 -07001933 for _, dir := range dirs {
1934 p := parentDir(dir)
1935 if p != "." && p != "/" {
1936 modulesInDir[p] = append(modulesInDir[p], mmTarget(dir))
1937 }
1938 }
1939
Dan Willemsend2e95fb2017-09-20 14:30:50 -07001940 // Create a MODULES-IN-<directory> target that depends on all modules in a directory, and
1941 // depends on the MODULES-IN-* targets of all of its subdirectories that contain Android.bp
1942 // files.
Colin Cross1f8c52b2015-06-16 16:38:17 -07001943 for _, dir := range dirs {
Colin Cross0875c522017-11-28 17:34:01 -08001944 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07001945 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001946 Output: mmTarget(dir),
Colin Cross87d8b562017-04-25 10:01:55 -07001947 Implicits: modulesInDir[dir],
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001948 // HACK: checkbuild should be an optional build, but force it
1949 // enabled for now in standalone builds
Colin Crossaabf6792017-11-29 00:27:14 -08001950 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross1f8c52b2015-06-16 16:38:17 -07001951 })
1952 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07001953
1954 // Create (host|host-cross|target)-<OS> phony rules to build a reduced checkbuild.
1955 osDeps := map[OsType]Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08001956 ctx.VisitAllModules(func(module Module) {
1957 if module.Enabled() {
1958 os := module.Target().Os
1959 osDeps[os] = append(osDeps[os], module.base().checkbuildFiles...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07001960 }
1961 })
1962
Colin Cross0875c522017-11-28 17:34:01 -08001963 osClass := make(map[string]Paths)
Dan Willemsen61d88b82017-09-20 17:29:08 -07001964 for os, deps := range osDeps {
1965 var className string
1966
1967 switch os.Class {
1968 case Host:
1969 className = "host"
1970 case HostCross:
1971 className = "host-cross"
1972 case Device:
1973 className = "target"
1974 default:
1975 continue
1976 }
1977
Colin Cross0875c522017-11-28 17:34:01 -08001978 name := PathForPhony(ctx, className+"-"+os.Name)
Dan Willemsen61d88b82017-09-20 17:29:08 -07001979 osClass[className] = append(osClass[className], name)
1980
Colin Cross0875c522017-11-28 17:34:01 -08001981 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07001982 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001983 Output: name,
1984 Implicits: deps,
Dan Willemsen61d88b82017-09-20 17:29:08 -07001985 })
1986 }
1987
1988 // Wrap those into host|host-cross|target phony rules
Inseob Kim1a365c62019-06-08 15:47:51 +09001989 for _, class := range SortedStringKeys(osClass) {
Colin Cross0875c522017-11-28 17:34:01 -08001990 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07001991 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001992 Output: PathForPhony(ctx, class),
Dan Willemsen61d88b82017-09-20 17:29:08 -07001993 Implicits: osClass[class],
Dan Willemsen61d88b82017-09-20 17:29:08 -07001994 })
1995 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07001996}
Colin Crossd779da42015-12-17 18:00:23 -08001997
Brandon Lee5d45c6f2018-08-15 15:35:38 -07001998// Collect information for opening IDE project files in java/jdeps.go.
1999type IDEInfo interface {
2000 IDEInfo(ideInfo *IdeInfo)
2001 BaseModuleName() string
2002}
2003
2004// Extract the base module name from the Import name.
2005// Often the Import name has a prefix "prebuilt_".
2006// Remove the prefix explicitly if needed
2007// until we find a better solution to get the Import name.
2008type IDECustomizedModuleName interface {
2009 IDECustomizedModuleName() string
2010}
2011
2012type IdeInfo struct {
2013 Deps []string `json:"dependencies,omitempty"`
2014 Srcs []string `json:"srcs,omitempty"`
2015 Aidl_include_dirs []string `json:"aidl_include_dirs,omitempty"`
2016 Jarjar_rules []string `json:"jarjar_rules,omitempty"`
2017 Jars []string `json:"jars,omitempty"`
2018 Classes []string `json:"class,omitempty"`
2019 Installed_paths []string `json:"installed,omitempty"`
patricktu18c82ff2019-05-10 15:48:50 +08002020 SrcJars []string `json:"srcjars,omitempty"`
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002021}