blob: e7959e82f974f36773d47eb3d96c27d8053c4596 [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"
Jiyong Park1c7e9622020-05-07 16:12:13 +090022 "regexp"
Colin Cross6ff51382015-12-17 16:39:19 -080023 "strings"
Colin Crossaabf6792017-11-29 00:27:14 -080024 "text/scanner"
Colin Crossf6566ed2015-03-24 11:13:38 -070025
26 "github.com/google/blueprint"
Colin Crossfe4bc362018-09-12 10:02:13 -070027 "github.com/google/blueprint/proptools"
Colin Cross3f40fa42015-01-30 17:27:36 -080028)
29
30var (
31 DeviceSharedLibrary = "shared_library"
32 DeviceStaticLibrary = "static_library"
33 DeviceExecutable = "executable"
34 HostSharedLibrary = "host_shared_library"
35 HostStaticLibrary = "host_static_library"
36 HostExecutable = "host_executable"
37)
38
Colin Crossae887032017-10-23 17:16:14 -070039type BuildParams struct {
Dan Willemsen9f3c5742016-11-03 14:28:31 -070040 Rule blueprint.Rule
Colin Cross33bfb0a2016-11-21 17:23:08 -080041 Deps blueprint.Deps
42 Depfile WritablePath
Colin Cross67a5c132017-05-09 13:45:28 -070043 Description string
Dan Willemsen9f3c5742016-11-03 14:28:31 -070044 Output WritablePath
45 Outputs WritablePaths
46 ImplicitOutput WritablePath
47 ImplicitOutputs WritablePaths
48 Input Path
49 Inputs Paths
50 Implicit Path
51 Implicits Paths
52 OrderOnly Paths
53 Default bool
54 Args map[string]string
Dan Willemsen34cc69e2015-09-23 15:26:20 -070055}
56
Colin Crossae887032017-10-23 17:16:14 -070057type ModuleBuildParams BuildParams
58
Colin Cross1184b642019-12-30 18:43:07 -080059// EarlyModuleContext provides methods that can be called early, as soon as the properties have
60// been parsed into the module and before any mutators have run.
61type EarlyModuleContext interface {
62 Module() Module
63 ModuleName() string
64 ModuleDir() string
65 ModuleType() string
Colin Cross9d34f352019-11-22 16:03:51 -080066 BlueprintsFile() string
Colin Cross1184b642019-12-30 18:43:07 -080067
68 ContainsProperty(name string) bool
69 Errorf(pos scanner.Position, fmt string, args ...interface{})
70 ModuleErrorf(fmt string, args ...interface{})
71 PropertyErrorf(property, fmt string, args ...interface{})
72 Failed() bool
73
74 AddNinjaFileDeps(deps ...string)
75
76 DeviceSpecific() bool
77 SocSpecific() bool
78 ProductSpecific() bool
79 SystemExtSpecific() bool
80 Platform() bool
81
82 Config() Config
83 DeviceConfig() DeviceConfig
84
85 // Deprecated: use Config()
86 AConfig() Config
87
88 // GlobWithDeps returns a list of files that match the specified pattern but do not match any
89 // of the patterns in excludes. It also adds efficient dependencies to rerun the primary
90 // builder whenever a file matching the pattern as added or removed, without rerunning if a
91 // file that does not match the pattern is added to a searched directory.
92 GlobWithDeps(pattern string, excludes []string) ([]string, error)
93
94 Glob(globPattern string, excludes []string) Paths
95 GlobFiles(globPattern string, excludes []string) Paths
Colin Cross988414c2020-01-11 01:11:46 +000096 IsSymlink(path Path) bool
97 Readlink(path Path) string
Colin Cross1184b642019-12-30 18:43:07 -080098}
99
Colin Cross0ea8ba82019-06-06 14:33:29 -0700100// BaseModuleContext is the same as blueprint.BaseModuleContext except that Config() returns
Colin Crossdc35e212019-06-06 16:13:11 -0700101// a Config instead of an interface{}, and some methods have been wrapped to use an android.Module
102// instead of a blueprint.Module, plus some extra methods that return Android-specific information
Colin Cross0ea8ba82019-06-06 14:33:29 -0700103// about the current module.
104type BaseModuleContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800105 EarlyModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -0700106
Paul Duffinf88d8e02020-05-07 20:21:34 +0100107 blueprintBaseModuleContext() blueprint.BaseModuleContext
108
Colin Crossdc35e212019-06-06 16:13:11 -0700109 OtherModuleName(m blueprint.Module) string
110 OtherModuleDir(m blueprint.Module) string
111 OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{})
112 OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag
113 OtherModuleExists(name string) bool
Jiyong Park9e6c2422019-08-09 20:39:45 +0900114 OtherModuleType(m blueprint.Module) string
Colin Crossdc35e212019-06-06 16:13:11 -0700115
116 GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module
117 GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module
118 GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag)
119
120 VisitDirectDepsBlueprint(visit func(blueprint.Module))
121 VisitDirectDeps(visit func(Module))
122 VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module))
123 VisitDirectDepsIf(pred func(Module) bool, visit func(Module))
124 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
125 VisitDepsDepthFirst(visit func(Module))
126 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
127 VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module))
128 WalkDeps(visit func(Module, Module) bool)
129 WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool)
130 // GetWalkPath is supposed to be called in visit function passed in WalkDeps()
131 // and returns a top-down dependency path from a start module to current child module.
132 GetWalkPath() []Module
133
Paul Duffinc5192442020-03-31 11:31:36 +0100134 // GetTagPath is supposed to be called in visit function passed in WalkDeps()
135 // and returns a top-down dependency tags path from a start module to current child module.
136 // It has one less entry than GetWalkPath() as it contains the dependency tags that
137 // exist between each adjacent pair of modules in the GetWalkPath().
138 // GetTagPath()[i] is the tag between GetWalkPath()[i] and GetWalkPath()[i+1]
139 GetTagPath() []blueprint.DependencyTag
140
Jiyong Park1c7e9622020-05-07 16:12:13 +0900141 // GetPathString is supposed to be called in visit function passed in WalkDeps()
142 // and returns a multi-line string showing the modules and dependency tags
143 // among them along the top-down dependency path from a start module to current child module.
144 // skipFirst when set to true, the output doesn't include the start module,
145 // which is already printed when this function is used along with ModuleErrorf().
146 GetPathString(skipFirst bool) string
147
Colin Crossdc35e212019-06-06 16:13:11 -0700148 AddMissingDependencies(missingDeps []string)
149
Colin Crossa1ad8d12016-06-01 17:09:44 -0700150 Target() Target
Colin Cross8b74d172016-09-13 09:59:14 -0700151 TargetPrimary() bool
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000152
153 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
154 // responsible for creating.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700155 MultiTargets() []Target
Colin Crossf6566ed2015-03-24 11:13:38 -0700156 Arch() Arch
Colin Crossa1ad8d12016-06-01 17:09:44 -0700157 Os() OsType
Colin Crossf6566ed2015-03-24 11:13:38 -0700158 Host() bool
159 Device() bool
Colin Cross0af4b842015-04-30 16:36:18 -0700160 Darwin() bool
Doug Horn21b94272019-01-16 12:06:11 -0800161 Fuchsia() bool
Colin Cross3edeee12017-04-04 12:59:48 -0700162 Windows() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700163 Debug() bool
Colin Cross1e7d3702016-08-24 15:25:47 -0700164 PrimaryArch() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700165}
166
Colin Cross1184b642019-12-30 18:43:07 -0800167// Deprecated: use EarlyModuleContext instead
Colin Cross635c3b02016-05-18 15:37:25 -0700168type BaseContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800169 EarlyModuleContext
Colin Crossaabf6792017-11-29 00:27:14 -0800170}
171
Colin Cross635c3b02016-05-18 15:37:25 -0700172type ModuleContext interface {
Colin Crossaabf6792017-11-29 00:27:14 -0800173 BaseModuleContext
Colin Cross3f40fa42015-01-30 17:27:36 -0800174
Colin Crossae887032017-10-23 17:16:14 -0700175 // Deprecated: use ModuleContext.Build instead.
Colin Cross0875c522017-11-28 17:34:01 -0800176 ModuleBuild(pctx PackageContext, params ModuleBuildParams)
Colin Cross8f101b42015-06-17 15:09:06 -0700177
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700178 ExpandSources(srcFiles, excludes []string) Paths
Colin Cross366938f2017-12-11 16:29:02 -0800179 ExpandSource(srcFile, prop string) Path
Colin Cross2383f3b2018-02-06 14:40:13 -0800180 ExpandOptionalSource(srcFile *string, prop string) OptionalPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700181
Colin Cross70dda7e2019-10-01 22:05:35 -0700182 InstallExecutable(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
183 InstallFile(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
184 InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath
185 InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700186 CheckbuildFile(srcPath Path)
Dan Willemsen6553f5e2016-03-10 18:14:25 -0800187
Colin Cross8d8f8e22016-08-03 11:57:50 -0700188 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700189 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700190 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800191 InstallInRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900192 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700193 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700194 InstallBypassMake() bool
Colin Cross6e359402020-02-10 15:29:54 -0800195 InstallForceOS() *OsType
Nan Zhang6d34b302017-02-04 17:47:46 -0800196
197 RequiredModuleNames() []string
Sasha Smundakb6d23052019-04-01 18:37:36 -0700198 HostRequiredModuleNames() []string
199 TargetRequiredModuleNames() []string
Colin Cross3f68a132017-10-23 17:10:29 -0700200
Colin Cross3f68a132017-10-23 17:10:29 -0700201 ModuleSubDir() string
202
Colin Cross0875c522017-11-28 17:34:01 -0800203 Variable(pctx PackageContext, name, value string)
204 Rule(pctx PackageContext, name string, params blueprint.RuleParams, argNames ...string) blueprint.Rule
Colin Crossae887032017-10-23 17:16:14 -0700205 // Similar to blueprint.ModuleContext.Build, but takes Paths instead of []string,
206 // and performs more verification.
Colin Cross0875c522017-11-28 17:34:01 -0800207 Build(pctx PackageContext, params BuildParams)
Colin Cross3f68a132017-10-23 17:10:29 -0700208
Colin Cross0875c522017-11-28 17:34:01 -0800209 PrimaryModule() Module
210 FinalModule() Module
211 VisitAllModuleVariants(visit func(Module))
Colin Cross3f68a132017-10-23 17:10:29 -0700212
213 GetMissingDependencies() []string
Jeff Gaston088e29e2017-11-29 16:47:17 -0800214 Namespace() blueprint.Namespace
Colin Cross3f40fa42015-01-30 17:27:36 -0800215}
216
Colin Cross635c3b02016-05-18 15:37:25 -0700217type Module interface {
Colin Cross3f40fa42015-01-30 17:27:36 -0800218 blueprint.Module
219
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700220 // GenerateAndroidBuildActions is analogous to Blueprints' GenerateBuildActions,
221 // but GenerateAndroidBuildActions also has access to Android-specific information.
222 // For more information, see Module.GenerateBuildActions within Blueprint's module_ctx.go
Colin Cross635c3b02016-05-18 15:37:25 -0700223 GenerateAndroidBuildActions(ModuleContext)
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700224
Colin Cross1e676be2016-10-12 14:38:15 -0700225 DepsMutator(BottomUpMutatorContext)
Colin Cross3f40fa42015-01-30 17:27:36 -0800226
Colin Cross635c3b02016-05-18 15:37:25 -0700227 base() *ModuleBase
Inseob Kimeec88e12020-01-22 11:11:29 +0900228 Disable()
Dan Willemsen0effe062015-11-30 16:06:01 -0800229 Enabled() bool
Colin Crossa1ad8d12016-06-01 17:09:44 -0700230 Target() Target
Dan Willemsen782a2d12015-12-21 14:55:28 -0800231 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700232 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700233 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800234 InstallInRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900235 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700236 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700237 InstallBypassMake() bool
Colin Cross6e359402020-02-10 15:29:54 -0800238 InstallForceOS() *OsType
Colin Crossa2f296f2016-11-29 15:16:18 -0800239 SkipInstall()
Ulya Trafimovichb28cc372020-01-13 15:18:16 +0000240 IsSkipInstall() bool
Jiyong Park374510b2018-03-19 18:23:01 +0900241 ExportedToMake() bool
Inseob Kim8471cda2019-11-15 09:59:12 +0900242 InitRc() Paths
243 VintfFragments() Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800244 NoticeFiles() Paths
Colin Cross36242852017-06-23 15:06:31 -0700245
246 AddProperties(props ...interface{})
247 GetProperties() []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700248
Colin Crossae887032017-10-23 17:16:14 -0700249 BuildParamsForTests() []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800250 RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800251 VariablesForTests() map[string]string
Paul Duffine2453c72019-05-31 14:00:04 +0100252
Colin Cross9a362232019-07-01 15:32:45 -0700253 // String returns a string that includes the module name and variants for printing during debugging.
254 String() string
255
Paul Duffine2453c72019-05-31 14:00:04 +0100256 // Get the qualified module id for this module.
257 qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName
258
259 // Get information about the properties that can contain visibility rules.
260 visibilityProperties() []visibilityProperty
Paul Duffin63c6e182019-07-24 14:24:38 +0100261
262 // Get the visibility rules that control the visibility of this module.
263 visibility() []string
Jiyong Park6a8cf5f2019-12-30 16:31:09 +0900264
265 RequiredModuleNames() []string
266 HostRequiredModuleNames() []string
267 TargetRequiredModuleNames() []string
Colin Cross897266e2020-02-13 13:22:08 -0800268
269 filesToInstall() InstallPaths
Paul Duffine2453c72019-05-31 14:00:04 +0100270}
271
272// Qualified id for a module
273type qualifiedModuleName struct {
274 // The package (i.e. directory) in which the module is defined, without trailing /
275 pkg string
276
277 // The name of the module, empty string if package.
278 name string
279}
280
281func (q qualifiedModuleName) String() string {
282 if q.name == "" {
283 return "//" + q.pkg
284 }
285 return "//" + q.pkg + ":" + q.name
286}
287
Paul Duffine484f472019-06-20 16:38:08 +0100288func (q qualifiedModuleName) isRootPackage() bool {
289 return q.pkg == "" && q.name == ""
290}
291
Paul Duffine2453c72019-05-31 14:00:04 +0100292// Get the id for the package containing this module.
293func (q qualifiedModuleName) getContainingPackageId() qualifiedModuleName {
294 pkg := q.pkg
295 if q.name == "" {
Paul Duffine484f472019-06-20 16:38:08 +0100296 if pkg == "" {
297 panic(fmt.Errorf("Cannot get containing package id of root package"))
298 }
299
300 index := strings.LastIndex(pkg, "/")
301 if index == -1 {
302 pkg = ""
303 } else {
304 pkg = pkg[:index]
305 }
Paul Duffine2453c72019-05-31 14:00:04 +0100306 }
307 return newPackageId(pkg)
308}
309
310func newPackageId(pkg string) qualifiedModuleName {
311 // A qualified id for a package module has no name.
312 return qualifiedModuleName{pkg: pkg, name: ""}
Colin Cross3f40fa42015-01-30 17:27:36 -0800313}
314
Colin Crossfc754582016-05-17 16:34:16 -0700315type nameProperties struct {
316 // The name of the module. Must be unique across all modules.
Nan Zhang0007d812017-11-07 10:57:05 -0800317 Name *string
Colin Crossfc754582016-05-17 16:34:16 -0700318}
319
320type commonProperties struct {
Dan Willemsen0effe062015-11-30 16:06:01 -0800321 // emit build rules for this module
Paul Duffin54d9bb72020-02-12 10:20:56 +0000322 //
323 // Disabling a module should only be done for those modules that cannot be built
324 // in the current environment. Modules that can build in the current environment
325 // but are not usually required (e.g. superceded by a prebuilt) should not be
326 // disabled as that will prevent them from being built by the checkbuild target
327 // and so prevent early detection of changes that have broken those modules.
Dan Willemsen0effe062015-11-30 16:06:01 -0800328 Enabled *bool `android:"arch_variant"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800329
Paul Duffin2e61fa62019-03-28 14:10:57 +0000330 // Controls the visibility of this module to other modules. Allowable values are one or more of
331 // these formats:
332 //
333 // ["//visibility:public"]: Anyone can use this module.
334 // ["//visibility:private"]: Only rules in the module's package (not its subpackages) can use
335 // this module.
336 // ["//some/package:__pkg__", "//other/package:__pkg__"]: Only modules in some/package and
337 // other/package (defined in some/package/*.bp and other/package/*.bp) have access to
338 // this module. Note that sub-packages do not have access to the rule; for example,
339 // //some/package/foo:bar or //other/package/testing:bla wouldn't have access. __pkg__
340 // is a special module and must be used verbatim. It represents all of the modules in the
341 // package.
342 // ["//project:__subpackages__", "//other:__subpackages__"]: Only modules in packages project
343 // or other or in one of their sub-packages have access to this module. For example,
344 // //project:rule, //project/library:lib or //other/testing/internal:munge are allowed
345 // to depend on this rule (but not //independent:evil)
346 // ["//project"]: This is shorthand for ["//project:__pkg__"]
347 // [":__subpackages__"]: This is shorthand for ["//project:__subpackages__"] where
348 // //project is the module's package. e.g. using [":__subpackages__"] in
349 // packages/apps/Settings/Android.bp is equivalent to
350 // //packages/apps/Settings:__subpackages__.
351 // ["//visibility:legacy_public"]: The default visibility, behaves as //visibility:public
352 // for now. It is an error if it is used in a module.
Paul Duffine2453c72019-05-31 14:00:04 +0100353 //
354 // If a module does not specify the `visibility` property then it uses the
355 // `default_visibility` property of the `package` module in the module's package.
356 //
357 // If the `default_visibility` property is not set for the module's package then
Paul Duffine484f472019-06-20 16:38:08 +0100358 // it will use the `default_visibility` of its closest ancestor package for which
359 // a `default_visibility` property is specified.
360 //
361 // If no `default_visibility` property can be found then the module uses the
362 // global default of `//visibility:legacy_public`.
Paul Duffine2453c72019-05-31 14:00:04 +0100363 //
Paul Duffin95d53b52019-07-24 13:45:05 +0100364 // The `visibility` property has no effect on a defaults module although it does
365 // apply to any non-defaults module that uses it. To set the visibility of a
366 // defaults module, use the `defaults_visibility` property on the defaults module;
367 // not to be confused with the `default_visibility` property on the package module.
368 //
Paul Duffin2e61fa62019-03-28 14:10:57 +0000369 // See https://android.googlesource.com/platform/build/soong/+/master/README.md#visibility for
370 // more details.
371 Visibility []string
372
Colin Cross7d5136f2015-05-11 13:39:40 -0700373 // control whether this module compiles for 32-bit, 64-bit, or both. Possible values
Colin Cross3f40fa42015-01-30 17:27:36 -0800374 // are "32" (compile for 32-bit only), "64" (compile for 64-bit only), "both" (compile for both
375 // architectures), or "first" (compile for 64-bit on a 64-bit platform, and 32-bit on a 32-bit
376 // platform
Colin Cross7d716ba2017-11-01 10:38:29 -0700377 Compile_multilib *string `android:"arch_variant"`
Colin Cross69617d32016-09-06 10:39:07 -0700378
379 Target struct {
380 Host struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700381 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700382 }
383 Android struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700384 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700385 }
386 }
387
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000388 // If set to true then the archMutator will create variants for each arch specific target
389 // (e.g. 32/64) that the module is required to produce. If set to false then it will only
390 // create a variant for the architecture and will list the additional arch specific targets
391 // that the variant needs to produce in the CompileMultiTargets property.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700392 UseTargetVariants bool `blueprint:"mutated"`
393 Default_multilib string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800394
Dan Willemsen782a2d12015-12-21 14:55:28 -0800395 // whether this is a proprietary vendor module, and should be installed into /vendor
Colin Cross7d716ba2017-11-01 10:38:29 -0700396 Proprietary *bool
Dan Willemsen782a2d12015-12-21 14:55:28 -0800397
Colin Cross55708f32017-03-20 13:23:34 -0700398 // vendor who owns this module
Dan Willemsenefac4a82017-07-18 19:42:09 -0700399 Owner *string
Colin Cross55708f32017-03-20 13:23:34 -0700400
Jiyong Park2db76922017-11-08 16:03:48 +0900401 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
402 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
403 // Use `soc_specific` instead for better meaning.
Colin Cross7d716ba2017-11-01 10:38:29 -0700404 Vendor *bool
Dan Willemsenaa118f92017-04-06 12:49:58 -0700405
Jiyong Park2db76922017-11-08 16:03:48 +0900406 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
407 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
408 Soc_specific *bool
409
410 // whether this module is specific to a device, not only for SoC, but also for off-chip
411 // peripherals. When set to true, it is installed into /odm (or /vendor/odm if odm partition
412 // does not exist, or /system/vendor/odm if both odm and vendor partitions do not exist).
413 // This implies `soc_specific:true`.
414 Device_specific *bool
415
416 // whether this module is specific to a software configuration of a product (e.g. country,
Jaekyun Seok5cfbfbb2018-01-10 19:00:15 +0900417 // network operator, etc). When set to true, it is installed into /product (or
418 // /system/product if product partition does not exist).
Jiyong Park2db76922017-11-08 16:03:48 +0900419 Product_specific *bool
420
Justin Yund5f6c822019-06-25 16:47:17 +0900421 // whether this module extends system. When set to true, it is installed into /system_ext
422 // (or /system/system_ext if system_ext partition does not exist).
423 System_ext_specific *bool
424
Jiyong Parkf9332f12018-02-01 00:54:12 +0900425 // Whether this module is installed to recovery partition
426 Recovery *bool
427
Yifan Hong1b3348d2020-01-21 15:53:22 -0800428 // Whether this module is installed to ramdisk
429 Ramdisk *bool
430
dimitry1f33e402019-03-26 12:39:31 +0100431 // Whether this module is built for non-native architecures (also known as native bridge binary)
432 Native_bridge_supported *bool `android:"arch_variant"`
433
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700434 // init.rc files to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800435 Init_rc []string `android:"path"`
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700436
Steven Moreland57a23d22018-04-04 15:42:19 -0700437 // VINTF manifest fragments to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800438 Vintf_fragments []string `android:"path"`
Steven Moreland57a23d22018-04-04 15:42:19 -0700439
Chris Wolfe998306e2016-08-15 14:47:23 -0400440 // names of other modules to install if this module is installed
Colin Crossc602b7d2017-05-05 13:36:36 -0700441 Required []string `android:"arch_variant"`
Chris Wolfe998306e2016-08-15 14:47:23 -0400442
Sasha Smundakb6d23052019-04-01 18:37:36 -0700443 // names of other modules to install on host if this module is installed
444 Host_required []string `android:"arch_variant"`
445
446 // names of other modules to install on target if this module is installed
447 Target_required []string `android:"arch_variant"`
448
Colin Cross5aac3622017-08-31 15:07:09 -0700449 // relative path to a file to include in the list of notices for the device
Colin Cross27b922f2019-03-04 22:35:41 -0800450 Notice *string `android:"path"`
Colin Cross5aac3622017-08-31 15:07:09 -0700451
Dan Willemsen569edc52018-11-19 09:33:29 -0800452 Dist struct {
453 // copy the output of this module to the $DIST_DIR when `dist` is specified on the
454 // command line and any of these targets are also on the command line, or otherwise
455 // built
456 Targets []string `android:"arch_variant"`
457
458 // The name of the output artifact. This defaults to the basename of the output of
459 // the module.
460 Dest *string `android:"arch_variant"`
461
462 // The directory within the dist directory to store the artifact. Defaults to the
463 // top level directory ("").
464 Dir *string `android:"arch_variant"`
465
466 // A suffix to add to the artifact file name (before any extension).
467 Suffix *string `android:"arch_variant"`
468 } `android:"arch_variant"`
469
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000470 // The OsType of artifacts that this module variant is responsible for creating.
471 //
472 // Set by osMutator
473 CompileOS OsType `blueprint:"mutated"`
474
475 // The Target of artifacts that this module variant is responsible for creating.
476 //
477 // Set by archMutator
478 CompileTarget Target `blueprint:"mutated"`
479
480 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
481 // responsible for creating.
482 //
483 // By default this is nil as, where necessary, separate variants are created for the
484 // different multilib types supported and that information is encapsulated in the
485 // CompileTarget so the module variant simply needs to create artifacts for that.
486 //
487 // However, if UseTargetVariants is set to false (e.g. by
488 // InitAndroidMultiTargetsArchModule) then no separate variants are created for the
489 // multilib targets. Instead a single variant is created for the architecture and
490 // this contains the multilib specific targets that this variant should create.
491 //
492 // Set by archMutator
Colin Crossee0bc3b2018-10-02 22:01:37 -0700493 CompileMultiTargets []Target `blueprint:"mutated"`
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000494
495 // True if the module variant's CompileTarget is the primary target
496 //
497 // Set by archMutator
498 CompilePrimary bool `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800499
500 // Set by InitAndroidModule
501 HostOrDeviceSupported HostOrDeviceSupported `blueprint:"mutated"`
Dan Willemsen0b24c742016-10-04 15:13:37 -0700502 ArchSpecific bool `blueprint:"mutated"`
Colin Crossce75d2c2016-10-06 16:12:58 -0700503
Paul Duffin1356d8c2020-02-25 19:26:33 +0000504 // If set to true then a CommonOS variant will be created which will have dependencies
505 // on all its OsType specific variants. Used by sdk/module_exports to create a snapshot
506 // that covers all os and architecture variants.
507 //
508 // The OsType specific variants can be retrieved by calling
509 // GetOsSpecificVariantsOfCommonOSVariant
510 //
511 // Set at module initialization time by calling InitCommonOSAndroidMultiTargetsArchModule
512 CreateCommonOSVariant bool `blueprint:"mutated"`
513
514 // If set to true then this variant is the CommonOS variant that has dependencies on its
515 // OsType specific variants.
516 //
517 // Set by osMutator.
518 CommonOSVariant bool `blueprint:"mutated"`
519
Colin Crossce75d2c2016-10-06 16:12:58 -0700520 SkipInstall bool `blueprint:"mutated"`
Jeff Gaston088e29e2017-11-29 16:47:17 -0800521
522 NamespaceExportedToMake bool `blueprint:"mutated"`
Colin Cross6c4f21f2019-06-06 15:41:36 -0700523
524 MissingDeps []string `blueprint:"mutated"`
Colin Cross9a362232019-07-01 15:32:45 -0700525
526 // Name and variant strings stored by mutators to enable Module.String()
527 DebugName string `blueprint:"mutated"`
528 DebugMutators []string `blueprint:"mutated"`
529 DebugVariations []string `blueprint:"mutated"`
Colin Cross7228ecd2019-11-18 16:00:16 -0800530
531 // set by ImageMutator
532 ImageVariation string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800533}
534
535type hostAndDeviceProperties struct {
Colin Cross4e81d702018-11-09 10:36:55 -0800536 // If set to true, build a variant of the module for the host. Defaults to false.
537 Host_supported *bool
538
539 // If set to true, build a variant of the module for the device. Defaults to true.
Colin Crossa4190c12016-07-12 13:11:25 -0700540 Device_supported *bool
Colin Cross3f40fa42015-01-30 17:27:36 -0800541}
542
Colin Crossc472d572015-03-17 15:06:21 -0700543type Multilib string
544
545const (
Colin Cross6b4a32d2017-12-05 13:42:45 -0800546 MultilibBoth Multilib = "both"
547 MultilibFirst Multilib = "first"
548 MultilibCommon Multilib = "common"
549 MultilibCommonFirst Multilib = "common_first"
550 MultilibDefault Multilib = ""
Colin Crossc472d572015-03-17 15:06:21 -0700551)
552
Colin Crossa1ad8d12016-06-01 17:09:44 -0700553type HostOrDeviceSupported int
554
555const (
556 _ HostOrDeviceSupported = iota
Dan Albert0981b5c2018-08-02 13:46:35 -0700557
558 // Host and HostCross are built by default. Device is not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700559 HostSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700560
561 // Host is built by default. HostCross and Device are not supported.
Dan Albertc6345fb2016-10-20 01:36:11 -0700562 HostSupportedNoCross
Dan Albert0981b5c2018-08-02 13:46:35 -0700563
564 // Device is built by default. Host and HostCross are not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700565 DeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700566
567 // Device is built by default. Host and HostCross are supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700568 HostAndDeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700569
570 // Host, HostCross, and Device are built by default.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700571 HostAndDeviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700572
573 // Nothing is supported. This is not exposed to the user, but used to mark a
574 // host only module as unsupported when the module type is not supported on
575 // the host OS. E.g. benchmarks are supported on Linux but not Darwin.
Dan Willemsen0b24c742016-10-04 15:13:37 -0700576 NeitherHostNorDeviceSupported
Colin Crossa1ad8d12016-06-01 17:09:44 -0700577)
578
Jiyong Park2db76922017-11-08 16:03:48 +0900579type moduleKind int
580
581const (
582 platformModule moduleKind = iota
583 deviceSpecificModule
584 socSpecificModule
585 productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900586 systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900587)
588
589func (k moduleKind) String() string {
590 switch k {
591 case platformModule:
592 return "platform"
593 case deviceSpecificModule:
594 return "device-specific"
595 case socSpecificModule:
596 return "soc-specific"
597 case productSpecificModule:
598 return "product-specific"
Justin Yund5f6c822019-06-25 16:47:17 +0900599 case systemExtSpecificModule:
600 return "systemext-specific"
Jiyong Park2db76922017-11-08 16:03:48 +0900601 default:
602 panic(fmt.Errorf("unknown module kind %d", k))
603 }
604}
605
Colin Cross9d34f352019-11-22 16:03:51 -0800606func initAndroidModuleBase(m Module) {
607 m.base().module = m
608}
609
Colin Cross36242852017-06-23 15:06:31 -0700610func InitAndroidModule(m Module) {
Colin Cross9d34f352019-11-22 16:03:51 -0800611 initAndroidModuleBase(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800612 base := m.base()
Colin Cross5049f022015-03-18 13:28:46 -0700613
Colin Cross36242852017-06-23 15:06:31 -0700614 m.AddProperties(
Colin Crossfc754582016-05-17 16:34:16 -0700615 &base.nameProperties,
Colin Cross18c46802019-09-24 22:19:02 -0700616 &base.commonProperties)
617
Colin Crosseabaedd2020-02-06 17:01:55 -0800618 initProductVariableModule(m)
Colin Cross18c46802019-09-24 22:19:02 -0700619
Colin Crossa3a97412019-03-18 12:24:29 -0700620 base.generalProperties = m.GetProperties()
Pirama Arumuga Nainar955dc492018-04-17 14:58:42 -0700621 base.customizableProperties = m.GetProperties()
Paul Duffin63c6e182019-07-24 14:24:38 +0100622
623 // The default_visibility property needs to be checked and parsed by the visibility module during
Paul Duffin5ec73ec2020-05-01 17:52:01 +0100624 // its checking and parsing phases so make it the primary visibility property.
625 setPrimaryVisibilityProperty(m, "visibility", &base.commonProperties.Visibility)
Colin Cross5049f022015-03-18 13:28:46 -0700626}
627
Colin Cross36242852017-06-23 15:06:31 -0700628func InitAndroidArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
629 InitAndroidModule(m)
Colin Cross5049f022015-03-18 13:28:46 -0700630
631 base := m.base()
Colin Cross3f40fa42015-01-30 17:27:36 -0800632 base.commonProperties.HostOrDeviceSupported = hod
Colin Cross69617d32016-09-06 10:39:07 -0700633 base.commonProperties.Default_multilib = string(defaultMultilib)
Dan Willemsen0b24c742016-10-04 15:13:37 -0700634 base.commonProperties.ArchSpecific = true
Colin Crossee0bc3b2018-10-02 22:01:37 -0700635 base.commonProperties.UseTargetVariants = true
Colin Cross3f40fa42015-01-30 17:27:36 -0800636
Dan Willemsen218f6562015-07-08 18:13:11 -0700637 switch hod {
Nan Zhang1a0f09b2017-07-05 10:35:11 -0700638 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Cross36242852017-06-23 15:06:31 -0700639 m.AddProperties(&base.hostAndDeviceProperties)
Colin Cross3f40fa42015-01-30 17:27:36 -0800640 }
641
Colin Cross36242852017-06-23 15:06:31 -0700642 InitArchModule(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800643}
644
Colin Crossee0bc3b2018-10-02 22:01:37 -0700645func InitAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
646 InitAndroidArchModule(m, hod, defaultMultilib)
647 m.base().commonProperties.UseTargetVariants = false
648}
649
Paul Duffin1356d8c2020-02-25 19:26:33 +0000650// As InitAndroidMultiTargetsArchModule except it creates an additional CommonOS variant that
651// has dependencies on all the OsType specific variants.
652func InitCommonOSAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
653 InitAndroidArchModule(m, hod, defaultMultilib)
654 m.base().commonProperties.UseTargetVariants = false
655 m.base().commonProperties.CreateCommonOSVariant = true
656}
657
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800658// A ModuleBase object contains the properties that are common to all Android
Colin Cross3f40fa42015-01-30 17:27:36 -0800659// modules. It should be included as an anonymous field in every module
660// struct definition. InitAndroidModule should then be called from the module's
661// factory function, and the return values from InitAndroidModule should be
662// returned from the factory function.
663//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800664// The ModuleBase type is responsible for implementing the GenerateBuildActions
665// method to support the blueprint.Module interface. This method will then call
666// the module's GenerateAndroidBuildActions method once for each build variant
Colin Cross25de6c32019-06-06 14:29:25 -0700667// that is to be built. GenerateAndroidBuildActions is passed a ModuleContext
668// rather than the usual blueprint.ModuleContext.
669// ModuleContext exposes extra functionality specific to the Android build
Colin Cross3f40fa42015-01-30 17:27:36 -0800670// system including details about the particular build variant that is to be
671// generated.
672//
673// For example:
674//
675// import (
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800676// "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -0800677// )
678//
679// type myModule struct {
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800680// android.ModuleBase
Colin Cross3f40fa42015-01-30 17:27:36 -0800681// properties struct {
682// MyProperty string
683// }
684// }
685//
Colin Cross36242852017-06-23 15:06:31 -0700686// func NewMyModule() android.Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800687// m := &myModule{}
Colin Cross36242852017-06-23 15:06:31 -0700688// m.AddProperties(&m.properties)
689// android.InitAndroidModule(m)
690// return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800691// }
692//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800693// func (m *myModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800694// // Get the CPU architecture for the current build variant.
695// variantArch := ctx.Arch()
696//
697// // ...
698// }
Colin Cross635c3b02016-05-18 15:37:25 -0700699type ModuleBase struct {
Colin Cross3f40fa42015-01-30 17:27:36 -0800700 // Putting the curiously recurring thing pointing to the thing that contains
701 // the thing pattern to good use.
Colin Cross36242852017-06-23 15:06:31 -0700702 // TODO: remove this
Colin Cross635c3b02016-05-18 15:37:25 -0700703 module Module
Colin Cross3f40fa42015-01-30 17:27:36 -0800704
Colin Crossfc754582016-05-17 16:34:16 -0700705 nameProperties nameProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800706 commonProperties commonProperties
Colin Cross18c46802019-09-24 22:19:02 -0700707 variableProperties interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800708 hostAndDeviceProperties hostAndDeviceProperties
709 generalProperties []interface{}
Colin Crossc17727d2018-10-24 12:42:09 -0700710 archProperties [][]interface{}
Colin Crossa120ec12016-08-19 16:07:38 -0700711 customizableProperties []interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800712
Paul Duffin63c6e182019-07-24 14:24:38 +0100713 // Information about all the properties on the module that contains visibility rules that need
714 // checking.
715 visibilityPropertyInfo []visibilityProperty
716
717 // The primary visibility property, may be nil, that controls access to the module.
718 primaryVisibilityProperty visibilityProperty
719
Colin Cross3f40fa42015-01-30 17:27:36 -0800720 noAddressSanitizer bool
Colin Cross897266e2020-02-13 13:22:08 -0800721 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700722 checkbuildFiles Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800723 noticeFiles Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -0700724
725 // Used by buildTargetSingleton to create checkbuild and per-directory build targets
726 // Only set on the final variant of each module
Colin Cross0875c522017-11-28 17:34:01 -0800727 installTarget WritablePath
728 checkbuildTarget WritablePath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700729 blueprintDir string
Colin Crossa120ec12016-08-19 16:07:38 -0700730
Colin Cross178a5092016-09-13 13:42:32 -0700731 hooks hooks
Colin Cross36242852017-06-23 15:06:31 -0700732
733 registerProps []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700734
735 // For tests
Colin Crossae887032017-10-23 17:16:14 -0700736 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800737 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800738 variables map[string]string
Colin Crossa9d8bee2018-10-02 13:59:46 -0700739
Inseob Kim8471cda2019-11-15 09:59:12 +0900740 initRcPaths Paths
741 vintfFragmentsPaths Paths
742
Colin Crossa9d8bee2018-10-02 13:59:46 -0700743 prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool
Colin Cross36242852017-06-23 15:06:31 -0700744}
745
Colin Cross4157e882019-06-06 16:57:04 -0700746func (m *ModuleBase) DepsMutator(BottomUpMutatorContext) {}
Colin Cross5f692ec2019-02-01 16:53:07 -0800747
Colin Cross4157e882019-06-06 16:57:04 -0700748func (m *ModuleBase) AddProperties(props ...interface{}) {
749 m.registerProps = append(m.registerProps, props...)
Colin Cross36242852017-06-23 15:06:31 -0700750}
751
Colin Cross4157e882019-06-06 16:57:04 -0700752func (m *ModuleBase) GetProperties() []interface{} {
753 return m.registerProps
Colin Cross3f40fa42015-01-30 17:27:36 -0800754}
755
Colin Cross4157e882019-06-06 16:57:04 -0700756func (m *ModuleBase) BuildParamsForTests() []BuildParams {
757 return m.buildParams
Colin Crosscec81712017-07-13 14:43:27 -0700758}
759
Colin Cross4157e882019-06-06 16:57:04 -0700760func (m *ModuleBase) RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams {
761 return m.ruleParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800762}
763
Colin Cross4157e882019-06-06 16:57:04 -0700764func (m *ModuleBase) VariablesForTests() map[string]string {
765 return m.variables
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800766}
767
Colin Cross4157e882019-06-06 16:57:04 -0700768func (m *ModuleBase) Prefer32(prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool) {
769 m.prefer32 = prefer32
Colin Crossa9d8bee2018-10-02 13:59:46 -0700770}
771
Colin Crossce75d2c2016-10-06 16:12:58 -0700772// Name returns the name of the module. It may be overridden by individual module types, for
773// example prebuilts will prepend prebuilt_ to the name.
Colin Cross4157e882019-06-06 16:57:04 -0700774func (m *ModuleBase) Name() string {
775 return String(m.nameProperties.Name)
Colin Crossfc754582016-05-17 16:34:16 -0700776}
777
Colin Cross9a362232019-07-01 15:32:45 -0700778// String returns a string that includes the module name and variants for printing during debugging.
779func (m *ModuleBase) String() string {
780 sb := strings.Builder{}
781 sb.WriteString(m.commonProperties.DebugName)
782 sb.WriteString("{")
783 for i := range m.commonProperties.DebugMutators {
784 if i != 0 {
785 sb.WriteString(",")
786 }
787 sb.WriteString(m.commonProperties.DebugMutators[i])
788 sb.WriteString(":")
789 sb.WriteString(m.commonProperties.DebugVariations[i])
790 }
791 sb.WriteString("}")
792 return sb.String()
793}
794
Colin Crossce75d2c2016-10-06 16:12:58 -0700795// BaseModuleName returns the name of the module as specified in the blueprints file.
Colin Cross4157e882019-06-06 16:57:04 -0700796func (m *ModuleBase) BaseModuleName() string {
797 return String(m.nameProperties.Name)
Colin Crossce75d2c2016-10-06 16:12:58 -0700798}
799
Colin Cross4157e882019-06-06 16:57:04 -0700800func (m *ModuleBase) base() *ModuleBase {
801 return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800802}
803
Paul Duffine2453c72019-05-31 14:00:04 +0100804func (m *ModuleBase) qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName {
805 return qualifiedModuleName{pkg: ctx.ModuleDir(), name: ctx.ModuleName()}
806}
807
808func (m *ModuleBase) visibilityProperties() []visibilityProperty {
Paul Duffin63c6e182019-07-24 14:24:38 +0100809 return m.visibilityPropertyInfo
810}
811
812func (m *ModuleBase) visibility() []string {
813 // The soong_namespace module does not initialize the primaryVisibilityProperty.
814 if m.primaryVisibilityProperty != nil {
815 return m.primaryVisibilityProperty.getStrings()
816 } else {
817 return nil
Paul Duffine2453c72019-05-31 14:00:04 +0100818 }
819}
820
Colin Cross4157e882019-06-06 16:57:04 -0700821func (m *ModuleBase) Target() Target {
822 return m.commonProperties.CompileTarget
Dan Willemsen490fd492015-11-24 17:53:15 -0800823}
824
Colin Cross4157e882019-06-06 16:57:04 -0700825func (m *ModuleBase) TargetPrimary() bool {
826 return m.commonProperties.CompilePrimary
Colin Cross8b74d172016-09-13 09:59:14 -0700827}
828
Colin Cross4157e882019-06-06 16:57:04 -0700829func (m *ModuleBase) MultiTargets() []Target {
830 return m.commonProperties.CompileMultiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -0700831}
832
Colin Cross4157e882019-06-06 16:57:04 -0700833func (m *ModuleBase) Os() OsType {
834 return m.Target().Os
Dan Willemsen490fd492015-11-24 17:53:15 -0800835}
836
Colin Cross4157e882019-06-06 16:57:04 -0700837func (m *ModuleBase) Host() bool {
838 return m.Os().Class == Host || m.Os().Class == HostCross
Dan Willemsen97750522016-02-09 17:43:51 -0800839}
840
Colin Cross4157e882019-06-06 16:57:04 -0700841func (m *ModuleBase) Arch() Arch {
842 return m.Target().Arch
Dan Willemsen97750522016-02-09 17:43:51 -0800843}
844
Colin Cross4157e882019-06-06 16:57:04 -0700845func (m *ModuleBase) ArchSpecific() bool {
846 return m.commonProperties.ArchSpecific
Dan Willemsen0b24c742016-10-04 15:13:37 -0700847}
848
Paul Duffin1356d8c2020-02-25 19:26:33 +0000849// True if the current variant is a CommonOS variant, false otherwise.
850func (m *ModuleBase) IsCommonOSVariant() bool {
851 return m.commonProperties.CommonOSVariant
852}
853
Colin Cross4157e882019-06-06 16:57:04 -0700854func (m *ModuleBase) OsClassSupported() []OsClass {
855 switch m.commonProperties.HostOrDeviceSupported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700856 case HostSupported:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700857 return []OsClass{Host, HostCross}
Dan Albertc6345fb2016-10-20 01:36:11 -0700858 case HostSupportedNoCross:
859 return []OsClass{Host}
Colin Crossa1ad8d12016-06-01 17:09:44 -0700860 case DeviceSupported:
861 return []OsClass{Device}
Dan Albert0981b5c2018-08-02 13:46:35 -0700862 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700863 var supported []OsClass
Colin Cross4157e882019-06-06 16:57:04 -0700864 if Bool(m.hostAndDeviceProperties.Host_supported) ||
865 (m.commonProperties.HostOrDeviceSupported == HostAndDeviceDefault &&
866 m.hostAndDeviceProperties.Host_supported == nil) {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700867 supported = append(supported, Host, HostCross)
868 }
Colin Cross4157e882019-06-06 16:57:04 -0700869 if m.hostAndDeviceProperties.Device_supported == nil ||
870 *m.hostAndDeviceProperties.Device_supported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700871 supported = append(supported, Device)
872 }
873 return supported
874 default:
875 return nil
876 }
Colin Cross3f40fa42015-01-30 17:27:36 -0800877}
878
Colin Cross4157e882019-06-06 16:57:04 -0700879func (m *ModuleBase) DeviceSupported() bool {
880 return m.commonProperties.HostOrDeviceSupported == DeviceSupported ||
881 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
882 (m.hostAndDeviceProperties.Device_supported == nil ||
883 *m.hostAndDeviceProperties.Device_supported)
Colin Cross3f40fa42015-01-30 17:27:36 -0800884}
885
Paul Duffine44358f2019-11-26 18:04:12 +0000886func (m *ModuleBase) HostSupported() bool {
887 return m.commonProperties.HostOrDeviceSupported == HostSupported ||
888 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
889 (m.hostAndDeviceProperties.Host_supported != nil &&
890 *m.hostAndDeviceProperties.Host_supported)
891}
892
Colin Cross4157e882019-06-06 16:57:04 -0700893func (m *ModuleBase) Platform() bool {
Justin Yund5f6c822019-06-25 16:47:17 +0900894 return !m.DeviceSpecific() && !m.SocSpecific() && !m.ProductSpecific() && !m.SystemExtSpecific()
Jiyong Parkc678ad32018-04-10 13:07:10 +0900895}
896
Colin Cross4157e882019-06-06 16:57:04 -0700897func (m *ModuleBase) DeviceSpecific() bool {
898 return Bool(m.commonProperties.Device_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900899}
900
Colin Cross4157e882019-06-06 16:57:04 -0700901func (m *ModuleBase) SocSpecific() bool {
902 return Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900903}
904
Colin Cross4157e882019-06-06 16:57:04 -0700905func (m *ModuleBase) ProductSpecific() bool {
906 return Bool(m.commonProperties.Product_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900907}
908
Justin Yund5f6c822019-06-25 16:47:17 +0900909func (m *ModuleBase) SystemExtSpecific() bool {
910 return Bool(m.commonProperties.System_ext_specific)
Dario Frenifd05a742018-05-29 13:28:54 +0100911}
912
Bill Peckhamfff3f8a2020-03-20 18:33:20 -0700913func (m *ModuleBase) PartitionTag(config DeviceConfig) string {
914 partition := "system"
915 if m.SocSpecific() {
916 // A SoC-specific module could be on the vendor partition at
917 // "vendor" or the system partition at "system/vendor".
918 if config.VendorPath() == "vendor" {
919 partition = "vendor"
920 }
921 } else if m.DeviceSpecific() {
922 // A device-specific module could be on the odm partition at
923 // "odm", the vendor partition at "vendor/odm", or the system
924 // partition at "system/vendor/odm".
925 if config.OdmPath() == "odm" {
926 partition = "odm"
Ramy Medhat944839a2020-03-31 22:14:52 -0400927 } else if strings.HasPrefix(config.OdmPath(), "vendor/") {
Bill Peckhamfff3f8a2020-03-20 18:33:20 -0700928 partition = "vendor"
929 }
930 } else if m.ProductSpecific() {
931 // A product-specific module could be on the product partition
932 // at "product" or the system partition at "system/product".
933 if config.ProductPath() == "product" {
934 partition = "product"
935 }
936 } else if m.SystemExtSpecific() {
937 // A system_ext-specific module could be on the system_ext
938 // partition at "system_ext" or the system partition at
939 // "system/system_ext".
940 if config.SystemExtPath() == "system_ext" {
941 partition = "system_ext"
942 }
943 }
944 return partition
945}
946
Colin Cross4157e882019-06-06 16:57:04 -0700947func (m *ModuleBase) Enabled() bool {
948 if m.commonProperties.Enabled == nil {
949 return !m.Os().DefaultDisabled
Dan Willemsen490fd492015-11-24 17:53:15 -0800950 }
Colin Cross4157e882019-06-06 16:57:04 -0700951 return *m.commonProperties.Enabled
Colin Cross3f40fa42015-01-30 17:27:36 -0800952}
953
Inseob Kimeec88e12020-01-22 11:11:29 +0900954func (m *ModuleBase) Disable() {
955 m.commonProperties.Enabled = proptools.BoolPtr(false)
956}
957
Colin Cross4157e882019-06-06 16:57:04 -0700958func (m *ModuleBase) SkipInstall() {
959 m.commonProperties.SkipInstall = true
Colin Crossce75d2c2016-10-06 16:12:58 -0700960}
961
Ulya Trafimovichb28cc372020-01-13 15:18:16 +0000962func (m *ModuleBase) IsSkipInstall() bool {
963 return m.commonProperties.SkipInstall == true
964}
965
Colin Cross4157e882019-06-06 16:57:04 -0700966func (m *ModuleBase) ExportedToMake() bool {
967 return m.commonProperties.NamespaceExportedToMake
Jiyong Park374510b2018-03-19 18:23:01 +0900968}
969
Colin Cross897266e2020-02-13 13:22:08 -0800970func (m *ModuleBase) computeInstallDeps(ctx blueprint.ModuleContext) InstallPaths {
Colin Cross3f40fa42015-01-30 17:27:36 -0800971
Colin Cross897266e2020-02-13 13:22:08 -0800972 var result InstallPaths
Colin Cross6b753602018-06-21 13:03:07 -0700973 // TODO(ccross): we need to use WalkDeps and have some way to know which dependencies require installation
Colin Cross897266e2020-02-13 13:22:08 -0800974 ctx.VisitDepsDepthFirst(func(m blueprint.Module) {
975 if a, ok := m.(Module); ok {
976 result = append(result, a.filesToInstall()...)
977 }
978 })
Colin Cross3f40fa42015-01-30 17:27:36 -0800979
980 return result
981}
982
Colin Cross897266e2020-02-13 13:22:08 -0800983func (m *ModuleBase) filesToInstall() InstallPaths {
Colin Cross4157e882019-06-06 16:57:04 -0700984 return m.installFiles
Colin Cross3f40fa42015-01-30 17:27:36 -0800985}
986
Colin Cross4157e882019-06-06 16:57:04 -0700987func (m *ModuleBase) NoAddressSanitizer() bool {
988 return m.noAddressSanitizer
Colin Cross3f40fa42015-01-30 17:27:36 -0800989}
990
Colin Cross4157e882019-06-06 16:57:04 -0700991func (m *ModuleBase) InstallInData() bool {
Dan Willemsen782a2d12015-12-21 14:55:28 -0800992 return false
993}
994
Jaewoong Jung0949f312019-09-11 10:25:18 -0700995func (m *ModuleBase) InstallInTestcases() bool {
996 return false
997}
998
Colin Cross4157e882019-06-06 16:57:04 -0700999func (m *ModuleBase) InstallInSanitizerDir() bool {
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001000 return false
1001}
1002
Yifan Hong1b3348d2020-01-21 15:53:22 -08001003func (m *ModuleBase) InstallInRamdisk() bool {
1004 return Bool(m.commonProperties.Ramdisk)
1005}
1006
Colin Cross4157e882019-06-06 16:57:04 -07001007func (m *ModuleBase) InstallInRecovery() bool {
1008 return Bool(m.commonProperties.Recovery)
Jiyong Parkf9332f12018-02-01 00:54:12 +09001009}
1010
Colin Cross90ba5f42019-10-02 11:10:58 -07001011func (m *ModuleBase) InstallInRoot() bool {
1012 return false
1013}
1014
Colin Cross607d8582019-07-29 16:44:46 -07001015func (m *ModuleBase) InstallBypassMake() bool {
1016 return false
1017}
1018
Colin Cross6e359402020-02-10 15:29:54 -08001019func (m *ModuleBase) InstallForceOS() *OsType {
1020 return nil
1021}
1022
Colin Cross4157e882019-06-06 16:57:04 -07001023func (m *ModuleBase) Owner() string {
1024 return String(m.commonProperties.Owner)
Sundong Ahn4fd04bb2018-08-31 18:01:37 +09001025}
1026
Bob Badoura75b0572020-02-18 20:21:55 -08001027func (m *ModuleBase) NoticeFiles() Paths {
1028 return m.noticeFiles
Jiyong Park52818fc2019-03-18 12:01:38 +09001029}
1030
Colin Cross7228ecd2019-11-18 16:00:16 -08001031func (m *ModuleBase) setImageVariation(variant string) {
1032 m.commonProperties.ImageVariation = variant
1033}
1034
1035func (m *ModuleBase) ImageVariation() blueprint.Variation {
1036 return blueprint.Variation{
1037 Mutator: "image",
1038 Variation: m.base().commonProperties.ImageVariation,
1039 }
1040}
1041
Paul Duffin9b76c0b2020-03-12 10:24:35 +00001042func (m *ModuleBase) getVariationByMutatorName(mutator string) string {
1043 for i, v := range m.commonProperties.DebugMutators {
1044 if v == mutator {
1045 return m.commonProperties.DebugVariations[i]
1046 }
1047 }
1048
1049 return ""
1050}
1051
Yifan Hong1b3348d2020-01-21 15:53:22 -08001052func (m *ModuleBase) InRamdisk() bool {
1053 return m.base().commonProperties.ImageVariation == RamdiskVariation
1054}
1055
Colin Cross7228ecd2019-11-18 16:00:16 -08001056func (m *ModuleBase) InRecovery() bool {
1057 return m.base().commonProperties.ImageVariation == RecoveryVariation
1058}
1059
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09001060func (m *ModuleBase) RequiredModuleNames() []string {
1061 return m.base().commonProperties.Required
1062}
1063
1064func (m *ModuleBase) HostRequiredModuleNames() []string {
1065 return m.base().commonProperties.Host_required
1066}
1067
1068func (m *ModuleBase) TargetRequiredModuleNames() []string {
1069 return m.base().commonProperties.Target_required
1070}
1071
Inseob Kim8471cda2019-11-15 09:59:12 +09001072func (m *ModuleBase) InitRc() Paths {
1073 return append(Paths{}, m.initRcPaths...)
1074}
1075
1076func (m *ModuleBase) VintfFragments() Paths {
1077 return append(Paths{}, m.vintfFragmentsPaths...)
1078}
1079
Colin Cross4157e882019-06-06 16:57:04 -07001080func (m *ModuleBase) generateModuleTarget(ctx ModuleContext) {
Colin Cross897266e2020-02-13 13:22:08 -08001081 var allInstalledFiles InstallPaths
1082 var allCheckbuildFiles Paths
Colin Cross0875c522017-11-28 17:34:01 -08001083 ctx.VisitAllModuleVariants(func(module Module) {
1084 a := module.base()
Colin Crossc9404352015-03-26 16:10:12 -07001085 allInstalledFiles = append(allInstalledFiles, a.installFiles...)
1086 allCheckbuildFiles = append(allCheckbuildFiles, a.checkbuildFiles...)
Colin Cross3f40fa42015-01-30 17:27:36 -08001087 })
1088
Colin Cross0875c522017-11-28 17:34:01 -08001089 var deps Paths
Colin Cross9454bfa2015-03-17 13:24:18 -07001090
Jeff Gaston088e29e2017-11-29 16:47:17 -08001091 namespacePrefix := ctx.Namespace().(*Namespace).id
1092 if namespacePrefix != "" {
1093 namespacePrefix = namespacePrefix + "-"
1094 }
1095
Colin Cross3f40fa42015-01-30 17:27:36 -08001096 if len(allInstalledFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -08001097 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-install")
Colin Cross0875c522017-11-28 17:34:01 -08001098 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001099 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001100 Output: name,
Colin Cross897266e2020-02-13 13:22:08 -08001101 Implicits: allInstalledFiles.Paths(),
Colin Crossaabf6792017-11-29 00:27:14 -08001102 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross9454bfa2015-03-17 13:24:18 -07001103 })
1104 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -07001105 m.installTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -07001106 }
1107
1108 if len(allCheckbuildFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -08001109 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-checkbuild")
Colin Cross0875c522017-11-28 17:34:01 -08001110 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001111 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001112 Output: name,
1113 Implicits: allCheckbuildFiles,
Colin Cross9454bfa2015-03-17 13:24:18 -07001114 })
1115 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -07001116 m.checkbuildTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -07001117 }
1118
1119 if len(deps) > 0 {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001120 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08001121 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001122 suffix = "-soong"
1123 }
1124
Jeff Gaston088e29e2017-11-29 16:47:17 -08001125 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+suffix)
Colin Cross0875c522017-11-28 17:34:01 -08001126 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001127 Rule: blueprint.Phony,
Jeff Gaston088e29e2017-11-29 16:47:17 -08001128 Outputs: []WritablePath{name},
Colin Cross9454bfa2015-03-17 13:24:18 -07001129 Implicits: deps,
Colin Cross3f40fa42015-01-30 17:27:36 -08001130 })
Colin Cross1f8c52b2015-06-16 16:38:17 -07001131
Colin Cross4157e882019-06-06 16:57:04 -07001132 m.blueprintDir = ctx.ModuleDir()
Colin Cross3f40fa42015-01-30 17:27:36 -08001133 }
1134}
1135
Colin Crossc34d2322020-01-03 15:23:27 -08001136func determineModuleKind(m *ModuleBase, ctx blueprint.EarlyModuleContext) moduleKind {
Colin Cross4157e882019-06-06 16:57:04 -07001137 var socSpecific = Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
1138 var deviceSpecific = Bool(m.commonProperties.Device_specific)
1139 var productSpecific = Bool(m.commonProperties.Product_specific)
Justin Yund5f6c822019-06-25 16:47:17 +09001140 var systemExtSpecific = Bool(m.commonProperties.System_ext_specific)
Jiyong Park2db76922017-11-08 16:03:48 +09001141
Dario Frenifd05a742018-05-29 13:28:54 +01001142 msg := "conflicting value set here"
1143 if socSpecific && deviceSpecific {
1144 ctx.PropertyErrorf("device_specific", "a module cannot be specific to SoC and device at the same time.")
Colin Cross4157e882019-06-06 16:57:04 -07001145 if Bool(m.commonProperties.Vendor) {
Jiyong Park2db76922017-11-08 16:03:48 +09001146 ctx.PropertyErrorf("vendor", msg)
1147 }
Colin Cross4157e882019-06-06 16:57:04 -07001148 if Bool(m.commonProperties.Proprietary) {
Jiyong Park2db76922017-11-08 16:03:48 +09001149 ctx.PropertyErrorf("proprietary", msg)
1150 }
Colin Cross4157e882019-06-06 16:57:04 -07001151 if Bool(m.commonProperties.Soc_specific) {
Jiyong Park2db76922017-11-08 16:03:48 +09001152 ctx.PropertyErrorf("soc_specific", msg)
1153 }
1154 }
1155
Justin Yund5f6c822019-06-25 16:47:17 +09001156 if productSpecific && systemExtSpecific {
1157 ctx.PropertyErrorf("product_specific", "a module cannot be specific to product and system_ext at the same time.")
1158 ctx.PropertyErrorf("system_ext_specific", msg)
Dario Frenifd05a742018-05-29 13:28:54 +01001159 }
1160
Justin Yund5f6c822019-06-25 16:47:17 +09001161 if (socSpecific || deviceSpecific) && (productSpecific || systemExtSpecific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001162 if productSpecific {
1163 ctx.PropertyErrorf("product_specific", "a module cannot be specific to SoC or device and product at the same time.")
1164 } else {
Justin Yund5f6c822019-06-25 16:47:17 +09001165 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 +01001166 }
1167 if deviceSpecific {
1168 ctx.PropertyErrorf("device_specific", msg)
1169 } else {
Colin Cross4157e882019-06-06 16:57:04 -07001170 if Bool(m.commonProperties.Vendor) {
Dario Frenifd05a742018-05-29 13:28:54 +01001171 ctx.PropertyErrorf("vendor", msg)
1172 }
Colin Cross4157e882019-06-06 16:57:04 -07001173 if Bool(m.commonProperties.Proprietary) {
Dario Frenifd05a742018-05-29 13:28:54 +01001174 ctx.PropertyErrorf("proprietary", msg)
1175 }
Colin Cross4157e882019-06-06 16:57:04 -07001176 if Bool(m.commonProperties.Soc_specific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001177 ctx.PropertyErrorf("soc_specific", msg)
1178 }
1179 }
1180 }
1181
Jiyong Park2db76922017-11-08 16:03:48 +09001182 if productSpecific {
1183 return productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +09001184 } else if systemExtSpecific {
1185 return systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001186 } else if deviceSpecific {
1187 return deviceSpecificModule
1188 } else if socSpecific {
1189 return socSpecificModule
1190 } else {
1191 return platformModule
1192 }
1193}
1194
Colin Crossc34d2322020-01-03 15:23:27 -08001195func (m *ModuleBase) earlyModuleContextFactory(ctx blueprint.EarlyModuleContext) earlyModuleContext {
Colin Cross1184b642019-12-30 18:43:07 -08001196 return earlyModuleContext{
Colin Crossc34d2322020-01-03 15:23:27 -08001197 EarlyModuleContext: ctx,
1198 kind: determineModuleKind(m, ctx),
1199 config: ctx.Config().(Config),
Colin Cross3f40fa42015-01-30 17:27:36 -08001200 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001201}
1202
Colin Cross1184b642019-12-30 18:43:07 -08001203func (m *ModuleBase) baseModuleContextFactory(ctx blueprint.BaseModuleContext) baseModuleContext {
1204 return baseModuleContext{
1205 bp: ctx,
1206 earlyModuleContext: m.earlyModuleContextFactory(ctx),
1207 os: m.commonProperties.CompileOS,
1208 target: m.commonProperties.CompileTarget,
1209 targetPrimary: m.commonProperties.CompilePrimary,
1210 multiTargets: m.commonProperties.CompileMultiTargets,
1211 }
1212}
1213
Colin Cross4157e882019-06-06 16:57:04 -07001214func (m *ModuleBase) GenerateBuildActions(blueprintCtx blueprint.ModuleContext) {
Colin Cross25de6c32019-06-06 14:29:25 -07001215 ctx := &moduleContext{
Colin Cross0ea8ba82019-06-06 14:33:29 -07001216 module: m.module,
Colin Crossdc35e212019-06-06 16:13:11 -07001217 bp: blueprintCtx,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001218 baseModuleContext: m.baseModuleContextFactory(blueprintCtx),
1219 installDeps: m.computeInstallDeps(blueprintCtx),
1220 installFiles: m.installFiles,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001221 variables: make(map[string]string),
Colin Cross3f40fa42015-01-30 17:27:36 -08001222 }
1223
Colin Cross6c4f21f2019-06-06 15:41:36 -07001224 // Temporarily continue to call blueprintCtx.GetMissingDependencies() to maintain the previous behavior of never
1225 // reporting missing dependency errors in Blueprint when AllowMissingDependencies == true.
1226 // TODO: This will be removed once defaults modules handle missing dependency errors
1227 blueprintCtx.GetMissingDependencies()
1228
Colin Crossdc35e212019-06-06 16:13:11 -07001229 // For the final GenerateAndroidBuildActions pass, require that all visited dependencies Soong modules and
Paul Duffin1356d8c2020-02-25 19:26:33 +00001230 // are enabled. Unless the module is a CommonOS variant which may have dependencies on disabled variants
1231 // (because the dependencies are added before the modules are disabled). The
1232 // GetOsSpecificVariantsOfCommonOSVariant(...) method will ensure that the disabled variants are
1233 // ignored.
1234 ctx.baseModuleContext.strictVisitDeps = !m.IsCommonOSVariant()
Colin Crossdc35e212019-06-06 16:13:11 -07001235
Colin Cross4c83e5c2019-02-25 14:54:28 -08001236 if ctx.config.captureBuild {
1237 ctx.ruleParams = make(map[blueprint.Rule]blueprint.RuleParams)
1238 }
1239
Colin Cross67a5c132017-05-09 13:45:28 -07001240 desc := "//" + ctx.ModuleDir() + ":" + ctx.ModuleName() + " "
1241 var suffix []string
Colin Cross0875c522017-11-28 17:34:01 -08001242 if ctx.Os().Class != Device && ctx.Os().Class != Generic {
1243 suffix = append(suffix, ctx.Os().String())
Colin Cross67a5c132017-05-09 13:45:28 -07001244 }
Colin Cross0875c522017-11-28 17:34:01 -08001245 if !ctx.PrimaryArch() {
1246 suffix = append(suffix, ctx.Arch().ArchType.String())
Colin Cross67a5c132017-05-09 13:45:28 -07001247 }
Dan Willemsenb13a9482020-02-14 11:25:54 -08001248 if apex, ok := m.module.(ApexModule); ok && !apex.IsForPlatform() {
1249 suffix = append(suffix, apex.ApexName())
1250 }
Colin Cross67a5c132017-05-09 13:45:28 -07001251
1252 ctx.Variable(pctx, "moduleDesc", desc)
1253
1254 s := ""
1255 if len(suffix) > 0 {
1256 s = " [" + strings.Join(suffix, " ") + "]"
1257 }
1258 ctx.Variable(pctx, "moduleDescSuffix", s)
1259
Dan Willemsen569edc52018-11-19 09:33:29 -08001260 // Some common property checks for properties that will be used later in androidmk.go
Colin Cross4157e882019-06-06 16:57:04 -07001261 if m.commonProperties.Dist.Dest != nil {
1262 _, err := validateSafePath(*m.commonProperties.Dist.Dest)
Dan Willemsen569edc52018-11-19 09:33:29 -08001263 if err != nil {
1264 ctx.PropertyErrorf("dist.dest", "%s", err.Error())
1265 }
1266 }
Colin Cross4157e882019-06-06 16:57:04 -07001267 if m.commonProperties.Dist.Dir != nil {
1268 _, err := validateSafePath(*m.commonProperties.Dist.Dir)
Dan Willemsen569edc52018-11-19 09:33:29 -08001269 if err != nil {
1270 ctx.PropertyErrorf("dist.dir", "%s", err.Error())
1271 }
1272 }
Colin Cross4157e882019-06-06 16:57:04 -07001273 if m.commonProperties.Dist.Suffix != nil {
1274 if strings.Contains(*m.commonProperties.Dist.Suffix, "/") {
Dan Willemsen569edc52018-11-19 09:33:29 -08001275 ctx.PropertyErrorf("dist.suffix", "Suffix may not contain a '/' character.")
1276 }
1277 }
1278
Colin Cross4157e882019-06-06 16:57:04 -07001279 if m.Enabled() {
Jooyung Hand48f3c32019-08-23 11:18:57 +09001280 // ensure all direct android.Module deps are enabled
1281 ctx.VisitDirectDepsBlueprint(func(bm blueprint.Module) {
1282 if _, ok := bm.(Module); ok {
1283 ctx.validateAndroidModule(bm, ctx.baseModuleContext.strictVisitDeps)
1284 }
1285 })
1286
Bob Badoura75b0572020-02-18 20:21:55 -08001287 m.noticeFiles = make([]Path, 0)
1288 optPath := OptionalPath{}
1289 notice := proptools.StringDefault(m.commonProperties.Notice, "")
Colin Cross4157e882019-06-06 16:57:04 -07001290 if module := SrcIsModule(notice); module != "" {
Bob Badoura75b0572020-02-18 20:21:55 -08001291 optPath = ctx.ExpandOptionalSource(&notice, "notice")
1292 } else if notice != "" {
Jiyong Park52818fc2019-03-18 12:01:38 +09001293 noticePath := filepath.Join(ctx.ModuleDir(), notice)
Bob Badoura75b0572020-02-18 20:21:55 -08001294 optPath = ExistentPathForSource(ctx, noticePath)
1295 }
1296 if optPath.Valid() {
1297 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1298 } else {
1299 for _, notice = range []string{"LICENSE", "LICENCE", "NOTICE"} {
1300 noticePath := filepath.Join(ctx.ModuleDir(), notice)
1301 optPath = ExistentPathForSource(ctx, noticePath)
1302 if optPath.Valid() {
1303 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1304 }
1305 }
Jaewoong Jung62707f72018-11-16 13:26:43 -08001306 }
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001307
1308 m.module.GenerateAndroidBuildActions(ctx)
1309 if ctx.Failed() {
1310 return
1311 }
1312
1313 m.installFiles = append(m.installFiles, ctx.installFiles...)
1314 m.checkbuildFiles = append(m.checkbuildFiles, ctx.checkbuildFiles...)
Inseob Kim8471cda2019-11-15 09:59:12 +09001315 m.initRcPaths = PathsForModuleSrc(ctx, m.commonProperties.Init_rc)
1316 m.vintfFragmentsPaths = PathsForModuleSrc(ctx, m.commonProperties.Vintf_fragments)
Colin Crossdc35e212019-06-06 16:13:11 -07001317 } else if ctx.Config().AllowMissingDependencies() {
1318 // If the module is not enabled it will not create any build rules, nothing will call
1319 // ctx.GetMissingDependencies(), and blueprint will consider the missing dependencies to be unhandled
1320 // and report them as an error even when AllowMissingDependencies = true. Call
1321 // ctx.GetMissingDependencies() here to tell blueprint not to handle them.
1322 ctx.GetMissingDependencies()
Colin Cross3f40fa42015-01-30 17:27:36 -08001323 }
1324
Colin Cross4157e882019-06-06 16:57:04 -07001325 if m == ctx.FinalModule().(Module).base() {
1326 m.generateModuleTarget(ctx)
Colin Cross9b1d13d2016-09-19 15:18:11 -07001327 if ctx.Failed() {
1328 return
1329 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001330 }
Colin Crosscec81712017-07-13 14:43:27 -07001331
Colin Cross4157e882019-06-06 16:57:04 -07001332 m.buildParams = ctx.buildParams
1333 m.ruleParams = ctx.ruleParams
1334 m.variables = ctx.variables
Colin Cross3f40fa42015-01-30 17:27:36 -08001335}
1336
Colin Cross1184b642019-12-30 18:43:07 -08001337type earlyModuleContext struct {
Colin Crossc34d2322020-01-03 15:23:27 -08001338 blueprint.EarlyModuleContext
Colin Cross1184b642019-12-30 18:43:07 -08001339
1340 kind moduleKind
1341 config Config
1342}
1343
1344func (e *earlyModuleContext) Glob(globPattern string, excludes []string) Paths {
1345 ret, err := e.GlobWithDeps(globPattern, excludes)
1346 if err != nil {
1347 e.ModuleErrorf("glob: %s", err.Error())
1348 }
1349 return pathsForModuleSrcFromFullPath(e, ret, true)
1350}
1351
1352func (e *earlyModuleContext) GlobFiles(globPattern string, excludes []string) Paths {
1353 ret, err := e.GlobWithDeps(globPattern, excludes)
1354 if err != nil {
1355 e.ModuleErrorf("glob: %s", err.Error())
1356 }
1357 return pathsForModuleSrcFromFullPath(e, ret, false)
1358}
1359
Colin Cross988414c2020-01-11 01:11:46 +00001360func (b *earlyModuleContext) IsSymlink(path Path) bool {
1361 fileInfo, err := b.config.fs.Lstat(path.String())
1362 if err != nil {
1363 b.ModuleErrorf("os.Lstat(%q) failed: %s", path.String(), err)
1364 }
1365 return fileInfo.Mode()&os.ModeSymlink == os.ModeSymlink
1366}
1367
1368func (b *earlyModuleContext) Readlink(path Path) string {
1369 dest, err := b.config.fs.Readlink(path.String())
1370 if err != nil {
1371 b.ModuleErrorf("os.Readlink(%q) failed: %s", path.String(), err)
1372 }
1373 return dest
1374}
1375
Colin Cross1184b642019-12-30 18:43:07 -08001376func (e *earlyModuleContext) Module() Module {
Colin Crossc34d2322020-01-03 15:23:27 -08001377 module, _ := e.EarlyModuleContext.Module().(Module)
Colin Cross1184b642019-12-30 18:43:07 -08001378 return module
1379}
1380
1381func (e *earlyModuleContext) Config() Config {
Colin Crossc34d2322020-01-03 15:23:27 -08001382 return e.EarlyModuleContext.Config().(Config)
Colin Cross1184b642019-12-30 18:43:07 -08001383}
1384
1385func (e *earlyModuleContext) AConfig() Config {
1386 return e.config
1387}
1388
1389func (e *earlyModuleContext) DeviceConfig() DeviceConfig {
1390 return DeviceConfig{e.config.deviceConfig}
1391}
1392
1393func (e *earlyModuleContext) Platform() bool {
1394 return e.kind == platformModule
1395}
1396
1397func (e *earlyModuleContext) DeviceSpecific() bool {
1398 return e.kind == deviceSpecificModule
1399}
1400
1401func (e *earlyModuleContext) SocSpecific() bool {
1402 return e.kind == socSpecificModule
1403}
1404
1405func (e *earlyModuleContext) ProductSpecific() bool {
1406 return e.kind == productSpecificModule
1407}
1408
1409func (e *earlyModuleContext) SystemExtSpecific() bool {
1410 return e.kind == systemExtSpecificModule
1411}
1412
1413type baseModuleContext struct {
1414 bp blueprint.BaseModuleContext
1415 earlyModuleContext
Colin Crossfb0c16e2019-11-20 17:12:35 -08001416 os OsType
Colin Cross8b74d172016-09-13 09:59:14 -07001417 target Target
Colin Crossee0bc3b2018-10-02 22:01:37 -07001418 multiTargets []Target
Colin Cross8b74d172016-09-13 09:59:14 -07001419 targetPrimary bool
1420 debug bool
Colin Crossdc35e212019-06-06 16:13:11 -07001421
1422 walkPath []Module
Paul Duffinc5192442020-03-31 11:31:36 +01001423 tagPath []blueprint.DependencyTag
Colin Crossdc35e212019-06-06 16:13:11 -07001424
1425 strictVisitDeps bool // If true, enforce that all dependencies are enabled
Colin Crossf6566ed2015-03-24 11:13:38 -07001426}
1427
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001428func (b *baseModuleContext) OtherModuleName(m blueprint.Module) string {
1429 return b.bp.OtherModuleName(m)
1430}
1431func (b *baseModuleContext) OtherModuleDir(m blueprint.Module) string { return b.bp.OtherModuleDir(m) }
Colin Cross1184b642019-12-30 18:43:07 -08001432func (b *baseModuleContext) OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{}) {
Jooyung Hancd87c692020-02-26 02:05:18 +09001433 b.bp.OtherModuleErrorf(m, fmt, args...)
Colin Cross1184b642019-12-30 18:43:07 -08001434}
1435func (b *baseModuleContext) OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag {
1436 return b.bp.OtherModuleDependencyTag(m)
1437}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001438func (b *baseModuleContext) OtherModuleExists(name string) bool { return b.bp.OtherModuleExists(name) }
1439func (b *baseModuleContext) OtherModuleType(m blueprint.Module) string {
1440 return b.bp.OtherModuleType(m)
1441}
Colin Cross1184b642019-12-30 18:43:07 -08001442
1443func (b *baseModuleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1444 return b.bp.GetDirectDepWithTag(name, tag)
1445}
1446
Paul Duffinf88d8e02020-05-07 20:21:34 +01001447func (b *baseModuleContext) blueprintBaseModuleContext() blueprint.BaseModuleContext {
1448 return b.bp
1449}
1450
Colin Cross25de6c32019-06-06 14:29:25 -07001451type moduleContext struct {
Colin Crossdc35e212019-06-06 16:13:11 -07001452 bp blueprint.ModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -07001453 baseModuleContext
Colin Cross897266e2020-02-13 13:22:08 -08001454 installDeps InstallPaths
1455 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001456 checkbuildFiles Paths
Colin Cross8d8f8e22016-08-03 11:57:50 -07001457 module Module
Colin Crosscec81712017-07-13 14:43:27 -07001458
1459 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001460 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001461 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001462 variables map[string]string
Colin Cross6ff51382015-12-17 16:39:19 -08001463}
1464
Colin Crossb88b3c52019-06-10 15:15:17 -07001465func (m *moduleContext) ninjaError(params BuildParams, err error) (PackageContext, BuildParams) {
1466 return pctx, BuildParams{
Colin Cross4b69c492019-06-07 13:06:06 -07001467 Rule: ErrorRule,
1468 Description: params.Description,
1469 Output: params.Output,
1470 Outputs: params.Outputs,
1471 ImplicitOutput: params.ImplicitOutput,
1472 ImplicitOutputs: params.ImplicitOutputs,
Colin Cross6ff51382015-12-17 16:39:19 -08001473 Args: map[string]string{
1474 "error": err.Error(),
1475 },
Colin Crossb88b3c52019-06-10 15:15:17 -07001476 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001477}
1478
Colin Cross25de6c32019-06-06 14:29:25 -07001479func (m *moduleContext) ModuleBuild(pctx PackageContext, params ModuleBuildParams) {
1480 m.Build(pctx, BuildParams(params))
Colin Cross3f40fa42015-01-30 17:27:36 -08001481}
1482
Colin Cross0875c522017-11-28 17:34:01 -08001483func convertBuildParams(params BuildParams) blueprint.BuildParams {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001484 bparams := blueprint.BuildParams{
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001485 Rule: params.Rule,
Colin Cross0875c522017-11-28 17:34:01 -08001486 Description: params.Description,
Colin Cross33bfb0a2016-11-21 17:23:08 -08001487 Deps: params.Deps,
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001488 Outputs: params.Outputs.Strings(),
1489 ImplicitOutputs: params.ImplicitOutputs.Strings(),
1490 Inputs: params.Inputs.Strings(),
1491 Implicits: params.Implicits.Strings(),
1492 OrderOnly: params.OrderOnly.Strings(),
1493 Args: params.Args,
1494 Optional: !params.Default,
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001495 }
1496
Colin Cross33bfb0a2016-11-21 17:23:08 -08001497 if params.Depfile != nil {
1498 bparams.Depfile = params.Depfile.String()
1499 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001500 if params.Output != nil {
1501 bparams.Outputs = append(bparams.Outputs, params.Output.String())
1502 }
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001503 if params.ImplicitOutput != nil {
1504 bparams.ImplicitOutputs = append(bparams.ImplicitOutputs, params.ImplicitOutput.String())
1505 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001506 if params.Input != nil {
1507 bparams.Inputs = append(bparams.Inputs, params.Input.String())
1508 }
1509 if params.Implicit != nil {
1510 bparams.Implicits = append(bparams.Implicits, params.Implicit.String())
1511 }
1512
Colin Cross0b9f31f2019-02-28 11:00:01 -08001513 bparams.Outputs = proptools.NinjaEscapeList(bparams.Outputs)
1514 bparams.ImplicitOutputs = proptools.NinjaEscapeList(bparams.ImplicitOutputs)
1515 bparams.Inputs = proptools.NinjaEscapeList(bparams.Inputs)
1516 bparams.Implicits = proptools.NinjaEscapeList(bparams.Implicits)
1517 bparams.OrderOnly = proptools.NinjaEscapeList(bparams.OrderOnly)
1518 bparams.Depfile = proptools.NinjaEscapeList([]string{bparams.Depfile})[0]
Colin Crossfe4bc362018-09-12 10:02:13 -07001519
Colin Cross0875c522017-11-28 17:34:01 -08001520 return bparams
1521}
1522
Colin Cross25de6c32019-06-06 14:29:25 -07001523func (m *moduleContext) Variable(pctx PackageContext, name, value string) {
1524 if m.config.captureBuild {
1525 m.variables[name] = value
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001526 }
1527
Colin Crossdc35e212019-06-06 16:13:11 -07001528 m.bp.Variable(pctx.PackageContext, name, value)
Colin Cross0875c522017-11-28 17:34:01 -08001529}
1530
Colin Cross25de6c32019-06-06 14:29:25 -07001531func (m *moduleContext) Rule(pctx PackageContext, name string, params blueprint.RuleParams,
Colin Cross0875c522017-11-28 17:34:01 -08001532 argNames ...string) blueprint.Rule {
1533
Ramy Medhat944839a2020-03-31 22:14:52 -04001534 if m.config.UseRemoteBuild() {
1535 if params.Pool == nil {
1536 // When USE_GOMA=true or USE_RBE=true are set and the rule is not supported by goma/RBE, restrict
1537 // jobs to the local parallelism value
1538 params.Pool = localPool
1539 } else if params.Pool == remotePool {
1540 // remotePool is a fake pool used to identify rule that are supported for remoting. If the rule's
1541 // pool is the remotePool, replace with nil so that ninja runs it at NINJA_REMOTE_NUM_JOBS
1542 // parallelism.
1543 params.Pool = nil
1544 }
Colin Cross2e2dbc22019-09-25 13:31:46 -07001545 }
1546
Colin Crossdc35e212019-06-06 16:13:11 -07001547 rule := m.bp.Rule(pctx.PackageContext, name, params, argNames...)
Colin Cross4c83e5c2019-02-25 14:54:28 -08001548
Colin Cross25de6c32019-06-06 14:29:25 -07001549 if m.config.captureBuild {
1550 m.ruleParams[rule] = params
Colin Cross4c83e5c2019-02-25 14:54:28 -08001551 }
1552
1553 return rule
Colin Cross0875c522017-11-28 17:34:01 -08001554}
1555
Colin Cross25de6c32019-06-06 14:29:25 -07001556func (m *moduleContext) Build(pctx PackageContext, params BuildParams) {
Colin Crossb88b3c52019-06-10 15:15:17 -07001557 if params.Description != "" {
1558 params.Description = "${moduleDesc}" + params.Description + "${moduleDescSuffix}"
1559 }
1560
1561 if missingDeps := m.GetMissingDependencies(); len(missingDeps) > 0 {
1562 pctx, params = m.ninjaError(params, fmt.Errorf("module %s missing dependencies: %s\n",
1563 m.ModuleName(), strings.Join(missingDeps, ", ")))
1564 }
1565
Colin Cross25de6c32019-06-06 14:29:25 -07001566 if m.config.captureBuild {
1567 m.buildParams = append(m.buildParams, params)
Colin Cross0875c522017-11-28 17:34:01 -08001568 }
1569
Colin Crossdc35e212019-06-06 16:13:11 -07001570 m.bp.Build(pctx.PackageContext, convertBuildParams(params))
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001571}
Colin Cross25de6c32019-06-06 14:29:25 -07001572func (m *moduleContext) GetMissingDependencies() []string {
Colin Cross6c4f21f2019-06-06 15:41:36 -07001573 var missingDeps []string
1574 missingDeps = append(missingDeps, m.Module().base().commonProperties.MissingDeps...)
Colin Crossdc35e212019-06-06 16:13:11 -07001575 missingDeps = append(missingDeps, m.bp.GetMissingDependencies()...)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001576 missingDeps = FirstUniqueStrings(missingDeps)
1577 return missingDeps
Colin Cross6ff51382015-12-17 16:39:19 -08001578}
1579
Colin Crossdc35e212019-06-06 16:13:11 -07001580func (b *baseModuleContext) AddMissingDependencies(deps []string) {
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001581 if deps != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001582 missingDeps := &b.Module().base().commonProperties.MissingDeps
Colin Cross6c4f21f2019-06-06 15:41:36 -07001583 *missingDeps = append(*missingDeps, deps...)
1584 *missingDeps = FirstUniqueStrings(*missingDeps)
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001585 }
1586}
1587
Colin Crossdc35e212019-06-06 16:13:11 -07001588func (b *baseModuleContext) validateAndroidModule(module blueprint.Module, strict bool) Module {
Colin Crossd11fcda2017-10-23 17:59:01 -07001589 aModule, _ := module.(Module)
Colin Crossdc35e212019-06-06 16:13:11 -07001590
1591 if !strict {
1592 return aModule
1593 }
1594
Colin Cross380c69a2019-06-10 17:49:58 +00001595 if aModule == nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001596 b.ModuleErrorf("module %q not an android module", b.OtherModuleName(module))
Colin Cross380c69a2019-06-10 17:49:58 +00001597 return nil
1598 }
1599
1600 if !aModule.Enabled() {
Colin Crossdc35e212019-06-06 16:13:11 -07001601 if b.Config().AllowMissingDependencies() {
1602 b.AddMissingDependencies([]string{b.OtherModuleName(aModule)})
Colin Cross380c69a2019-06-10 17:49:58 +00001603 } else {
Colin Crossdc35e212019-06-06 16:13:11 -07001604 b.ModuleErrorf("depends on disabled module %q", b.OtherModuleName(aModule))
Colin Cross380c69a2019-06-10 17:49:58 +00001605 }
1606 return nil
1607 }
Colin Crossd11fcda2017-10-23 17:59:01 -07001608 return aModule
1609}
1610
Colin Crossdc35e212019-06-06 16:13:11 -07001611func (b *baseModuleContext) getDirectDepInternal(name string, tag blueprint.DependencyTag) (blueprint.Module, blueprint.DependencyTag) {
Jiyong Parkf2976302019-04-17 21:47:37 +09001612 type dep struct {
1613 mod blueprint.Module
1614 tag blueprint.DependencyTag
1615 }
1616 var deps []dep
Colin Crossdc35e212019-06-06 16:13:11 -07001617 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001618 if aModule, _ := module.(Module); aModule != nil && aModule.base().BaseModuleName() == name {
Colin Cross1184b642019-12-30 18:43:07 -08001619 returnedTag := b.bp.OtherModuleDependencyTag(aModule)
Jiyong Parkf2976302019-04-17 21:47:37 +09001620 if tag == nil || returnedTag == tag {
1621 deps = append(deps, dep{aModule, returnedTag})
1622 }
1623 }
1624 })
1625 if len(deps) == 1 {
1626 return deps[0].mod, deps[0].tag
1627 } else if len(deps) >= 2 {
1628 panic(fmt.Errorf("Multiple dependencies having same BaseModuleName() %q found from %q",
Colin Crossdc35e212019-06-06 16:13:11 -07001629 name, b.ModuleName()))
Jiyong Parkf2976302019-04-17 21:47:37 +09001630 } else {
1631 return nil, nil
1632 }
1633}
1634
Colin Crossdc35e212019-06-06 16:13:11 -07001635func (b *baseModuleContext) GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module {
Colin Cross0ef08162019-05-01 15:50:51 -07001636 var deps []Module
Colin Crossdc35e212019-06-06 16:13:11 -07001637 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001638 if aModule, _ := module.(Module); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001639 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Cross0ef08162019-05-01 15:50:51 -07001640 deps = append(deps, aModule)
1641 }
1642 }
1643 })
1644 return deps
1645}
1646
Colin Cross25de6c32019-06-06 14:29:25 -07001647func (m *moduleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1648 module, _ := m.getDirectDepInternal(name, tag)
1649 return module
Jiyong Parkf2976302019-04-17 21:47:37 +09001650}
1651
Colin Crossdc35e212019-06-06 16:13:11 -07001652func (b *baseModuleContext) GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag) {
1653 return b.getDirectDepInternal(name, nil)
Jiyong Parkf2976302019-04-17 21:47:37 +09001654}
1655
Colin Crossdc35e212019-06-06 16:13:11 -07001656func (b *baseModuleContext) VisitDirectDepsBlueprint(visit func(blueprint.Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001657 b.bp.VisitDirectDeps(visit)
Colin Cross35143d02017-11-16 00:11:20 -08001658}
1659
Colin Crossdc35e212019-06-06 16:13:11 -07001660func (b *baseModuleContext) VisitDirectDeps(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001661 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001662 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001663 visit(aModule)
1664 }
1665 })
1666}
1667
Colin Crossdc35e212019-06-06 16:13:11 -07001668func (b *baseModuleContext) VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001669 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001670 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001671 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Crossee6143c2017-12-30 17:54:27 -08001672 visit(aModule)
1673 }
1674 }
1675 })
1676}
1677
Colin Crossdc35e212019-06-06 16:13:11 -07001678func (b *baseModuleContext) VisitDirectDepsIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001679 b.bp.VisitDirectDepsIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001680 // pred
1681 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001682 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001683 return pred(aModule)
1684 } else {
1685 return false
1686 }
1687 },
1688 // visit
1689 func(module blueprint.Module) {
1690 visit(module.(Module))
1691 })
1692}
1693
Colin Crossdc35e212019-06-06 16:13:11 -07001694func (b *baseModuleContext) VisitDepsDepthFirst(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001695 b.bp.VisitDepsDepthFirst(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001696 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001697 visit(aModule)
1698 }
1699 })
1700}
1701
Colin Crossdc35e212019-06-06 16:13:11 -07001702func (b *baseModuleContext) VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001703 b.bp.VisitDepsDepthFirstIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001704 // pred
1705 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001706 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001707 return pred(aModule)
1708 } else {
1709 return false
1710 }
1711 },
1712 // visit
1713 func(module blueprint.Module) {
1714 visit(module.(Module))
1715 })
1716}
1717
Colin Crossdc35e212019-06-06 16:13:11 -07001718func (b *baseModuleContext) WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool) {
Colin Cross1184b642019-12-30 18:43:07 -08001719 b.bp.WalkDeps(visit)
Alex Light778127a2019-02-27 14:19:50 -08001720}
1721
Colin Crossdc35e212019-06-06 16:13:11 -07001722func (b *baseModuleContext) WalkDeps(visit func(Module, Module) bool) {
1723 b.walkPath = []Module{b.Module()}
Paul Duffinc5192442020-03-31 11:31:36 +01001724 b.tagPath = []blueprint.DependencyTag{}
Colin Cross1184b642019-12-30 18:43:07 -08001725 b.bp.WalkDeps(func(child, parent blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001726 childAndroidModule, _ := child.(Module)
1727 parentAndroidModule, _ := parent.(Module)
Colin Crossd11fcda2017-10-23 17:59:01 -07001728 if childAndroidModule != nil && parentAndroidModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001729 // record walkPath before visit
1730 for b.walkPath[len(b.walkPath)-1] != parentAndroidModule {
1731 b.walkPath = b.walkPath[0 : len(b.walkPath)-1]
Paul Duffinc5192442020-03-31 11:31:36 +01001732 b.tagPath = b.tagPath[0 : len(b.tagPath)-1]
Colin Crossdc35e212019-06-06 16:13:11 -07001733 }
1734 b.walkPath = append(b.walkPath, childAndroidModule)
Paul Duffinc5192442020-03-31 11:31:36 +01001735 b.tagPath = append(b.tagPath, b.OtherModuleDependencyTag(childAndroidModule))
Colin Crossd11fcda2017-10-23 17:59:01 -07001736 return visit(childAndroidModule, parentAndroidModule)
1737 } else {
1738 return false
1739 }
1740 })
1741}
1742
Colin Crossdc35e212019-06-06 16:13:11 -07001743func (b *baseModuleContext) GetWalkPath() []Module {
1744 return b.walkPath
1745}
1746
Paul Duffinc5192442020-03-31 11:31:36 +01001747func (b *baseModuleContext) GetTagPath() []blueprint.DependencyTag {
1748 return b.tagPath
1749}
1750
Jiyong Park1c7e9622020-05-07 16:12:13 +09001751// A regexp for removing boilerplate from BaseDependencyTag from the string representation of
1752// a dependency tag.
1753var tagCleaner = regexp.MustCompile(`\QBaseDependencyTag:blueprint.BaseDependencyTag{}\E(, )?`)
1754
1755// PrettyPrintTag returns string representation of the tag, but prefers
1756// custom String() method if available.
1757func PrettyPrintTag(tag blueprint.DependencyTag) string {
1758 // Use tag's custom String() method if available.
1759 if stringer, ok := tag.(fmt.Stringer); ok {
1760 return stringer.String()
1761 }
1762
1763 // Otherwise, get a default string representation of the tag's struct.
1764 tagString := fmt.Sprintf("%#v", tag)
1765
1766 // Remove the boilerplate from BaseDependencyTag as it adds no value.
1767 tagString = tagCleaner.ReplaceAllString(tagString, "")
1768 return tagString
1769}
1770
1771func (b *baseModuleContext) GetPathString(skipFirst bool) string {
1772 sb := strings.Builder{}
1773 tagPath := b.GetTagPath()
1774 walkPath := b.GetWalkPath()
1775 if !skipFirst {
1776 sb.WriteString(walkPath[0].String())
1777 }
1778 for i, m := range walkPath[1:] {
1779 sb.WriteString("\n")
1780 sb.WriteString(fmt.Sprintf(" via tag %s\n", PrettyPrintTag(tagPath[i])))
1781 sb.WriteString(fmt.Sprintf(" -> %s", m.String()))
1782 }
1783 return sb.String()
1784}
1785
Colin Cross25de6c32019-06-06 14:29:25 -07001786func (m *moduleContext) VisitAllModuleVariants(visit func(Module)) {
Colin Crossdc35e212019-06-06 16:13:11 -07001787 m.bp.VisitAllModuleVariants(func(module blueprint.Module) {
Colin Cross0875c522017-11-28 17:34:01 -08001788 visit(module.(Module))
1789 })
1790}
1791
Colin Cross25de6c32019-06-06 14:29:25 -07001792func (m *moduleContext) PrimaryModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001793 return m.bp.PrimaryModule().(Module)
Colin Cross0875c522017-11-28 17:34:01 -08001794}
1795
Colin Cross25de6c32019-06-06 14:29:25 -07001796func (m *moduleContext) FinalModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001797 return m.bp.FinalModule().(Module)
1798}
1799
1800func (m *moduleContext) ModuleSubDir() string {
1801 return m.bp.ModuleSubDir()
Colin Cross0875c522017-11-28 17:34:01 -08001802}
1803
Colin Cross0ea8ba82019-06-06 14:33:29 -07001804func (b *baseModuleContext) Target() Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001805 return b.target
Colin Crossa1ad8d12016-06-01 17:09:44 -07001806}
1807
Colin Cross0ea8ba82019-06-06 14:33:29 -07001808func (b *baseModuleContext) TargetPrimary() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001809 return b.targetPrimary
Colin Cross8b74d172016-09-13 09:59:14 -07001810}
1811
Colin Cross0ea8ba82019-06-06 14:33:29 -07001812func (b *baseModuleContext) MultiTargets() []Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001813 return b.multiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07001814}
1815
Colin Cross0ea8ba82019-06-06 14:33:29 -07001816func (b *baseModuleContext) Arch() Arch {
Colin Cross25de6c32019-06-06 14:29:25 -07001817 return b.target.Arch
Colin Cross3f40fa42015-01-30 17:27:36 -08001818}
1819
Colin Cross0ea8ba82019-06-06 14:33:29 -07001820func (b *baseModuleContext) Os() OsType {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001821 return b.os
Dan Willemsen490fd492015-11-24 17:53:15 -08001822}
1823
Colin Cross0ea8ba82019-06-06 14:33:29 -07001824func (b *baseModuleContext) Host() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001825 return b.os.Class == Host || b.os.Class == HostCross
Colin Crossf6566ed2015-03-24 11:13:38 -07001826}
1827
Colin Cross0ea8ba82019-06-06 14:33:29 -07001828func (b *baseModuleContext) Device() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001829 return b.os.Class == Device
Colin Crossf6566ed2015-03-24 11:13:38 -07001830}
1831
Colin Cross0ea8ba82019-06-06 14:33:29 -07001832func (b *baseModuleContext) Darwin() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001833 return b.os == Darwin
Colin Cross0af4b842015-04-30 16:36:18 -07001834}
1835
Colin Cross0ea8ba82019-06-06 14:33:29 -07001836func (b *baseModuleContext) Fuchsia() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001837 return b.os == Fuchsia
Doug Horn21b94272019-01-16 12:06:11 -08001838}
1839
Colin Cross0ea8ba82019-06-06 14:33:29 -07001840func (b *baseModuleContext) Windows() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001841 return b.os == Windows
Colin Cross3edeee12017-04-04 12:59:48 -07001842}
1843
Colin Cross0ea8ba82019-06-06 14:33:29 -07001844func (b *baseModuleContext) Debug() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001845 return b.debug
Colin Crossf6566ed2015-03-24 11:13:38 -07001846}
1847
Colin Cross0ea8ba82019-06-06 14:33:29 -07001848func (b *baseModuleContext) PrimaryArch() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001849 if len(b.config.Targets[b.target.Os]) <= 1 {
Colin Cross67a5c132017-05-09 13:45:28 -07001850 return true
1851 }
Colin Cross25de6c32019-06-06 14:29:25 -07001852 return b.target.Arch.ArchType == b.config.Targets[b.target.Os][0].Arch.ArchType
Colin Cross1e7d3702016-08-24 15:25:47 -07001853}
1854
Jiyong Park5baac542018-08-28 09:55:37 +09001855// Makes this module a platform module, i.e. not specific to soc, device,
Justin Yund5f6c822019-06-25 16:47:17 +09001856// product, or system_ext.
Colin Cross4157e882019-06-06 16:57:04 -07001857func (m *ModuleBase) MakeAsPlatform() {
1858 m.commonProperties.Vendor = boolPtr(false)
1859 m.commonProperties.Proprietary = boolPtr(false)
1860 m.commonProperties.Soc_specific = boolPtr(false)
1861 m.commonProperties.Product_specific = boolPtr(false)
Justin Yund5f6c822019-06-25 16:47:17 +09001862 m.commonProperties.System_ext_specific = boolPtr(false)
Jiyong Park5baac542018-08-28 09:55:37 +09001863}
1864
Colin Cross4157e882019-06-06 16:57:04 -07001865func (m *ModuleBase) EnableNativeBridgeSupportByDefault() {
1866 m.commonProperties.Native_bridge_supported = boolPtr(true)
dimitry03dc3f62019-05-09 14:07:34 +02001867}
1868
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001869func (m *ModuleBase) MakeAsSystemExt() {
Jooyung Han91df2082019-11-20 01:49:42 +09001870 m.commonProperties.Vendor = boolPtr(false)
1871 m.commonProperties.Proprietary = boolPtr(false)
1872 m.commonProperties.Soc_specific = boolPtr(false)
1873 m.commonProperties.Product_specific = boolPtr(false)
1874 m.commonProperties.System_ext_specific = boolPtr(true)
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001875}
1876
Jooyung Han344d5432019-08-23 11:17:39 +09001877// IsNativeBridgeSupported returns true if "native_bridge_supported" is explicitly set as "true"
1878func (m *ModuleBase) IsNativeBridgeSupported() bool {
1879 return proptools.Bool(m.commonProperties.Native_bridge_supported)
1880}
1881
Colin Cross25de6c32019-06-06 14:29:25 -07001882func (m *moduleContext) InstallInData() bool {
1883 return m.module.InstallInData()
Dan Willemsen782a2d12015-12-21 14:55:28 -08001884}
1885
Jaewoong Jung0949f312019-09-11 10:25:18 -07001886func (m *moduleContext) InstallInTestcases() bool {
1887 return m.module.InstallInTestcases()
1888}
1889
Colin Cross25de6c32019-06-06 14:29:25 -07001890func (m *moduleContext) InstallInSanitizerDir() bool {
1891 return m.module.InstallInSanitizerDir()
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001892}
1893
Yifan Hong1b3348d2020-01-21 15:53:22 -08001894func (m *moduleContext) InstallInRamdisk() bool {
1895 return m.module.InstallInRamdisk()
1896}
1897
Colin Cross25de6c32019-06-06 14:29:25 -07001898func (m *moduleContext) InstallInRecovery() bool {
1899 return m.module.InstallInRecovery()
Jiyong Parkf9332f12018-02-01 00:54:12 +09001900}
1901
Colin Cross90ba5f42019-10-02 11:10:58 -07001902func (m *moduleContext) InstallInRoot() bool {
1903 return m.module.InstallInRoot()
1904}
1905
Colin Cross607d8582019-07-29 16:44:46 -07001906func (m *moduleContext) InstallBypassMake() bool {
1907 return m.module.InstallBypassMake()
1908}
1909
Colin Cross6e359402020-02-10 15:29:54 -08001910func (m *moduleContext) InstallForceOS() *OsType {
1911 return m.module.InstallForceOS()
1912}
1913
Colin Cross70dda7e2019-10-01 22:05:35 -07001914func (m *moduleContext) skipInstall(fullInstallPath InstallPath) bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001915 if m.module.base().commonProperties.SkipInstall {
Colin Cross893d8162017-04-26 17:34:03 -07001916 return true
1917 }
1918
Colin Cross3607f212018-05-07 15:28:05 -07001919 // We'll need a solution for choosing which of modules with the same name in different
1920 // namespaces to install. For now, reuse the list of namespaces exported to Make as the
1921 // list of namespaces to install in a Soong-only build.
Colin Cross25de6c32019-06-06 14:29:25 -07001922 if !m.module.base().commonProperties.NamespaceExportedToMake {
Colin Cross3607f212018-05-07 15:28:05 -07001923 return true
1924 }
1925
Colin Cross25de6c32019-06-06 14:29:25 -07001926 if m.Device() {
Colin Cross607d8582019-07-29 16:44:46 -07001927 if m.Config().EmbeddedInMake() && !m.InstallBypassMake() {
Colin Cross893d8162017-04-26 17:34:03 -07001928 return true
1929 }
1930
Colin Cross25de6c32019-06-06 14:29:25 -07001931 if m.Config().SkipMegaDeviceInstall(fullInstallPath.String()) {
Colin Cross893d8162017-04-26 17:34:03 -07001932 return true
1933 }
1934 }
1935
1936 return false
1937}
1938
Colin Cross70dda7e2019-10-01 22:05:35 -07001939func (m *moduleContext) InstallFile(installPath InstallPath, name string, srcPath Path,
1940 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001941 return m.installFile(installPath, name, srcPath, Cp, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001942}
1943
Colin Cross70dda7e2019-10-01 22:05:35 -07001944func (m *moduleContext) InstallExecutable(installPath InstallPath, name string, srcPath Path,
1945 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001946 return m.installFile(installPath, name, srcPath, CpExecutable, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001947}
1948
Colin Cross70dda7e2019-10-01 22:05:35 -07001949func (m *moduleContext) installFile(installPath InstallPath, name string, srcPath Path,
1950 rule blueprint.Rule, deps []Path) InstallPath {
Colin Cross35cec122015-04-02 14:37:16 -07001951
Colin Cross25de6c32019-06-06 14:29:25 -07001952 fullInstallPath := installPath.Join(m, name)
1953 m.module.base().hooks.runInstallHooks(m, fullInstallPath, false)
Colin Cross3f40fa42015-01-30 17:27:36 -08001954
Colin Cross25de6c32019-06-06 14:29:25 -07001955 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001956
Colin Cross897266e2020-02-13 13:22:08 -08001957 deps = append(deps, m.installDeps.Paths()...)
Colin Cross35cec122015-04-02 14:37:16 -07001958
Colin Cross89562dc2016-10-03 17:47:19 -07001959 var implicitDeps, orderOnlyDeps Paths
1960
Colin Cross25de6c32019-06-06 14:29:25 -07001961 if m.Host() {
Colin Cross89562dc2016-10-03 17:47:19 -07001962 // Installed host modules might be used during the build, depend directly on their
1963 // dependencies so their timestamp is updated whenever their dependency is updated
1964 implicitDeps = deps
1965 } else {
1966 orderOnlyDeps = deps
1967 }
1968
Colin Cross25de6c32019-06-06 14:29:25 -07001969 m.Build(pctx, BuildParams{
Colin Cross5c517922017-08-31 12:29:17 -07001970 Rule: rule,
Colin Cross67a5c132017-05-09 13:45:28 -07001971 Description: "install " + fullInstallPath.Base(),
1972 Output: fullInstallPath,
1973 Input: srcPath,
1974 Implicits: implicitDeps,
1975 OrderOnly: orderOnlyDeps,
Colin Cross25de6c32019-06-06 14:29:25 -07001976 Default: !m.Config().EmbeddedInMake(),
Dan Willemsen322acaf2016-01-12 23:07:05 -08001977 })
Colin Cross3f40fa42015-01-30 17:27:36 -08001978
Colin Cross25de6c32019-06-06 14:29:25 -07001979 m.installFiles = append(m.installFiles, fullInstallPath)
Dan Willemsen322acaf2016-01-12 23:07:05 -08001980 }
Colin Cross25de6c32019-06-06 14:29:25 -07001981 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross35cec122015-04-02 14:37:16 -07001982 return fullInstallPath
1983}
1984
Colin Cross70dda7e2019-10-01 22:05:35 -07001985func (m *moduleContext) InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001986 fullInstallPath := installPath.Join(m, name)
1987 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Colin Cross3854a602016-01-11 12:49:11 -08001988
Colin Cross25de6c32019-06-06 14:29:25 -07001989 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001990
Alex Lightfb4353d2019-01-17 13:57:45 -08001991 relPath, err := filepath.Rel(path.Dir(fullInstallPath.String()), srcPath.String())
1992 if err != nil {
1993 panic(fmt.Sprintf("Unable to generate symlink between %q and %q: %s", fullInstallPath.Base(), srcPath.Base(), err))
1994 }
Colin Cross25de6c32019-06-06 14:29:25 -07001995 m.Build(pctx, BuildParams{
Colin Cross67a5c132017-05-09 13:45:28 -07001996 Rule: Symlink,
1997 Description: "install symlink " + fullInstallPath.Base(),
1998 Output: fullInstallPath,
Dan Willemsen40efa1c2020-01-14 15:19:52 -08001999 Input: srcPath,
Colin Cross25de6c32019-06-06 14:29:25 -07002000 Default: !m.Config().EmbeddedInMake(),
Colin Cross12fc4972016-01-11 12:49:11 -08002001 Args: map[string]string{
Alex Lightfb4353d2019-01-17 13:57:45 -08002002 "fromPath": relPath,
Colin Cross12fc4972016-01-11 12:49:11 -08002003 },
2004 })
Colin Cross3854a602016-01-11 12:49:11 -08002005
Colin Cross25de6c32019-06-06 14:29:25 -07002006 m.installFiles = append(m.installFiles, fullInstallPath)
2007 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross12fc4972016-01-11 12:49:11 -08002008 }
Colin Cross3854a602016-01-11 12:49:11 -08002009 return fullInstallPath
2010}
2011
Jiyong Parkf1194352019-02-25 11:05:47 +09002012// installPath/name -> absPath where absPath might be a path that is available only at runtime
2013// (e.g. /apex/...)
Colin Cross70dda7e2019-10-01 22:05:35 -07002014func (m *moduleContext) InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002015 fullInstallPath := installPath.Join(m, name)
2016 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Jiyong Parkf1194352019-02-25 11:05:47 +09002017
Colin Cross25de6c32019-06-06 14:29:25 -07002018 if !m.skipInstall(fullInstallPath) {
2019 m.Build(pctx, BuildParams{
Jiyong Parkf1194352019-02-25 11:05:47 +09002020 Rule: Symlink,
2021 Description: "install symlink " + fullInstallPath.Base() + " -> " + absPath,
2022 Output: fullInstallPath,
Colin Cross25de6c32019-06-06 14:29:25 -07002023 Default: !m.Config().EmbeddedInMake(),
Jiyong Parkf1194352019-02-25 11:05:47 +09002024 Args: map[string]string{
2025 "fromPath": absPath,
2026 },
2027 })
2028
Colin Cross25de6c32019-06-06 14:29:25 -07002029 m.installFiles = append(m.installFiles, fullInstallPath)
Jiyong Parkf1194352019-02-25 11:05:47 +09002030 }
2031 return fullInstallPath
2032}
2033
Colin Cross25de6c32019-06-06 14:29:25 -07002034func (m *moduleContext) CheckbuildFile(srcPath Path) {
2035 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross3f40fa42015-01-30 17:27:36 -08002036}
2037
Dan Willemsen2ef08f42015-06-30 18:15:24 -07002038func findStringInSlice(str string, slice []string) int {
2039 for i, s := range slice {
2040 if s == str {
2041 return i
Colin Crossfce53272015-04-08 11:21:40 -07002042 }
2043 }
Dan Willemsen2ef08f42015-06-30 18:15:24 -07002044 return -1
2045}
2046
Colin Cross41955e82019-05-29 14:40:35 -07002047// SrcIsModule decodes module references in the format ":name" into the module name, or empty string if the input
2048// was not a module reference.
2049func SrcIsModule(s string) (module string) {
Colin Cross068e0fe2016-12-13 15:23:47 -08002050 if len(s) > 1 && s[0] == ':' {
2051 return s[1:]
2052 }
2053 return ""
2054}
2055
Colin Cross41955e82019-05-29 14:40:35 -07002056// SrcIsModule decodes module references in the format ":name{.tag}" into the module name and tag, ":name" into the
2057// module name and an empty string for the tag, or empty strings if the input was not a module reference.
2058func SrcIsModuleWithTag(s string) (module, tag string) {
2059 if len(s) > 1 && s[0] == ':' {
2060 module = s[1:]
2061 if tagStart := strings.IndexByte(module, '{'); tagStart > 0 {
2062 if module[len(module)-1] == '}' {
2063 tag = module[tagStart+1 : len(module)-1]
2064 module = module[:tagStart]
2065 return module, tag
2066 }
2067 }
2068 return module, ""
2069 }
2070 return "", ""
Colin Cross068e0fe2016-12-13 15:23:47 -08002071}
2072
Colin Cross41955e82019-05-29 14:40:35 -07002073type sourceOrOutputDependencyTag struct {
2074 blueprint.BaseDependencyTag
2075 tag string
2076}
2077
2078func sourceOrOutputDepTag(tag string) blueprint.DependencyTag {
2079 return sourceOrOutputDependencyTag{tag: tag}
2080}
2081
2082var SourceDepTag = sourceOrOutputDepTag("")
Colin Cross068e0fe2016-12-13 15:23:47 -08002083
Colin Cross366938f2017-12-11 16:29:02 -08002084// Adds necessary dependencies to satisfy filegroup or generated sources modules listed in srcFiles
2085// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002086//
2087// Deprecated: tag the property with `android:"path"` instead.
Colin Cross068e0fe2016-12-13 15:23:47 -08002088func ExtractSourcesDeps(ctx BottomUpMutatorContext, srcFiles []string) {
Nan Zhang2439eb72017-04-10 11:27:50 -07002089 set := make(map[string]bool)
2090
Colin Cross068e0fe2016-12-13 15:23:47 -08002091 for _, s := range srcFiles {
Colin Cross41955e82019-05-29 14:40:35 -07002092 if m, t := SrcIsModuleWithTag(s); m != "" {
2093 if _, found := set[s]; found {
2094 ctx.ModuleErrorf("found source dependency duplicate: %q!", s)
Nan Zhang2439eb72017-04-10 11:27:50 -07002095 } else {
Colin Cross41955e82019-05-29 14:40:35 -07002096 set[s] = true
2097 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Nan Zhang2439eb72017-04-10 11:27:50 -07002098 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002099 }
2100 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002101}
2102
Colin Cross366938f2017-12-11 16:29:02 -08002103// Adds necessary dependencies to satisfy filegroup or generated sources modules specified in s
2104// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002105//
2106// Deprecated: tag the property with `android:"path"` instead.
Colin Cross366938f2017-12-11 16:29:02 -08002107func ExtractSourceDeps(ctx BottomUpMutatorContext, s *string) {
2108 if s != nil {
Colin Cross41955e82019-05-29 14:40:35 -07002109 if m, t := SrcIsModuleWithTag(*s); m != "" {
2110 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Colin Cross366938f2017-12-11 16:29:02 -08002111 }
2112 }
2113}
2114
Colin Cross41955e82019-05-29 14:40:35 -07002115// A module that implements SourceFileProducer can be referenced from any property that is tagged with `android:"path"`
2116// 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 -08002117type SourceFileProducer interface {
2118 Srcs() Paths
2119}
2120
Colin Cross41955e82019-05-29 14:40:35 -07002121// A module that implements OutputFileProducer can be referenced from any property that is tagged with `android:"path"`
Roland Levillain97c1f342019-11-22 14:20:54 +00002122// 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 -07002123// listed in the property.
2124type OutputFileProducer interface {
2125 OutputFiles(tag string) (Paths, error)
2126}
2127
Colin Cross5e708052019-08-06 13:59:50 -07002128// OutputFilesForModule returns the paths from an OutputFileProducer with the given tag. On error, including if the
2129// module produced zero paths, it reports errors to the ctx and returns nil.
2130func OutputFilesForModule(ctx PathContext, module blueprint.Module, tag string) Paths {
2131 paths, err := outputFilesForModule(ctx, module, tag)
2132 if err != nil {
2133 reportPathError(ctx, err)
2134 return nil
2135 }
2136 return paths
2137}
2138
2139// OutputFileForModule returns the path from an OutputFileProducer with the given tag. On error, including if the
2140// module produced zero or multiple paths, it reports errors to the ctx and returns nil.
2141func OutputFileForModule(ctx PathContext, module blueprint.Module, tag string) Path {
2142 paths, err := outputFilesForModule(ctx, module, tag)
2143 if err != nil {
2144 reportPathError(ctx, err)
2145 return nil
2146 }
2147 if len(paths) > 1 {
2148 reportPathErrorf(ctx, "got multiple output files from module %q, expected exactly one",
2149 pathContextName(ctx, module))
2150 return nil
2151 }
2152 return paths[0]
2153}
2154
2155func outputFilesForModule(ctx PathContext, module blueprint.Module, tag string) (Paths, error) {
2156 if outputFileProducer, ok := module.(OutputFileProducer); ok {
2157 paths, err := outputFileProducer.OutputFiles(tag)
2158 if err != nil {
2159 return nil, fmt.Errorf("failed to get output file from module %q: %s",
2160 pathContextName(ctx, module), err.Error())
2161 }
2162 if len(paths) == 0 {
2163 return nil, fmt.Errorf("failed to get output files from module %q", pathContextName(ctx, module))
2164 }
2165 return paths, nil
2166 } else {
2167 return nil, fmt.Errorf("module %q is not an OutputFileProducer", pathContextName(ctx, module))
2168 }
2169}
2170
Colin Crossfe17f6f2019-03-28 19:30:56 -07002171type HostToolProvider interface {
2172 HostToolPath() OptionalPath
2173}
2174
Colin Cross27b922f2019-03-04 22:35:41 -08002175// Returns a list of paths expanded from globs and modules referenced using ":module" syntax. The property must
2176// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002177//
2178// Deprecated: use PathsForModuleSrc or PathsForModuleSrcExcludes instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002179func (m *moduleContext) ExpandSources(srcFiles, excludes []string) Paths {
2180 return PathsForModuleSrcExcludes(m, srcFiles, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07002181}
2182
Colin Cross2fafa3e2019-03-05 12:39:51 -08002183// Returns a single path expanded from globs and modules referenced using ":module" syntax. The property must
2184// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002185//
2186// Deprecated: use PathForModuleSrc instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002187func (m *moduleContext) ExpandSource(srcFile, prop string) Path {
2188 return PathForModuleSrc(m, srcFile)
Colin Cross2fafa3e2019-03-05 12:39:51 -08002189}
2190
2191// Returns an optional single path expanded from globs and modules referenced using ":module" syntax if
2192// the srcFile is non-nil. The property must be tagged with `android:"path" to support automatic source module
2193// dependency resolution.
Colin Cross25de6c32019-06-06 14:29:25 -07002194func (m *moduleContext) ExpandOptionalSource(srcFile *string, prop string) OptionalPath {
Colin Cross2fafa3e2019-03-05 12:39:51 -08002195 if srcFile != nil {
Colin Cross25de6c32019-06-06 14:29:25 -07002196 return OptionalPathForPath(PathForModuleSrc(m, *srcFile))
Colin Cross2fafa3e2019-03-05 12:39:51 -08002197 }
2198 return OptionalPath{}
2199}
2200
Colin Cross25de6c32019-06-06 14:29:25 -07002201func (m *moduleContext) RequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002202 return m.module.RequiredModuleNames()
Nan Zhang6d34b302017-02-04 17:47:46 -08002203}
2204
Colin Cross25de6c32019-06-06 14:29:25 -07002205func (m *moduleContext) HostRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002206 return m.module.HostRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002207}
2208
Colin Cross25de6c32019-06-06 14:29:25 -07002209func (m *moduleContext) TargetRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002210 return m.module.TargetRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002211}
2212
Colin Cross463a90e2015-06-17 14:20:06 -07002213func init() {
Colin Cross798bfce2016-10-12 14:28:16 -07002214 RegisterSingletonType("buildtarget", BuildTargetSingleton)
Colin Cross463a90e2015-06-17 14:20:06 -07002215}
2216
Colin Cross0875c522017-11-28 17:34:01 -08002217func BuildTargetSingleton() Singleton {
Colin Cross1f8c52b2015-06-16 16:38:17 -07002218 return &buildTargetSingleton{}
2219}
2220
Colin Cross87d8b562017-04-25 10:01:55 -07002221func parentDir(dir string) string {
2222 dir, _ = filepath.Split(dir)
2223 return filepath.Clean(dir)
2224}
2225
Colin Cross1f8c52b2015-06-16 16:38:17 -07002226type buildTargetSingleton struct{}
2227
Colin Cross0875c522017-11-28 17:34:01 -08002228func (c *buildTargetSingleton) GenerateBuildActions(ctx SingletonContext) {
2229 var checkbuildDeps Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07002230
Colin Cross0875c522017-11-28 17:34:01 -08002231 mmTarget := func(dir string) WritablePath {
2232 return PathForPhony(ctx,
2233 "MODULES-IN-"+strings.Replace(filepath.Clean(dir), "/", "-", -1))
Colin Cross87d8b562017-04-25 10:01:55 -07002234 }
2235
Colin Cross0875c522017-11-28 17:34:01 -08002236 modulesInDir := make(map[string]Paths)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002237
Colin Cross0875c522017-11-28 17:34:01 -08002238 ctx.VisitAllModules(func(module Module) {
2239 blueprintDir := module.base().blueprintDir
2240 installTarget := module.base().installTarget
2241 checkbuildTarget := module.base().checkbuildTarget
Colin Cross1f8c52b2015-06-16 16:38:17 -07002242
Colin Cross0875c522017-11-28 17:34:01 -08002243 if checkbuildTarget != nil {
2244 checkbuildDeps = append(checkbuildDeps, checkbuildTarget)
2245 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], checkbuildTarget)
2246 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002247
Colin Cross0875c522017-11-28 17:34:01 -08002248 if installTarget != nil {
2249 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], installTarget)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002250 }
2251 })
2252
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002253 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08002254 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002255 suffix = "-soong"
2256 }
2257
Colin Cross1f8c52b2015-06-16 16:38:17 -07002258 // Create a top-level checkbuild target that depends on all modules
Colin Cross0875c522017-11-28 17:34:01 -08002259 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07002260 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002261 Output: PathForPhony(ctx, "checkbuild"+suffix),
Colin Cross1f8c52b2015-06-16 16:38:17 -07002262 Implicits: checkbuildDeps,
Colin Cross1f8c52b2015-06-16 16:38:17 -07002263 })
2264
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002265 // Make will generate the MODULES-IN-* targets
Colin Crossaabf6792017-11-29 00:27:14 -08002266 if ctx.Config().EmbeddedInMake() {
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002267 return
2268 }
2269
Colin Cross87d8b562017-04-25 10:01:55 -07002270 // Ensure ancestor directories are in modulesInDir
Inseob Kim1a365c62019-06-08 15:47:51 +09002271 dirs := SortedStringKeys(modulesInDir)
Colin Cross87d8b562017-04-25 10:01:55 -07002272 for _, dir := range dirs {
2273 dir := parentDir(dir)
2274 for dir != "." && dir != "/" {
2275 if _, exists := modulesInDir[dir]; exists {
2276 break
2277 }
2278 modulesInDir[dir] = nil
2279 dir = parentDir(dir)
2280 }
2281 }
2282
2283 // Make directories build their direct subdirectories
Colin Cross87d8b562017-04-25 10:01:55 -07002284 for _, dir := range dirs {
2285 p := parentDir(dir)
2286 if p != "." && p != "/" {
2287 modulesInDir[p] = append(modulesInDir[p], mmTarget(dir))
2288 }
2289 }
2290
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002291 // Create a MODULES-IN-<directory> target that depends on all modules in a directory, and
2292 // depends on the MODULES-IN-* targets of all of its subdirectories that contain Android.bp
2293 // files.
Colin Cross1f8c52b2015-06-16 16:38:17 -07002294 for _, dir := range dirs {
Colin Cross0875c522017-11-28 17:34:01 -08002295 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07002296 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002297 Output: mmTarget(dir),
Colin Cross87d8b562017-04-25 10:01:55 -07002298 Implicits: modulesInDir[dir],
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002299 // HACK: checkbuild should be an optional build, but force it
2300 // enabled for now in standalone builds
Colin Crossaabf6792017-11-29 00:27:14 -08002301 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross1f8c52b2015-06-16 16:38:17 -07002302 })
2303 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002304
2305 // Create (host|host-cross|target)-<OS> phony rules to build a reduced checkbuild.
2306 osDeps := map[OsType]Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08002307 ctx.VisitAllModules(func(module Module) {
2308 if module.Enabled() {
2309 os := module.Target().Os
2310 osDeps[os] = append(osDeps[os], module.base().checkbuildFiles...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002311 }
2312 })
2313
Colin Cross0875c522017-11-28 17:34:01 -08002314 osClass := make(map[string]Paths)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002315 for os, deps := range osDeps {
2316 var className string
2317
2318 switch os.Class {
2319 case Host:
2320 className = "host"
2321 case HostCross:
2322 className = "host-cross"
2323 case Device:
2324 className = "target"
2325 default:
2326 continue
2327 }
2328
Colin Cross0875c522017-11-28 17:34:01 -08002329 name := PathForPhony(ctx, className+"-"+os.Name)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002330 osClass[className] = append(osClass[className], name)
2331
Colin Cross0875c522017-11-28 17:34:01 -08002332 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07002333 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002334 Output: name,
2335 Implicits: deps,
Dan Willemsen61d88b82017-09-20 17:29:08 -07002336 })
2337 }
2338
2339 // Wrap those into host|host-cross|target phony rules
Inseob Kim1a365c62019-06-08 15:47:51 +09002340 for _, class := range SortedStringKeys(osClass) {
Colin Cross0875c522017-11-28 17:34:01 -08002341 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07002342 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002343 Output: PathForPhony(ctx, class),
Dan Willemsen61d88b82017-09-20 17:29:08 -07002344 Implicits: osClass[class],
Dan Willemsen61d88b82017-09-20 17:29:08 -07002345 })
2346 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002347}
Colin Crossd779da42015-12-17 18:00:23 -08002348
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002349// Collect information for opening IDE project files in java/jdeps.go.
2350type IDEInfo interface {
2351 IDEInfo(ideInfo *IdeInfo)
2352 BaseModuleName() string
2353}
2354
2355// Extract the base module name from the Import name.
2356// Often the Import name has a prefix "prebuilt_".
2357// Remove the prefix explicitly if needed
2358// until we find a better solution to get the Import name.
2359type IDECustomizedModuleName interface {
2360 IDECustomizedModuleName() string
2361}
2362
2363type IdeInfo struct {
2364 Deps []string `json:"dependencies,omitempty"`
2365 Srcs []string `json:"srcs,omitempty"`
2366 Aidl_include_dirs []string `json:"aidl_include_dirs,omitempty"`
2367 Jarjar_rules []string `json:"jarjar_rules,omitempty"`
2368 Jars []string `json:"jars,omitempty"`
2369 Classes []string `json:"class,omitempty"`
2370 Installed_paths []string `json:"installed,omitempty"`
patricktu18c82ff2019-05-10 15:48:50 +08002371 SrcJars []string `json:"srcjars,omitempty"`
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002372}
Paul Duffinf88d8e02020-05-07 20:21:34 +01002373
2374func CheckBlueprintSyntax(ctx BaseModuleContext, filename string, contents string) []error {
2375 bpctx := ctx.blueprintBaseModuleContext()
2376 return blueprint.CheckBlueprintSyntax(bpctx.ModuleFactories(), filename, contents)
2377}