blob: 6239d272bc48deaad99ba1dd746c627aa61aaac5 [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
Jiyong Park6a8cf5f2019-12-30 16:31:09 +0900262 RequiredModuleNames() []string
263 HostRequiredModuleNames() []string
264 TargetRequiredModuleNames() []string
Colin Cross897266e2020-02-13 13:22:08 -0800265
266 filesToInstall() InstallPaths
Paul Duffine2453c72019-05-31 14:00:04 +0100267}
268
269// Qualified id for a module
270type qualifiedModuleName struct {
271 // The package (i.e. directory) in which the module is defined, without trailing /
272 pkg string
273
274 // The name of the module, empty string if package.
275 name string
276}
277
278func (q qualifiedModuleName) String() string {
279 if q.name == "" {
280 return "//" + q.pkg
281 }
282 return "//" + q.pkg + ":" + q.name
283}
284
Paul Duffine484f472019-06-20 16:38:08 +0100285func (q qualifiedModuleName) isRootPackage() bool {
286 return q.pkg == "" && q.name == ""
287}
288
Paul Duffine2453c72019-05-31 14:00:04 +0100289// Get the id for the package containing this module.
290func (q qualifiedModuleName) getContainingPackageId() qualifiedModuleName {
291 pkg := q.pkg
292 if q.name == "" {
Paul Duffine484f472019-06-20 16:38:08 +0100293 if pkg == "" {
294 panic(fmt.Errorf("Cannot get containing package id of root package"))
295 }
296
297 index := strings.LastIndex(pkg, "/")
298 if index == -1 {
299 pkg = ""
300 } else {
301 pkg = pkg[:index]
302 }
Paul Duffine2453c72019-05-31 14:00:04 +0100303 }
304 return newPackageId(pkg)
305}
306
307func newPackageId(pkg string) qualifiedModuleName {
308 // A qualified id for a package module has no name.
309 return qualifiedModuleName{pkg: pkg, name: ""}
Colin Cross3f40fa42015-01-30 17:27:36 -0800310}
311
Colin Crossfc754582016-05-17 16:34:16 -0700312type nameProperties struct {
313 // The name of the module. Must be unique across all modules.
Nan Zhang0007d812017-11-07 10:57:05 -0800314 Name *string
Colin Crossfc754582016-05-17 16:34:16 -0700315}
316
317type commonProperties struct {
Dan Willemsen0effe062015-11-30 16:06:01 -0800318 // emit build rules for this module
Paul Duffin54d9bb72020-02-12 10:20:56 +0000319 //
320 // Disabling a module should only be done for those modules that cannot be built
321 // in the current environment. Modules that can build in the current environment
322 // but are not usually required (e.g. superceded by a prebuilt) should not be
323 // disabled as that will prevent them from being built by the checkbuild target
324 // and so prevent early detection of changes that have broken those modules.
Dan Willemsen0effe062015-11-30 16:06:01 -0800325 Enabled *bool `android:"arch_variant"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800326
Paul Duffin2e61fa62019-03-28 14:10:57 +0000327 // Controls the visibility of this module to other modules. Allowable values are one or more of
328 // these formats:
329 //
330 // ["//visibility:public"]: Anyone can use this module.
331 // ["//visibility:private"]: Only rules in the module's package (not its subpackages) can use
332 // this module.
Paul Duffin51084ff2020-05-05 19:19:22 +0100333 // ["//visibility:override"]: Discards any rules inherited from defaults or a creating module.
334 // Can only be used at the beginning of a list of visibility rules.
Paul Duffin2e61fa62019-03-28 14:10:57 +0000335 // ["//some/package:__pkg__", "//other/package:__pkg__"]: Only modules in some/package and
336 // other/package (defined in some/package/*.bp and other/package/*.bp) have access to
337 // this module. Note that sub-packages do not have access to the rule; for example,
338 // //some/package/foo:bar or //other/package/testing:bla wouldn't have access. __pkg__
339 // is a special module and must be used verbatim. It represents all of the modules in the
340 // package.
341 // ["//project:__subpackages__", "//other:__subpackages__"]: Only modules in packages project
342 // or other or in one of their sub-packages have access to this module. For example,
343 // //project:rule, //project/library:lib or //other/testing/internal:munge are allowed
344 // to depend on this rule (but not //independent:evil)
345 // ["//project"]: This is shorthand for ["//project:__pkg__"]
346 // [":__subpackages__"]: This is shorthand for ["//project:__subpackages__"] where
347 // //project is the module's package. e.g. using [":__subpackages__"] in
348 // packages/apps/Settings/Android.bp is equivalent to
349 // //packages/apps/Settings:__subpackages__.
350 // ["//visibility:legacy_public"]: The default visibility, behaves as //visibility:public
351 // for now. It is an error if it is used in a module.
Paul Duffine2453c72019-05-31 14:00:04 +0100352 //
353 // If a module does not specify the `visibility` property then it uses the
354 // `default_visibility` property of the `package` module in the module's package.
355 //
356 // If the `default_visibility` property is not set for the module's package then
Paul Duffine484f472019-06-20 16:38:08 +0100357 // it will use the `default_visibility` of its closest ancestor package for which
358 // a `default_visibility` property is specified.
359 //
360 // If no `default_visibility` property can be found then the module uses the
361 // global default of `//visibility:legacy_public`.
Paul Duffine2453c72019-05-31 14:00:04 +0100362 //
Paul Duffin95d53b52019-07-24 13:45:05 +0100363 // The `visibility` property has no effect on a defaults module although it does
364 // apply to any non-defaults module that uses it. To set the visibility of a
365 // defaults module, use the `defaults_visibility` property on the defaults module;
366 // not to be confused with the `default_visibility` property on the package module.
367 //
Paul Duffin2e61fa62019-03-28 14:10:57 +0000368 // See https://android.googlesource.com/platform/build/soong/+/master/README.md#visibility for
369 // more details.
370 Visibility []string
371
Colin Cross7d5136f2015-05-11 13:39:40 -0700372 // control whether this module compiles for 32-bit, 64-bit, or both. Possible values
Colin Cross3f40fa42015-01-30 17:27:36 -0800373 // are "32" (compile for 32-bit only), "64" (compile for 64-bit only), "both" (compile for both
374 // architectures), or "first" (compile for 64-bit on a 64-bit platform, and 32-bit on a 32-bit
375 // platform
Colin Cross7d716ba2017-11-01 10:38:29 -0700376 Compile_multilib *string `android:"arch_variant"`
Colin Cross69617d32016-09-06 10:39:07 -0700377
378 Target struct {
379 Host struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700380 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700381 }
382 Android struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700383 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700384 }
385 }
386
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000387 // If set to true then the archMutator will create variants for each arch specific target
388 // (e.g. 32/64) that the module is required to produce. If set to false then it will only
389 // create a variant for the architecture and will list the additional arch specific targets
390 // that the variant needs to produce in the CompileMultiTargets property.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700391 UseTargetVariants bool `blueprint:"mutated"`
392 Default_multilib string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800393
Dan Willemsen782a2d12015-12-21 14:55:28 -0800394 // whether this is a proprietary vendor module, and should be installed into /vendor
Colin Cross7d716ba2017-11-01 10:38:29 -0700395 Proprietary *bool
Dan Willemsen782a2d12015-12-21 14:55:28 -0800396
Colin Cross55708f32017-03-20 13:23:34 -0700397 // vendor who owns this module
Dan Willemsenefac4a82017-07-18 19:42:09 -0700398 Owner *string
Colin Cross55708f32017-03-20 13:23:34 -0700399
Jiyong Park2db76922017-11-08 16:03:48 +0900400 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
401 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
402 // Use `soc_specific` instead for better meaning.
Colin Cross7d716ba2017-11-01 10:38:29 -0700403 Vendor *bool
Dan Willemsenaa118f92017-04-06 12:49:58 -0700404
Jiyong Park2db76922017-11-08 16:03:48 +0900405 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
406 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
407 Soc_specific *bool
408
409 // whether this module is specific to a device, not only for SoC, but also for off-chip
410 // peripherals. When set to true, it is installed into /odm (or /vendor/odm if odm partition
411 // does not exist, or /system/vendor/odm if both odm and vendor partitions do not exist).
412 // This implies `soc_specific:true`.
413 Device_specific *bool
414
415 // whether this module is specific to a software configuration of a product (e.g. country,
Jaekyun Seok5cfbfbb2018-01-10 19:00:15 +0900416 // network operator, etc). When set to true, it is installed into /product (or
417 // /system/product if product partition does not exist).
Jiyong Park2db76922017-11-08 16:03:48 +0900418 Product_specific *bool
419
Justin Yund5f6c822019-06-25 16:47:17 +0900420 // whether this module extends system. When set to true, it is installed into /system_ext
421 // (or /system/system_ext if system_ext partition does not exist).
422 System_ext_specific *bool
423
Jiyong Parkf9332f12018-02-01 00:54:12 +0900424 // Whether this module is installed to recovery partition
425 Recovery *bool
426
Yifan Hong1b3348d2020-01-21 15:53:22 -0800427 // Whether this module is installed to ramdisk
428 Ramdisk *bool
429
dimitry1f33e402019-03-26 12:39:31 +0100430 // Whether this module is built for non-native architecures (also known as native bridge binary)
431 Native_bridge_supported *bool `android:"arch_variant"`
432
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700433 // init.rc files to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800434 Init_rc []string `android:"path"`
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700435
Steven Moreland57a23d22018-04-04 15:42:19 -0700436 // VINTF manifest fragments to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800437 Vintf_fragments []string `android:"path"`
Steven Moreland57a23d22018-04-04 15:42:19 -0700438
Chris Wolfe998306e2016-08-15 14:47:23 -0400439 // names of other modules to install if this module is installed
Colin Crossc602b7d2017-05-05 13:36:36 -0700440 Required []string `android:"arch_variant"`
Chris Wolfe998306e2016-08-15 14:47:23 -0400441
Sasha Smundakb6d23052019-04-01 18:37:36 -0700442 // names of other modules to install on host if this module is installed
443 Host_required []string `android:"arch_variant"`
444
445 // names of other modules to install on target if this module is installed
446 Target_required []string `android:"arch_variant"`
447
Colin Cross5aac3622017-08-31 15:07:09 -0700448 // relative path to a file to include in the list of notices for the device
Colin Cross27b922f2019-03-04 22:35:41 -0800449 Notice *string `android:"path"`
Colin Cross5aac3622017-08-31 15:07:09 -0700450
Dan Willemsen569edc52018-11-19 09:33:29 -0800451 Dist struct {
452 // copy the output of this module to the $DIST_DIR when `dist` is specified on the
453 // command line and any of these targets are also on the command line, or otherwise
454 // built
455 Targets []string `android:"arch_variant"`
456
457 // The name of the output artifact. This defaults to the basename of the output of
458 // the module.
459 Dest *string `android:"arch_variant"`
460
461 // The directory within the dist directory to store the artifact. Defaults to the
462 // top level directory ("").
463 Dir *string `android:"arch_variant"`
464
465 // A suffix to add to the artifact file name (before any extension).
466 Suffix *string `android:"arch_variant"`
467 } `android:"arch_variant"`
468
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000469 // The OsType of artifacts that this module variant is responsible for creating.
470 //
471 // Set by osMutator
472 CompileOS OsType `blueprint:"mutated"`
473
474 // The Target of artifacts that this module variant is responsible for creating.
475 //
476 // Set by archMutator
477 CompileTarget Target `blueprint:"mutated"`
478
479 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
480 // responsible for creating.
481 //
482 // By default this is nil as, where necessary, separate variants are created for the
483 // different multilib types supported and that information is encapsulated in the
484 // CompileTarget so the module variant simply needs to create artifacts for that.
485 //
486 // However, if UseTargetVariants is set to false (e.g. by
487 // InitAndroidMultiTargetsArchModule) then no separate variants are created for the
488 // multilib targets. Instead a single variant is created for the architecture and
489 // this contains the multilib specific targets that this variant should create.
490 //
491 // Set by archMutator
Colin Crossee0bc3b2018-10-02 22:01:37 -0700492 CompileMultiTargets []Target `blueprint:"mutated"`
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000493
494 // True if the module variant's CompileTarget is the primary target
495 //
496 // Set by archMutator
497 CompilePrimary bool `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800498
499 // Set by InitAndroidModule
500 HostOrDeviceSupported HostOrDeviceSupported `blueprint:"mutated"`
Dan Willemsen0b24c742016-10-04 15:13:37 -0700501 ArchSpecific bool `blueprint:"mutated"`
Colin Crossce75d2c2016-10-06 16:12:58 -0700502
Paul Duffin1356d8c2020-02-25 19:26:33 +0000503 // If set to true then a CommonOS variant will be created which will have dependencies
504 // on all its OsType specific variants. Used by sdk/module_exports to create a snapshot
505 // that covers all os and architecture variants.
506 //
507 // The OsType specific variants can be retrieved by calling
508 // GetOsSpecificVariantsOfCommonOSVariant
509 //
510 // Set at module initialization time by calling InitCommonOSAndroidMultiTargetsArchModule
511 CreateCommonOSVariant bool `blueprint:"mutated"`
512
513 // If set to true then this variant is the CommonOS variant that has dependencies on its
514 // OsType specific variants.
515 //
516 // Set by osMutator.
517 CommonOSVariant bool `blueprint:"mutated"`
518
Colin Crossce75d2c2016-10-06 16:12:58 -0700519 SkipInstall bool `blueprint:"mutated"`
Jeff Gaston088e29e2017-11-29 16:47:17 -0800520
521 NamespaceExportedToMake bool `blueprint:"mutated"`
Colin Cross6c4f21f2019-06-06 15:41:36 -0700522
523 MissingDeps []string `blueprint:"mutated"`
Colin Cross9a362232019-07-01 15:32:45 -0700524
525 // Name and variant strings stored by mutators to enable Module.String()
526 DebugName string `blueprint:"mutated"`
527 DebugMutators []string `blueprint:"mutated"`
528 DebugVariations []string `blueprint:"mutated"`
Colin Cross7228ecd2019-11-18 16:00:16 -0800529
530 // set by ImageMutator
531 ImageVariation string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800532}
533
534type hostAndDeviceProperties struct {
Colin Cross4e81d702018-11-09 10:36:55 -0800535 // If set to true, build a variant of the module for the host. Defaults to false.
536 Host_supported *bool
537
538 // If set to true, build a variant of the module for the device. Defaults to true.
Colin Crossa4190c12016-07-12 13:11:25 -0700539 Device_supported *bool
Colin Cross3f40fa42015-01-30 17:27:36 -0800540}
541
Colin Crossc472d572015-03-17 15:06:21 -0700542type Multilib string
543
544const (
Colin Cross6b4a32d2017-12-05 13:42:45 -0800545 MultilibBoth Multilib = "both"
546 MultilibFirst Multilib = "first"
547 MultilibCommon Multilib = "common"
548 MultilibCommonFirst Multilib = "common_first"
549 MultilibDefault Multilib = ""
Colin Crossc472d572015-03-17 15:06:21 -0700550)
551
Colin Crossa1ad8d12016-06-01 17:09:44 -0700552type HostOrDeviceSupported int
553
554const (
555 _ HostOrDeviceSupported = iota
Dan Albert0981b5c2018-08-02 13:46:35 -0700556
557 // Host and HostCross are built by default. Device is not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700558 HostSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700559
560 // Host is built by default. HostCross and Device are not supported.
Dan Albertc6345fb2016-10-20 01:36:11 -0700561 HostSupportedNoCross
Dan Albert0981b5c2018-08-02 13:46:35 -0700562
563 // Device is built by default. Host and HostCross are not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700564 DeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700565
566 // Device is built by default. Host and HostCross are supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700567 HostAndDeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700568
569 // Host, HostCross, and Device are built by default.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700570 HostAndDeviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700571
572 // Nothing is supported. This is not exposed to the user, but used to mark a
573 // host only module as unsupported when the module type is not supported on
574 // the host OS. E.g. benchmarks are supported on Linux but not Darwin.
Dan Willemsen0b24c742016-10-04 15:13:37 -0700575 NeitherHostNorDeviceSupported
Colin Crossa1ad8d12016-06-01 17:09:44 -0700576)
577
Jiyong Park2db76922017-11-08 16:03:48 +0900578type moduleKind int
579
580const (
581 platformModule moduleKind = iota
582 deviceSpecificModule
583 socSpecificModule
584 productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900585 systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900586)
587
588func (k moduleKind) String() string {
589 switch k {
590 case platformModule:
591 return "platform"
592 case deviceSpecificModule:
593 return "device-specific"
594 case socSpecificModule:
595 return "soc-specific"
596 case productSpecificModule:
597 return "product-specific"
Justin Yund5f6c822019-06-25 16:47:17 +0900598 case systemExtSpecificModule:
599 return "systemext-specific"
Jiyong Park2db76922017-11-08 16:03:48 +0900600 default:
601 panic(fmt.Errorf("unknown module kind %d", k))
602 }
603}
604
Colin Cross9d34f352019-11-22 16:03:51 -0800605func initAndroidModuleBase(m Module) {
606 m.base().module = m
607}
608
Colin Cross36242852017-06-23 15:06:31 -0700609func InitAndroidModule(m Module) {
Colin Cross9d34f352019-11-22 16:03:51 -0800610 initAndroidModuleBase(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800611 base := m.base()
Colin Cross5049f022015-03-18 13:28:46 -0700612
Colin Cross36242852017-06-23 15:06:31 -0700613 m.AddProperties(
Colin Crossfc754582016-05-17 16:34:16 -0700614 &base.nameProperties,
Colin Cross18c46802019-09-24 22:19:02 -0700615 &base.commonProperties)
616
Colin Crosseabaedd2020-02-06 17:01:55 -0800617 initProductVariableModule(m)
Colin Cross18c46802019-09-24 22:19:02 -0700618
Colin Crossa3a97412019-03-18 12:24:29 -0700619 base.generalProperties = m.GetProperties()
Pirama Arumuga Nainar955dc492018-04-17 14:58:42 -0700620 base.customizableProperties = m.GetProperties()
Paul Duffin63c6e182019-07-24 14:24:38 +0100621
622 // The default_visibility property needs to be checked and parsed by the visibility module during
Paul Duffin5ec73ec2020-05-01 17:52:01 +0100623 // its checking and parsing phases so make it the primary visibility property.
624 setPrimaryVisibilityProperty(m, "visibility", &base.commonProperties.Visibility)
Colin Cross5049f022015-03-18 13:28:46 -0700625}
626
Colin Cross36242852017-06-23 15:06:31 -0700627func InitAndroidArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
628 InitAndroidModule(m)
Colin Cross5049f022015-03-18 13:28:46 -0700629
630 base := m.base()
Colin Cross3f40fa42015-01-30 17:27:36 -0800631 base.commonProperties.HostOrDeviceSupported = hod
Colin Cross69617d32016-09-06 10:39:07 -0700632 base.commonProperties.Default_multilib = string(defaultMultilib)
Dan Willemsen0b24c742016-10-04 15:13:37 -0700633 base.commonProperties.ArchSpecific = true
Colin Crossee0bc3b2018-10-02 22:01:37 -0700634 base.commonProperties.UseTargetVariants = true
Colin Cross3f40fa42015-01-30 17:27:36 -0800635
Dan Willemsen218f6562015-07-08 18:13:11 -0700636 switch hod {
Nan Zhang1a0f09b2017-07-05 10:35:11 -0700637 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Cross36242852017-06-23 15:06:31 -0700638 m.AddProperties(&base.hostAndDeviceProperties)
Colin Cross3f40fa42015-01-30 17:27:36 -0800639 }
640
Colin Cross36242852017-06-23 15:06:31 -0700641 InitArchModule(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800642}
643
Colin Crossee0bc3b2018-10-02 22:01:37 -0700644func InitAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
645 InitAndroidArchModule(m, hod, defaultMultilib)
646 m.base().commonProperties.UseTargetVariants = false
647}
648
Paul Duffin1356d8c2020-02-25 19:26:33 +0000649// As InitAndroidMultiTargetsArchModule except it creates an additional CommonOS variant that
650// has dependencies on all the OsType specific variants.
651func InitCommonOSAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
652 InitAndroidArchModule(m, hod, defaultMultilib)
653 m.base().commonProperties.UseTargetVariants = false
654 m.base().commonProperties.CreateCommonOSVariant = true
655}
656
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800657// A ModuleBase object contains the properties that are common to all Android
Colin Cross3f40fa42015-01-30 17:27:36 -0800658// modules. It should be included as an anonymous field in every module
659// struct definition. InitAndroidModule should then be called from the module's
660// factory function, and the return values from InitAndroidModule should be
661// returned from the factory function.
662//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800663// The ModuleBase type is responsible for implementing the GenerateBuildActions
664// method to support the blueprint.Module interface. This method will then call
665// the module's GenerateAndroidBuildActions method once for each build variant
Colin Cross25de6c32019-06-06 14:29:25 -0700666// that is to be built. GenerateAndroidBuildActions is passed a ModuleContext
667// rather than the usual blueprint.ModuleContext.
668// ModuleContext exposes extra functionality specific to the Android build
Colin Cross3f40fa42015-01-30 17:27:36 -0800669// system including details about the particular build variant that is to be
670// generated.
671//
672// For example:
673//
674// import (
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800675// "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -0800676// )
677//
678// type myModule struct {
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800679// android.ModuleBase
Colin Cross3f40fa42015-01-30 17:27:36 -0800680// properties struct {
681// MyProperty string
682// }
683// }
684//
Colin Cross36242852017-06-23 15:06:31 -0700685// func NewMyModule() android.Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800686// m := &myModule{}
Colin Cross36242852017-06-23 15:06:31 -0700687// m.AddProperties(&m.properties)
688// android.InitAndroidModule(m)
689// return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800690// }
691//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800692// func (m *myModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800693// // Get the CPU architecture for the current build variant.
694// variantArch := ctx.Arch()
695//
696// // ...
697// }
Colin Cross635c3b02016-05-18 15:37:25 -0700698type ModuleBase struct {
Colin Cross3f40fa42015-01-30 17:27:36 -0800699 // Putting the curiously recurring thing pointing to the thing that contains
700 // the thing pattern to good use.
Colin Cross36242852017-06-23 15:06:31 -0700701 // TODO: remove this
Colin Cross635c3b02016-05-18 15:37:25 -0700702 module Module
Colin Cross3f40fa42015-01-30 17:27:36 -0800703
Colin Crossfc754582016-05-17 16:34:16 -0700704 nameProperties nameProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800705 commonProperties commonProperties
Colin Cross18c46802019-09-24 22:19:02 -0700706 variableProperties interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800707 hostAndDeviceProperties hostAndDeviceProperties
708 generalProperties []interface{}
Colin Crossc17727d2018-10-24 12:42:09 -0700709 archProperties [][]interface{}
Colin Crossa120ec12016-08-19 16:07:38 -0700710 customizableProperties []interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800711
Paul Duffin63c6e182019-07-24 14:24:38 +0100712 // Information about all the properties on the module that contains visibility rules that need
713 // checking.
714 visibilityPropertyInfo []visibilityProperty
715
716 // The primary visibility property, may be nil, that controls access to the module.
717 primaryVisibilityProperty visibilityProperty
718
Colin Cross3f40fa42015-01-30 17:27:36 -0800719 noAddressSanitizer bool
Colin Cross897266e2020-02-13 13:22:08 -0800720 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700721 checkbuildFiles Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800722 noticeFiles Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -0700723
724 // Used by buildTargetSingleton to create checkbuild and per-directory build targets
725 // Only set on the final variant of each module
Colin Cross0875c522017-11-28 17:34:01 -0800726 installTarget WritablePath
727 checkbuildTarget WritablePath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700728 blueprintDir string
Colin Crossa120ec12016-08-19 16:07:38 -0700729
Colin Cross178a5092016-09-13 13:42:32 -0700730 hooks hooks
Colin Cross36242852017-06-23 15:06:31 -0700731
732 registerProps []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700733
734 // For tests
Colin Crossae887032017-10-23 17:16:14 -0700735 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800736 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800737 variables map[string]string
Colin Crossa9d8bee2018-10-02 13:59:46 -0700738
Inseob Kim8471cda2019-11-15 09:59:12 +0900739 initRcPaths Paths
740 vintfFragmentsPaths Paths
741
Colin Crossa9d8bee2018-10-02 13:59:46 -0700742 prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool
Colin Cross36242852017-06-23 15:06:31 -0700743}
744
Colin Cross4157e882019-06-06 16:57:04 -0700745func (m *ModuleBase) DepsMutator(BottomUpMutatorContext) {}
Colin Cross5f692ec2019-02-01 16:53:07 -0800746
Colin Cross4157e882019-06-06 16:57:04 -0700747func (m *ModuleBase) AddProperties(props ...interface{}) {
748 m.registerProps = append(m.registerProps, props...)
Colin Cross36242852017-06-23 15:06:31 -0700749}
750
Colin Cross4157e882019-06-06 16:57:04 -0700751func (m *ModuleBase) GetProperties() []interface{} {
752 return m.registerProps
Colin Cross3f40fa42015-01-30 17:27:36 -0800753}
754
Colin Cross4157e882019-06-06 16:57:04 -0700755func (m *ModuleBase) BuildParamsForTests() []BuildParams {
756 return m.buildParams
Colin Crosscec81712017-07-13 14:43:27 -0700757}
758
Colin Cross4157e882019-06-06 16:57:04 -0700759func (m *ModuleBase) RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams {
760 return m.ruleParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800761}
762
Colin Cross4157e882019-06-06 16:57:04 -0700763func (m *ModuleBase) VariablesForTests() map[string]string {
764 return m.variables
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800765}
766
Colin Cross4157e882019-06-06 16:57:04 -0700767func (m *ModuleBase) Prefer32(prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool) {
768 m.prefer32 = prefer32
Colin Crossa9d8bee2018-10-02 13:59:46 -0700769}
770
Colin Crossce75d2c2016-10-06 16:12:58 -0700771// Name returns the name of the module. It may be overridden by individual module types, for
772// example prebuilts will prepend prebuilt_ to the name.
Colin Cross4157e882019-06-06 16:57:04 -0700773func (m *ModuleBase) Name() string {
774 return String(m.nameProperties.Name)
Colin Crossfc754582016-05-17 16:34:16 -0700775}
776
Colin Cross9a362232019-07-01 15:32:45 -0700777// String returns a string that includes the module name and variants for printing during debugging.
778func (m *ModuleBase) String() string {
779 sb := strings.Builder{}
780 sb.WriteString(m.commonProperties.DebugName)
781 sb.WriteString("{")
782 for i := range m.commonProperties.DebugMutators {
783 if i != 0 {
784 sb.WriteString(",")
785 }
786 sb.WriteString(m.commonProperties.DebugMutators[i])
787 sb.WriteString(":")
788 sb.WriteString(m.commonProperties.DebugVariations[i])
789 }
790 sb.WriteString("}")
791 return sb.String()
792}
793
Colin Crossce75d2c2016-10-06 16:12:58 -0700794// BaseModuleName returns the name of the module as specified in the blueprints file.
Colin Cross4157e882019-06-06 16:57:04 -0700795func (m *ModuleBase) BaseModuleName() string {
796 return String(m.nameProperties.Name)
Colin Crossce75d2c2016-10-06 16:12:58 -0700797}
798
Colin Cross4157e882019-06-06 16:57:04 -0700799func (m *ModuleBase) base() *ModuleBase {
800 return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800801}
802
Paul Duffine2453c72019-05-31 14:00:04 +0100803func (m *ModuleBase) qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName {
804 return qualifiedModuleName{pkg: ctx.ModuleDir(), name: ctx.ModuleName()}
805}
806
807func (m *ModuleBase) visibilityProperties() []visibilityProperty {
Paul Duffin63c6e182019-07-24 14:24:38 +0100808 return m.visibilityPropertyInfo
809}
810
Colin Cross4157e882019-06-06 16:57:04 -0700811func (m *ModuleBase) Target() Target {
812 return m.commonProperties.CompileTarget
Dan Willemsen490fd492015-11-24 17:53:15 -0800813}
814
Colin Cross4157e882019-06-06 16:57:04 -0700815func (m *ModuleBase) TargetPrimary() bool {
816 return m.commonProperties.CompilePrimary
Colin Cross8b74d172016-09-13 09:59:14 -0700817}
818
Colin Cross4157e882019-06-06 16:57:04 -0700819func (m *ModuleBase) MultiTargets() []Target {
820 return m.commonProperties.CompileMultiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -0700821}
822
Colin Cross4157e882019-06-06 16:57:04 -0700823func (m *ModuleBase) Os() OsType {
824 return m.Target().Os
Dan Willemsen490fd492015-11-24 17:53:15 -0800825}
826
Colin Cross4157e882019-06-06 16:57:04 -0700827func (m *ModuleBase) Host() bool {
828 return m.Os().Class == Host || m.Os().Class == HostCross
Dan Willemsen97750522016-02-09 17:43:51 -0800829}
830
Colin Cross4157e882019-06-06 16:57:04 -0700831func (m *ModuleBase) Arch() Arch {
832 return m.Target().Arch
Dan Willemsen97750522016-02-09 17:43:51 -0800833}
834
Colin Cross4157e882019-06-06 16:57:04 -0700835func (m *ModuleBase) ArchSpecific() bool {
836 return m.commonProperties.ArchSpecific
Dan Willemsen0b24c742016-10-04 15:13:37 -0700837}
838
Paul Duffin1356d8c2020-02-25 19:26:33 +0000839// True if the current variant is a CommonOS variant, false otherwise.
840func (m *ModuleBase) IsCommonOSVariant() bool {
841 return m.commonProperties.CommonOSVariant
842}
843
Colin Cross4157e882019-06-06 16:57:04 -0700844func (m *ModuleBase) OsClassSupported() []OsClass {
845 switch m.commonProperties.HostOrDeviceSupported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700846 case HostSupported:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700847 return []OsClass{Host, HostCross}
Dan Albertc6345fb2016-10-20 01:36:11 -0700848 case HostSupportedNoCross:
849 return []OsClass{Host}
Colin Crossa1ad8d12016-06-01 17:09:44 -0700850 case DeviceSupported:
851 return []OsClass{Device}
Dan Albert0981b5c2018-08-02 13:46:35 -0700852 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700853 var supported []OsClass
Colin Cross4157e882019-06-06 16:57:04 -0700854 if Bool(m.hostAndDeviceProperties.Host_supported) ||
855 (m.commonProperties.HostOrDeviceSupported == HostAndDeviceDefault &&
856 m.hostAndDeviceProperties.Host_supported == nil) {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700857 supported = append(supported, Host, HostCross)
858 }
Colin Cross4157e882019-06-06 16:57:04 -0700859 if m.hostAndDeviceProperties.Device_supported == nil ||
860 *m.hostAndDeviceProperties.Device_supported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700861 supported = append(supported, Device)
862 }
863 return supported
864 default:
865 return nil
866 }
Colin Cross3f40fa42015-01-30 17:27:36 -0800867}
868
Colin Cross4157e882019-06-06 16:57:04 -0700869func (m *ModuleBase) DeviceSupported() bool {
870 return m.commonProperties.HostOrDeviceSupported == DeviceSupported ||
871 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
872 (m.hostAndDeviceProperties.Device_supported == nil ||
873 *m.hostAndDeviceProperties.Device_supported)
Colin Cross3f40fa42015-01-30 17:27:36 -0800874}
875
Paul Duffine44358f2019-11-26 18:04:12 +0000876func (m *ModuleBase) HostSupported() bool {
877 return m.commonProperties.HostOrDeviceSupported == HostSupported ||
878 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
879 (m.hostAndDeviceProperties.Host_supported != nil &&
880 *m.hostAndDeviceProperties.Host_supported)
881}
882
Colin Cross4157e882019-06-06 16:57:04 -0700883func (m *ModuleBase) Platform() bool {
Justin Yund5f6c822019-06-25 16:47:17 +0900884 return !m.DeviceSpecific() && !m.SocSpecific() && !m.ProductSpecific() && !m.SystemExtSpecific()
Jiyong Parkc678ad32018-04-10 13:07:10 +0900885}
886
Colin Cross4157e882019-06-06 16:57:04 -0700887func (m *ModuleBase) DeviceSpecific() bool {
888 return Bool(m.commonProperties.Device_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900889}
890
Colin Cross4157e882019-06-06 16:57:04 -0700891func (m *ModuleBase) SocSpecific() bool {
892 return Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900893}
894
Colin Cross4157e882019-06-06 16:57:04 -0700895func (m *ModuleBase) ProductSpecific() bool {
896 return Bool(m.commonProperties.Product_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900897}
898
Justin Yund5f6c822019-06-25 16:47:17 +0900899func (m *ModuleBase) SystemExtSpecific() bool {
900 return Bool(m.commonProperties.System_ext_specific)
Dario Frenifd05a742018-05-29 13:28:54 +0100901}
902
Colin Crossc2d24052020-05-13 11:05:02 -0700903// RequiresStableAPIs returns true if the module will be installed to a partition that may
904// be updated separately from the system image.
905func (m *ModuleBase) RequiresStableAPIs(ctx BaseModuleContext) bool {
906 return m.SocSpecific() || m.DeviceSpecific() ||
907 (m.ProductSpecific() && ctx.Config().EnforceProductPartitionInterface())
908}
909
Bill Peckhamfff3f8a2020-03-20 18:33:20 -0700910func (m *ModuleBase) PartitionTag(config DeviceConfig) string {
911 partition := "system"
912 if m.SocSpecific() {
913 // A SoC-specific module could be on the vendor partition at
914 // "vendor" or the system partition at "system/vendor".
915 if config.VendorPath() == "vendor" {
916 partition = "vendor"
917 }
918 } else if m.DeviceSpecific() {
919 // A device-specific module could be on the odm partition at
920 // "odm", the vendor partition at "vendor/odm", or the system
921 // partition at "system/vendor/odm".
922 if config.OdmPath() == "odm" {
923 partition = "odm"
Ramy Medhat944839a2020-03-31 22:14:52 -0400924 } else if strings.HasPrefix(config.OdmPath(), "vendor/") {
Bill Peckhamfff3f8a2020-03-20 18:33:20 -0700925 partition = "vendor"
926 }
927 } else if m.ProductSpecific() {
928 // A product-specific module could be on the product partition
929 // at "product" or the system partition at "system/product".
930 if config.ProductPath() == "product" {
931 partition = "product"
932 }
933 } else if m.SystemExtSpecific() {
934 // A system_ext-specific module could be on the system_ext
935 // partition at "system_ext" or the system partition at
936 // "system/system_ext".
937 if config.SystemExtPath() == "system_ext" {
938 partition = "system_ext"
939 }
940 }
941 return partition
942}
943
Colin Cross4157e882019-06-06 16:57:04 -0700944func (m *ModuleBase) Enabled() bool {
945 if m.commonProperties.Enabled == nil {
946 return !m.Os().DefaultDisabled
Dan Willemsen490fd492015-11-24 17:53:15 -0800947 }
Colin Cross4157e882019-06-06 16:57:04 -0700948 return *m.commonProperties.Enabled
Colin Cross3f40fa42015-01-30 17:27:36 -0800949}
950
Inseob Kimeec88e12020-01-22 11:11:29 +0900951func (m *ModuleBase) Disable() {
952 m.commonProperties.Enabled = proptools.BoolPtr(false)
953}
954
Colin Cross4157e882019-06-06 16:57:04 -0700955func (m *ModuleBase) SkipInstall() {
956 m.commonProperties.SkipInstall = true
Colin Crossce75d2c2016-10-06 16:12:58 -0700957}
958
Ulya Trafimovichb28cc372020-01-13 15:18:16 +0000959func (m *ModuleBase) IsSkipInstall() bool {
960 return m.commonProperties.SkipInstall == true
961}
962
Colin Cross4157e882019-06-06 16:57:04 -0700963func (m *ModuleBase) ExportedToMake() bool {
964 return m.commonProperties.NamespaceExportedToMake
Jiyong Park374510b2018-03-19 18:23:01 +0900965}
966
Colin Cross897266e2020-02-13 13:22:08 -0800967func (m *ModuleBase) computeInstallDeps(ctx blueprint.ModuleContext) InstallPaths {
Colin Cross3f40fa42015-01-30 17:27:36 -0800968
Colin Cross897266e2020-02-13 13:22:08 -0800969 var result InstallPaths
Colin Cross6b753602018-06-21 13:03:07 -0700970 // TODO(ccross): we need to use WalkDeps and have some way to know which dependencies require installation
Colin Cross897266e2020-02-13 13:22:08 -0800971 ctx.VisitDepsDepthFirst(func(m blueprint.Module) {
972 if a, ok := m.(Module); ok {
973 result = append(result, a.filesToInstall()...)
974 }
975 })
Colin Cross3f40fa42015-01-30 17:27:36 -0800976
977 return result
978}
979
Colin Cross897266e2020-02-13 13:22:08 -0800980func (m *ModuleBase) filesToInstall() InstallPaths {
Colin Cross4157e882019-06-06 16:57:04 -0700981 return m.installFiles
Colin Cross3f40fa42015-01-30 17:27:36 -0800982}
983
Colin Cross4157e882019-06-06 16:57:04 -0700984func (m *ModuleBase) NoAddressSanitizer() bool {
985 return m.noAddressSanitizer
Colin Cross3f40fa42015-01-30 17:27:36 -0800986}
987
Colin Cross4157e882019-06-06 16:57:04 -0700988func (m *ModuleBase) InstallInData() bool {
Dan Willemsen782a2d12015-12-21 14:55:28 -0800989 return false
990}
991
Jaewoong Jung0949f312019-09-11 10:25:18 -0700992func (m *ModuleBase) InstallInTestcases() bool {
993 return false
994}
995
Colin Cross4157e882019-06-06 16:57:04 -0700996func (m *ModuleBase) InstallInSanitizerDir() bool {
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700997 return false
998}
999
Yifan Hong1b3348d2020-01-21 15:53:22 -08001000func (m *ModuleBase) InstallInRamdisk() bool {
1001 return Bool(m.commonProperties.Ramdisk)
1002}
1003
Colin Cross4157e882019-06-06 16:57:04 -07001004func (m *ModuleBase) InstallInRecovery() bool {
1005 return Bool(m.commonProperties.Recovery)
Jiyong Parkf9332f12018-02-01 00:54:12 +09001006}
1007
Colin Cross90ba5f42019-10-02 11:10:58 -07001008func (m *ModuleBase) InstallInRoot() bool {
1009 return false
1010}
1011
Colin Cross607d8582019-07-29 16:44:46 -07001012func (m *ModuleBase) InstallBypassMake() bool {
1013 return false
1014}
1015
Colin Cross6e359402020-02-10 15:29:54 -08001016func (m *ModuleBase) InstallForceOS() *OsType {
1017 return nil
1018}
1019
Colin Cross4157e882019-06-06 16:57:04 -07001020func (m *ModuleBase) Owner() string {
1021 return String(m.commonProperties.Owner)
Sundong Ahn4fd04bb2018-08-31 18:01:37 +09001022}
1023
Bob Badoura75b0572020-02-18 20:21:55 -08001024func (m *ModuleBase) NoticeFiles() Paths {
1025 return m.noticeFiles
Jiyong Park52818fc2019-03-18 12:01:38 +09001026}
1027
Colin Cross7228ecd2019-11-18 16:00:16 -08001028func (m *ModuleBase) setImageVariation(variant string) {
1029 m.commonProperties.ImageVariation = variant
1030}
1031
1032func (m *ModuleBase) ImageVariation() blueprint.Variation {
1033 return blueprint.Variation{
1034 Mutator: "image",
1035 Variation: m.base().commonProperties.ImageVariation,
1036 }
1037}
1038
Paul Duffin9b76c0b2020-03-12 10:24:35 +00001039func (m *ModuleBase) getVariationByMutatorName(mutator string) string {
1040 for i, v := range m.commonProperties.DebugMutators {
1041 if v == mutator {
1042 return m.commonProperties.DebugVariations[i]
1043 }
1044 }
1045
1046 return ""
1047}
1048
Yifan Hong1b3348d2020-01-21 15:53:22 -08001049func (m *ModuleBase) InRamdisk() bool {
1050 return m.base().commonProperties.ImageVariation == RamdiskVariation
1051}
1052
Colin Cross7228ecd2019-11-18 16:00:16 -08001053func (m *ModuleBase) InRecovery() bool {
1054 return m.base().commonProperties.ImageVariation == RecoveryVariation
1055}
1056
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09001057func (m *ModuleBase) RequiredModuleNames() []string {
1058 return m.base().commonProperties.Required
1059}
1060
1061func (m *ModuleBase) HostRequiredModuleNames() []string {
1062 return m.base().commonProperties.Host_required
1063}
1064
1065func (m *ModuleBase) TargetRequiredModuleNames() []string {
1066 return m.base().commonProperties.Target_required
1067}
1068
Inseob Kim8471cda2019-11-15 09:59:12 +09001069func (m *ModuleBase) InitRc() Paths {
1070 return append(Paths{}, m.initRcPaths...)
1071}
1072
1073func (m *ModuleBase) VintfFragments() Paths {
1074 return append(Paths{}, m.vintfFragmentsPaths...)
1075}
1076
Colin Cross4157e882019-06-06 16:57:04 -07001077func (m *ModuleBase) generateModuleTarget(ctx ModuleContext) {
Colin Cross897266e2020-02-13 13:22:08 -08001078 var allInstalledFiles InstallPaths
1079 var allCheckbuildFiles Paths
Colin Cross0875c522017-11-28 17:34:01 -08001080 ctx.VisitAllModuleVariants(func(module Module) {
1081 a := module.base()
Colin Crossc9404352015-03-26 16:10:12 -07001082 allInstalledFiles = append(allInstalledFiles, a.installFiles...)
1083 allCheckbuildFiles = append(allCheckbuildFiles, a.checkbuildFiles...)
Colin Cross3f40fa42015-01-30 17:27:36 -08001084 })
1085
Colin Cross0875c522017-11-28 17:34:01 -08001086 var deps Paths
Colin Cross9454bfa2015-03-17 13:24:18 -07001087
Jeff Gaston088e29e2017-11-29 16:47:17 -08001088 namespacePrefix := ctx.Namespace().(*Namespace).id
1089 if namespacePrefix != "" {
1090 namespacePrefix = namespacePrefix + "-"
1091 }
1092
Colin Cross3f40fa42015-01-30 17:27:36 -08001093 if len(allInstalledFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -08001094 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-install")
Colin Cross0875c522017-11-28 17:34:01 -08001095 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001096 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001097 Output: name,
Colin Cross897266e2020-02-13 13:22:08 -08001098 Implicits: allInstalledFiles.Paths(),
Colin Crossaabf6792017-11-29 00:27:14 -08001099 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross9454bfa2015-03-17 13:24:18 -07001100 })
1101 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -07001102 m.installTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -07001103 }
1104
1105 if len(allCheckbuildFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -08001106 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-checkbuild")
Colin Cross0875c522017-11-28 17:34:01 -08001107 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001108 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001109 Output: name,
1110 Implicits: allCheckbuildFiles,
Colin Cross9454bfa2015-03-17 13:24:18 -07001111 })
1112 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -07001113 m.checkbuildTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -07001114 }
1115
1116 if len(deps) > 0 {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001117 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08001118 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001119 suffix = "-soong"
1120 }
1121
Jeff Gaston088e29e2017-11-29 16:47:17 -08001122 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+suffix)
Colin Cross0875c522017-11-28 17:34:01 -08001123 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001124 Rule: blueprint.Phony,
Jeff Gaston088e29e2017-11-29 16:47:17 -08001125 Outputs: []WritablePath{name},
Colin Cross9454bfa2015-03-17 13:24:18 -07001126 Implicits: deps,
Colin Cross3f40fa42015-01-30 17:27:36 -08001127 })
Colin Cross1f8c52b2015-06-16 16:38:17 -07001128
Colin Cross4157e882019-06-06 16:57:04 -07001129 m.blueprintDir = ctx.ModuleDir()
Colin Cross3f40fa42015-01-30 17:27:36 -08001130 }
1131}
1132
Colin Crossc34d2322020-01-03 15:23:27 -08001133func determineModuleKind(m *ModuleBase, ctx blueprint.EarlyModuleContext) moduleKind {
Colin Cross4157e882019-06-06 16:57:04 -07001134 var socSpecific = Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
1135 var deviceSpecific = Bool(m.commonProperties.Device_specific)
1136 var productSpecific = Bool(m.commonProperties.Product_specific)
Justin Yund5f6c822019-06-25 16:47:17 +09001137 var systemExtSpecific = Bool(m.commonProperties.System_ext_specific)
Jiyong Park2db76922017-11-08 16:03:48 +09001138
Dario Frenifd05a742018-05-29 13:28:54 +01001139 msg := "conflicting value set here"
1140 if socSpecific && deviceSpecific {
1141 ctx.PropertyErrorf("device_specific", "a module cannot be specific to SoC and device at the same time.")
Colin Cross4157e882019-06-06 16:57:04 -07001142 if Bool(m.commonProperties.Vendor) {
Jiyong Park2db76922017-11-08 16:03:48 +09001143 ctx.PropertyErrorf("vendor", msg)
1144 }
Colin Cross4157e882019-06-06 16:57:04 -07001145 if Bool(m.commonProperties.Proprietary) {
Jiyong Park2db76922017-11-08 16:03:48 +09001146 ctx.PropertyErrorf("proprietary", msg)
1147 }
Colin Cross4157e882019-06-06 16:57:04 -07001148 if Bool(m.commonProperties.Soc_specific) {
Jiyong Park2db76922017-11-08 16:03:48 +09001149 ctx.PropertyErrorf("soc_specific", msg)
1150 }
1151 }
1152
Justin Yund5f6c822019-06-25 16:47:17 +09001153 if productSpecific && systemExtSpecific {
1154 ctx.PropertyErrorf("product_specific", "a module cannot be specific to product and system_ext at the same time.")
1155 ctx.PropertyErrorf("system_ext_specific", msg)
Dario Frenifd05a742018-05-29 13:28:54 +01001156 }
1157
Justin Yund5f6c822019-06-25 16:47:17 +09001158 if (socSpecific || deviceSpecific) && (productSpecific || systemExtSpecific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001159 if productSpecific {
1160 ctx.PropertyErrorf("product_specific", "a module cannot be specific to SoC or device and product at the same time.")
1161 } else {
Justin Yund5f6c822019-06-25 16:47:17 +09001162 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 +01001163 }
1164 if deviceSpecific {
1165 ctx.PropertyErrorf("device_specific", msg)
1166 } else {
Colin Cross4157e882019-06-06 16:57:04 -07001167 if Bool(m.commonProperties.Vendor) {
Dario Frenifd05a742018-05-29 13:28:54 +01001168 ctx.PropertyErrorf("vendor", msg)
1169 }
Colin Cross4157e882019-06-06 16:57:04 -07001170 if Bool(m.commonProperties.Proprietary) {
Dario Frenifd05a742018-05-29 13:28:54 +01001171 ctx.PropertyErrorf("proprietary", msg)
1172 }
Colin Cross4157e882019-06-06 16:57:04 -07001173 if Bool(m.commonProperties.Soc_specific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001174 ctx.PropertyErrorf("soc_specific", msg)
1175 }
1176 }
1177 }
1178
Jiyong Park2db76922017-11-08 16:03:48 +09001179 if productSpecific {
1180 return productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +09001181 } else if systemExtSpecific {
1182 return systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001183 } else if deviceSpecific {
1184 return deviceSpecificModule
1185 } else if socSpecific {
1186 return socSpecificModule
1187 } else {
1188 return platformModule
1189 }
1190}
1191
Colin Crossc34d2322020-01-03 15:23:27 -08001192func (m *ModuleBase) earlyModuleContextFactory(ctx blueprint.EarlyModuleContext) earlyModuleContext {
Colin Cross1184b642019-12-30 18:43:07 -08001193 return earlyModuleContext{
Colin Crossc34d2322020-01-03 15:23:27 -08001194 EarlyModuleContext: ctx,
1195 kind: determineModuleKind(m, ctx),
1196 config: ctx.Config().(Config),
Colin Cross3f40fa42015-01-30 17:27:36 -08001197 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001198}
1199
Colin Cross1184b642019-12-30 18:43:07 -08001200func (m *ModuleBase) baseModuleContextFactory(ctx blueprint.BaseModuleContext) baseModuleContext {
1201 return baseModuleContext{
1202 bp: ctx,
1203 earlyModuleContext: m.earlyModuleContextFactory(ctx),
1204 os: m.commonProperties.CompileOS,
1205 target: m.commonProperties.CompileTarget,
1206 targetPrimary: m.commonProperties.CompilePrimary,
1207 multiTargets: m.commonProperties.CompileMultiTargets,
1208 }
1209}
1210
Colin Cross4157e882019-06-06 16:57:04 -07001211func (m *ModuleBase) GenerateBuildActions(blueprintCtx blueprint.ModuleContext) {
Colin Cross25de6c32019-06-06 14:29:25 -07001212 ctx := &moduleContext{
Colin Cross0ea8ba82019-06-06 14:33:29 -07001213 module: m.module,
Colin Crossdc35e212019-06-06 16:13:11 -07001214 bp: blueprintCtx,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001215 baseModuleContext: m.baseModuleContextFactory(blueprintCtx),
1216 installDeps: m.computeInstallDeps(blueprintCtx),
1217 installFiles: m.installFiles,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001218 variables: make(map[string]string),
Colin Cross3f40fa42015-01-30 17:27:36 -08001219 }
1220
Colin Cross6c4f21f2019-06-06 15:41:36 -07001221 // Temporarily continue to call blueprintCtx.GetMissingDependencies() to maintain the previous behavior of never
1222 // reporting missing dependency errors in Blueprint when AllowMissingDependencies == true.
1223 // TODO: This will be removed once defaults modules handle missing dependency errors
1224 blueprintCtx.GetMissingDependencies()
1225
Colin Crossdc35e212019-06-06 16:13:11 -07001226 // For the final GenerateAndroidBuildActions pass, require that all visited dependencies Soong modules and
Paul Duffin1356d8c2020-02-25 19:26:33 +00001227 // are enabled. Unless the module is a CommonOS variant which may have dependencies on disabled variants
1228 // (because the dependencies are added before the modules are disabled). The
1229 // GetOsSpecificVariantsOfCommonOSVariant(...) method will ensure that the disabled variants are
1230 // ignored.
1231 ctx.baseModuleContext.strictVisitDeps = !m.IsCommonOSVariant()
Colin Crossdc35e212019-06-06 16:13:11 -07001232
Colin Cross4c83e5c2019-02-25 14:54:28 -08001233 if ctx.config.captureBuild {
1234 ctx.ruleParams = make(map[blueprint.Rule]blueprint.RuleParams)
1235 }
1236
Colin Cross67a5c132017-05-09 13:45:28 -07001237 desc := "//" + ctx.ModuleDir() + ":" + ctx.ModuleName() + " "
1238 var suffix []string
Colin Cross0875c522017-11-28 17:34:01 -08001239 if ctx.Os().Class != Device && ctx.Os().Class != Generic {
1240 suffix = append(suffix, ctx.Os().String())
Colin Cross67a5c132017-05-09 13:45:28 -07001241 }
Colin Cross0875c522017-11-28 17:34:01 -08001242 if !ctx.PrimaryArch() {
1243 suffix = append(suffix, ctx.Arch().ArchType.String())
Colin Cross67a5c132017-05-09 13:45:28 -07001244 }
Dan Willemsenb13a9482020-02-14 11:25:54 -08001245 if apex, ok := m.module.(ApexModule); ok && !apex.IsForPlatform() {
1246 suffix = append(suffix, apex.ApexName())
1247 }
Colin Cross67a5c132017-05-09 13:45:28 -07001248
1249 ctx.Variable(pctx, "moduleDesc", desc)
1250
1251 s := ""
1252 if len(suffix) > 0 {
1253 s = " [" + strings.Join(suffix, " ") + "]"
1254 }
1255 ctx.Variable(pctx, "moduleDescSuffix", s)
1256
Dan Willemsen569edc52018-11-19 09:33:29 -08001257 // Some common property checks for properties that will be used later in androidmk.go
Colin Cross4157e882019-06-06 16:57:04 -07001258 if m.commonProperties.Dist.Dest != nil {
1259 _, err := validateSafePath(*m.commonProperties.Dist.Dest)
Dan Willemsen569edc52018-11-19 09:33:29 -08001260 if err != nil {
1261 ctx.PropertyErrorf("dist.dest", "%s", err.Error())
1262 }
1263 }
Colin Cross4157e882019-06-06 16:57:04 -07001264 if m.commonProperties.Dist.Dir != nil {
1265 _, err := validateSafePath(*m.commonProperties.Dist.Dir)
Dan Willemsen569edc52018-11-19 09:33:29 -08001266 if err != nil {
1267 ctx.PropertyErrorf("dist.dir", "%s", err.Error())
1268 }
1269 }
Colin Cross4157e882019-06-06 16:57:04 -07001270 if m.commonProperties.Dist.Suffix != nil {
1271 if strings.Contains(*m.commonProperties.Dist.Suffix, "/") {
Dan Willemsen569edc52018-11-19 09:33:29 -08001272 ctx.PropertyErrorf("dist.suffix", "Suffix may not contain a '/' character.")
1273 }
1274 }
1275
Colin Cross4157e882019-06-06 16:57:04 -07001276 if m.Enabled() {
Jooyung Hand48f3c32019-08-23 11:18:57 +09001277 // ensure all direct android.Module deps are enabled
1278 ctx.VisitDirectDepsBlueprint(func(bm blueprint.Module) {
1279 if _, ok := bm.(Module); ok {
1280 ctx.validateAndroidModule(bm, ctx.baseModuleContext.strictVisitDeps)
1281 }
1282 })
1283
Bob Badoura75b0572020-02-18 20:21:55 -08001284 m.noticeFiles = make([]Path, 0)
1285 optPath := OptionalPath{}
1286 notice := proptools.StringDefault(m.commonProperties.Notice, "")
Colin Cross4157e882019-06-06 16:57:04 -07001287 if module := SrcIsModule(notice); module != "" {
Bob Badoura75b0572020-02-18 20:21:55 -08001288 optPath = ctx.ExpandOptionalSource(&notice, "notice")
1289 } else if notice != "" {
Jiyong Park52818fc2019-03-18 12:01:38 +09001290 noticePath := filepath.Join(ctx.ModuleDir(), notice)
Bob Badoura75b0572020-02-18 20:21:55 -08001291 optPath = ExistentPathForSource(ctx, noticePath)
1292 }
1293 if optPath.Valid() {
1294 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1295 } else {
1296 for _, notice = range []string{"LICENSE", "LICENCE", "NOTICE"} {
1297 noticePath := filepath.Join(ctx.ModuleDir(), notice)
1298 optPath = ExistentPathForSource(ctx, noticePath)
1299 if optPath.Valid() {
1300 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1301 }
1302 }
Jaewoong Jung62707f72018-11-16 13:26:43 -08001303 }
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001304
1305 m.module.GenerateAndroidBuildActions(ctx)
1306 if ctx.Failed() {
1307 return
1308 }
1309
1310 m.installFiles = append(m.installFiles, ctx.installFiles...)
1311 m.checkbuildFiles = append(m.checkbuildFiles, ctx.checkbuildFiles...)
Inseob Kim8471cda2019-11-15 09:59:12 +09001312 m.initRcPaths = PathsForModuleSrc(ctx, m.commonProperties.Init_rc)
1313 m.vintfFragmentsPaths = PathsForModuleSrc(ctx, m.commonProperties.Vintf_fragments)
Colin Crossdc35e212019-06-06 16:13:11 -07001314 } else if ctx.Config().AllowMissingDependencies() {
1315 // If the module is not enabled it will not create any build rules, nothing will call
1316 // ctx.GetMissingDependencies(), and blueprint will consider the missing dependencies to be unhandled
1317 // and report them as an error even when AllowMissingDependencies = true. Call
1318 // ctx.GetMissingDependencies() here to tell blueprint not to handle them.
1319 ctx.GetMissingDependencies()
Colin Cross3f40fa42015-01-30 17:27:36 -08001320 }
1321
Colin Cross4157e882019-06-06 16:57:04 -07001322 if m == ctx.FinalModule().(Module).base() {
1323 m.generateModuleTarget(ctx)
Colin Cross9b1d13d2016-09-19 15:18:11 -07001324 if ctx.Failed() {
1325 return
1326 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001327 }
Colin Crosscec81712017-07-13 14:43:27 -07001328
Colin Cross4157e882019-06-06 16:57:04 -07001329 m.buildParams = ctx.buildParams
1330 m.ruleParams = ctx.ruleParams
1331 m.variables = ctx.variables
Colin Cross3f40fa42015-01-30 17:27:36 -08001332}
1333
Colin Cross1184b642019-12-30 18:43:07 -08001334type earlyModuleContext struct {
Colin Crossc34d2322020-01-03 15:23:27 -08001335 blueprint.EarlyModuleContext
Colin Cross1184b642019-12-30 18:43:07 -08001336
1337 kind moduleKind
1338 config Config
1339}
1340
1341func (e *earlyModuleContext) Glob(globPattern string, excludes []string) Paths {
1342 ret, err := e.GlobWithDeps(globPattern, excludes)
1343 if err != nil {
1344 e.ModuleErrorf("glob: %s", err.Error())
1345 }
1346 return pathsForModuleSrcFromFullPath(e, ret, true)
1347}
1348
1349func (e *earlyModuleContext) GlobFiles(globPattern string, excludes []string) Paths {
1350 ret, err := e.GlobWithDeps(globPattern, excludes)
1351 if err != nil {
1352 e.ModuleErrorf("glob: %s", err.Error())
1353 }
1354 return pathsForModuleSrcFromFullPath(e, ret, false)
1355}
1356
Colin Cross988414c2020-01-11 01:11:46 +00001357func (b *earlyModuleContext) IsSymlink(path Path) bool {
1358 fileInfo, err := b.config.fs.Lstat(path.String())
1359 if err != nil {
1360 b.ModuleErrorf("os.Lstat(%q) failed: %s", path.String(), err)
1361 }
1362 return fileInfo.Mode()&os.ModeSymlink == os.ModeSymlink
1363}
1364
1365func (b *earlyModuleContext) Readlink(path Path) string {
1366 dest, err := b.config.fs.Readlink(path.String())
1367 if err != nil {
1368 b.ModuleErrorf("os.Readlink(%q) failed: %s", path.String(), err)
1369 }
1370 return dest
1371}
1372
Colin Cross1184b642019-12-30 18:43:07 -08001373func (e *earlyModuleContext) Module() Module {
Colin Crossc34d2322020-01-03 15:23:27 -08001374 module, _ := e.EarlyModuleContext.Module().(Module)
Colin Cross1184b642019-12-30 18:43:07 -08001375 return module
1376}
1377
1378func (e *earlyModuleContext) Config() Config {
Colin Crossc34d2322020-01-03 15:23:27 -08001379 return e.EarlyModuleContext.Config().(Config)
Colin Cross1184b642019-12-30 18:43:07 -08001380}
1381
1382func (e *earlyModuleContext) AConfig() Config {
1383 return e.config
1384}
1385
1386func (e *earlyModuleContext) DeviceConfig() DeviceConfig {
1387 return DeviceConfig{e.config.deviceConfig}
1388}
1389
1390func (e *earlyModuleContext) Platform() bool {
1391 return e.kind == platformModule
1392}
1393
1394func (e *earlyModuleContext) DeviceSpecific() bool {
1395 return e.kind == deviceSpecificModule
1396}
1397
1398func (e *earlyModuleContext) SocSpecific() bool {
1399 return e.kind == socSpecificModule
1400}
1401
1402func (e *earlyModuleContext) ProductSpecific() bool {
1403 return e.kind == productSpecificModule
1404}
1405
1406func (e *earlyModuleContext) SystemExtSpecific() bool {
1407 return e.kind == systemExtSpecificModule
1408}
1409
1410type baseModuleContext struct {
1411 bp blueprint.BaseModuleContext
1412 earlyModuleContext
Colin Crossfb0c16e2019-11-20 17:12:35 -08001413 os OsType
Colin Cross8b74d172016-09-13 09:59:14 -07001414 target Target
Colin Crossee0bc3b2018-10-02 22:01:37 -07001415 multiTargets []Target
Colin Cross8b74d172016-09-13 09:59:14 -07001416 targetPrimary bool
1417 debug bool
Colin Crossdc35e212019-06-06 16:13:11 -07001418
1419 walkPath []Module
Paul Duffinc5192442020-03-31 11:31:36 +01001420 tagPath []blueprint.DependencyTag
Colin Crossdc35e212019-06-06 16:13:11 -07001421
1422 strictVisitDeps bool // If true, enforce that all dependencies are enabled
Colin Crossf6566ed2015-03-24 11:13:38 -07001423}
1424
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001425func (b *baseModuleContext) OtherModuleName(m blueprint.Module) string {
1426 return b.bp.OtherModuleName(m)
1427}
1428func (b *baseModuleContext) OtherModuleDir(m blueprint.Module) string { return b.bp.OtherModuleDir(m) }
Colin Cross1184b642019-12-30 18:43:07 -08001429func (b *baseModuleContext) OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{}) {
Jooyung Hancd87c692020-02-26 02:05:18 +09001430 b.bp.OtherModuleErrorf(m, fmt, args...)
Colin Cross1184b642019-12-30 18:43:07 -08001431}
1432func (b *baseModuleContext) OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag {
1433 return b.bp.OtherModuleDependencyTag(m)
1434}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001435func (b *baseModuleContext) OtherModuleExists(name string) bool { return b.bp.OtherModuleExists(name) }
1436func (b *baseModuleContext) OtherModuleType(m blueprint.Module) string {
1437 return b.bp.OtherModuleType(m)
1438}
Colin Cross1184b642019-12-30 18:43:07 -08001439
1440func (b *baseModuleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1441 return b.bp.GetDirectDepWithTag(name, tag)
1442}
1443
Paul Duffinf88d8e02020-05-07 20:21:34 +01001444func (b *baseModuleContext) blueprintBaseModuleContext() blueprint.BaseModuleContext {
1445 return b.bp
1446}
1447
Colin Cross25de6c32019-06-06 14:29:25 -07001448type moduleContext struct {
Colin Crossdc35e212019-06-06 16:13:11 -07001449 bp blueprint.ModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -07001450 baseModuleContext
Colin Cross897266e2020-02-13 13:22:08 -08001451 installDeps InstallPaths
1452 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001453 checkbuildFiles Paths
Colin Cross8d8f8e22016-08-03 11:57:50 -07001454 module Module
Colin Crosscec81712017-07-13 14:43:27 -07001455
1456 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001457 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001458 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001459 variables map[string]string
Colin Cross6ff51382015-12-17 16:39:19 -08001460}
1461
Colin Crossb88b3c52019-06-10 15:15:17 -07001462func (m *moduleContext) ninjaError(params BuildParams, err error) (PackageContext, BuildParams) {
1463 return pctx, BuildParams{
Colin Cross4b69c492019-06-07 13:06:06 -07001464 Rule: ErrorRule,
1465 Description: params.Description,
1466 Output: params.Output,
1467 Outputs: params.Outputs,
1468 ImplicitOutput: params.ImplicitOutput,
1469 ImplicitOutputs: params.ImplicitOutputs,
Colin Cross6ff51382015-12-17 16:39:19 -08001470 Args: map[string]string{
1471 "error": err.Error(),
1472 },
Colin Crossb88b3c52019-06-10 15:15:17 -07001473 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001474}
1475
Colin Cross25de6c32019-06-06 14:29:25 -07001476func (m *moduleContext) ModuleBuild(pctx PackageContext, params ModuleBuildParams) {
1477 m.Build(pctx, BuildParams(params))
Colin Cross3f40fa42015-01-30 17:27:36 -08001478}
1479
Colin Cross0875c522017-11-28 17:34:01 -08001480func convertBuildParams(params BuildParams) blueprint.BuildParams {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001481 bparams := blueprint.BuildParams{
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001482 Rule: params.Rule,
Colin Cross0875c522017-11-28 17:34:01 -08001483 Description: params.Description,
Colin Cross33bfb0a2016-11-21 17:23:08 -08001484 Deps: params.Deps,
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001485 Outputs: params.Outputs.Strings(),
1486 ImplicitOutputs: params.ImplicitOutputs.Strings(),
1487 Inputs: params.Inputs.Strings(),
1488 Implicits: params.Implicits.Strings(),
1489 OrderOnly: params.OrderOnly.Strings(),
1490 Args: params.Args,
1491 Optional: !params.Default,
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001492 }
1493
Colin Cross33bfb0a2016-11-21 17:23:08 -08001494 if params.Depfile != nil {
1495 bparams.Depfile = params.Depfile.String()
1496 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001497 if params.Output != nil {
1498 bparams.Outputs = append(bparams.Outputs, params.Output.String())
1499 }
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001500 if params.ImplicitOutput != nil {
1501 bparams.ImplicitOutputs = append(bparams.ImplicitOutputs, params.ImplicitOutput.String())
1502 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001503 if params.Input != nil {
1504 bparams.Inputs = append(bparams.Inputs, params.Input.String())
1505 }
1506 if params.Implicit != nil {
1507 bparams.Implicits = append(bparams.Implicits, params.Implicit.String())
1508 }
1509
Colin Cross0b9f31f2019-02-28 11:00:01 -08001510 bparams.Outputs = proptools.NinjaEscapeList(bparams.Outputs)
1511 bparams.ImplicitOutputs = proptools.NinjaEscapeList(bparams.ImplicitOutputs)
1512 bparams.Inputs = proptools.NinjaEscapeList(bparams.Inputs)
1513 bparams.Implicits = proptools.NinjaEscapeList(bparams.Implicits)
1514 bparams.OrderOnly = proptools.NinjaEscapeList(bparams.OrderOnly)
1515 bparams.Depfile = proptools.NinjaEscapeList([]string{bparams.Depfile})[0]
Colin Crossfe4bc362018-09-12 10:02:13 -07001516
Colin Cross0875c522017-11-28 17:34:01 -08001517 return bparams
1518}
1519
Colin Cross25de6c32019-06-06 14:29:25 -07001520func (m *moduleContext) Variable(pctx PackageContext, name, value string) {
1521 if m.config.captureBuild {
1522 m.variables[name] = value
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001523 }
1524
Colin Crossdc35e212019-06-06 16:13:11 -07001525 m.bp.Variable(pctx.PackageContext, name, value)
Colin Cross0875c522017-11-28 17:34:01 -08001526}
1527
Colin Cross25de6c32019-06-06 14:29:25 -07001528func (m *moduleContext) Rule(pctx PackageContext, name string, params blueprint.RuleParams,
Colin Cross0875c522017-11-28 17:34:01 -08001529 argNames ...string) blueprint.Rule {
1530
Ramy Medhat944839a2020-03-31 22:14:52 -04001531 if m.config.UseRemoteBuild() {
1532 if params.Pool == nil {
1533 // When USE_GOMA=true or USE_RBE=true are set and the rule is not supported by goma/RBE, restrict
1534 // jobs to the local parallelism value
1535 params.Pool = localPool
1536 } else if params.Pool == remotePool {
1537 // remotePool is a fake pool used to identify rule that are supported for remoting. If the rule's
1538 // pool is the remotePool, replace with nil so that ninja runs it at NINJA_REMOTE_NUM_JOBS
1539 // parallelism.
1540 params.Pool = nil
1541 }
Colin Cross2e2dbc22019-09-25 13:31:46 -07001542 }
1543
Colin Crossdc35e212019-06-06 16:13:11 -07001544 rule := m.bp.Rule(pctx.PackageContext, name, params, argNames...)
Colin Cross4c83e5c2019-02-25 14:54:28 -08001545
Colin Cross25de6c32019-06-06 14:29:25 -07001546 if m.config.captureBuild {
1547 m.ruleParams[rule] = params
Colin Cross4c83e5c2019-02-25 14:54:28 -08001548 }
1549
1550 return rule
Colin Cross0875c522017-11-28 17:34:01 -08001551}
1552
Colin Cross25de6c32019-06-06 14:29:25 -07001553func (m *moduleContext) Build(pctx PackageContext, params BuildParams) {
Colin Crossb88b3c52019-06-10 15:15:17 -07001554 if params.Description != "" {
1555 params.Description = "${moduleDesc}" + params.Description + "${moduleDescSuffix}"
1556 }
1557
1558 if missingDeps := m.GetMissingDependencies(); len(missingDeps) > 0 {
1559 pctx, params = m.ninjaError(params, fmt.Errorf("module %s missing dependencies: %s\n",
1560 m.ModuleName(), strings.Join(missingDeps, ", ")))
1561 }
1562
Colin Cross25de6c32019-06-06 14:29:25 -07001563 if m.config.captureBuild {
1564 m.buildParams = append(m.buildParams, params)
Colin Cross0875c522017-11-28 17:34:01 -08001565 }
1566
Colin Crossdc35e212019-06-06 16:13:11 -07001567 m.bp.Build(pctx.PackageContext, convertBuildParams(params))
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001568}
Colin Cross25de6c32019-06-06 14:29:25 -07001569func (m *moduleContext) GetMissingDependencies() []string {
Colin Cross6c4f21f2019-06-06 15:41:36 -07001570 var missingDeps []string
1571 missingDeps = append(missingDeps, m.Module().base().commonProperties.MissingDeps...)
Colin Crossdc35e212019-06-06 16:13:11 -07001572 missingDeps = append(missingDeps, m.bp.GetMissingDependencies()...)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001573 missingDeps = FirstUniqueStrings(missingDeps)
1574 return missingDeps
Colin Cross6ff51382015-12-17 16:39:19 -08001575}
1576
Colin Crossdc35e212019-06-06 16:13:11 -07001577func (b *baseModuleContext) AddMissingDependencies(deps []string) {
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001578 if deps != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001579 missingDeps := &b.Module().base().commonProperties.MissingDeps
Colin Cross6c4f21f2019-06-06 15:41:36 -07001580 *missingDeps = append(*missingDeps, deps...)
1581 *missingDeps = FirstUniqueStrings(*missingDeps)
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001582 }
1583}
1584
Colin Crossdc35e212019-06-06 16:13:11 -07001585func (b *baseModuleContext) validateAndroidModule(module blueprint.Module, strict bool) Module {
Colin Crossd11fcda2017-10-23 17:59:01 -07001586 aModule, _ := module.(Module)
Colin Crossdc35e212019-06-06 16:13:11 -07001587
1588 if !strict {
1589 return aModule
1590 }
1591
Colin Cross380c69a2019-06-10 17:49:58 +00001592 if aModule == nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001593 b.ModuleErrorf("module %q not an android module", b.OtherModuleName(module))
Colin Cross380c69a2019-06-10 17:49:58 +00001594 return nil
1595 }
1596
1597 if !aModule.Enabled() {
Colin Crossdc35e212019-06-06 16:13:11 -07001598 if b.Config().AllowMissingDependencies() {
1599 b.AddMissingDependencies([]string{b.OtherModuleName(aModule)})
Colin Cross380c69a2019-06-10 17:49:58 +00001600 } else {
Colin Crossdc35e212019-06-06 16:13:11 -07001601 b.ModuleErrorf("depends on disabled module %q", b.OtherModuleName(aModule))
Colin Cross380c69a2019-06-10 17:49:58 +00001602 }
1603 return nil
1604 }
Colin Crossd11fcda2017-10-23 17:59:01 -07001605 return aModule
1606}
1607
Colin Crossdc35e212019-06-06 16:13:11 -07001608func (b *baseModuleContext) getDirectDepInternal(name string, tag blueprint.DependencyTag) (blueprint.Module, blueprint.DependencyTag) {
Jiyong Parkf2976302019-04-17 21:47:37 +09001609 type dep struct {
1610 mod blueprint.Module
1611 tag blueprint.DependencyTag
1612 }
1613 var deps []dep
Colin Crossdc35e212019-06-06 16:13:11 -07001614 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001615 if aModule, _ := module.(Module); aModule != nil && aModule.base().BaseModuleName() == name {
Colin Cross1184b642019-12-30 18:43:07 -08001616 returnedTag := b.bp.OtherModuleDependencyTag(aModule)
Jiyong Parkf2976302019-04-17 21:47:37 +09001617 if tag == nil || returnedTag == tag {
1618 deps = append(deps, dep{aModule, returnedTag})
1619 }
1620 }
1621 })
1622 if len(deps) == 1 {
1623 return deps[0].mod, deps[0].tag
1624 } else if len(deps) >= 2 {
1625 panic(fmt.Errorf("Multiple dependencies having same BaseModuleName() %q found from %q",
Colin Crossdc35e212019-06-06 16:13:11 -07001626 name, b.ModuleName()))
Jiyong Parkf2976302019-04-17 21:47:37 +09001627 } else {
1628 return nil, nil
1629 }
1630}
1631
Colin Crossdc35e212019-06-06 16:13:11 -07001632func (b *baseModuleContext) GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module {
Colin Cross0ef08162019-05-01 15:50:51 -07001633 var deps []Module
Colin Crossdc35e212019-06-06 16:13:11 -07001634 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001635 if aModule, _ := module.(Module); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001636 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Cross0ef08162019-05-01 15:50:51 -07001637 deps = append(deps, aModule)
1638 }
1639 }
1640 })
1641 return deps
1642}
1643
Colin Cross25de6c32019-06-06 14:29:25 -07001644func (m *moduleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1645 module, _ := m.getDirectDepInternal(name, tag)
1646 return module
Jiyong Parkf2976302019-04-17 21:47:37 +09001647}
1648
Colin Crossdc35e212019-06-06 16:13:11 -07001649func (b *baseModuleContext) GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag) {
1650 return b.getDirectDepInternal(name, nil)
Jiyong Parkf2976302019-04-17 21:47:37 +09001651}
1652
Colin Crossdc35e212019-06-06 16:13:11 -07001653func (b *baseModuleContext) VisitDirectDepsBlueprint(visit func(blueprint.Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001654 b.bp.VisitDirectDeps(visit)
Colin Cross35143d02017-11-16 00:11:20 -08001655}
1656
Colin Crossdc35e212019-06-06 16:13:11 -07001657func (b *baseModuleContext) VisitDirectDeps(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001658 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001659 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001660 visit(aModule)
1661 }
1662 })
1663}
1664
Colin Crossdc35e212019-06-06 16:13:11 -07001665func (b *baseModuleContext) VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001666 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001667 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001668 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Crossee6143c2017-12-30 17:54:27 -08001669 visit(aModule)
1670 }
1671 }
1672 })
1673}
1674
Colin Crossdc35e212019-06-06 16:13:11 -07001675func (b *baseModuleContext) VisitDirectDepsIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001676 b.bp.VisitDirectDepsIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001677 // pred
1678 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001679 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001680 return pred(aModule)
1681 } else {
1682 return false
1683 }
1684 },
1685 // visit
1686 func(module blueprint.Module) {
1687 visit(module.(Module))
1688 })
1689}
1690
Colin Crossdc35e212019-06-06 16:13:11 -07001691func (b *baseModuleContext) VisitDepsDepthFirst(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001692 b.bp.VisitDepsDepthFirst(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001693 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001694 visit(aModule)
1695 }
1696 })
1697}
1698
Colin Crossdc35e212019-06-06 16:13:11 -07001699func (b *baseModuleContext) VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001700 b.bp.VisitDepsDepthFirstIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001701 // pred
1702 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001703 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001704 return pred(aModule)
1705 } else {
1706 return false
1707 }
1708 },
1709 // visit
1710 func(module blueprint.Module) {
1711 visit(module.(Module))
1712 })
1713}
1714
Colin Crossdc35e212019-06-06 16:13:11 -07001715func (b *baseModuleContext) WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool) {
Colin Cross1184b642019-12-30 18:43:07 -08001716 b.bp.WalkDeps(visit)
Alex Light778127a2019-02-27 14:19:50 -08001717}
1718
Colin Crossdc35e212019-06-06 16:13:11 -07001719func (b *baseModuleContext) WalkDeps(visit func(Module, Module) bool) {
1720 b.walkPath = []Module{b.Module()}
Paul Duffinc5192442020-03-31 11:31:36 +01001721 b.tagPath = []blueprint.DependencyTag{}
Colin Cross1184b642019-12-30 18:43:07 -08001722 b.bp.WalkDeps(func(child, parent blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001723 childAndroidModule, _ := child.(Module)
1724 parentAndroidModule, _ := parent.(Module)
Colin Crossd11fcda2017-10-23 17:59:01 -07001725 if childAndroidModule != nil && parentAndroidModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001726 // record walkPath before visit
1727 for b.walkPath[len(b.walkPath)-1] != parentAndroidModule {
1728 b.walkPath = b.walkPath[0 : len(b.walkPath)-1]
Paul Duffinc5192442020-03-31 11:31:36 +01001729 b.tagPath = b.tagPath[0 : len(b.tagPath)-1]
Colin Crossdc35e212019-06-06 16:13:11 -07001730 }
1731 b.walkPath = append(b.walkPath, childAndroidModule)
Paul Duffinc5192442020-03-31 11:31:36 +01001732 b.tagPath = append(b.tagPath, b.OtherModuleDependencyTag(childAndroidModule))
Colin Crossd11fcda2017-10-23 17:59:01 -07001733 return visit(childAndroidModule, parentAndroidModule)
1734 } else {
1735 return false
1736 }
1737 })
1738}
1739
Colin Crossdc35e212019-06-06 16:13:11 -07001740func (b *baseModuleContext) GetWalkPath() []Module {
1741 return b.walkPath
1742}
1743
Paul Duffinc5192442020-03-31 11:31:36 +01001744func (b *baseModuleContext) GetTagPath() []blueprint.DependencyTag {
1745 return b.tagPath
1746}
1747
Jiyong Park1c7e9622020-05-07 16:12:13 +09001748// A regexp for removing boilerplate from BaseDependencyTag from the string representation of
1749// a dependency tag.
1750var tagCleaner = regexp.MustCompile(`\QBaseDependencyTag:blueprint.BaseDependencyTag{}\E(, )?`)
1751
1752// PrettyPrintTag returns string representation of the tag, but prefers
1753// custom String() method if available.
1754func PrettyPrintTag(tag blueprint.DependencyTag) string {
1755 // Use tag's custom String() method if available.
1756 if stringer, ok := tag.(fmt.Stringer); ok {
1757 return stringer.String()
1758 }
1759
1760 // Otherwise, get a default string representation of the tag's struct.
1761 tagString := fmt.Sprintf("%#v", tag)
1762
1763 // Remove the boilerplate from BaseDependencyTag as it adds no value.
1764 tagString = tagCleaner.ReplaceAllString(tagString, "")
1765 return tagString
1766}
1767
1768func (b *baseModuleContext) GetPathString(skipFirst bool) string {
1769 sb := strings.Builder{}
1770 tagPath := b.GetTagPath()
1771 walkPath := b.GetWalkPath()
1772 if !skipFirst {
1773 sb.WriteString(walkPath[0].String())
1774 }
1775 for i, m := range walkPath[1:] {
1776 sb.WriteString("\n")
1777 sb.WriteString(fmt.Sprintf(" via tag %s\n", PrettyPrintTag(tagPath[i])))
1778 sb.WriteString(fmt.Sprintf(" -> %s", m.String()))
1779 }
1780 return sb.String()
1781}
1782
Colin Cross25de6c32019-06-06 14:29:25 -07001783func (m *moduleContext) VisitAllModuleVariants(visit func(Module)) {
Colin Crossdc35e212019-06-06 16:13:11 -07001784 m.bp.VisitAllModuleVariants(func(module blueprint.Module) {
Colin Cross0875c522017-11-28 17:34:01 -08001785 visit(module.(Module))
1786 })
1787}
1788
Colin Cross25de6c32019-06-06 14:29:25 -07001789func (m *moduleContext) PrimaryModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001790 return m.bp.PrimaryModule().(Module)
Colin Cross0875c522017-11-28 17:34:01 -08001791}
1792
Colin Cross25de6c32019-06-06 14:29:25 -07001793func (m *moduleContext) FinalModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001794 return m.bp.FinalModule().(Module)
1795}
1796
1797func (m *moduleContext) ModuleSubDir() string {
1798 return m.bp.ModuleSubDir()
Colin Cross0875c522017-11-28 17:34:01 -08001799}
1800
Colin Cross0ea8ba82019-06-06 14:33:29 -07001801func (b *baseModuleContext) Target() Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001802 return b.target
Colin Crossa1ad8d12016-06-01 17:09:44 -07001803}
1804
Colin Cross0ea8ba82019-06-06 14:33:29 -07001805func (b *baseModuleContext) TargetPrimary() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001806 return b.targetPrimary
Colin Cross8b74d172016-09-13 09:59:14 -07001807}
1808
Colin Cross0ea8ba82019-06-06 14:33:29 -07001809func (b *baseModuleContext) MultiTargets() []Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001810 return b.multiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07001811}
1812
Colin Cross0ea8ba82019-06-06 14:33:29 -07001813func (b *baseModuleContext) Arch() Arch {
Colin Cross25de6c32019-06-06 14:29:25 -07001814 return b.target.Arch
Colin Cross3f40fa42015-01-30 17:27:36 -08001815}
1816
Colin Cross0ea8ba82019-06-06 14:33:29 -07001817func (b *baseModuleContext) Os() OsType {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001818 return b.os
Dan Willemsen490fd492015-11-24 17:53:15 -08001819}
1820
Colin Cross0ea8ba82019-06-06 14:33:29 -07001821func (b *baseModuleContext) Host() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001822 return b.os.Class == Host || b.os.Class == HostCross
Colin Crossf6566ed2015-03-24 11:13:38 -07001823}
1824
Colin Cross0ea8ba82019-06-06 14:33:29 -07001825func (b *baseModuleContext) Device() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001826 return b.os.Class == Device
Colin Crossf6566ed2015-03-24 11:13:38 -07001827}
1828
Colin Cross0ea8ba82019-06-06 14:33:29 -07001829func (b *baseModuleContext) Darwin() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001830 return b.os == Darwin
Colin Cross0af4b842015-04-30 16:36:18 -07001831}
1832
Colin Cross0ea8ba82019-06-06 14:33:29 -07001833func (b *baseModuleContext) Fuchsia() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001834 return b.os == Fuchsia
Doug Horn21b94272019-01-16 12:06:11 -08001835}
1836
Colin Cross0ea8ba82019-06-06 14:33:29 -07001837func (b *baseModuleContext) Windows() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001838 return b.os == Windows
Colin Cross3edeee12017-04-04 12:59:48 -07001839}
1840
Colin Cross0ea8ba82019-06-06 14:33:29 -07001841func (b *baseModuleContext) Debug() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001842 return b.debug
Colin Crossf6566ed2015-03-24 11:13:38 -07001843}
1844
Colin Cross0ea8ba82019-06-06 14:33:29 -07001845func (b *baseModuleContext) PrimaryArch() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001846 if len(b.config.Targets[b.target.Os]) <= 1 {
Colin Cross67a5c132017-05-09 13:45:28 -07001847 return true
1848 }
Colin Cross25de6c32019-06-06 14:29:25 -07001849 return b.target.Arch.ArchType == b.config.Targets[b.target.Os][0].Arch.ArchType
Colin Cross1e7d3702016-08-24 15:25:47 -07001850}
1851
Jiyong Park5baac542018-08-28 09:55:37 +09001852// Makes this module a platform module, i.e. not specific to soc, device,
Justin Yund5f6c822019-06-25 16:47:17 +09001853// product, or system_ext.
Colin Cross4157e882019-06-06 16:57:04 -07001854func (m *ModuleBase) MakeAsPlatform() {
1855 m.commonProperties.Vendor = boolPtr(false)
1856 m.commonProperties.Proprietary = boolPtr(false)
1857 m.commonProperties.Soc_specific = boolPtr(false)
1858 m.commonProperties.Product_specific = boolPtr(false)
Justin Yund5f6c822019-06-25 16:47:17 +09001859 m.commonProperties.System_ext_specific = boolPtr(false)
Jiyong Park5baac542018-08-28 09:55:37 +09001860}
1861
Colin Cross4157e882019-06-06 16:57:04 -07001862func (m *ModuleBase) EnableNativeBridgeSupportByDefault() {
1863 m.commonProperties.Native_bridge_supported = boolPtr(true)
dimitry03dc3f62019-05-09 14:07:34 +02001864}
1865
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001866func (m *ModuleBase) MakeAsSystemExt() {
Jooyung Han91df2082019-11-20 01:49:42 +09001867 m.commonProperties.Vendor = boolPtr(false)
1868 m.commonProperties.Proprietary = boolPtr(false)
1869 m.commonProperties.Soc_specific = boolPtr(false)
1870 m.commonProperties.Product_specific = boolPtr(false)
1871 m.commonProperties.System_ext_specific = boolPtr(true)
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001872}
1873
Jooyung Han344d5432019-08-23 11:17:39 +09001874// IsNativeBridgeSupported returns true if "native_bridge_supported" is explicitly set as "true"
1875func (m *ModuleBase) IsNativeBridgeSupported() bool {
1876 return proptools.Bool(m.commonProperties.Native_bridge_supported)
1877}
1878
Colin Cross25de6c32019-06-06 14:29:25 -07001879func (m *moduleContext) InstallInData() bool {
1880 return m.module.InstallInData()
Dan Willemsen782a2d12015-12-21 14:55:28 -08001881}
1882
Jaewoong Jung0949f312019-09-11 10:25:18 -07001883func (m *moduleContext) InstallInTestcases() bool {
1884 return m.module.InstallInTestcases()
1885}
1886
Colin Cross25de6c32019-06-06 14:29:25 -07001887func (m *moduleContext) InstallInSanitizerDir() bool {
1888 return m.module.InstallInSanitizerDir()
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001889}
1890
Yifan Hong1b3348d2020-01-21 15:53:22 -08001891func (m *moduleContext) InstallInRamdisk() bool {
1892 return m.module.InstallInRamdisk()
1893}
1894
Colin Cross25de6c32019-06-06 14:29:25 -07001895func (m *moduleContext) InstallInRecovery() bool {
1896 return m.module.InstallInRecovery()
Jiyong Parkf9332f12018-02-01 00:54:12 +09001897}
1898
Colin Cross90ba5f42019-10-02 11:10:58 -07001899func (m *moduleContext) InstallInRoot() bool {
1900 return m.module.InstallInRoot()
1901}
1902
Colin Cross607d8582019-07-29 16:44:46 -07001903func (m *moduleContext) InstallBypassMake() bool {
1904 return m.module.InstallBypassMake()
1905}
1906
Colin Cross6e359402020-02-10 15:29:54 -08001907func (m *moduleContext) InstallForceOS() *OsType {
1908 return m.module.InstallForceOS()
1909}
1910
Colin Cross70dda7e2019-10-01 22:05:35 -07001911func (m *moduleContext) skipInstall(fullInstallPath InstallPath) bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001912 if m.module.base().commonProperties.SkipInstall {
Colin Cross893d8162017-04-26 17:34:03 -07001913 return true
1914 }
1915
Colin Cross3607f212018-05-07 15:28:05 -07001916 // We'll need a solution for choosing which of modules with the same name in different
1917 // namespaces to install. For now, reuse the list of namespaces exported to Make as the
1918 // list of namespaces to install in a Soong-only build.
Colin Cross25de6c32019-06-06 14:29:25 -07001919 if !m.module.base().commonProperties.NamespaceExportedToMake {
Colin Cross3607f212018-05-07 15:28:05 -07001920 return true
1921 }
1922
Colin Cross25de6c32019-06-06 14:29:25 -07001923 if m.Device() {
Colin Cross607d8582019-07-29 16:44:46 -07001924 if m.Config().EmbeddedInMake() && !m.InstallBypassMake() {
Colin Cross893d8162017-04-26 17:34:03 -07001925 return true
1926 }
1927
Colin Cross25de6c32019-06-06 14:29:25 -07001928 if m.Config().SkipMegaDeviceInstall(fullInstallPath.String()) {
Colin Cross893d8162017-04-26 17:34:03 -07001929 return true
1930 }
1931 }
1932
1933 return false
1934}
1935
Colin Cross70dda7e2019-10-01 22:05:35 -07001936func (m *moduleContext) InstallFile(installPath InstallPath, name string, srcPath Path,
1937 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001938 return m.installFile(installPath, name, srcPath, Cp, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001939}
1940
Colin Cross70dda7e2019-10-01 22:05:35 -07001941func (m *moduleContext) InstallExecutable(installPath InstallPath, name string, srcPath Path,
1942 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001943 return m.installFile(installPath, name, srcPath, CpExecutable, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001944}
1945
Colin Cross70dda7e2019-10-01 22:05:35 -07001946func (m *moduleContext) installFile(installPath InstallPath, name string, srcPath Path,
1947 rule blueprint.Rule, deps []Path) InstallPath {
Colin Cross35cec122015-04-02 14:37:16 -07001948
Colin Cross25de6c32019-06-06 14:29:25 -07001949 fullInstallPath := installPath.Join(m, name)
1950 m.module.base().hooks.runInstallHooks(m, fullInstallPath, false)
Colin Cross3f40fa42015-01-30 17:27:36 -08001951
Colin Cross25de6c32019-06-06 14:29:25 -07001952 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001953
Colin Cross897266e2020-02-13 13:22:08 -08001954 deps = append(deps, m.installDeps.Paths()...)
Colin Cross35cec122015-04-02 14:37:16 -07001955
Colin Cross89562dc2016-10-03 17:47:19 -07001956 var implicitDeps, orderOnlyDeps Paths
1957
Colin Cross25de6c32019-06-06 14:29:25 -07001958 if m.Host() {
Colin Cross89562dc2016-10-03 17:47:19 -07001959 // Installed host modules might be used during the build, depend directly on their
1960 // dependencies so their timestamp is updated whenever their dependency is updated
1961 implicitDeps = deps
1962 } else {
1963 orderOnlyDeps = deps
1964 }
1965
Colin Cross25de6c32019-06-06 14:29:25 -07001966 m.Build(pctx, BuildParams{
Colin Cross5c517922017-08-31 12:29:17 -07001967 Rule: rule,
Colin Cross67a5c132017-05-09 13:45:28 -07001968 Description: "install " + fullInstallPath.Base(),
1969 Output: fullInstallPath,
1970 Input: srcPath,
1971 Implicits: implicitDeps,
1972 OrderOnly: orderOnlyDeps,
Colin Cross25de6c32019-06-06 14:29:25 -07001973 Default: !m.Config().EmbeddedInMake(),
Dan Willemsen322acaf2016-01-12 23:07:05 -08001974 })
Colin Cross3f40fa42015-01-30 17:27:36 -08001975
Colin Cross25de6c32019-06-06 14:29:25 -07001976 m.installFiles = append(m.installFiles, fullInstallPath)
Dan Willemsen322acaf2016-01-12 23:07:05 -08001977 }
Colin Cross25de6c32019-06-06 14:29:25 -07001978 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross35cec122015-04-02 14:37:16 -07001979 return fullInstallPath
1980}
1981
Colin Cross70dda7e2019-10-01 22:05:35 -07001982func (m *moduleContext) InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001983 fullInstallPath := installPath.Join(m, name)
1984 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Colin Cross3854a602016-01-11 12:49:11 -08001985
Colin Cross25de6c32019-06-06 14:29:25 -07001986 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001987
Alex Lightfb4353d2019-01-17 13:57:45 -08001988 relPath, err := filepath.Rel(path.Dir(fullInstallPath.String()), srcPath.String())
1989 if err != nil {
1990 panic(fmt.Sprintf("Unable to generate symlink between %q and %q: %s", fullInstallPath.Base(), srcPath.Base(), err))
1991 }
Colin Cross25de6c32019-06-06 14:29:25 -07001992 m.Build(pctx, BuildParams{
Colin Cross67a5c132017-05-09 13:45:28 -07001993 Rule: Symlink,
1994 Description: "install symlink " + fullInstallPath.Base(),
1995 Output: fullInstallPath,
Dan Willemsen40efa1c2020-01-14 15:19:52 -08001996 Input: srcPath,
Colin Cross25de6c32019-06-06 14:29:25 -07001997 Default: !m.Config().EmbeddedInMake(),
Colin Cross12fc4972016-01-11 12:49:11 -08001998 Args: map[string]string{
Alex Lightfb4353d2019-01-17 13:57:45 -08001999 "fromPath": relPath,
Colin Cross12fc4972016-01-11 12:49:11 -08002000 },
2001 })
Colin Cross3854a602016-01-11 12:49:11 -08002002
Colin Cross25de6c32019-06-06 14:29:25 -07002003 m.installFiles = append(m.installFiles, fullInstallPath)
2004 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross12fc4972016-01-11 12:49:11 -08002005 }
Colin Cross3854a602016-01-11 12:49:11 -08002006 return fullInstallPath
2007}
2008
Jiyong Parkf1194352019-02-25 11:05:47 +09002009// installPath/name -> absPath where absPath might be a path that is available only at runtime
2010// (e.g. /apex/...)
Colin Cross70dda7e2019-10-01 22:05:35 -07002011func (m *moduleContext) InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002012 fullInstallPath := installPath.Join(m, name)
2013 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Jiyong Parkf1194352019-02-25 11:05:47 +09002014
Colin Cross25de6c32019-06-06 14:29:25 -07002015 if !m.skipInstall(fullInstallPath) {
2016 m.Build(pctx, BuildParams{
Jiyong Parkf1194352019-02-25 11:05:47 +09002017 Rule: Symlink,
2018 Description: "install symlink " + fullInstallPath.Base() + " -> " + absPath,
2019 Output: fullInstallPath,
Colin Cross25de6c32019-06-06 14:29:25 -07002020 Default: !m.Config().EmbeddedInMake(),
Jiyong Parkf1194352019-02-25 11:05:47 +09002021 Args: map[string]string{
2022 "fromPath": absPath,
2023 },
2024 })
2025
Colin Cross25de6c32019-06-06 14:29:25 -07002026 m.installFiles = append(m.installFiles, fullInstallPath)
Jiyong Parkf1194352019-02-25 11:05:47 +09002027 }
2028 return fullInstallPath
2029}
2030
Colin Cross25de6c32019-06-06 14:29:25 -07002031func (m *moduleContext) CheckbuildFile(srcPath Path) {
2032 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross3f40fa42015-01-30 17:27:36 -08002033}
2034
Dan Willemsen2ef08f42015-06-30 18:15:24 -07002035func findStringInSlice(str string, slice []string) int {
2036 for i, s := range slice {
2037 if s == str {
2038 return i
Colin Crossfce53272015-04-08 11:21:40 -07002039 }
2040 }
Dan Willemsen2ef08f42015-06-30 18:15:24 -07002041 return -1
2042}
2043
Colin Cross41955e82019-05-29 14:40:35 -07002044// SrcIsModule decodes module references in the format ":name" into the module name, or empty string if the input
2045// was not a module reference.
2046func SrcIsModule(s string) (module string) {
Colin Cross068e0fe2016-12-13 15:23:47 -08002047 if len(s) > 1 && s[0] == ':' {
2048 return s[1:]
2049 }
2050 return ""
2051}
2052
Colin Cross41955e82019-05-29 14:40:35 -07002053// SrcIsModule decodes module references in the format ":name{.tag}" into the module name and tag, ":name" into the
2054// module name and an empty string for the tag, or empty strings if the input was not a module reference.
2055func SrcIsModuleWithTag(s string) (module, tag string) {
2056 if len(s) > 1 && s[0] == ':' {
2057 module = s[1:]
2058 if tagStart := strings.IndexByte(module, '{'); tagStart > 0 {
2059 if module[len(module)-1] == '}' {
2060 tag = module[tagStart+1 : len(module)-1]
2061 module = module[:tagStart]
2062 return module, tag
2063 }
2064 }
2065 return module, ""
2066 }
2067 return "", ""
Colin Cross068e0fe2016-12-13 15:23:47 -08002068}
2069
Colin Cross41955e82019-05-29 14:40:35 -07002070type sourceOrOutputDependencyTag struct {
2071 blueprint.BaseDependencyTag
2072 tag string
2073}
2074
2075func sourceOrOutputDepTag(tag string) blueprint.DependencyTag {
2076 return sourceOrOutputDependencyTag{tag: tag}
2077}
2078
2079var SourceDepTag = sourceOrOutputDepTag("")
Colin Cross068e0fe2016-12-13 15:23:47 -08002080
Colin Cross366938f2017-12-11 16:29:02 -08002081// Adds necessary dependencies to satisfy filegroup or generated sources modules listed in srcFiles
2082// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002083//
2084// Deprecated: tag the property with `android:"path"` instead.
Colin Cross068e0fe2016-12-13 15:23:47 -08002085func ExtractSourcesDeps(ctx BottomUpMutatorContext, srcFiles []string) {
Nan Zhang2439eb72017-04-10 11:27:50 -07002086 set := make(map[string]bool)
2087
Colin Cross068e0fe2016-12-13 15:23:47 -08002088 for _, s := range srcFiles {
Colin Cross41955e82019-05-29 14:40:35 -07002089 if m, t := SrcIsModuleWithTag(s); m != "" {
2090 if _, found := set[s]; found {
2091 ctx.ModuleErrorf("found source dependency duplicate: %q!", s)
Nan Zhang2439eb72017-04-10 11:27:50 -07002092 } else {
Colin Cross41955e82019-05-29 14:40:35 -07002093 set[s] = true
2094 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Nan Zhang2439eb72017-04-10 11:27:50 -07002095 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002096 }
2097 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002098}
2099
Colin Cross366938f2017-12-11 16:29:02 -08002100// Adds necessary dependencies to satisfy filegroup or generated sources modules specified in s
2101// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002102//
2103// Deprecated: tag the property with `android:"path"` instead.
Colin Cross366938f2017-12-11 16:29:02 -08002104func ExtractSourceDeps(ctx BottomUpMutatorContext, s *string) {
2105 if s != nil {
Colin Cross41955e82019-05-29 14:40:35 -07002106 if m, t := SrcIsModuleWithTag(*s); m != "" {
2107 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Colin Cross366938f2017-12-11 16:29:02 -08002108 }
2109 }
2110}
2111
Colin Cross41955e82019-05-29 14:40:35 -07002112// A module that implements SourceFileProducer can be referenced from any property that is tagged with `android:"path"`
2113// 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 -08002114type SourceFileProducer interface {
2115 Srcs() Paths
2116}
2117
Colin Cross41955e82019-05-29 14:40:35 -07002118// A module that implements OutputFileProducer can be referenced from any property that is tagged with `android:"path"`
Roland Levillain97c1f342019-11-22 14:20:54 +00002119// 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 -07002120// listed in the property.
2121type OutputFileProducer interface {
2122 OutputFiles(tag string) (Paths, error)
2123}
2124
Colin Cross5e708052019-08-06 13:59:50 -07002125// OutputFilesForModule returns the paths from an OutputFileProducer with the given tag. On error, including if the
2126// module produced zero paths, it reports errors to the ctx and returns nil.
2127func OutputFilesForModule(ctx PathContext, module blueprint.Module, tag string) Paths {
2128 paths, err := outputFilesForModule(ctx, module, tag)
2129 if err != nil {
2130 reportPathError(ctx, err)
2131 return nil
2132 }
2133 return paths
2134}
2135
2136// OutputFileForModule returns the path from an OutputFileProducer with the given tag. On error, including if the
2137// module produced zero or multiple paths, it reports errors to the ctx and returns nil.
2138func OutputFileForModule(ctx PathContext, module blueprint.Module, tag string) Path {
2139 paths, err := outputFilesForModule(ctx, module, tag)
2140 if err != nil {
2141 reportPathError(ctx, err)
2142 return nil
2143 }
2144 if len(paths) > 1 {
2145 reportPathErrorf(ctx, "got multiple output files from module %q, expected exactly one",
2146 pathContextName(ctx, module))
2147 return nil
2148 }
2149 return paths[0]
2150}
2151
2152func outputFilesForModule(ctx PathContext, module blueprint.Module, tag string) (Paths, error) {
2153 if outputFileProducer, ok := module.(OutputFileProducer); ok {
2154 paths, err := outputFileProducer.OutputFiles(tag)
2155 if err != nil {
2156 return nil, fmt.Errorf("failed to get output file from module %q: %s",
2157 pathContextName(ctx, module), err.Error())
2158 }
2159 if len(paths) == 0 {
2160 return nil, fmt.Errorf("failed to get output files from module %q", pathContextName(ctx, module))
2161 }
2162 return paths, nil
2163 } else {
2164 return nil, fmt.Errorf("module %q is not an OutputFileProducer", pathContextName(ctx, module))
2165 }
2166}
2167
Colin Crossfe17f6f2019-03-28 19:30:56 -07002168type HostToolProvider interface {
2169 HostToolPath() OptionalPath
2170}
2171
Colin Cross27b922f2019-03-04 22:35:41 -08002172// Returns a list of paths expanded from globs and modules referenced using ":module" syntax. The property must
2173// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002174//
2175// Deprecated: use PathsForModuleSrc or PathsForModuleSrcExcludes instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002176func (m *moduleContext) ExpandSources(srcFiles, excludes []string) Paths {
2177 return PathsForModuleSrcExcludes(m, srcFiles, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07002178}
2179
Colin Cross2fafa3e2019-03-05 12:39:51 -08002180// Returns a single path expanded from globs and modules referenced using ":module" syntax. The property must
2181// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002182//
2183// Deprecated: use PathForModuleSrc instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002184func (m *moduleContext) ExpandSource(srcFile, prop string) Path {
2185 return PathForModuleSrc(m, srcFile)
Colin Cross2fafa3e2019-03-05 12:39:51 -08002186}
2187
2188// Returns an optional single path expanded from globs and modules referenced using ":module" syntax if
2189// the srcFile is non-nil. The property must be tagged with `android:"path" to support automatic source module
2190// dependency resolution.
Colin Cross25de6c32019-06-06 14:29:25 -07002191func (m *moduleContext) ExpandOptionalSource(srcFile *string, prop string) OptionalPath {
Colin Cross2fafa3e2019-03-05 12:39:51 -08002192 if srcFile != nil {
Colin Cross25de6c32019-06-06 14:29:25 -07002193 return OptionalPathForPath(PathForModuleSrc(m, *srcFile))
Colin Cross2fafa3e2019-03-05 12:39:51 -08002194 }
2195 return OptionalPath{}
2196}
2197
Colin Cross25de6c32019-06-06 14:29:25 -07002198func (m *moduleContext) RequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002199 return m.module.RequiredModuleNames()
Nan Zhang6d34b302017-02-04 17:47:46 -08002200}
2201
Colin Cross25de6c32019-06-06 14:29:25 -07002202func (m *moduleContext) HostRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002203 return m.module.HostRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002204}
2205
Colin Cross25de6c32019-06-06 14:29:25 -07002206func (m *moduleContext) TargetRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002207 return m.module.TargetRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002208}
2209
Colin Cross463a90e2015-06-17 14:20:06 -07002210func init() {
Colin Cross798bfce2016-10-12 14:28:16 -07002211 RegisterSingletonType("buildtarget", BuildTargetSingleton)
Colin Cross463a90e2015-06-17 14:20:06 -07002212}
2213
Colin Cross0875c522017-11-28 17:34:01 -08002214func BuildTargetSingleton() Singleton {
Colin Cross1f8c52b2015-06-16 16:38:17 -07002215 return &buildTargetSingleton{}
2216}
2217
Colin Cross87d8b562017-04-25 10:01:55 -07002218func parentDir(dir string) string {
2219 dir, _ = filepath.Split(dir)
2220 return filepath.Clean(dir)
2221}
2222
Colin Cross1f8c52b2015-06-16 16:38:17 -07002223type buildTargetSingleton struct{}
2224
Colin Cross0875c522017-11-28 17:34:01 -08002225func (c *buildTargetSingleton) GenerateBuildActions(ctx SingletonContext) {
2226 var checkbuildDeps Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07002227
Colin Cross0875c522017-11-28 17:34:01 -08002228 mmTarget := func(dir string) WritablePath {
2229 return PathForPhony(ctx,
2230 "MODULES-IN-"+strings.Replace(filepath.Clean(dir), "/", "-", -1))
Colin Cross87d8b562017-04-25 10:01:55 -07002231 }
2232
Colin Cross0875c522017-11-28 17:34:01 -08002233 modulesInDir := make(map[string]Paths)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002234
Colin Cross0875c522017-11-28 17:34:01 -08002235 ctx.VisitAllModules(func(module Module) {
2236 blueprintDir := module.base().blueprintDir
2237 installTarget := module.base().installTarget
2238 checkbuildTarget := module.base().checkbuildTarget
Colin Cross1f8c52b2015-06-16 16:38:17 -07002239
Colin Cross0875c522017-11-28 17:34:01 -08002240 if checkbuildTarget != nil {
2241 checkbuildDeps = append(checkbuildDeps, checkbuildTarget)
2242 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], checkbuildTarget)
2243 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002244
Colin Cross0875c522017-11-28 17:34:01 -08002245 if installTarget != nil {
2246 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], installTarget)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002247 }
2248 })
2249
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002250 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08002251 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002252 suffix = "-soong"
2253 }
2254
Colin Cross1f8c52b2015-06-16 16:38:17 -07002255 // Create a top-level checkbuild target that depends on all modules
Colin Cross0875c522017-11-28 17:34:01 -08002256 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07002257 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002258 Output: PathForPhony(ctx, "checkbuild"+suffix),
Colin Cross1f8c52b2015-06-16 16:38:17 -07002259 Implicits: checkbuildDeps,
Colin Cross1f8c52b2015-06-16 16:38:17 -07002260 })
2261
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002262 // Make will generate the MODULES-IN-* targets
Colin Crossaabf6792017-11-29 00:27:14 -08002263 if ctx.Config().EmbeddedInMake() {
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002264 return
2265 }
2266
Colin Cross87d8b562017-04-25 10:01:55 -07002267 // Ensure ancestor directories are in modulesInDir
Inseob Kim1a365c62019-06-08 15:47:51 +09002268 dirs := SortedStringKeys(modulesInDir)
Colin Cross87d8b562017-04-25 10:01:55 -07002269 for _, dir := range dirs {
2270 dir := parentDir(dir)
2271 for dir != "." && dir != "/" {
2272 if _, exists := modulesInDir[dir]; exists {
2273 break
2274 }
2275 modulesInDir[dir] = nil
2276 dir = parentDir(dir)
2277 }
2278 }
2279
2280 // Make directories build their direct subdirectories
Colin Cross87d8b562017-04-25 10:01:55 -07002281 for _, dir := range dirs {
2282 p := parentDir(dir)
2283 if p != "." && p != "/" {
2284 modulesInDir[p] = append(modulesInDir[p], mmTarget(dir))
2285 }
2286 }
2287
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002288 // Create a MODULES-IN-<directory> target that depends on all modules in a directory, and
2289 // depends on the MODULES-IN-* targets of all of its subdirectories that contain Android.bp
2290 // files.
Colin Cross1f8c52b2015-06-16 16:38:17 -07002291 for _, dir := range dirs {
Colin Cross0875c522017-11-28 17:34:01 -08002292 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07002293 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002294 Output: mmTarget(dir),
Colin Cross87d8b562017-04-25 10:01:55 -07002295 Implicits: modulesInDir[dir],
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002296 // HACK: checkbuild should be an optional build, but force it
2297 // enabled for now in standalone builds
Colin Crossaabf6792017-11-29 00:27:14 -08002298 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross1f8c52b2015-06-16 16:38:17 -07002299 })
2300 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002301
2302 // Create (host|host-cross|target)-<OS> phony rules to build a reduced checkbuild.
2303 osDeps := map[OsType]Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08002304 ctx.VisitAllModules(func(module Module) {
2305 if module.Enabled() {
2306 os := module.Target().Os
2307 osDeps[os] = append(osDeps[os], module.base().checkbuildFiles...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002308 }
2309 })
2310
Colin Cross0875c522017-11-28 17:34:01 -08002311 osClass := make(map[string]Paths)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002312 for os, deps := range osDeps {
2313 var className string
2314
2315 switch os.Class {
2316 case Host:
2317 className = "host"
2318 case HostCross:
2319 className = "host-cross"
2320 case Device:
2321 className = "target"
2322 default:
2323 continue
2324 }
2325
Colin Cross0875c522017-11-28 17:34:01 -08002326 name := PathForPhony(ctx, className+"-"+os.Name)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002327 osClass[className] = append(osClass[className], name)
2328
Colin Cross0875c522017-11-28 17:34:01 -08002329 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07002330 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002331 Output: name,
2332 Implicits: deps,
Dan Willemsen61d88b82017-09-20 17:29:08 -07002333 })
2334 }
2335
2336 // Wrap those into host|host-cross|target phony rules
Inseob Kim1a365c62019-06-08 15:47:51 +09002337 for _, class := range SortedStringKeys(osClass) {
Colin Cross0875c522017-11-28 17:34:01 -08002338 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07002339 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002340 Output: PathForPhony(ctx, class),
Dan Willemsen61d88b82017-09-20 17:29:08 -07002341 Implicits: osClass[class],
Dan Willemsen61d88b82017-09-20 17:29:08 -07002342 })
2343 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002344}
Colin Crossd779da42015-12-17 18:00:23 -08002345
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002346// Collect information for opening IDE project files in java/jdeps.go.
2347type IDEInfo interface {
2348 IDEInfo(ideInfo *IdeInfo)
2349 BaseModuleName() string
2350}
2351
2352// Extract the base module name from the Import name.
2353// Often the Import name has a prefix "prebuilt_".
2354// Remove the prefix explicitly if needed
2355// until we find a better solution to get the Import name.
2356type IDECustomizedModuleName interface {
2357 IDECustomizedModuleName() string
2358}
2359
2360type IdeInfo struct {
2361 Deps []string `json:"dependencies,omitempty"`
2362 Srcs []string `json:"srcs,omitempty"`
2363 Aidl_include_dirs []string `json:"aidl_include_dirs,omitempty"`
2364 Jarjar_rules []string `json:"jarjar_rules,omitempty"`
2365 Jars []string `json:"jars,omitempty"`
2366 Classes []string `json:"class,omitempty"`
2367 Installed_paths []string `json:"installed,omitempty"`
patricktu18c82ff2019-05-10 15:48:50 +08002368 SrcJars []string `json:"srcjars,omitempty"`
bralee1fbf4402020-05-21 10:11:59 +08002369 Paths []string `json:"path,omitempty"`
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002370}
Paul Duffinf88d8e02020-05-07 20:21:34 +01002371
2372func CheckBlueprintSyntax(ctx BaseModuleContext, filename string, contents string) []error {
2373 bpctx := ctx.blueprintBaseModuleContext()
2374 return blueprint.CheckBlueprintSyntax(bpctx.ModuleFactories(), filename, contents)
2375}