blob: 696421becd25fd2c861033fffd6c7592bf503f26 [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"
Colin Cross988414c2020-01-11 01:11:46 +000019 "os"
Alex Lightfb4353d2019-01-17 13:57:45 -080020 "path"
Colin Cross3f40fa42015-01-30 17:27:36 -080021 "path/filepath"
Colin Cross6ff51382015-12-17 16:39:19 -080022 "strings"
Colin Crossaabf6792017-11-29 00:27:14 -080023 "text/scanner"
Colin Crossf6566ed2015-03-24 11:13:38 -070024
25 "github.com/google/blueprint"
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 Cross1184b642019-12-30 18:43:07 -080058// EarlyModuleContext provides methods that can be called early, as soon as the properties have
59// been parsed into the module and before any mutators have run.
60type EarlyModuleContext interface {
61 Module() Module
62 ModuleName() string
63 ModuleDir() string
64 ModuleType() string
Colin Cross9d34f352019-11-22 16:03:51 -080065 BlueprintsFile() string
Colin Cross1184b642019-12-30 18:43:07 -080066
67 ContainsProperty(name string) bool
68 Errorf(pos scanner.Position, fmt string, args ...interface{})
69 ModuleErrorf(fmt string, args ...interface{})
70 PropertyErrorf(property, fmt string, args ...interface{})
71 Failed() bool
72
73 AddNinjaFileDeps(deps ...string)
74
75 DeviceSpecific() bool
76 SocSpecific() bool
77 ProductSpecific() bool
78 SystemExtSpecific() bool
79 Platform() bool
80
81 Config() Config
82 DeviceConfig() DeviceConfig
83
84 // Deprecated: use Config()
85 AConfig() Config
86
87 // GlobWithDeps returns a list of files that match the specified pattern but do not match any
88 // of the patterns in excludes. It also adds efficient dependencies to rerun the primary
89 // builder whenever a file matching the pattern as added or removed, without rerunning if a
90 // file that does not match the pattern is added to a searched directory.
91 GlobWithDeps(pattern string, excludes []string) ([]string, error)
92
93 Glob(globPattern string, excludes []string) Paths
94 GlobFiles(globPattern string, excludes []string) Paths
Colin Cross988414c2020-01-11 01:11:46 +000095 IsSymlink(path Path) bool
96 Readlink(path Path) string
Colin Cross1184b642019-12-30 18:43:07 -080097}
98
Colin Cross0ea8ba82019-06-06 14:33:29 -070099// BaseModuleContext is the same as blueprint.BaseModuleContext except that Config() returns
Colin Crossdc35e212019-06-06 16:13:11 -0700100// a Config instead of an interface{}, and some methods have been wrapped to use an android.Module
101// instead of a blueprint.Module, plus some extra methods that return Android-specific information
Colin Cross0ea8ba82019-06-06 14:33:29 -0700102// about the current module.
103type BaseModuleContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800104 EarlyModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -0700105
Colin Crossdc35e212019-06-06 16:13:11 -0700106 OtherModuleName(m blueprint.Module) string
107 OtherModuleDir(m blueprint.Module) string
108 OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{})
109 OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag
110 OtherModuleExists(name string) bool
Jiyong Park9e6c2422019-08-09 20:39:45 +0900111 OtherModuleType(m blueprint.Module) string
Colin Crossdc35e212019-06-06 16:13:11 -0700112
113 GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module
114 GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module
115 GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag)
116
117 VisitDirectDepsBlueprint(visit func(blueprint.Module))
118 VisitDirectDeps(visit func(Module))
119 VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module))
120 VisitDirectDepsIf(pred func(Module) bool, visit func(Module))
121 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
122 VisitDepsDepthFirst(visit func(Module))
123 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
124 VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module))
125 WalkDeps(visit func(Module, Module) bool)
126 WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool)
127 // GetWalkPath is supposed to be called in visit function passed in WalkDeps()
128 // and returns a top-down dependency path from a start module to current child module.
129 GetWalkPath() []Module
130
Colin Crossdc35e212019-06-06 16:13:11 -0700131 AddMissingDependencies(missingDeps []string)
132
Colin Crossa1ad8d12016-06-01 17:09:44 -0700133 Target() Target
Colin Cross8b74d172016-09-13 09:59:14 -0700134 TargetPrimary() bool
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000135
136 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
137 // responsible for creating.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700138 MultiTargets() []Target
Colin Crossf6566ed2015-03-24 11:13:38 -0700139 Arch() Arch
Colin Crossa1ad8d12016-06-01 17:09:44 -0700140 Os() OsType
Colin Crossf6566ed2015-03-24 11:13:38 -0700141 Host() bool
142 Device() bool
Colin Cross0af4b842015-04-30 16:36:18 -0700143 Darwin() bool
Doug Horn21b94272019-01-16 12:06:11 -0800144 Fuchsia() bool
Colin Cross3edeee12017-04-04 12:59:48 -0700145 Windows() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700146 Debug() bool
Colin Cross1e7d3702016-08-24 15:25:47 -0700147 PrimaryArch() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700148}
149
Colin Cross1184b642019-12-30 18:43:07 -0800150// Deprecated: use EarlyModuleContext instead
Colin Cross635c3b02016-05-18 15:37:25 -0700151type BaseContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800152 EarlyModuleContext
Colin Crossaabf6792017-11-29 00:27:14 -0800153}
154
Colin Cross635c3b02016-05-18 15:37:25 -0700155type ModuleContext interface {
Colin Crossaabf6792017-11-29 00:27:14 -0800156 BaseModuleContext
Colin Cross3f40fa42015-01-30 17:27:36 -0800157
Colin Crossae887032017-10-23 17:16:14 -0700158 // Deprecated: use ModuleContext.Build instead.
Colin Cross0875c522017-11-28 17:34:01 -0800159 ModuleBuild(pctx PackageContext, params ModuleBuildParams)
Colin Cross8f101b42015-06-17 15:09:06 -0700160
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700161 ExpandSources(srcFiles, excludes []string) Paths
Colin Cross366938f2017-12-11 16:29:02 -0800162 ExpandSource(srcFile, prop string) Path
Colin Cross2383f3b2018-02-06 14:40:13 -0800163 ExpandOptionalSource(srcFile *string, prop string) OptionalPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700164
Colin Cross70dda7e2019-10-01 22:05:35 -0700165 InstallExecutable(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
166 InstallFile(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
167 InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath
168 InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700169 CheckbuildFile(srcPath Path)
Dan Willemsen6553f5e2016-03-10 18:14:25 -0800170
Colin Cross8d8f8e22016-08-03 11:57:50 -0700171 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700172 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700173 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800174 InstallInRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900175 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700176 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700177 InstallBypassMake() bool
Colin Cross6e359402020-02-10 15:29:54 -0800178 InstallForceOS() *OsType
Nan Zhang6d34b302017-02-04 17:47:46 -0800179
180 RequiredModuleNames() []string
Sasha Smundakb6d23052019-04-01 18:37:36 -0700181 HostRequiredModuleNames() []string
182 TargetRequiredModuleNames() []string
Colin Cross3f68a132017-10-23 17:10:29 -0700183
Colin Cross3f68a132017-10-23 17:10:29 -0700184 ModuleSubDir() string
185
Colin Cross0875c522017-11-28 17:34:01 -0800186 Variable(pctx PackageContext, name, value string)
187 Rule(pctx PackageContext, name string, params blueprint.RuleParams, argNames ...string) blueprint.Rule
Colin Crossae887032017-10-23 17:16:14 -0700188 // Similar to blueprint.ModuleContext.Build, but takes Paths instead of []string,
189 // and performs more verification.
Colin Cross0875c522017-11-28 17:34:01 -0800190 Build(pctx PackageContext, params BuildParams)
Colin Cross3f68a132017-10-23 17:10:29 -0700191
Colin Cross0875c522017-11-28 17:34:01 -0800192 PrimaryModule() Module
193 FinalModule() Module
194 VisitAllModuleVariants(visit func(Module))
Colin Cross3f68a132017-10-23 17:10:29 -0700195
196 GetMissingDependencies() []string
Jeff Gaston088e29e2017-11-29 16:47:17 -0800197 Namespace() blueprint.Namespace
Colin Cross3f40fa42015-01-30 17:27:36 -0800198}
199
Colin Cross635c3b02016-05-18 15:37:25 -0700200type Module interface {
Colin Cross3f40fa42015-01-30 17:27:36 -0800201 blueprint.Module
202
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700203 // GenerateAndroidBuildActions is analogous to Blueprints' GenerateBuildActions,
204 // but GenerateAndroidBuildActions also has access to Android-specific information.
205 // For more information, see Module.GenerateBuildActions within Blueprint's module_ctx.go
Colin Cross635c3b02016-05-18 15:37:25 -0700206 GenerateAndroidBuildActions(ModuleContext)
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700207
Colin Cross1e676be2016-10-12 14:38:15 -0700208 DepsMutator(BottomUpMutatorContext)
Colin Cross3f40fa42015-01-30 17:27:36 -0800209
Colin Cross635c3b02016-05-18 15:37:25 -0700210 base() *ModuleBase
Inseob Kimeec88e12020-01-22 11:11:29 +0900211 Disable()
Dan Willemsen0effe062015-11-30 16:06:01 -0800212 Enabled() bool
Colin Crossa1ad8d12016-06-01 17:09:44 -0700213 Target() Target
Dan Willemsen782a2d12015-12-21 14:55:28 -0800214 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700215 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700216 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800217 InstallInRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900218 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700219 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700220 InstallBypassMake() bool
Colin Cross6e359402020-02-10 15:29:54 -0800221 InstallForceOS() *OsType
Colin Crossa2f296f2016-11-29 15:16:18 -0800222 SkipInstall()
Ulya Trafimovichb28cc372020-01-13 15:18:16 +0000223 IsSkipInstall() bool
Jiyong Park374510b2018-03-19 18:23:01 +0900224 ExportedToMake() bool
Inseob Kim8471cda2019-11-15 09:59:12 +0900225 InitRc() Paths
226 VintfFragments() Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800227 NoticeFiles() Paths
Colin Cross36242852017-06-23 15:06:31 -0700228
229 AddProperties(props ...interface{})
230 GetProperties() []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700231
Colin Crossae887032017-10-23 17:16:14 -0700232 BuildParamsForTests() []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800233 RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800234 VariablesForTests() map[string]string
Paul Duffine2453c72019-05-31 14:00:04 +0100235
Colin Cross9a362232019-07-01 15:32:45 -0700236 // String returns a string that includes the module name and variants for printing during debugging.
237 String() string
238
Paul Duffine2453c72019-05-31 14:00:04 +0100239 // Get the qualified module id for this module.
240 qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName
241
242 // Get information about the properties that can contain visibility rules.
243 visibilityProperties() []visibilityProperty
Paul Duffin63c6e182019-07-24 14:24:38 +0100244
245 // Get the visibility rules that control the visibility of this module.
246 visibility() []string
Jiyong Park6a8cf5f2019-12-30 16:31:09 +0900247
248 RequiredModuleNames() []string
249 HostRequiredModuleNames() []string
250 TargetRequiredModuleNames() []string
Colin Cross897266e2020-02-13 13:22:08 -0800251
252 filesToInstall() InstallPaths
Paul Duffine2453c72019-05-31 14:00:04 +0100253}
254
255// Qualified id for a module
256type qualifiedModuleName struct {
257 // The package (i.e. directory) in which the module is defined, without trailing /
258 pkg string
259
260 // The name of the module, empty string if package.
261 name string
262}
263
264func (q qualifiedModuleName) String() string {
265 if q.name == "" {
266 return "//" + q.pkg
267 }
268 return "//" + q.pkg + ":" + q.name
269}
270
Paul Duffine484f472019-06-20 16:38:08 +0100271func (q qualifiedModuleName) isRootPackage() bool {
272 return q.pkg == "" && q.name == ""
273}
274
Paul Duffine2453c72019-05-31 14:00:04 +0100275// Get the id for the package containing this module.
276func (q qualifiedModuleName) getContainingPackageId() qualifiedModuleName {
277 pkg := q.pkg
278 if q.name == "" {
Paul Duffine484f472019-06-20 16:38:08 +0100279 if pkg == "" {
280 panic(fmt.Errorf("Cannot get containing package id of root package"))
281 }
282
283 index := strings.LastIndex(pkg, "/")
284 if index == -1 {
285 pkg = ""
286 } else {
287 pkg = pkg[:index]
288 }
Paul Duffine2453c72019-05-31 14:00:04 +0100289 }
290 return newPackageId(pkg)
291}
292
293func newPackageId(pkg string) qualifiedModuleName {
294 // A qualified id for a package module has no name.
295 return qualifiedModuleName{pkg: pkg, name: ""}
Colin Cross3f40fa42015-01-30 17:27:36 -0800296}
297
Colin Crossfc754582016-05-17 16:34:16 -0700298type nameProperties struct {
299 // The name of the module. Must be unique across all modules.
Nan Zhang0007d812017-11-07 10:57:05 -0800300 Name *string
Colin Crossfc754582016-05-17 16:34:16 -0700301}
302
303type commonProperties struct {
Dan Willemsen0effe062015-11-30 16:06:01 -0800304 // emit build rules for this module
Paul Duffin54d9bb72020-02-12 10:20:56 +0000305 //
306 // Disabling a module should only be done for those modules that cannot be built
307 // in the current environment. Modules that can build in the current environment
308 // but are not usually required (e.g. superceded by a prebuilt) should not be
309 // disabled as that will prevent them from being built by the checkbuild target
310 // and so prevent early detection of changes that have broken those modules.
Dan Willemsen0effe062015-11-30 16:06:01 -0800311 Enabled *bool `android:"arch_variant"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800312
Paul Duffin2e61fa62019-03-28 14:10:57 +0000313 // Controls the visibility of this module to other modules. Allowable values are one or more of
314 // these formats:
315 //
316 // ["//visibility:public"]: Anyone can use this module.
317 // ["//visibility:private"]: Only rules in the module's package (not its subpackages) can use
318 // this module.
319 // ["//some/package:__pkg__", "//other/package:__pkg__"]: Only modules in some/package and
320 // other/package (defined in some/package/*.bp and other/package/*.bp) have access to
321 // this module. Note that sub-packages do not have access to the rule; for example,
322 // //some/package/foo:bar or //other/package/testing:bla wouldn't have access. __pkg__
323 // is a special module and must be used verbatim. It represents all of the modules in the
324 // package.
325 // ["//project:__subpackages__", "//other:__subpackages__"]: Only modules in packages project
326 // or other or in one of their sub-packages have access to this module. For example,
327 // //project:rule, //project/library:lib or //other/testing/internal:munge are allowed
328 // to depend on this rule (but not //independent:evil)
329 // ["//project"]: This is shorthand for ["//project:__pkg__"]
330 // [":__subpackages__"]: This is shorthand for ["//project:__subpackages__"] where
331 // //project is the module's package. e.g. using [":__subpackages__"] in
332 // packages/apps/Settings/Android.bp is equivalent to
333 // //packages/apps/Settings:__subpackages__.
334 // ["//visibility:legacy_public"]: The default visibility, behaves as //visibility:public
335 // for now. It is an error if it is used in a module.
Paul Duffine2453c72019-05-31 14:00:04 +0100336 //
337 // If a module does not specify the `visibility` property then it uses the
338 // `default_visibility` property of the `package` module in the module's package.
339 //
340 // If the `default_visibility` property is not set for the module's package then
Paul Duffine484f472019-06-20 16:38:08 +0100341 // it will use the `default_visibility` of its closest ancestor package for which
342 // a `default_visibility` property is specified.
343 //
344 // If no `default_visibility` property can be found then the module uses the
345 // global default of `//visibility:legacy_public`.
Paul Duffine2453c72019-05-31 14:00:04 +0100346 //
Paul Duffin95d53b52019-07-24 13:45:05 +0100347 // The `visibility` property has no effect on a defaults module although it does
348 // apply to any non-defaults module that uses it. To set the visibility of a
349 // defaults module, use the `defaults_visibility` property on the defaults module;
350 // not to be confused with the `default_visibility` property on the package module.
351 //
Paul Duffin2e61fa62019-03-28 14:10:57 +0000352 // See https://android.googlesource.com/platform/build/soong/+/master/README.md#visibility for
353 // more details.
354 Visibility []string
355
Colin Cross7d5136f2015-05-11 13:39:40 -0700356 // control whether this module compiles for 32-bit, 64-bit, or both. Possible values
Colin Cross3f40fa42015-01-30 17:27:36 -0800357 // are "32" (compile for 32-bit only), "64" (compile for 64-bit only), "both" (compile for both
358 // architectures), or "first" (compile for 64-bit on a 64-bit platform, and 32-bit on a 32-bit
359 // platform
Colin Cross7d716ba2017-11-01 10:38:29 -0700360 Compile_multilib *string `android:"arch_variant"`
Colin Cross69617d32016-09-06 10:39:07 -0700361
362 Target struct {
363 Host struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700364 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700365 }
366 Android struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700367 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700368 }
369 }
370
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000371 // If set to true then the archMutator will create variants for each arch specific target
372 // (e.g. 32/64) that the module is required to produce. If set to false then it will only
373 // create a variant for the architecture and will list the additional arch specific targets
374 // that the variant needs to produce in the CompileMultiTargets property.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700375 UseTargetVariants bool `blueprint:"mutated"`
376 Default_multilib string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800377
Dan Willemsen782a2d12015-12-21 14:55:28 -0800378 // whether this is a proprietary vendor module, and should be installed into /vendor
Colin Cross7d716ba2017-11-01 10:38:29 -0700379 Proprietary *bool
Dan Willemsen782a2d12015-12-21 14:55:28 -0800380
Colin Cross55708f32017-03-20 13:23:34 -0700381 // vendor who owns this module
Dan Willemsenefac4a82017-07-18 19:42:09 -0700382 Owner *string
Colin Cross55708f32017-03-20 13:23:34 -0700383
Jiyong Park2db76922017-11-08 16:03:48 +0900384 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
385 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
386 // Use `soc_specific` instead for better meaning.
Colin Cross7d716ba2017-11-01 10:38:29 -0700387 Vendor *bool
Dan Willemsenaa118f92017-04-06 12:49:58 -0700388
Jiyong Park2db76922017-11-08 16:03:48 +0900389 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
390 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
391 Soc_specific *bool
392
393 // whether this module is specific to a device, not only for SoC, but also for off-chip
394 // peripherals. When set to true, it is installed into /odm (or /vendor/odm if odm partition
395 // does not exist, or /system/vendor/odm if both odm and vendor partitions do not exist).
396 // This implies `soc_specific:true`.
397 Device_specific *bool
398
399 // whether this module is specific to a software configuration of a product (e.g. country,
Jaekyun Seok5cfbfbb2018-01-10 19:00:15 +0900400 // network operator, etc). When set to true, it is installed into /product (or
401 // /system/product if product partition does not exist).
Jiyong Park2db76922017-11-08 16:03:48 +0900402 Product_specific *bool
403
Justin Yund5f6c822019-06-25 16:47:17 +0900404 // whether this module extends system. When set to true, it is installed into /system_ext
405 // (or /system/system_ext if system_ext partition does not exist).
406 System_ext_specific *bool
407
Jiyong Parkf9332f12018-02-01 00:54:12 +0900408 // Whether this module is installed to recovery partition
409 Recovery *bool
410
Yifan Hong1b3348d2020-01-21 15:53:22 -0800411 // Whether this module is installed to ramdisk
412 Ramdisk *bool
413
dimitry1f33e402019-03-26 12:39:31 +0100414 // Whether this module is built for non-native architecures (also known as native bridge binary)
415 Native_bridge_supported *bool `android:"arch_variant"`
416
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700417 // init.rc files to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800418 Init_rc []string `android:"path"`
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700419
Steven Moreland57a23d22018-04-04 15:42:19 -0700420 // VINTF manifest fragments to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800421 Vintf_fragments []string `android:"path"`
Steven Moreland57a23d22018-04-04 15:42:19 -0700422
Chris Wolfe998306e2016-08-15 14:47:23 -0400423 // names of other modules to install if this module is installed
Colin Crossc602b7d2017-05-05 13:36:36 -0700424 Required []string `android:"arch_variant"`
Chris Wolfe998306e2016-08-15 14:47:23 -0400425
Sasha Smundakb6d23052019-04-01 18:37:36 -0700426 // names of other modules to install on host if this module is installed
427 Host_required []string `android:"arch_variant"`
428
429 // names of other modules to install on target if this module is installed
430 Target_required []string `android:"arch_variant"`
431
Colin Cross5aac3622017-08-31 15:07:09 -0700432 // relative path to a file to include in the list of notices for the device
Colin Cross27b922f2019-03-04 22:35:41 -0800433 Notice *string `android:"path"`
Colin Cross5aac3622017-08-31 15:07:09 -0700434
Dan Willemsen569edc52018-11-19 09:33:29 -0800435 Dist struct {
436 // copy the output of this module to the $DIST_DIR when `dist` is specified on the
437 // command line and any of these targets are also on the command line, or otherwise
438 // built
439 Targets []string `android:"arch_variant"`
440
441 // The name of the output artifact. This defaults to the basename of the output of
442 // the module.
443 Dest *string `android:"arch_variant"`
444
445 // The directory within the dist directory to store the artifact. Defaults to the
446 // top level directory ("").
447 Dir *string `android:"arch_variant"`
448
449 // A suffix to add to the artifact file name (before any extension).
450 Suffix *string `android:"arch_variant"`
451 } `android:"arch_variant"`
452
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000453 // The OsType of artifacts that this module variant is responsible for creating.
454 //
455 // Set by osMutator
456 CompileOS OsType `blueprint:"mutated"`
457
458 // The Target of artifacts that this module variant is responsible for creating.
459 //
460 // Set by archMutator
461 CompileTarget Target `blueprint:"mutated"`
462
463 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
464 // responsible for creating.
465 //
466 // By default this is nil as, where necessary, separate variants are created for the
467 // different multilib types supported and that information is encapsulated in the
468 // CompileTarget so the module variant simply needs to create artifacts for that.
469 //
470 // However, if UseTargetVariants is set to false (e.g. by
471 // InitAndroidMultiTargetsArchModule) then no separate variants are created for the
472 // multilib targets. Instead a single variant is created for the architecture and
473 // this contains the multilib specific targets that this variant should create.
474 //
475 // Set by archMutator
Colin Crossee0bc3b2018-10-02 22:01:37 -0700476 CompileMultiTargets []Target `blueprint:"mutated"`
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000477
478 // True if the module variant's CompileTarget is the primary target
479 //
480 // Set by archMutator
481 CompilePrimary bool `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800482
483 // Set by InitAndroidModule
484 HostOrDeviceSupported HostOrDeviceSupported `blueprint:"mutated"`
Dan Willemsen0b24c742016-10-04 15:13:37 -0700485 ArchSpecific bool `blueprint:"mutated"`
Colin Crossce75d2c2016-10-06 16:12:58 -0700486
Paul Duffin1356d8c2020-02-25 19:26:33 +0000487 // If set to true then a CommonOS variant will be created which will have dependencies
488 // on all its OsType specific variants. Used by sdk/module_exports to create a snapshot
489 // that covers all os and architecture variants.
490 //
491 // The OsType specific variants can be retrieved by calling
492 // GetOsSpecificVariantsOfCommonOSVariant
493 //
494 // Set at module initialization time by calling InitCommonOSAndroidMultiTargetsArchModule
495 CreateCommonOSVariant bool `blueprint:"mutated"`
496
497 // If set to true then this variant is the CommonOS variant that has dependencies on its
498 // OsType specific variants.
499 //
500 // Set by osMutator.
501 CommonOSVariant bool `blueprint:"mutated"`
502
Colin Crossce75d2c2016-10-06 16:12:58 -0700503 SkipInstall bool `blueprint:"mutated"`
Jeff Gaston088e29e2017-11-29 16:47:17 -0800504
505 NamespaceExportedToMake bool `blueprint:"mutated"`
Colin Cross6c4f21f2019-06-06 15:41:36 -0700506
507 MissingDeps []string `blueprint:"mutated"`
Colin Cross9a362232019-07-01 15:32:45 -0700508
509 // Name and variant strings stored by mutators to enable Module.String()
510 DebugName string `blueprint:"mutated"`
511 DebugMutators []string `blueprint:"mutated"`
512 DebugVariations []string `blueprint:"mutated"`
Colin Cross7228ecd2019-11-18 16:00:16 -0800513
514 // set by ImageMutator
515 ImageVariation string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800516}
517
518type hostAndDeviceProperties struct {
Colin Cross4e81d702018-11-09 10:36:55 -0800519 // If set to true, build a variant of the module for the host. Defaults to false.
520 Host_supported *bool
521
522 // If set to true, build a variant of the module for the device. Defaults to true.
Colin Crossa4190c12016-07-12 13:11:25 -0700523 Device_supported *bool
Colin Cross3f40fa42015-01-30 17:27:36 -0800524}
525
Colin Crossc472d572015-03-17 15:06:21 -0700526type Multilib string
527
528const (
Colin Cross6b4a32d2017-12-05 13:42:45 -0800529 MultilibBoth Multilib = "both"
530 MultilibFirst Multilib = "first"
531 MultilibCommon Multilib = "common"
532 MultilibCommonFirst Multilib = "common_first"
533 MultilibDefault Multilib = ""
Colin Crossc472d572015-03-17 15:06:21 -0700534)
535
Colin Crossa1ad8d12016-06-01 17:09:44 -0700536type HostOrDeviceSupported int
537
538const (
539 _ HostOrDeviceSupported = iota
Dan Albert0981b5c2018-08-02 13:46:35 -0700540
541 // Host and HostCross are built by default. Device is not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700542 HostSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700543
544 // Host is built by default. HostCross and Device are not supported.
Dan Albertc6345fb2016-10-20 01:36:11 -0700545 HostSupportedNoCross
Dan Albert0981b5c2018-08-02 13:46:35 -0700546
547 // Device is built by default. Host and HostCross are not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700548 DeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700549
550 // Device is built by default. Host and HostCross are supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700551 HostAndDeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700552
553 // Host, HostCross, and Device are built by default.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700554 HostAndDeviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700555
556 // Nothing is supported. This is not exposed to the user, but used to mark a
557 // host only module as unsupported when the module type is not supported on
558 // the host OS. E.g. benchmarks are supported on Linux but not Darwin.
Dan Willemsen0b24c742016-10-04 15:13:37 -0700559 NeitherHostNorDeviceSupported
Colin Crossa1ad8d12016-06-01 17:09:44 -0700560)
561
Jiyong Park2db76922017-11-08 16:03:48 +0900562type moduleKind int
563
564const (
565 platformModule moduleKind = iota
566 deviceSpecificModule
567 socSpecificModule
568 productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900569 systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900570)
571
572func (k moduleKind) String() string {
573 switch k {
574 case platformModule:
575 return "platform"
576 case deviceSpecificModule:
577 return "device-specific"
578 case socSpecificModule:
579 return "soc-specific"
580 case productSpecificModule:
581 return "product-specific"
Justin Yund5f6c822019-06-25 16:47:17 +0900582 case systemExtSpecificModule:
583 return "systemext-specific"
Jiyong Park2db76922017-11-08 16:03:48 +0900584 default:
585 panic(fmt.Errorf("unknown module kind %d", k))
586 }
587}
588
Colin Cross9d34f352019-11-22 16:03:51 -0800589func initAndroidModuleBase(m Module) {
590 m.base().module = m
591}
592
Colin Cross36242852017-06-23 15:06:31 -0700593func InitAndroidModule(m Module) {
Colin Cross9d34f352019-11-22 16:03:51 -0800594 initAndroidModuleBase(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800595 base := m.base()
Colin Cross5049f022015-03-18 13:28:46 -0700596
Colin Cross36242852017-06-23 15:06:31 -0700597 m.AddProperties(
Colin Crossfc754582016-05-17 16:34:16 -0700598 &base.nameProperties,
Colin Cross18c46802019-09-24 22:19:02 -0700599 &base.commonProperties)
600
Colin Crosseabaedd2020-02-06 17:01:55 -0800601 initProductVariableModule(m)
Colin Cross18c46802019-09-24 22:19:02 -0700602
Colin Crossa3a97412019-03-18 12:24:29 -0700603 base.generalProperties = m.GetProperties()
Pirama Arumuga Nainar955dc492018-04-17 14:58:42 -0700604 base.customizableProperties = m.GetProperties()
Paul Duffin63c6e182019-07-24 14:24:38 +0100605
606 // The default_visibility property needs to be checked and parsed by the visibility module during
607 // its checking and parsing phases.
608 base.primaryVisibilityProperty =
609 newVisibilityProperty("visibility", &base.commonProperties.Visibility)
610 base.visibilityPropertyInfo = []visibilityProperty{base.primaryVisibilityProperty}
Colin Cross5049f022015-03-18 13:28:46 -0700611}
612
Colin Cross36242852017-06-23 15:06:31 -0700613func InitAndroidArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
614 InitAndroidModule(m)
Colin Cross5049f022015-03-18 13:28:46 -0700615
616 base := m.base()
Colin Cross3f40fa42015-01-30 17:27:36 -0800617 base.commonProperties.HostOrDeviceSupported = hod
Colin Cross69617d32016-09-06 10:39:07 -0700618 base.commonProperties.Default_multilib = string(defaultMultilib)
Dan Willemsen0b24c742016-10-04 15:13:37 -0700619 base.commonProperties.ArchSpecific = true
Colin Crossee0bc3b2018-10-02 22:01:37 -0700620 base.commonProperties.UseTargetVariants = true
Colin Cross3f40fa42015-01-30 17:27:36 -0800621
Dan Willemsen218f6562015-07-08 18:13:11 -0700622 switch hod {
Nan Zhang1a0f09b2017-07-05 10:35:11 -0700623 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Cross36242852017-06-23 15:06:31 -0700624 m.AddProperties(&base.hostAndDeviceProperties)
Colin Cross3f40fa42015-01-30 17:27:36 -0800625 }
626
Colin Cross36242852017-06-23 15:06:31 -0700627 InitArchModule(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800628}
629
Colin Crossee0bc3b2018-10-02 22:01:37 -0700630func InitAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
631 InitAndroidArchModule(m, hod, defaultMultilib)
632 m.base().commonProperties.UseTargetVariants = false
633}
634
Paul Duffin1356d8c2020-02-25 19:26:33 +0000635// As InitAndroidMultiTargetsArchModule except it creates an additional CommonOS variant that
636// has dependencies on all the OsType specific variants.
637func InitCommonOSAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
638 InitAndroidArchModule(m, hod, defaultMultilib)
639 m.base().commonProperties.UseTargetVariants = false
640 m.base().commonProperties.CreateCommonOSVariant = true
641}
642
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800643// A ModuleBase object contains the properties that are common to all Android
Colin Cross3f40fa42015-01-30 17:27:36 -0800644// modules. It should be included as an anonymous field in every module
645// struct definition. InitAndroidModule should then be called from the module's
646// factory function, and the return values from InitAndroidModule should be
647// returned from the factory function.
648//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800649// The ModuleBase type is responsible for implementing the GenerateBuildActions
650// method to support the blueprint.Module interface. This method will then call
651// the module's GenerateAndroidBuildActions method once for each build variant
Colin Cross25de6c32019-06-06 14:29:25 -0700652// that is to be built. GenerateAndroidBuildActions is passed a ModuleContext
653// rather than the usual blueprint.ModuleContext.
654// ModuleContext exposes extra functionality specific to the Android build
Colin Cross3f40fa42015-01-30 17:27:36 -0800655// system including details about the particular build variant that is to be
656// generated.
657//
658// For example:
659//
660// import (
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800661// "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -0800662// )
663//
664// type myModule struct {
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800665// android.ModuleBase
Colin Cross3f40fa42015-01-30 17:27:36 -0800666// properties struct {
667// MyProperty string
668// }
669// }
670//
Colin Cross36242852017-06-23 15:06:31 -0700671// func NewMyModule() android.Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800672// m := &myModule{}
Colin Cross36242852017-06-23 15:06:31 -0700673// m.AddProperties(&m.properties)
674// android.InitAndroidModule(m)
675// return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800676// }
677//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800678// func (m *myModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800679// // Get the CPU architecture for the current build variant.
680// variantArch := ctx.Arch()
681//
682// // ...
683// }
Colin Cross635c3b02016-05-18 15:37:25 -0700684type ModuleBase struct {
Colin Cross3f40fa42015-01-30 17:27:36 -0800685 // Putting the curiously recurring thing pointing to the thing that contains
686 // the thing pattern to good use.
Colin Cross36242852017-06-23 15:06:31 -0700687 // TODO: remove this
Colin Cross635c3b02016-05-18 15:37:25 -0700688 module Module
Colin Cross3f40fa42015-01-30 17:27:36 -0800689
Colin Crossfc754582016-05-17 16:34:16 -0700690 nameProperties nameProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800691 commonProperties commonProperties
Colin Cross18c46802019-09-24 22:19:02 -0700692 variableProperties interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800693 hostAndDeviceProperties hostAndDeviceProperties
694 generalProperties []interface{}
Colin Crossc17727d2018-10-24 12:42:09 -0700695 archProperties [][]interface{}
Colin Crossa120ec12016-08-19 16:07:38 -0700696 customizableProperties []interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800697
Paul Duffin63c6e182019-07-24 14:24:38 +0100698 // Information about all the properties on the module that contains visibility rules that need
699 // checking.
700 visibilityPropertyInfo []visibilityProperty
701
702 // The primary visibility property, may be nil, that controls access to the module.
703 primaryVisibilityProperty visibilityProperty
704
Colin Cross3f40fa42015-01-30 17:27:36 -0800705 noAddressSanitizer bool
Colin Cross897266e2020-02-13 13:22:08 -0800706 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700707 checkbuildFiles Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800708 noticeFiles Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -0700709
710 // Used by buildTargetSingleton to create checkbuild and per-directory build targets
711 // Only set on the final variant of each module
Colin Cross0875c522017-11-28 17:34:01 -0800712 installTarget WritablePath
713 checkbuildTarget WritablePath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700714 blueprintDir string
Colin Crossa120ec12016-08-19 16:07:38 -0700715
Colin Cross178a5092016-09-13 13:42:32 -0700716 hooks hooks
Colin Cross36242852017-06-23 15:06:31 -0700717
718 registerProps []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700719
720 // For tests
Colin Crossae887032017-10-23 17:16:14 -0700721 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800722 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800723 variables map[string]string
Colin Crossa9d8bee2018-10-02 13:59:46 -0700724
Inseob Kim8471cda2019-11-15 09:59:12 +0900725 initRcPaths Paths
726 vintfFragmentsPaths Paths
727
Colin Crossa9d8bee2018-10-02 13:59:46 -0700728 prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool
Colin Cross36242852017-06-23 15:06:31 -0700729}
730
Colin Cross4157e882019-06-06 16:57:04 -0700731func (m *ModuleBase) DepsMutator(BottomUpMutatorContext) {}
Colin Cross5f692ec2019-02-01 16:53:07 -0800732
Colin Cross4157e882019-06-06 16:57:04 -0700733func (m *ModuleBase) AddProperties(props ...interface{}) {
734 m.registerProps = append(m.registerProps, props...)
Colin Cross36242852017-06-23 15:06:31 -0700735}
736
Colin Cross4157e882019-06-06 16:57:04 -0700737func (m *ModuleBase) GetProperties() []interface{} {
738 return m.registerProps
Colin Cross3f40fa42015-01-30 17:27:36 -0800739}
740
Colin Cross4157e882019-06-06 16:57:04 -0700741func (m *ModuleBase) BuildParamsForTests() []BuildParams {
742 return m.buildParams
Colin Crosscec81712017-07-13 14:43:27 -0700743}
744
Colin Cross4157e882019-06-06 16:57:04 -0700745func (m *ModuleBase) RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams {
746 return m.ruleParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800747}
748
Colin Cross4157e882019-06-06 16:57:04 -0700749func (m *ModuleBase) VariablesForTests() map[string]string {
750 return m.variables
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800751}
752
Colin Cross4157e882019-06-06 16:57:04 -0700753func (m *ModuleBase) Prefer32(prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool) {
754 m.prefer32 = prefer32
Colin Crossa9d8bee2018-10-02 13:59:46 -0700755}
756
Colin Crossce75d2c2016-10-06 16:12:58 -0700757// Name returns the name of the module. It may be overridden by individual module types, for
758// example prebuilts will prepend prebuilt_ to the name.
Colin Cross4157e882019-06-06 16:57:04 -0700759func (m *ModuleBase) Name() string {
760 return String(m.nameProperties.Name)
Colin Crossfc754582016-05-17 16:34:16 -0700761}
762
Colin Cross9a362232019-07-01 15:32:45 -0700763// String returns a string that includes the module name and variants for printing during debugging.
764func (m *ModuleBase) String() string {
765 sb := strings.Builder{}
766 sb.WriteString(m.commonProperties.DebugName)
767 sb.WriteString("{")
768 for i := range m.commonProperties.DebugMutators {
769 if i != 0 {
770 sb.WriteString(",")
771 }
772 sb.WriteString(m.commonProperties.DebugMutators[i])
773 sb.WriteString(":")
774 sb.WriteString(m.commonProperties.DebugVariations[i])
775 }
776 sb.WriteString("}")
777 return sb.String()
778}
779
Colin Crossce75d2c2016-10-06 16:12:58 -0700780// BaseModuleName returns the name of the module as specified in the blueprints file.
Colin Cross4157e882019-06-06 16:57:04 -0700781func (m *ModuleBase) BaseModuleName() string {
782 return String(m.nameProperties.Name)
Colin Crossce75d2c2016-10-06 16:12:58 -0700783}
784
Colin Cross4157e882019-06-06 16:57:04 -0700785func (m *ModuleBase) base() *ModuleBase {
786 return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800787}
788
Paul Duffine2453c72019-05-31 14:00:04 +0100789func (m *ModuleBase) qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName {
790 return qualifiedModuleName{pkg: ctx.ModuleDir(), name: ctx.ModuleName()}
791}
792
793func (m *ModuleBase) visibilityProperties() []visibilityProperty {
Paul Duffin63c6e182019-07-24 14:24:38 +0100794 return m.visibilityPropertyInfo
795}
796
797func (m *ModuleBase) visibility() []string {
798 // The soong_namespace module does not initialize the primaryVisibilityProperty.
799 if m.primaryVisibilityProperty != nil {
800 return m.primaryVisibilityProperty.getStrings()
801 } else {
802 return nil
Paul Duffine2453c72019-05-31 14:00:04 +0100803 }
804}
805
Colin Cross4157e882019-06-06 16:57:04 -0700806func (m *ModuleBase) Target() Target {
807 return m.commonProperties.CompileTarget
Dan Willemsen490fd492015-11-24 17:53:15 -0800808}
809
Colin Cross4157e882019-06-06 16:57:04 -0700810func (m *ModuleBase) TargetPrimary() bool {
811 return m.commonProperties.CompilePrimary
Colin Cross8b74d172016-09-13 09:59:14 -0700812}
813
Colin Cross4157e882019-06-06 16:57:04 -0700814func (m *ModuleBase) MultiTargets() []Target {
815 return m.commonProperties.CompileMultiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -0700816}
817
Colin Cross4157e882019-06-06 16:57:04 -0700818func (m *ModuleBase) Os() OsType {
819 return m.Target().Os
Dan Willemsen490fd492015-11-24 17:53:15 -0800820}
821
Colin Cross4157e882019-06-06 16:57:04 -0700822func (m *ModuleBase) Host() bool {
823 return m.Os().Class == Host || m.Os().Class == HostCross
Dan Willemsen97750522016-02-09 17:43:51 -0800824}
825
Colin Cross4157e882019-06-06 16:57:04 -0700826func (m *ModuleBase) Arch() Arch {
827 return m.Target().Arch
Dan Willemsen97750522016-02-09 17:43:51 -0800828}
829
Colin Cross4157e882019-06-06 16:57:04 -0700830func (m *ModuleBase) ArchSpecific() bool {
831 return m.commonProperties.ArchSpecific
Dan Willemsen0b24c742016-10-04 15:13:37 -0700832}
833
Paul Duffin1356d8c2020-02-25 19:26:33 +0000834// True if the current variant is a CommonOS variant, false otherwise.
835func (m *ModuleBase) IsCommonOSVariant() bool {
836 return m.commonProperties.CommonOSVariant
837}
838
Colin Cross4157e882019-06-06 16:57:04 -0700839func (m *ModuleBase) OsClassSupported() []OsClass {
840 switch m.commonProperties.HostOrDeviceSupported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700841 case HostSupported:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700842 return []OsClass{Host, HostCross}
Dan Albertc6345fb2016-10-20 01:36:11 -0700843 case HostSupportedNoCross:
844 return []OsClass{Host}
Colin Crossa1ad8d12016-06-01 17:09:44 -0700845 case DeviceSupported:
846 return []OsClass{Device}
Dan Albert0981b5c2018-08-02 13:46:35 -0700847 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700848 var supported []OsClass
Colin Cross4157e882019-06-06 16:57:04 -0700849 if Bool(m.hostAndDeviceProperties.Host_supported) ||
850 (m.commonProperties.HostOrDeviceSupported == HostAndDeviceDefault &&
851 m.hostAndDeviceProperties.Host_supported == nil) {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700852 supported = append(supported, Host, HostCross)
853 }
Colin Cross4157e882019-06-06 16:57:04 -0700854 if m.hostAndDeviceProperties.Device_supported == nil ||
855 *m.hostAndDeviceProperties.Device_supported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700856 supported = append(supported, Device)
857 }
858 return supported
859 default:
860 return nil
861 }
Colin Cross3f40fa42015-01-30 17:27:36 -0800862}
863
Colin Cross4157e882019-06-06 16:57:04 -0700864func (m *ModuleBase) DeviceSupported() bool {
865 return m.commonProperties.HostOrDeviceSupported == DeviceSupported ||
866 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
867 (m.hostAndDeviceProperties.Device_supported == nil ||
868 *m.hostAndDeviceProperties.Device_supported)
Colin Cross3f40fa42015-01-30 17:27:36 -0800869}
870
Paul Duffine44358f2019-11-26 18:04:12 +0000871func (m *ModuleBase) HostSupported() bool {
872 return m.commonProperties.HostOrDeviceSupported == HostSupported ||
873 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
874 (m.hostAndDeviceProperties.Host_supported != nil &&
875 *m.hostAndDeviceProperties.Host_supported)
876}
877
Colin Cross4157e882019-06-06 16:57:04 -0700878func (m *ModuleBase) Platform() bool {
Justin Yund5f6c822019-06-25 16:47:17 +0900879 return !m.DeviceSpecific() && !m.SocSpecific() && !m.ProductSpecific() && !m.SystemExtSpecific()
Jiyong Parkc678ad32018-04-10 13:07:10 +0900880}
881
Colin Cross4157e882019-06-06 16:57:04 -0700882func (m *ModuleBase) DeviceSpecific() bool {
883 return Bool(m.commonProperties.Device_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900884}
885
Colin Cross4157e882019-06-06 16:57:04 -0700886func (m *ModuleBase) SocSpecific() bool {
887 return Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900888}
889
Colin Cross4157e882019-06-06 16:57:04 -0700890func (m *ModuleBase) ProductSpecific() bool {
891 return Bool(m.commonProperties.Product_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900892}
893
Justin Yund5f6c822019-06-25 16:47:17 +0900894func (m *ModuleBase) SystemExtSpecific() bool {
895 return Bool(m.commonProperties.System_ext_specific)
Dario Frenifd05a742018-05-29 13:28:54 +0100896}
897
Colin Cross4157e882019-06-06 16:57:04 -0700898func (m *ModuleBase) Enabled() bool {
899 if m.commonProperties.Enabled == nil {
900 return !m.Os().DefaultDisabled
Dan Willemsen490fd492015-11-24 17:53:15 -0800901 }
Colin Cross4157e882019-06-06 16:57:04 -0700902 return *m.commonProperties.Enabled
Colin Cross3f40fa42015-01-30 17:27:36 -0800903}
904
Inseob Kimeec88e12020-01-22 11:11:29 +0900905func (m *ModuleBase) Disable() {
906 m.commonProperties.Enabled = proptools.BoolPtr(false)
907}
908
Colin Cross4157e882019-06-06 16:57:04 -0700909func (m *ModuleBase) SkipInstall() {
910 m.commonProperties.SkipInstall = true
Colin Crossce75d2c2016-10-06 16:12:58 -0700911}
912
Ulya Trafimovichb28cc372020-01-13 15:18:16 +0000913func (m *ModuleBase) IsSkipInstall() bool {
914 return m.commonProperties.SkipInstall == true
915}
916
Colin Cross4157e882019-06-06 16:57:04 -0700917func (m *ModuleBase) ExportedToMake() bool {
918 return m.commonProperties.NamespaceExportedToMake
Jiyong Park374510b2018-03-19 18:23:01 +0900919}
920
Colin Cross897266e2020-02-13 13:22:08 -0800921func (m *ModuleBase) computeInstallDeps(ctx blueprint.ModuleContext) InstallPaths {
Colin Cross3f40fa42015-01-30 17:27:36 -0800922
Colin Cross897266e2020-02-13 13:22:08 -0800923 var result InstallPaths
Colin Cross6b753602018-06-21 13:03:07 -0700924 // TODO(ccross): we need to use WalkDeps and have some way to know which dependencies require installation
Colin Cross897266e2020-02-13 13:22:08 -0800925 ctx.VisitDepsDepthFirst(func(m blueprint.Module) {
926 if a, ok := m.(Module); ok {
927 result = append(result, a.filesToInstall()...)
928 }
929 })
Colin Cross3f40fa42015-01-30 17:27:36 -0800930
931 return result
932}
933
Colin Cross897266e2020-02-13 13:22:08 -0800934func (m *ModuleBase) filesToInstall() InstallPaths {
Colin Cross4157e882019-06-06 16:57:04 -0700935 return m.installFiles
Colin Cross3f40fa42015-01-30 17:27:36 -0800936}
937
Colin Cross4157e882019-06-06 16:57:04 -0700938func (m *ModuleBase) NoAddressSanitizer() bool {
939 return m.noAddressSanitizer
Colin Cross3f40fa42015-01-30 17:27:36 -0800940}
941
Colin Cross4157e882019-06-06 16:57:04 -0700942func (m *ModuleBase) InstallInData() bool {
Dan Willemsen782a2d12015-12-21 14:55:28 -0800943 return false
944}
945
Jaewoong Jung0949f312019-09-11 10:25:18 -0700946func (m *ModuleBase) InstallInTestcases() bool {
947 return false
948}
949
Colin Cross4157e882019-06-06 16:57:04 -0700950func (m *ModuleBase) InstallInSanitizerDir() bool {
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700951 return false
952}
953
Yifan Hong1b3348d2020-01-21 15:53:22 -0800954func (m *ModuleBase) InstallInRamdisk() bool {
955 return Bool(m.commonProperties.Ramdisk)
956}
957
Colin Cross4157e882019-06-06 16:57:04 -0700958func (m *ModuleBase) InstallInRecovery() bool {
959 return Bool(m.commonProperties.Recovery)
Jiyong Parkf9332f12018-02-01 00:54:12 +0900960}
961
Colin Cross90ba5f42019-10-02 11:10:58 -0700962func (m *ModuleBase) InstallInRoot() bool {
963 return false
964}
965
Colin Cross607d8582019-07-29 16:44:46 -0700966func (m *ModuleBase) InstallBypassMake() bool {
967 return false
968}
969
Colin Cross6e359402020-02-10 15:29:54 -0800970func (m *ModuleBase) InstallForceOS() *OsType {
971 return nil
972}
973
Colin Cross4157e882019-06-06 16:57:04 -0700974func (m *ModuleBase) Owner() string {
975 return String(m.commonProperties.Owner)
Sundong Ahn4fd04bb2018-08-31 18:01:37 +0900976}
977
Bob Badoura75b0572020-02-18 20:21:55 -0800978func (m *ModuleBase) NoticeFiles() Paths {
979 return m.noticeFiles
Jiyong Park52818fc2019-03-18 12:01:38 +0900980}
981
Colin Cross7228ecd2019-11-18 16:00:16 -0800982func (m *ModuleBase) setImageVariation(variant string) {
983 m.commonProperties.ImageVariation = variant
984}
985
986func (m *ModuleBase) ImageVariation() blueprint.Variation {
987 return blueprint.Variation{
988 Mutator: "image",
989 Variation: m.base().commonProperties.ImageVariation,
990 }
991}
992
Paul Duffin9b76c0b2020-03-12 10:24:35 +0000993func (m *ModuleBase) getVariationByMutatorName(mutator string) string {
994 for i, v := range m.commonProperties.DebugMutators {
995 if v == mutator {
996 return m.commonProperties.DebugVariations[i]
997 }
998 }
999
1000 return ""
1001}
1002
Yifan Hong1b3348d2020-01-21 15:53:22 -08001003func (m *ModuleBase) InRamdisk() bool {
1004 return m.base().commonProperties.ImageVariation == RamdiskVariation
1005}
1006
Colin Cross7228ecd2019-11-18 16:00:16 -08001007func (m *ModuleBase) InRecovery() bool {
1008 return m.base().commonProperties.ImageVariation == RecoveryVariation
1009}
1010
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09001011func (m *ModuleBase) RequiredModuleNames() []string {
1012 return m.base().commonProperties.Required
1013}
1014
1015func (m *ModuleBase) HostRequiredModuleNames() []string {
1016 return m.base().commonProperties.Host_required
1017}
1018
1019func (m *ModuleBase) TargetRequiredModuleNames() []string {
1020 return m.base().commonProperties.Target_required
1021}
1022
Inseob Kim8471cda2019-11-15 09:59:12 +09001023func (m *ModuleBase) InitRc() Paths {
1024 return append(Paths{}, m.initRcPaths...)
1025}
1026
1027func (m *ModuleBase) VintfFragments() Paths {
1028 return append(Paths{}, m.vintfFragmentsPaths...)
1029}
1030
Colin Cross4157e882019-06-06 16:57:04 -07001031func (m *ModuleBase) generateModuleTarget(ctx ModuleContext) {
Colin Cross897266e2020-02-13 13:22:08 -08001032 var allInstalledFiles InstallPaths
1033 var allCheckbuildFiles Paths
Colin Cross0875c522017-11-28 17:34:01 -08001034 ctx.VisitAllModuleVariants(func(module Module) {
1035 a := module.base()
Colin Crossc9404352015-03-26 16:10:12 -07001036 allInstalledFiles = append(allInstalledFiles, a.installFiles...)
1037 allCheckbuildFiles = append(allCheckbuildFiles, a.checkbuildFiles...)
Colin Cross3f40fa42015-01-30 17:27:36 -08001038 })
1039
Colin Cross0875c522017-11-28 17:34:01 -08001040 var deps Paths
Colin Cross9454bfa2015-03-17 13:24:18 -07001041
Jeff Gaston088e29e2017-11-29 16:47:17 -08001042 namespacePrefix := ctx.Namespace().(*Namespace).id
1043 if namespacePrefix != "" {
1044 namespacePrefix = namespacePrefix + "-"
1045 }
1046
Colin Cross3f40fa42015-01-30 17:27:36 -08001047 if len(allInstalledFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -08001048 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-install")
Colin Cross0875c522017-11-28 17:34:01 -08001049 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001050 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001051 Output: name,
Colin Cross897266e2020-02-13 13:22:08 -08001052 Implicits: allInstalledFiles.Paths(),
Colin Crossaabf6792017-11-29 00:27:14 -08001053 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross9454bfa2015-03-17 13:24:18 -07001054 })
1055 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -07001056 m.installTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -07001057 }
1058
1059 if len(allCheckbuildFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -08001060 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-checkbuild")
Colin Cross0875c522017-11-28 17:34:01 -08001061 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001062 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001063 Output: name,
1064 Implicits: allCheckbuildFiles,
Colin Cross9454bfa2015-03-17 13:24:18 -07001065 })
1066 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -07001067 m.checkbuildTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -07001068 }
1069
1070 if len(deps) > 0 {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001071 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08001072 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001073 suffix = "-soong"
1074 }
1075
Jeff Gaston088e29e2017-11-29 16:47:17 -08001076 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+suffix)
Colin Cross0875c522017-11-28 17:34:01 -08001077 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001078 Rule: blueprint.Phony,
Jeff Gaston088e29e2017-11-29 16:47:17 -08001079 Outputs: []WritablePath{name},
Colin Cross9454bfa2015-03-17 13:24:18 -07001080 Implicits: deps,
Colin Cross3f40fa42015-01-30 17:27:36 -08001081 })
Colin Cross1f8c52b2015-06-16 16:38:17 -07001082
Colin Cross4157e882019-06-06 16:57:04 -07001083 m.blueprintDir = ctx.ModuleDir()
Colin Cross3f40fa42015-01-30 17:27:36 -08001084 }
1085}
1086
Colin Crossc34d2322020-01-03 15:23:27 -08001087func determineModuleKind(m *ModuleBase, ctx blueprint.EarlyModuleContext) moduleKind {
Colin Cross4157e882019-06-06 16:57:04 -07001088 var socSpecific = Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
1089 var deviceSpecific = Bool(m.commonProperties.Device_specific)
1090 var productSpecific = Bool(m.commonProperties.Product_specific)
Justin Yund5f6c822019-06-25 16:47:17 +09001091 var systemExtSpecific = Bool(m.commonProperties.System_ext_specific)
Jiyong Park2db76922017-11-08 16:03:48 +09001092
Dario Frenifd05a742018-05-29 13:28:54 +01001093 msg := "conflicting value set here"
1094 if socSpecific && deviceSpecific {
1095 ctx.PropertyErrorf("device_specific", "a module cannot be specific to SoC and device at the same time.")
Colin Cross4157e882019-06-06 16:57:04 -07001096 if Bool(m.commonProperties.Vendor) {
Jiyong Park2db76922017-11-08 16:03:48 +09001097 ctx.PropertyErrorf("vendor", msg)
1098 }
Colin Cross4157e882019-06-06 16:57:04 -07001099 if Bool(m.commonProperties.Proprietary) {
Jiyong Park2db76922017-11-08 16:03:48 +09001100 ctx.PropertyErrorf("proprietary", msg)
1101 }
Colin Cross4157e882019-06-06 16:57:04 -07001102 if Bool(m.commonProperties.Soc_specific) {
Jiyong Park2db76922017-11-08 16:03:48 +09001103 ctx.PropertyErrorf("soc_specific", msg)
1104 }
1105 }
1106
Justin Yund5f6c822019-06-25 16:47:17 +09001107 if productSpecific && systemExtSpecific {
1108 ctx.PropertyErrorf("product_specific", "a module cannot be specific to product and system_ext at the same time.")
1109 ctx.PropertyErrorf("system_ext_specific", msg)
Dario Frenifd05a742018-05-29 13:28:54 +01001110 }
1111
Justin Yund5f6c822019-06-25 16:47:17 +09001112 if (socSpecific || deviceSpecific) && (productSpecific || systemExtSpecific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001113 if productSpecific {
1114 ctx.PropertyErrorf("product_specific", "a module cannot be specific to SoC or device and product at the same time.")
1115 } else {
Justin Yund5f6c822019-06-25 16:47:17 +09001116 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 +01001117 }
1118 if deviceSpecific {
1119 ctx.PropertyErrorf("device_specific", msg)
1120 } else {
Colin Cross4157e882019-06-06 16:57:04 -07001121 if Bool(m.commonProperties.Vendor) {
Dario Frenifd05a742018-05-29 13:28:54 +01001122 ctx.PropertyErrorf("vendor", msg)
1123 }
Colin Cross4157e882019-06-06 16:57:04 -07001124 if Bool(m.commonProperties.Proprietary) {
Dario Frenifd05a742018-05-29 13:28:54 +01001125 ctx.PropertyErrorf("proprietary", msg)
1126 }
Colin Cross4157e882019-06-06 16:57:04 -07001127 if Bool(m.commonProperties.Soc_specific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001128 ctx.PropertyErrorf("soc_specific", msg)
1129 }
1130 }
1131 }
1132
Jiyong Park2db76922017-11-08 16:03:48 +09001133 if productSpecific {
1134 return productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +09001135 } else if systemExtSpecific {
1136 return systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001137 } else if deviceSpecific {
1138 return deviceSpecificModule
1139 } else if socSpecific {
1140 return socSpecificModule
1141 } else {
1142 return platformModule
1143 }
1144}
1145
Colin Crossc34d2322020-01-03 15:23:27 -08001146func (m *ModuleBase) earlyModuleContextFactory(ctx blueprint.EarlyModuleContext) earlyModuleContext {
Colin Cross1184b642019-12-30 18:43:07 -08001147 return earlyModuleContext{
Colin Crossc34d2322020-01-03 15:23:27 -08001148 EarlyModuleContext: ctx,
1149 kind: determineModuleKind(m, ctx),
1150 config: ctx.Config().(Config),
Colin Cross3f40fa42015-01-30 17:27:36 -08001151 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001152}
1153
Colin Cross1184b642019-12-30 18:43:07 -08001154func (m *ModuleBase) baseModuleContextFactory(ctx blueprint.BaseModuleContext) baseModuleContext {
1155 return baseModuleContext{
1156 bp: ctx,
1157 earlyModuleContext: m.earlyModuleContextFactory(ctx),
1158 os: m.commonProperties.CompileOS,
1159 target: m.commonProperties.CompileTarget,
1160 targetPrimary: m.commonProperties.CompilePrimary,
1161 multiTargets: m.commonProperties.CompileMultiTargets,
1162 }
1163}
1164
Colin Cross4157e882019-06-06 16:57:04 -07001165func (m *ModuleBase) GenerateBuildActions(blueprintCtx blueprint.ModuleContext) {
Colin Cross25de6c32019-06-06 14:29:25 -07001166 ctx := &moduleContext{
Colin Cross0ea8ba82019-06-06 14:33:29 -07001167 module: m.module,
Colin Crossdc35e212019-06-06 16:13:11 -07001168 bp: blueprintCtx,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001169 baseModuleContext: m.baseModuleContextFactory(blueprintCtx),
1170 installDeps: m.computeInstallDeps(blueprintCtx),
1171 installFiles: m.installFiles,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001172 variables: make(map[string]string),
Colin Cross3f40fa42015-01-30 17:27:36 -08001173 }
1174
Colin Cross6c4f21f2019-06-06 15:41:36 -07001175 // Temporarily continue to call blueprintCtx.GetMissingDependencies() to maintain the previous behavior of never
1176 // reporting missing dependency errors in Blueprint when AllowMissingDependencies == true.
1177 // TODO: This will be removed once defaults modules handle missing dependency errors
1178 blueprintCtx.GetMissingDependencies()
1179
Colin Crossdc35e212019-06-06 16:13:11 -07001180 // For the final GenerateAndroidBuildActions pass, require that all visited dependencies Soong modules and
Paul Duffin1356d8c2020-02-25 19:26:33 +00001181 // are enabled. Unless the module is a CommonOS variant which may have dependencies on disabled variants
1182 // (because the dependencies are added before the modules are disabled). The
1183 // GetOsSpecificVariantsOfCommonOSVariant(...) method will ensure that the disabled variants are
1184 // ignored.
1185 ctx.baseModuleContext.strictVisitDeps = !m.IsCommonOSVariant()
Colin Crossdc35e212019-06-06 16:13:11 -07001186
Colin Cross4c83e5c2019-02-25 14:54:28 -08001187 if ctx.config.captureBuild {
1188 ctx.ruleParams = make(map[blueprint.Rule]blueprint.RuleParams)
1189 }
1190
Colin Cross67a5c132017-05-09 13:45:28 -07001191 desc := "//" + ctx.ModuleDir() + ":" + ctx.ModuleName() + " "
1192 var suffix []string
Colin Cross0875c522017-11-28 17:34:01 -08001193 if ctx.Os().Class != Device && ctx.Os().Class != Generic {
1194 suffix = append(suffix, ctx.Os().String())
Colin Cross67a5c132017-05-09 13:45:28 -07001195 }
Colin Cross0875c522017-11-28 17:34:01 -08001196 if !ctx.PrimaryArch() {
1197 suffix = append(suffix, ctx.Arch().ArchType.String())
Colin Cross67a5c132017-05-09 13:45:28 -07001198 }
Dan Willemsenb13a9482020-02-14 11:25:54 -08001199 if apex, ok := m.module.(ApexModule); ok && !apex.IsForPlatform() {
1200 suffix = append(suffix, apex.ApexName())
1201 }
Colin Cross67a5c132017-05-09 13:45:28 -07001202
1203 ctx.Variable(pctx, "moduleDesc", desc)
1204
1205 s := ""
1206 if len(suffix) > 0 {
1207 s = " [" + strings.Join(suffix, " ") + "]"
1208 }
1209 ctx.Variable(pctx, "moduleDescSuffix", s)
1210
Dan Willemsen569edc52018-11-19 09:33:29 -08001211 // Some common property checks for properties that will be used later in androidmk.go
Colin Cross4157e882019-06-06 16:57:04 -07001212 if m.commonProperties.Dist.Dest != nil {
1213 _, err := validateSafePath(*m.commonProperties.Dist.Dest)
Dan Willemsen569edc52018-11-19 09:33:29 -08001214 if err != nil {
1215 ctx.PropertyErrorf("dist.dest", "%s", err.Error())
1216 }
1217 }
Colin Cross4157e882019-06-06 16:57:04 -07001218 if m.commonProperties.Dist.Dir != nil {
1219 _, err := validateSafePath(*m.commonProperties.Dist.Dir)
Dan Willemsen569edc52018-11-19 09:33:29 -08001220 if err != nil {
1221 ctx.PropertyErrorf("dist.dir", "%s", err.Error())
1222 }
1223 }
Colin Cross4157e882019-06-06 16:57:04 -07001224 if m.commonProperties.Dist.Suffix != nil {
1225 if strings.Contains(*m.commonProperties.Dist.Suffix, "/") {
Dan Willemsen569edc52018-11-19 09:33:29 -08001226 ctx.PropertyErrorf("dist.suffix", "Suffix may not contain a '/' character.")
1227 }
1228 }
1229
Colin Cross4157e882019-06-06 16:57:04 -07001230 if m.Enabled() {
Jooyung Hand48f3c32019-08-23 11:18:57 +09001231 // ensure all direct android.Module deps are enabled
1232 ctx.VisitDirectDepsBlueprint(func(bm blueprint.Module) {
1233 if _, ok := bm.(Module); ok {
1234 ctx.validateAndroidModule(bm, ctx.baseModuleContext.strictVisitDeps)
1235 }
1236 })
1237
Bob Badoura75b0572020-02-18 20:21:55 -08001238 m.noticeFiles = make([]Path, 0)
1239 optPath := OptionalPath{}
1240 notice := proptools.StringDefault(m.commonProperties.Notice, "")
Colin Cross4157e882019-06-06 16:57:04 -07001241 if module := SrcIsModule(notice); module != "" {
Bob Badoura75b0572020-02-18 20:21:55 -08001242 optPath = ctx.ExpandOptionalSource(&notice, "notice")
1243 } else if notice != "" {
Jiyong Park52818fc2019-03-18 12:01:38 +09001244 noticePath := filepath.Join(ctx.ModuleDir(), notice)
Bob Badoura75b0572020-02-18 20:21:55 -08001245 optPath = ExistentPathForSource(ctx, noticePath)
1246 }
1247 if optPath.Valid() {
1248 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1249 } else {
1250 for _, notice = range []string{"LICENSE", "LICENCE", "NOTICE"} {
1251 noticePath := filepath.Join(ctx.ModuleDir(), notice)
1252 optPath = ExistentPathForSource(ctx, noticePath)
1253 if optPath.Valid() {
1254 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1255 }
1256 }
Jaewoong Jung62707f72018-11-16 13:26:43 -08001257 }
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001258
1259 m.module.GenerateAndroidBuildActions(ctx)
1260 if ctx.Failed() {
1261 return
1262 }
1263
1264 m.installFiles = append(m.installFiles, ctx.installFiles...)
1265 m.checkbuildFiles = append(m.checkbuildFiles, ctx.checkbuildFiles...)
Inseob Kim8471cda2019-11-15 09:59:12 +09001266 m.initRcPaths = PathsForModuleSrc(ctx, m.commonProperties.Init_rc)
1267 m.vintfFragmentsPaths = PathsForModuleSrc(ctx, m.commonProperties.Vintf_fragments)
Colin Crossdc35e212019-06-06 16:13:11 -07001268 } else if ctx.Config().AllowMissingDependencies() {
1269 // If the module is not enabled it will not create any build rules, nothing will call
1270 // ctx.GetMissingDependencies(), and blueprint will consider the missing dependencies to be unhandled
1271 // and report them as an error even when AllowMissingDependencies = true. Call
1272 // ctx.GetMissingDependencies() here to tell blueprint not to handle them.
1273 ctx.GetMissingDependencies()
Colin Cross3f40fa42015-01-30 17:27:36 -08001274 }
1275
Colin Cross4157e882019-06-06 16:57:04 -07001276 if m == ctx.FinalModule().(Module).base() {
1277 m.generateModuleTarget(ctx)
Colin Cross9b1d13d2016-09-19 15:18:11 -07001278 if ctx.Failed() {
1279 return
1280 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001281 }
Colin Crosscec81712017-07-13 14:43:27 -07001282
Colin Cross4157e882019-06-06 16:57:04 -07001283 m.buildParams = ctx.buildParams
1284 m.ruleParams = ctx.ruleParams
1285 m.variables = ctx.variables
Colin Cross3f40fa42015-01-30 17:27:36 -08001286}
1287
Colin Cross1184b642019-12-30 18:43:07 -08001288type earlyModuleContext struct {
Colin Crossc34d2322020-01-03 15:23:27 -08001289 blueprint.EarlyModuleContext
Colin Cross1184b642019-12-30 18:43:07 -08001290
1291 kind moduleKind
1292 config Config
1293}
1294
1295func (e *earlyModuleContext) Glob(globPattern string, excludes []string) Paths {
1296 ret, err := e.GlobWithDeps(globPattern, excludes)
1297 if err != nil {
1298 e.ModuleErrorf("glob: %s", err.Error())
1299 }
1300 return pathsForModuleSrcFromFullPath(e, ret, true)
1301}
1302
1303func (e *earlyModuleContext) GlobFiles(globPattern string, excludes []string) Paths {
1304 ret, err := e.GlobWithDeps(globPattern, excludes)
1305 if err != nil {
1306 e.ModuleErrorf("glob: %s", err.Error())
1307 }
1308 return pathsForModuleSrcFromFullPath(e, ret, false)
1309}
1310
Colin Cross988414c2020-01-11 01:11:46 +00001311func (b *earlyModuleContext) IsSymlink(path Path) bool {
1312 fileInfo, err := b.config.fs.Lstat(path.String())
1313 if err != nil {
1314 b.ModuleErrorf("os.Lstat(%q) failed: %s", path.String(), err)
1315 }
1316 return fileInfo.Mode()&os.ModeSymlink == os.ModeSymlink
1317}
1318
1319func (b *earlyModuleContext) Readlink(path Path) string {
1320 dest, err := b.config.fs.Readlink(path.String())
1321 if err != nil {
1322 b.ModuleErrorf("os.Readlink(%q) failed: %s", path.String(), err)
1323 }
1324 return dest
1325}
1326
Colin Cross1184b642019-12-30 18:43:07 -08001327func (e *earlyModuleContext) Module() Module {
Colin Crossc34d2322020-01-03 15:23:27 -08001328 module, _ := e.EarlyModuleContext.Module().(Module)
Colin Cross1184b642019-12-30 18:43:07 -08001329 return module
1330}
1331
1332func (e *earlyModuleContext) Config() Config {
Colin Crossc34d2322020-01-03 15:23:27 -08001333 return e.EarlyModuleContext.Config().(Config)
Colin Cross1184b642019-12-30 18:43:07 -08001334}
1335
1336func (e *earlyModuleContext) AConfig() Config {
1337 return e.config
1338}
1339
1340func (e *earlyModuleContext) DeviceConfig() DeviceConfig {
1341 return DeviceConfig{e.config.deviceConfig}
1342}
1343
1344func (e *earlyModuleContext) Platform() bool {
1345 return e.kind == platformModule
1346}
1347
1348func (e *earlyModuleContext) DeviceSpecific() bool {
1349 return e.kind == deviceSpecificModule
1350}
1351
1352func (e *earlyModuleContext) SocSpecific() bool {
1353 return e.kind == socSpecificModule
1354}
1355
1356func (e *earlyModuleContext) ProductSpecific() bool {
1357 return e.kind == productSpecificModule
1358}
1359
1360func (e *earlyModuleContext) SystemExtSpecific() bool {
1361 return e.kind == systemExtSpecificModule
1362}
1363
1364type baseModuleContext struct {
1365 bp blueprint.BaseModuleContext
1366 earlyModuleContext
Colin Crossfb0c16e2019-11-20 17:12:35 -08001367 os OsType
Colin Cross8b74d172016-09-13 09:59:14 -07001368 target Target
Colin Crossee0bc3b2018-10-02 22:01:37 -07001369 multiTargets []Target
Colin Cross8b74d172016-09-13 09:59:14 -07001370 targetPrimary bool
1371 debug bool
Colin Crossdc35e212019-06-06 16:13:11 -07001372
1373 walkPath []Module
1374
1375 strictVisitDeps bool // If true, enforce that all dependencies are enabled
Colin Crossf6566ed2015-03-24 11:13:38 -07001376}
1377
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001378func (b *baseModuleContext) OtherModuleName(m blueprint.Module) string {
1379 return b.bp.OtherModuleName(m)
1380}
1381func (b *baseModuleContext) OtherModuleDir(m blueprint.Module) string { return b.bp.OtherModuleDir(m) }
Colin Cross1184b642019-12-30 18:43:07 -08001382func (b *baseModuleContext) OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{}) {
Jooyung Hancd87c692020-02-26 02:05:18 +09001383 b.bp.OtherModuleErrorf(m, fmt, args...)
Colin Cross1184b642019-12-30 18:43:07 -08001384}
1385func (b *baseModuleContext) OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag {
1386 return b.bp.OtherModuleDependencyTag(m)
1387}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001388func (b *baseModuleContext) OtherModuleExists(name string) bool { return b.bp.OtherModuleExists(name) }
1389func (b *baseModuleContext) OtherModuleType(m blueprint.Module) string {
1390 return b.bp.OtherModuleType(m)
1391}
Colin Cross1184b642019-12-30 18:43:07 -08001392
1393func (b *baseModuleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1394 return b.bp.GetDirectDepWithTag(name, tag)
1395}
1396
Colin Cross25de6c32019-06-06 14:29:25 -07001397type moduleContext struct {
Colin Crossdc35e212019-06-06 16:13:11 -07001398 bp blueprint.ModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -07001399 baseModuleContext
Colin Cross897266e2020-02-13 13:22:08 -08001400 installDeps InstallPaths
1401 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001402 checkbuildFiles Paths
Colin Cross8d8f8e22016-08-03 11:57:50 -07001403 module Module
Colin Crosscec81712017-07-13 14:43:27 -07001404
1405 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001406 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001407 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001408 variables map[string]string
Colin Cross6ff51382015-12-17 16:39:19 -08001409}
1410
Colin Crossb88b3c52019-06-10 15:15:17 -07001411func (m *moduleContext) ninjaError(params BuildParams, err error) (PackageContext, BuildParams) {
1412 return pctx, BuildParams{
Colin Cross4b69c492019-06-07 13:06:06 -07001413 Rule: ErrorRule,
1414 Description: params.Description,
1415 Output: params.Output,
1416 Outputs: params.Outputs,
1417 ImplicitOutput: params.ImplicitOutput,
1418 ImplicitOutputs: params.ImplicitOutputs,
Colin Cross6ff51382015-12-17 16:39:19 -08001419 Args: map[string]string{
1420 "error": err.Error(),
1421 },
Colin Crossb88b3c52019-06-10 15:15:17 -07001422 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001423}
1424
Colin Cross25de6c32019-06-06 14:29:25 -07001425func (m *moduleContext) ModuleBuild(pctx PackageContext, params ModuleBuildParams) {
1426 m.Build(pctx, BuildParams(params))
Colin Cross3f40fa42015-01-30 17:27:36 -08001427}
1428
Colin Cross0875c522017-11-28 17:34:01 -08001429func convertBuildParams(params BuildParams) blueprint.BuildParams {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001430 bparams := blueprint.BuildParams{
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001431 Rule: params.Rule,
Colin Cross0875c522017-11-28 17:34:01 -08001432 Description: params.Description,
Colin Cross33bfb0a2016-11-21 17:23:08 -08001433 Deps: params.Deps,
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001434 Outputs: params.Outputs.Strings(),
1435 ImplicitOutputs: params.ImplicitOutputs.Strings(),
1436 Inputs: params.Inputs.Strings(),
1437 Implicits: params.Implicits.Strings(),
1438 OrderOnly: params.OrderOnly.Strings(),
1439 Args: params.Args,
1440 Optional: !params.Default,
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001441 }
1442
Colin Cross33bfb0a2016-11-21 17:23:08 -08001443 if params.Depfile != nil {
1444 bparams.Depfile = params.Depfile.String()
1445 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001446 if params.Output != nil {
1447 bparams.Outputs = append(bparams.Outputs, params.Output.String())
1448 }
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001449 if params.ImplicitOutput != nil {
1450 bparams.ImplicitOutputs = append(bparams.ImplicitOutputs, params.ImplicitOutput.String())
1451 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001452 if params.Input != nil {
1453 bparams.Inputs = append(bparams.Inputs, params.Input.String())
1454 }
1455 if params.Implicit != nil {
1456 bparams.Implicits = append(bparams.Implicits, params.Implicit.String())
1457 }
1458
Colin Cross0b9f31f2019-02-28 11:00:01 -08001459 bparams.Outputs = proptools.NinjaEscapeList(bparams.Outputs)
1460 bparams.ImplicitOutputs = proptools.NinjaEscapeList(bparams.ImplicitOutputs)
1461 bparams.Inputs = proptools.NinjaEscapeList(bparams.Inputs)
1462 bparams.Implicits = proptools.NinjaEscapeList(bparams.Implicits)
1463 bparams.OrderOnly = proptools.NinjaEscapeList(bparams.OrderOnly)
1464 bparams.Depfile = proptools.NinjaEscapeList([]string{bparams.Depfile})[0]
Colin Crossfe4bc362018-09-12 10:02:13 -07001465
Colin Cross0875c522017-11-28 17:34:01 -08001466 return bparams
1467}
1468
Colin Cross25de6c32019-06-06 14:29:25 -07001469func (m *moduleContext) Variable(pctx PackageContext, name, value string) {
1470 if m.config.captureBuild {
1471 m.variables[name] = value
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001472 }
1473
Colin Crossdc35e212019-06-06 16:13:11 -07001474 m.bp.Variable(pctx.PackageContext, name, value)
Colin Cross0875c522017-11-28 17:34:01 -08001475}
1476
Colin Cross25de6c32019-06-06 14:29:25 -07001477func (m *moduleContext) Rule(pctx PackageContext, name string, params blueprint.RuleParams,
Colin Cross0875c522017-11-28 17:34:01 -08001478 argNames ...string) blueprint.Rule {
1479
Colin Cross8b8bec32019-11-15 13:18:43 -08001480 if m.config.UseRemoteBuild() && params.Pool == nil {
Ramy Medhatdd0418a2019-11-04 18:16:11 -05001481 // When USE_GOMA=true or USE_RBE=true are set and the rule is not supported by goma/RBE, restrict
1482 // jobs to the local parallelism value
Colin Cross2e2dbc22019-09-25 13:31:46 -07001483 params.Pool = localPool
1484 }
1485
Colin Crossdc35e212019-06-06 16:13:11 -07001486 rule := m.bp.Rule(pctx.PackageContext, name, params, argNames...)
Colin Cross4c83e5c2019-02-25 14:54:28 -08001487
Colin Cross25de6c32019-06-06 14:29:25 -07001488 if m.config.captureBuild {
1489 m.ruleParams[rule] = params
Colin Cross4c83e5c2019-02-25 14:54:28 -08001490 }
1491
1492 return rule
Colin Cross0875c522017-11-28 17:34:01 -08001493}
1494
Colin Cross25de6c32019-06-06 14:29:25 -07001495func (m *moduleContext) Build(pctx PackageContext, params BuildParams) {
Colin Crossb88b3c52019-06-10 15:15:17 -07001496 if params.Description != "" {
1497 params.Description = "${moduleDesc}" + params.Description + "${moduleDescSuffix}"
1498 }
1499
1500 if missingDeps := m.GetMissingDependencies(); len(missingDeps) > 0 {
1501 pctx, params = m.ninjaError(params, fmt.Errorf("module %s missing dependencies: %s\n",
1502 m.ModuleName(), strings.Join(missingDeps, ", ")))
1503 }
1504
Colin Cross25de6c32019-06-06 14:29:25 -07001505 if m.config.captureBuild {
1506 m.buildParams = append(m.buildParams, params)
Colin Cross0875c522017-11-28 17:34:01 -08001507 }
1508
Colin Crossdc35e212019-06-06 16:13:11 -07001509 m.bp.Build(pctx.PackageContext, convertBuildParams(params))
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001510}
Colin Cross25de6c32019-06-06 14:29:25 -07001511func (m *moduleContext) GetMissingDependencies() []string {
Colin Cross6c4f21f2019-06-06 15:41:36 -07001512 var missingDeps []string
1513 missingDeps = append(missingDeps, m.Module().base().commonProperties.MissingDeps...)
Colin Crossdc35e212019-06-06 16:13:11 -07001514 missingDeps = append(missingDeps, m.bp.GetMissingDependencies()...)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001515 missingDeps = FirstUniqueStrings(missingDeps)
1516 return missingDeps
Colin Cross6ff51382015-12-17 16:39:19 -08001517}
1518
Colin Crossdc35e212019-06-06 16:13:11 -07001519func (b *baseModuleContext) AddMissingDependencies(deps []string) {
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001520 if deps != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001521 missingDeps := &b.Module().base().commonProperties.MissingDeps
Colin Cross6c4f21f2019-06-06 15:41:36 -07001522 *missingDeps = append(*missingDeps, deps...)
1523 *missingDeps = FirstUniqueStrings(*missingDeps)
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001524 }
1525}
1526
Colin Crossdc35e212019-06-06 16:13:11 -07001527func (b *baseModuleContext) validateAndroidModule(module blueprint.Module, strict bool) Module {
Colin Crossd11fcda2017-10-23 17:59:01 -07001528 aModule, _ := module.(Module)
Colin Crossdc35e212019-06-06 16:13:11 -07001529
1530 if !strict {
1531 return aModule
1532 }
1533
Colin Cross380c69a2019-06-10 17:49:58 +00001534 if aModule == nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001535 b.ModuleErrorf("module %q not an android module", b.OtherModuleName(module))
Colin Cross380c69a2019-06-10 17:49:58 +00001536 return nil
1537 }
1538
1539 if !aModule.Enabled() {
Colin Crossdc35e212019-06-06 16:13:11 -07001540 if b.Config().AllowMissingDependencies() {
1541 b.AddMissingDependencies([]string{b.OtherModuleName(aModule)})
Colin Cross380c69a2019-06-10 17:49:58 +00001542 } else {
Colin Crossdc35e212019-06-06 16:13:11 -07001543 b.ModuleErrorf("depends on disabled module %q", b.OtherModuleName(aModule))
Colin Cross380c69a2019-06-10 17:49:58 +00001544 }
1545 return nil
1546 }
Colin Crossd11fcda2017-10-23 17:59:01 -07001547 return aModule
1548}
1549
Colin Crossdc35e212019-06-06 16:13:11 -07001550func (b *baseModuleContext) getDirectDepInternal(name string, tag blueprint.DependencyTag) (blueprint.Module, blueprint.DependencyTag) {
Jiyong Parkf2976302019-04-17 21:47:37 +09001551 type dep struct {
1552 mod blueprint.Module
1553 tag blueprint.DependencyTag
1554 }
1555 var deps []dep
Colin Crossdc35e212019-06-06 16:13:11 -07001556 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001557 if aModule, _ := module.(Module); aModule != nil && aModule.base().BaseModuleName() == name {
Colin Cross1184b642019-12-30 18:43:07 -08001558 returnedTag := b.bp.OtherModuleDependencyTag(aModule)
Jiyong Parkf2976302019-04-17 21:47:37 +09001559 if tag == nil || returnedTag == tag {
1560 deps = append(deps, dep{aModule, returnedTag})
1561 }
1562 }
1563 })
1564 if len(deps) == 1 {
1565 return deps[0].mod, deps[0].tag
1566 } else if len(deps) >= 2 {
1567 panic(fmt.Errorf("Multiple dependencies having same BaseModuleName() %q found from %q",
Colin Crossdc35e212019-06-06 16:13:11 -07001568 name, b.ModuleName()))
Jiyong Parkf2976302019-04-17 21:47:37 +09001569 } else {
1570 return nil, nil
1571 }
1572}
1573
Colin Crossdc35e212019-06-06 16:13:11 -07001574func (b *baseModuleContext) GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module {
Colin Cross0ef08162019-05-01 15:50:51 -07001575 var deps []Module
Colin Crossdc35e212019-06-06 16:13:11 -07001576 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001577 if aModule, _ := module.(Module); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001578 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Cross0ef08162019-05-01 15:50:51 -07001579 deps = append(deps, aModule)
1580 }
1581 }
1582 })
1583 return deps
1584}
1585
Colin Cross25de6c32019-06-06 14:29:25 -07001586func (m *moduleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1587 module, _ := m.getDirectDepInternal(name, tag)
1588 return module
Jiyong Parkf2976302019-04-17 21:47:37 +09001589}
1590
Colin Crossdc35e212019-06-06 16:13:11 -07001591func (b *baseModuleContext) GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag) {
1592 return b.getDirectDepInternal(name, nil)
Jiyong Parkf2976302019-04-17 21:47:37 +09001593}
1594
Colin Crossdc35e212019-06-06 16:13:11 -07001595func (b *baseModuleContext) VisitDirectDepsBlueprint(visit func(blueprint.Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001596 b.bp.VisitDirectDeps(visit)
Colin Cross35143d02017-11-16 00:11:20 -08001597}
1598
Colin Crossdc35e212019-06-06 16:13:11 -07001599func (b *baseModuleContext) VisitDirectDeps(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001600 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001601 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001602 visit(aModule)
1603 }
1604 })
1605}
1606
Colin Crossdc35e212019-06-06 16:13:11 -07001607func (b *baseModuleContext) VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001608 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001609 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001610 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Crossee6143c2017-12-30 17:54:27 -08001611 visit(aModule)
1612 }
1613 }
1614 })
1615}
1616
Colin Crossdc35e212019-06-06 16:13:11 -07001617func (b *baseModuleContext) VisitDirectDepsIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001618 b.bp.VisitDirectDepsIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001619 // pred
1620 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001621 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001622 return pred(aModule)
1623 } else {
1624 return false
1625 }
1626 },
1627 // visit
1628 func(module blueprint.Module) {
1629 visit(module.(Module))
1630 })
1631}
1632
Colin Crossdc35e212019-06-06 16:13:11 -07001633func (b *baseModuleContext) VisitDepsDepthFirst(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001634 b.bp.VisitDepsDepthFirst(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001635 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001636 visit(aModule)
1637 }
1638 })
1639}
1640
Colin Crossdc35e212019-06-06 16:13:11 -07001641func (b *baseModuleContext) VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001642 b.bp.VisitDepsDepthFirstIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001643 // pred
1644 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001645 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001646 return pred(aModule)
1647 } else {
1648 return false
1649 }
1650 },
1651 // visit
1652 func(module blueprint.Module) {
1653 visit(module.(Module))
1654 })
1655}
1656
Colin Crossdc35e212019-06-06 16:13:11 -07001657func (b *baseModuleContext) WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool) {
Colin Cross1184b642019-12-30 18:43:07 -08001658 b.bp.WalkDeps(visit)
Alex Light778127a2019-02-27 14:19:50 -08001659}
1660
Colin Crossdc35e212019-06-06 16:13:11 -07001661func (b *baseModuleContext) WalkDeps(visit func(Module, Module) bool) {
1662 b.walkPath = []Module{b.Module()}
Colin Cross1184b642019-12-30 18:43:07 -08001663 b.bp.WalkDeps(func(child, parent blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001664 childAndroidModule, _ := child.(Module)
1665 parentAndroidModule, _ := parent.(Module)
Colin Crossd11fcda2017-10-23 17:59:01 -07001666 if childAndroidModule != nil && parentAndroidModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001667 // record walkPath before visit
1668 for b.walkPath[len(b.walkPath)-1] != parentAndroidModule {
1669 b.walkPath = b.walkPath[0 : len(b.walkPath)-1]
1670 }
1671 b.walkPath = append(b.walkPath, childAndroidModule)
Colin Crossd11fcda2017-10-23 17:59:01 -07001672 return visit(childAndroidModule, parentAndroidModule)
1673 } else {
1674 return false
1675 }
1676 })
1677}
1678
Colin Crossdc35e212019-06-06 16:13:11 -07001679func (b *baseModuleContext) GetWalkPath() []Module {
1680 return b.walkPath
1681}
1682
Colin Cross25de6c32019-06-06 14:29:25 -07001683func (m *moduleContext) VisitAllModuleVariants(visit func(Module)) {
Colin Crossdc35e212019-06-06 16:13:11 -07001684 m.bp.VisitAllModuleVariants(func(module blueprint.Module) {
Colin Cross0875c522017-11-28 17:34:01 -08001685 visit(module.(Module))
1686 })
1687}
1688
Colin Cross25de6c32019-06-06 14:29:25 -07001689func (m *moduleContext) PrimaryModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001690 return m.bp.PrimaryModule().(Module)
Colin Cross0875c522017-11-28 17:34:01 -08001691}
1692
Colin Cross25de6c32019-06-06 14:29:25 -07001693func (m *moduleContext) FinalModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001694 return m.bp.FinalModule().(Module)
1695}
1696
1697func (m *moduleContext) ModuleSubDir() string {
1698 return m.bp.ModuleSubDir()
Colin Cross0875c522017-11-28 17:34:01 -08001699}
1700
Colin Cross0ea8ba82019-06-06 14:33:29 -07001701func (b *baseModuleContext) Target() Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001702 return b.target
Colin Crossa1ad8d12016-06-01 17:09:44 -07001703}
1704
Colin Cross0ea8ba82019-06-06 14:33:29 -07001705func (b *baseModuleContext) TargetPrimary() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001706 return b.targetPrimary
Colin Cross8b74d172016-09-13 09:59:14 -07001707}
1708
Colin Cross0ea8ba82019-06-06 14:33:29 -07001709func (b *baseModuleContext) MultiTargets() []Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001710 return b.multiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07001711}
1712
Colin Cross0ea8ba82019-06-06 14:33:29 -07001713func (b *baseModuleContext) Arch() Arch {
Colin Cross25de6c32019-06-06 14:29:25 -07001714 return b.target.Arch
Colin Cross3f40fa42015-01-30 17:27:36 -08001715}
1716
Colin Cross0ea8ba82019-06-06 14:33:29 -07001717func (b *baseModuleContext) Os() OsType {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001718 return b.os
Dan Willemsen490fd492015-11-24 17:53:15 -08001719}
1720
Colin Cross0ea8ba82019-06-06 14:33:29 -07001721func (b *baseModuleContext) Host() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001722 return b.os.Class == Host || b.os.Class == HostCross
Colin Crossf6566ed2015-03-24 11:13:38 -07001723}
1724
Colin Cross0ea8ba82019-06-06 14:33:29 -07001725func (b *baseModuleContext) Device() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001726 return b.os.Class == Device
Colin Crossf6566ed2015-03-24 11:13:38 -07001727}
1728
Colin Cross0ea8ba82019-06-06 14:33:29 -07001729func (b *baseModuleContext) Darwin() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001730 return b.os == Darwin
Colin Cross0af4b842015-04-30 16:36:18 -07001731}
1732
Colin Cross0ea8ba82019-06-06 14:33:29 -07001733func (b *baseModuleContext) Fuchsia() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001734 return b.os == Fuchsia
Doug Horn21b94272019-01-16 12:06:11 -08001735}
1736
Colin Cross0ea8ba82019-06-06 14:33:29 -07001737func (b *baseModuleContext) Windows() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001738 return b.os == Windows
Colin Cross3edeee12017-04-04 12:59:48 -07001739}
1740
Colin Cross0ea8ba82019-06-06 14:33:29 -07001741func (b *baseModuleContext) Debug() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001742 return b.debug
Colin Crossf6566ed2015-03-24 11:13:38 -07001743}
1744
Colin Cross0ea8ba82019-06-06 14:33:29 -07001745func (b *baseModuleContext) PrimaryArch() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001746 if len(b.config.Targets[b.target.Os]) <= 1 {
Colin Cross67a5c132017-05-09 13:45:28 -07001747 return true
1748 }
Colin Cross25de6c32019-06-06 14:29:25 -07001749 return b.target.Arch.ArchType == b.config.Targets[b.target.Os][0].Arch.ArchType
Colin Cross1e7d3702016-08-24 15:25:47 -07001750}
1751
Jiyong Park5baac542018-08-28 09:55:37 +09001752// Makes this module a platform module, i.e. not specific to soc, device,
Justin Yund5f6c822019-06-25 16:47:17 +09001753// product, or system_ext.
Colin Cross4157e882019-06-06 16:57:04 -07001754func (m *ModuleBase) MakeAsPlatform() {
1755 m.commonProperties.Vendor = boolPtr(false)
1756 m.commonProperties.Proprietary = boolPtr(false)
1757 m.commonProperties.Soc_specific = boolPtr(false)
1758 m.commonProperties.Product_specific = boolPtr(false)
Justin Yund5f6c822019-06-25 16:47:17 +09001759 m.commonProperties.System_ext_specific = boolPtr(false)
Jiyong Park5baac542018-08-28 09:55:37 +09001760}
1761
Colin Cross4157e882019-06-06 16:57:04 -07001762func (m *ModuleBase) EnableNativeBridgeSupportByDefault() {
1763 m.commonProperties.Native_bridge_supported = boolPtr(true)
dimitry03dc3f62019-05-09 14:07:34 +02001764}
1765
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001766func (m *ModuleBase) MakeAsSystemExt() {
Jooyung Han91df2082019-11-20 01:49:42 +09001767 m.commonProperties.Vendor = boolPtr(false)
1768 m.commonProperties.Proprietary = boolPtr(false)
1769 m.commonProperties.Soc_specific = boolPtr(false)
1770 m.commonProperties.Product_specific = boolPtr(false)
1771 m.commonProperties.System_ext_specific = boolPtr(true)
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001772}
1773
Jooyung Han344d5432019-08-23 11:17:39 +09001774// IsNativeBridgeSupported returns true if "native_bridge_supported" is explicitly set as "true"
1775func (m *ModuleBase) IsNativeBridgeSupported() bool {
1776 return proptools.Bool(m.commonProperties.Native_bridge_supported)
1777}
1778
Colin Cross25de6c32019-06-06 14:29:25 -07001779func (m *moduleContext) InstallInData() bool {
1780 return m.module.InstallInData()
Dan Willemsen782a2d12015-12-21 14:55:28 -08001781}
1782
Jaewoong Jung0949f312019-09-11 10:25:18 -07001783func (m *moduleContext) InstallInTestcases() bool {
1784 return m.module.InstallInTestcases()
1785}
1786
Colin Cross25de6c32019-06-06 14:29:25 -07001787func (m *moduleContext) InstallInSanitizerDir() bool {
1788 return m.module.InstallInSanitizerDir()
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001789}
1790
Yifan Hong1b3348d2020-01-21 15:53:22 -08001791func (m *moduleContext) InstallInRamdisk() bool {
1792 return m.module.InstallInRamdisk()
1793}
1794
Colin Cross25de6c32019-06-06 14:29:25 -07001795func (m *moduleContext) InstallInRecovery() bool {
1796 return m.module.InstallInRecovery()
Jiyong Parkf9332f12018-02-01 00:54:12 +09001797}
1798
Colin Cross90ba5f42019-10-02 11:10:58 -07001799func (m *moduleContext) InstallInRoot() bool {
1800 return m.module.InstallInRoot()
1801}
1802
Colin Cross607d8582019-07-29 16:44:46 -07001803func (m *moduleContext) InstallBypassMake() bool {
1804 return m.module.InstallBypassMake()
1805}
1806
Colin Cross6e359402020-02-10 15:29:54 -08001807func (m *moduleContext) InstallForceOS() *OsType {
1808 return m.module.InstallForceOS()
1809}
1810
Colin Cross70dda7e2019-10-01 22:05:35 -07001811func (m *moduleContext) skipInstall(fullInstallPath InstallPath) bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001812 if m.module.base().commonProperties.SkipInstall {
Colin Cross893d8162017-04-26 17:34:03 -07001813 return true
1814 }
1815
Colin Cross3607f212018-05-07 15:28:05 -07001816 // We'll need a solution for choosing which of modules with the same name in different
1817 // namespaces to install. For now, reuse the list of namespaces exported to Make as the
1818 // list of namespaces to install in a Soong-only build.
Colin Cross25de6c32019-06-06 14:29:25 -07001819 if !m.module.base().commonProperties.NamespaceExportedToMake {
Colin Cross3607f212018-05-07 15:28:05 -07001820 return true
1821 }
1822
Colin Cross25de6c32019-06-06 14:29:25 -07001823 if m.Device() {
Colin Cross607d8582019-07-29 16:44:46 -07001824 if m.Config().EmbeddedInMake() && !m.InstallBypassMake() {
Colin Cross893d8162017-04-26 17:34:03 -07001825 return true
1826 }
1827
Colin Cross25de6c32019-06-06 14:29:25 -07001828 if m.Config().SkipMegaDeviceInstall(fullInstallPath.String()) {
Colin Cross893d8162017-04-26 17:34:03 -07001829 return true
1830 }
1831 }
1832
1833 return false
1834}
1835
Colin Cross70dda7e2019-10-01 22:05:35 -07001836func (m *moduleContext) InstallFile(installPath InstallPath, name string, srcPath Path,
1837 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001838 return m.installFile(installPath, name, srcPath, Cp, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001839}
1840
Colin Cross70dda7e2019-10-01 22:05:35 -07001841func (m *moduleContext) InstallExecutable(installPath InstallPath, name string, srcPath Path,
1842 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001843 return m.installFile(installPath, name, srcPath, CpExecutable, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001844}
1845
Colin Cross70dda7e2019-10-01 22:05:35 -07001846func (m *moduleContext) installFile(installPath InstallPath, name string, srcPath Path,
1847 rule blueprint.Rule, deps []Path) InstallPath {
Colin Cross35cec122015-04-02 14:37:16 -07001848
Colin Cross25de6c32019-06-06 14:29:25 -07001849 fullInstallPath := installPath.Join(m, name)
1850 m.module.base().hooks.runInstallHooks(m, fullInstallPath, false)
Colin Cross3f40fa42015-01-30 17:27:36 -08001851
Colin Cross25de6c32019-06-06 14:29:25 -07001852 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001853
Colin Cross897266e2020-02-13 13:22:08 -08001854 deps = append(deps, m.installDeps.Paths()...)
Colin Cross35cec122015-04-02 14:37:16 -07001855
Colin Cross89562dc2016-10-03 17:47:19 -07001856 var implicitDeps, orderOnlyDeps Paths
1857
Colin Cross25de6c32019-06-06 14:29:25 -07001858 if m.Host() {
Colin Cross89562dc2016-10-03 17:47:19 -07001859 // Installed host modules might be used during the build, depend directly on their
1860 // dependencies so their timestamp is updated whenever their dependency is updated
1861 implicitDeps = deps
1862 } else {
1863 orderOnlyDeps = deps
1864 }
1865
Colin Cross25de6c32019-06-06 14:29:25 -07001866 m.Build(pctx, BuildParams{
Colin Cross5c517922017-08-31 12:29:17 -07001867 Rule: rule,
Colin Cross67a5c132017-05-09 13:45:28 -07001868 Description: "install " + fullInstallPath.Base(),
1869 Output: fullInstallPath,
1870 Input: srcPath,
1871 Implicits: implicitDeps,
1872 OrderOnly: orderOnlyDeps,
Colin Cross25de6c32019-06-06 14:29:25 -07001873 Default: !m.Config().EmbeddedInMake(),
Dan Willemsen322acaf2016-01-12 23:07:05 -08001874 })
Colin Cross3f40fa42015-01-30 17:27:36 -08001875
Colin Cross25de6c32019-06-06 14:29:25 -07001876 m.installFiles = append(m.installFiles, fullInstallPath)
Dan Willemsen322acaf2016-01-12 23:07:05 -08001877 }
Colin Cross25de6c32019-06-06 14:29:25 -07001878 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross35cec122015-04-02 14:37:16 -07001879 return fullInstallPath
1880}
1881
Colin Cross70dda7e2019-10-01 22:05:35 -07001882func (m *moduleContext) InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001883 fullInstallPath := installPath.Join(m, name)
1884 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Colin Cross3854a602016-01-11 12:49:11 -08001885
Colin Cross25de6c32019-06-06 14:29:25 -07001886 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001887
Alex Lightfb4353d2019-01-17 13:57:45 -08001888 relPath, err := filepath.Rel(path.Dir(fullInstallPath.String()), srcPath.String())
1889 if err != nil {
1890 panic(fmt.Sprintf("Unable to generate symlink between %q and %q: %s", fullInstallPath.Base(), srcPath.Base(), err))
1891 }
Colin Cross25de6c32019-06-06 14:29:25 -07001892 m.Build(pctx, BuildParams{
Colin Cross67a5c132017-05-09 13:45:28 -07001893 Rule: Symlink,
1894 Description: "install symlink " + fullInstallPath.Base(),
1895 Output: fullInstallPath,
Dan Willemsen40efa1c2020-01-14 15:19:52 -08001896 Input: srcPath,
Colin Cross25de6c32019-06-06 14:29:25 -07001897 Default: !m.Config().EmbeddedInMake(),
Colin Cross12fc4972016-01-11 12:49:11 -08001898 Args: map[string]string{
Alex Lightfb4353d2019-01-17 13:57:45 -08001899 "fromPath": relPath,
Colin Cross12fc4972016-01-11 12:49:11 -08001900 },
1901 })
Colin Cross3854a602016-01-11 12:49:11 -08001902
Colin Cross25de6c32019-06-06 14:29:25 -07001903 m.installFiles = append(m.installFiles, fullInstallPath)
1904 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross12fc4972016-01-11 12:49:11 -08001905 }
Colin Cross3854a602016-01-11 12:49:11 -08001906 return fullInstallPath
1907}
1908
Jiyong Parkf1194352019-02-25 11:05:47 +09001909// installPath/name -> absPath where absPath might be a path that is available only at runtime
1910// (e.g. /apex/...)
Colin Cross70dda7e2019-10-01 22:05:35 -07001911func (m *moduleContext) InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001912 fullInstallPath := installPath.Join(m, name)
1913 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Jiyong Parkf1194352019-02-25 11:05:47 +09001914
Colin Cross25de6c32019-06-06 14:29:25 -07001915 if !m.skipInstall(fullInstallPath) {
1916 m.Build(pctx, BuildParams{
Jiyong Parkf1194352019-02-25 11:05:47 +09001917 Rule: Symlink,
1918 Description: "install symlink " + fullInstallPath.Base() + " -> " + absPath,
1919 Output: fullInstallPath,
Colin Cross25de6c32019-06-06 14:29:25 -07001920 Default: !m.Config().EmbeddedInMake(),
Jiyong Parkf1194352019-02-25 11:05:47 +09001921 Args: map[string]string{
1922 "fromPath": absPath,
1923 },
1924 })
1925
Colin Cross25de6c32019-06-06 14:29:25 -07001926 m.installFiles = append(m.installFiles, fullInstallPath)
Jiyong Parkf1194352019-02-25 11:05:47 +09001927 }
1928 return fullInstallPath
1929}
1930
Colin Cross25de6c32019-06-06 14:29:25 -07001931func (m *moduleContext) CheckbuildFile(srcPath Path) {
1932 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross3f40fa42015-01-30 17:27:36 -08001933}
1934
Dan Willemsen2ef08f42015-06-30 18:15:24 -07001935func findStringInSlice(str string, slice []string) int {
1936 for i, s := range slice {
1937 if s == str {
1938 return i
Colin Crossfce53272015-04-08 11:21:40 -07001939 }
1940 }
Dan Willemsen2ef08f42015-06-30 18:15:24 -07001941 return -1
1942}
1943
Colin Cross41955e82019-05-29 14:40:35 -07001944// SrcIsModule decodes module references in the format ":name" into the module name, or empty string if the input
1945// was not a module reference.
1946func SrcIsModule(s string) (module string) {
Colin Cross068e0fe2016-12-13 15:23:47 -08001947 if len(s) > 1 && s[0] == ':' {
1948 return s[1:]
1949 }
1950 return ""
1951}
1952
Colin Cross41955e82019-05-29 14:40:35 -07001953// SrcIsModule decodes module references in the format ":name{.tag}" into the module name and tag, ":name" into the
1954// module name and an empty string for the tag, or empty strings if the input was not a module reference.
1955func SrcIsModuleWithTag(s string) (module, tag string) {
1956 if len(s) > 1 && s[0] == ':' {
1957 module = s[1:]
1958 if tagStart := strings.IndexByte(module, '{'); tagStart > 0 {
1959 if module[len(module)-1] == '}' {
1960 tag = module[tagStart+1 : len(module)-1]
1961 module = module[:tagStart]
1962 return module, tag
1963 }
1964 }
1965 return module, ""
1966 }
1967 return "", ""
Colin Cross068e0fe2016-12-13 15:23:47 -08001968}
1969
Colin Cross41955e82019-05-29 14:40:35 -07001970type sourceOrOutputDependencyTag struct {
1971 blueprint.BaseDependencyTag
1972 tag string
1973}
1974
1975func sourceOrOutputDepTag(tag string) blueprint.DependencyTag {
1976 return sourceOrOutputDependencyTag{tag: tag}
1977}
1978
1979var SourceDepTag = sourceOrOutputDepTag("")
Colin Cross068e0fe2016-12-13 15:23:47 -08001980
Colin Cross366938f2017-12-11 16:29:02 -08001981// Adds necessary dependencies to satisfy filegroup or generated sources modules listed in srcFiles
1982// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08001983//
1984// Deprecated: tag the property with `android:"path"` instead.
Colin Cross068e0fe2016-12-13 15:23:47 -08001985func ExtractSourcesDeps(ctx BottomUpMutatorContext, srcFiles []string) {
Nan Zhang2439eb72017-04-10 11:27:50 -07001986 set := make(map[string]bool)
1987
Colin Cross068e0fe2016-12-13 15:23:47 -08001988 for _, s := range srcFiles {
Colin Cross41955e82019-05-29 14:40:35 -07001989 if m, t := SrcIsModuleWithTag(s); m != "" {
1990 if _, found := set[s]; found {
1991 ctx.ModuleErrorf("found source dependency duplicate: %q!", s)
Nan Zhang2439eb72017-04-10 11:27:50 -07001992 } else {
Colin Cross41955e82019-05-29 14:40:35 -07001993 set[s] = true
1994 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Nan Zhang2439eb72017-04-10 11:27:50 -07001995 }
Colin Cross068e0fe2016-12-13 15:23:47 -08001996 }
1997 }
Colin Cross068e0fe2016-12-13 15:23:47 -08001998}
1999
Colin Cross366938f2017-12-11 16:29:02 -08002000// Adds necessary dependencies to satisfy filegroup or generated sources modules specified in s
2001// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002002//
2003// Deprecated: tag the property with `android:"path"` instead.
Colin Cross366938f2017-12-11 16:29:02 -08002004func ExtractSourceDeps(ctx BottomUpMutatorContext, s *string) {
2005 if s != nil {
Colin Cross41955e82019-05-29 14:40:35 -07002006 if m, t := SrcIsModuleWithTag(*s); m != "" {
2007 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Colin Cross366938f2017-12-11 16:29:02 -08002008 }
2009 }
2010}
2011
Colin Cross41955e82019-05-29 14:40:35 -07002012// A module that implements SourceFileProducer can be referenced from any property that is tagged with `android:"path"`
2013// 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 -08002014type SourceFileProducer interface {
2015 Srcs() Paths
2016}
2017
Colin Cross41955e82019-05-29 14:40:35 -07002018// A module that implements OutputFileProducer can be referenced from any property that is tagged with `android:"path"`
Roland Levillain97c1f342019-11-22 14:20:54 +00002019// 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 -07002020// listed in the property.
2021type OutputFileProducer interface {
2022 OutputFiles(tag string) (Paths, error)
2023}
2024
Colin Cross5e708052019-08-06 13:59:50 -07002025// OutputFilesForModule returns the paths from an OutputFileProducer with the given tag. On error, including if the
2026// module produced zero paths, it reports errors to the ctx and returns nil.
2027func OutputFilesForModule(ctx PathContext, module blueprint.Module, tag string) Paths {
2028 paths, err := outputFilesForModule(ctx, module, tag)
2029 if err != nil {
2030 reportPathError(ctx, err)
2031 return nil
2032 }
2033 return paths
2034}
2035
2036// OutputFileForModule returns the path from an OutputFileProducer with the given tag. On error, including if the
2037// module produced zero or multiple paths, it reports errors to the ctx and returns nil.
2038func OutputFileForModule(ctx PathContext, module blueprint.Module, tag string) Path {
2039 paths, err := outputFilesForModule(ctx, module, tag)
2040 if err != nil {
2041 reportPathError(ctx, err)
2042 return nil
2043 }
2044 if len(paths) > 1 {
2045 reportPathErrorf(ctx, "got multiple output files from module %q, expected exactly one",
2046 pathContextName(ctx, module))
2047 return nil
2048 }
2049 return paths[0]
2050}
2051
2052func outputFilesForModule(ctx PathContext, module blueprint.Module, tag string) (Paths, error) {
2053 if outputFileProducer, ok := module.(OutputFileProducer); ok {
2054 paths, err := outputFileProducer.OutputFiles(tag)
2055 if err != nil {
2056 return nil, fmt.Errorf("failed to get output file from module %q: %s",
2057 pathContextName(ctx, module), err.Error())
2058 }
2059 if len(paths) == 0 {
2060 return nil, fmt.Errorf("failed to get output files from module %q", pathContextName(ctx, module))
2061 }
2062 return paths, nil
2063 } else {
2064 return nil, fmt.Errorf("module %q is not an OutputFileProducer", pathContextName(ctx, module))
2065 }
2066}
2067
Colin Crossfe17f6f2019-03-28 19:30:56 -07002068type HostToolProvider interface {
2069 HostToolPath() OptionalPath
2070}
2071
Colin Cross27b922f2019-03-04 22:35:41 -08002072// Returns a list of paths expanded from globs and modules referenced using ":module" syntax. The property must
2073// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002074//
2075// Deprecated: use PathsForModuleSrc or PathsForModuleSrcExcludes instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002076func (m *moduleContext) ExpandSources(srcFiles, excludes []string) Paths {
2077 return PathsForModuleSrcExcludes(m, srcFiles, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07002078}
2079
Colin Cross2fafa3e2019-03-05 12:39:51 -08002080// Returns a single path expanded from globs and modules referenced using ":module" syntax. The property must
2081// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002082//
2083// Deprecated: use PathForModuleSrc instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002084func (m *moduleContext) ExpandSource(srcFile, prop string) Path {
2085 return PathForModuleSrc(m, srcFile)
Colin Cross2fafa3e2019-03-05 12:39:51 -08002086}
2087
2088// Returns an optional single path expanded from globs and modules referenced using ":module" syntax if
2089// the srcFile is non-nil. The property must be tagged with `android:"path" to support automatic source module
2090// dependency resolution.
Colin Cross25de6c32019-06-06 14:29:25 -07002091func (m *moduleContext) ExpandOptionalSource(srcFile *string, prop string) OptionalPath {
Colin Cross2fafa3e2019-03-05 12:39:51 -08002092 if srcFile != nil {
Colin Cross25de6c32019-06-06 14:29:25 -07002093 return OptionalPathForPath(PathForModuleSrc(m, *srcFile))
Colin Cross2fafa3e2019-03-05 12:39:51 -08002094 }
2095 return OptionalPath{}
2096}
2097
Colin Cross25de6c32019-06-06 14:29:25 -07002098func (m *moduleContext) RequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002099 return m.module.RequiredModuleNames()
Nan Zhang6d34b302017-02-04 17:47:46 -08002100}
2101
Colin Cross25de6c32019-06-06 14:29:25 -07002102func (m *moduleContext) HostRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002103 return m.module.HostRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002104}
2105
Colin Cross25de6c32019-06-06 14:29:25 -07002106func (m *moduleContext) TargetRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002107 return m.module.TargetRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002108}
2109
Colin Cross463a90e2015-06-17 14:20:06 -07002110func init() {
Colin Cross798bfce2016-10-12 14:28:16 -07002111 RegisterSingletonType("buildtarget", BuildTargetSingleton)
Colin Cross463a90e2015-06-17 14:20:06 -07002112}
2113
Colin Cross0875c522017-11-28 17:34:01 -08002114func BuildTargetSingleton() Singleton {
Colin Cross1f8c52b2015-06-16 16:38:17 -07002115 return &buildTargetSingleton{}
2116}
2117
Colin Cross87d8b562017-04-25 10:01:55 -07002118func parentDir(dir string) string {
2119 dir, _ = filepath.Split(dir)
2120 return filepath.Clean(dir)
2121}
2122
Colin Cross1f8c52b2015-06-16 16:38:17 -07002123type buildTargetSingleton struct{}
2124
Colin Cross0875c522017-11-28 17:34:01 -08002125func (c *buildTargetSingleton) GenerateBuildActions(ctx SingletonContext) {
2126 var checkbuildDeps Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07002127
Colin Cross0875c522017-11-28 17:34:01 -08002128 mmTarget := func(dir string) WritablePath {
2129 return PathForPhony(ctx,
2130 "MODULES-IN-"+strings.Replace(filepath.Clean(dir), "/", "-", -1))
Colin Cross87d8b562017-04-25 10:01:55 -07002131 }
2132
Colin Cross0875c522017-11-28 17:34:01 -08002133 modulesInDir := make(map[string]Paths)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002134
Colin Cross0875c522017-11-28 17:34:01 -08002135 ctx.VisitAllModules(func(module Module) {
2136 blueprintDir := module.base().blueprintDir
2137 installTarget := module.base().installTarget
2138 checkbuildTarget := module.base().checkbuildTarget
Colin Cross1f8c52b2015-06-16 16:38:17 -07002139
Colin Cross0875c522017-11-28 17:34:01 -08002140 if checkbuildTarget != nil {
2141 checkbuildDeps = append(checkbuildDeps, checkbuildTarget)
2142 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], checkbuildTarget)
2143 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002144
Colin Cross0875c522017-11-28 17:34:01 -08002145 if installTarget != nil {
2146 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], installTarget)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002147 }
2148 })
2149
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002150 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08002151 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002152 suffix = "-soong"
2153 }
2154
Colin Cross1f8c52b2015-06-16 16:38:17 -07002155 // Create a top-level checkbuild target that depends on all modules
Colin Cross0875c522017-11-28 17:34:01 -08002156 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07002157 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002158 Output: PathForPhony(ctx, "checkbuild"+suffix),
Colin Cross1f8c52b2015-06-16 16:38:17 -07002159 Implicits: checkbuildDeps,
Colin Cross1f8c52b2015-06-16 16:38:17 -07002160 })
2161
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002162 // Make will generate the MODULES-IN-* targets
Colin Crossaabf6792017-11-29 00:27:14 -08002163 if ctx.Config().EmbeddedInMake() {
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002164 return
2165 }
2166
Colin Cross87d8b562017-04-25 10:01:55 -07002167 // Ensure ancestor directories are in modulesInDir
Inseob Kim1a365c62019-06-08 15:47:51 +09002168 dirs := SortedStringKeys(modulesInDir)
Colin Cross87d8b562017-04-25 10:01:55 -07002169 for _, dir := range dirs {
2170 dir := parentDir(dir)
2171 for dir != "." && dir != "/" {
2172 if _, exists := modulesInDir[dir]; exists {
2173 break
2174 }
2175 modulesInDir[dir] = nil
2176 dir = parentDir(dir)
2177 }
2178 }
2179
2180 // Make directories build their direct subdirectories
Colin Cross87d8b562017-04-25 10:01:55 -07002181 for _, dir := range dirs {
2182 p := parentDir(dir)
2183 if p != "." && p != "/" {
2184 modulesInDir[p] = append(modulesInDir[p], mmTarget(dir))
2185 }
2186 }
2187
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002188 // Create a MODULES-IN-<directory> target that depends on all modules in a directory, and
2189 // depends on the MODULES-IN-* targets of all of its subdirectories that contain Android.bp
2190 // files.
Colin Cross1f8c52b2015-06-16 16:38:17 -07002191 for _, dir := range dirs {
Colin Cross0875c522017-11-28 17:34:01 -08002192 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07002193 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002194 Output: mmTarget(dir),
Colin Cross87d8b562017-04-25 10:01:55 -07002195 Implicits: modulesInDir[dir],
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002196 // HACK: checkbuild should be an optional build, but force it
2197 // enabled for now in standalone builds
Colin Crossaabf6792017-11-29 00:27:14 -08002198 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross1f8c52b2015-06-16 16:38:17 -07002199 })
2200 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002201
2202 // Create (host|host-cross|target)-<OS> phony rules to build a reduced checkbuild.
2203 osDeps := map[OsType]Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08002204 ctx.VisitAllModules(func(module Module) {
2205 if module.Enabled() {
2206 os := module.Target().Os
2207 osDeps[os] = append(osDeps[os], module.base().checkbuildFiles...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002208 }
2209 })
2210
Colin Cross0875c522017-11-28 17:34:01 -08002211 osClass := make(map[string]Paths)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002212 for os, deps := range osDeps {
2213 var className string
2214
2215 switch os.Class {
2216 case Host:
2217 className = "host"
2218 case HostCross:
2219 className = "host-cross"
2220 case Device:
2221 className = "target"
2222 default:
2223 continue
2224 }
2225
Colin Cross0875c522017-11-28 17:34:01 -08002226 name := PathForPhony(ctx, className+"-"+os.Name)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002227 osClass[className] = append(osClass[className], name)
2228
Colin Cross0875c522017-11-28 17:34:01 -08002229 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07002230 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002231 Output: name,
2232 Implicits: deps,
Dan Willemsen61d88b82017-09-20 17:29:08 -07002233 })
2234 }
2235
2236 // Wrap those into host|host-cross|target phony rules
Inseob Kim1a365c62019-06-08 15:47:51 +09002237 for _, class := range SortedStringKeys(osClass) {
Colin Cross0875c522017-11-28 17:34:01 -08002238 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07002239 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002240 Output: PathForPhony(ctx, class),
Dan Willemsen61d88b82017-09-20 17:29:08 -07002241 Implicits: osClass[class],
Dan Willemsen61d88b82017-09-20 17:29:08 -07002242 })
2243 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002244}
Colin Crossd779da42015-12-17 18:00:23 -08002245
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002246// Collect information for opening IDE project files in java/jdeps.go.
2247type IDEInfo interface {
2248 IDEInfo(ideInfo *IdeInfo)
2249 BaseModuleName() string
2250}
2251
2252// Extract the base module name from the Import name.
2253// Often the Import name has a prefix "prebuilt_".
2254// Remove the prefix explicitly if needed
2255// until we find a better solution to get the Import name.
2256type IDECustomizedModuleName interface {
2257 IDECustomizedModuleName() string
2258}
2259
2260type IdeInfo struct {
2261 Deps []string `json:"dependencies,omitempty"`
2262 Srcs []string `json:"srcs,omitempty"`
2263 Aidl_include_dirs []string `json:"aidl_include_dirs,omitempty"`
2264 Jarjar_rules []string `json:"jarjar_rules,omitempty"`
2265 Jars []string `json:"jars,omitempty"`
2266 Classes []string `json:"class,omitempty"`
2267 Installed_paths []string `json:"installed,omitempty"`
patricktu18c82ff2019-05-10 15:48:50 +08002268 SrcJars []string `json:"srcjars,omitempty"`
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002269}