blob: e2b7dd38e72c2f5ab1fe6aaf3be1aba01f8ab85b [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
Colin Crossdc35e212019-06-06 16:13:11 -0700107 OtherModuleName(m blueprint.Module) string
108 OtherModuleDir(m blueprint.Module) string
109 OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{})
110 OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag
111 OtherModuleExists(name string) bool
Jiyong Park9e6c2422019-08-09 20:39:45 +0900112 OtherModuleType(m blueprint.Module) string
Colin Crossdc35e212019-06-06 16:13:11 -0700113
114 GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module
115 GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module
116 GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag)
117
118 VisitDirectDepsBlueprint(visit func(blueprint.Module))
119 VisitDirectDeps(visit func(Module))
120 VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module))
121 VisitDirectDepsIf(pred func(Module) bool, visit func(Module))
122 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
123 VisitDepsDepthFirst(visit func(Module))
124 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
125 VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module))
126 WalkDeps(visit func(Module, Module) bool)
127 WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool)
128 // GetWalkPath is supposed to be called in visit function passed in WalkDeps()
129 // and returns a top-down dependency path from a start module to current child module.
130 GetWalkPath() []Module
131
Paul Duffinc5192442020-03-31 11:31:36 +0100132 // GetTagPath is supposed to be called in visit function passed in WalkDeps()
133 // and returns a top-down dependency tags path from a start module to current child module.
134 // It has one less entry than GetWalkPath() as it contains the dependency tags that
135 // exist between each adjacent pair of modules in the GetWalkPath().
136 // GetTagPath()[i] is the tag between GetWalkPath()[i] and GetWalkPath()[i+1]
137 GetTagPath() []blueprint.DependencyTag
138
Jiyong Park1c7e9622020-05-07 16:12:13 +0900139 // GetPathString is supposed to be called in visit function passed in WalkDeps()
140 // and returns a multi-line string showing the modules and dependency tags
141 // among them along the top-down dependency path from a start module to current child module.
142 // skipFirst when set to true, the output doesn't include the start module,
143 // which is already printed when this function is used along with ModuleErrorf().
144 GetPathString(skipFirst bool) string
145
Colin Crossdc35e212019-06-06 16:13:11 -0700146 AddMissingDependencies(missingDeps []string)
147
Colin Crossa1ad8d12016-06-01 17:09:44 -0700148 Target() Target
Colin Cross8b74d172016-09-13 09:59:14 -0700149 TargetPrimary() bool
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000150
151 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
152 // responsible for creating.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700153 MultiTargets() []Target
Colin Crossf6566ed2015-03-24 11:13:38 -0700154 Arch() Arch
Colin Crossa1ad8d12016-06-01 17:09:44 -0700155 Os() OsType
Colin Crossf6566ed2015-03-24 11:13:38 -0700156 Host() bool
157 Device() bool
Colin Cross0af4b842015-04-30 16:36:18 -0700158 Darwin() bool
Doug Horn21b94272019-01-16 12:06:11 -0800159 Fuchsia() bool
Colin Cross3edeee12017-04-04 12:59:48 -0700160 Windows() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700161 Debug() bool
Colin Cross1e7d3702016-08-24 15:25:47 -0700162 PrimaryArch() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700163}
164
Colin Cross1184b642019-12-30 18:43:07 -0800165// Deprecated: use EarlyModuleContext instead
Colin Cross635c3b02016-05-18 15:37:25 -0700166type BaseContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800167 EarlyModuleContext
Colin Crossaabf6792017-11-29 00:27:14 -0800168}
169
Colin Cross635c3b02016-05-18 15:37:25 -0700170type ModuleContext interface {
Colin Crossaabf6792017-11-29 00:27:14 -0800171 BaseModuleContext
Colin Cross3f40fa42015-01-30 17:27:36 -0800172
Colin Crossae887032017-10-23 17:16:14 -0700173 // Deprecated: use ModuleContext.Build instead.
Colin Cross0875c522017-11-28 17:34:01 -0800174 ModuleBuild(pctx PackageContext, params ModuleBuildParams)
Colin Cross8f101b42015-06-17 15:09:06 -0700175
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700176 ExpandSources(srcFiles, excludes []string) Paths
Colin Cross366938f2017-12-11 16:29:02 -0800177 ExpandSource(srcFile, prop string) Path
Colin Cross2383f3b2018-02-06 14:40:13 -0800178 ExpandOptionalSource(srcFile *string, prop string) OptionalPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700179
Colin Cross70dda7e2019-10-01 22:05:35 -0700180 InstallExecutable(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
181 InstallFile(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
182 InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath
183 InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700184 CheckbuildFile(srcPath Path)
Dan Willemsen6553f5e2016-03-10 18:14:25 -0800185
Colin Cross8d8f8e22016-08-03 11:57:50 -0700186 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700187 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700188 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800189 InstallInRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900190 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700191 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700192 InstallBypassMake() bool
Colin Cross6e359402020-02-10 15:29:54 -0800193 InstallForceOS() *OsType
Nan Zhang6d34b302017-02-04 17:47:46 -0800194
195 RequiredModuleNames() []string
Sasha Smundakb6d23052019-04-01 18:37:36 -0700196 HostRequiredModuleNames() []string
197 TargetRequiredModuleNames() []string
Colin Cross3f68a132017-10-23 17:10:29 -0700198
Colin Cross3f68a132017-10-23 17:10:29 -0700199 ModuleSubDir() string
200
Colin Cross0875c522017-11-28 17:34:01 -0800201 Variable(pctx PackageContext, name, value string)
202 Rule(pctx PackageContext, name string, params blueprint.RuleParams, argNames ...string) blueprint.Rule
Colin Crossae887032017-10-23 17:16:14 -0700203 // Similar to blueprint.ModuleContext.Build, but takes Paths instead of []string,
204 // and performs more verification.
Colin Cross0875c522017-11-28 17:34:01 -0800205 Build(pctx PackageContext, params BuildParams)
Colin Cross3f68a132017-10-23 17:10:29 -0700206
Colin Cross0875c522017-11-28 17:34:01 -0800207 PrimaryModule() Module
208 FinalModule() Module
209 VisitAllModuleVariants(visit func(Module))
Colin Cross3f68a132017-10-23 17:10:29 -0700210
211 GetMissingDependencies() []string
Jeff Gaston088e29e2017-11-29 16:47:17 -0800212 Namespace() blueprint.Namespace
Colin Cross3f40fa42015-01-30 17:27:36 -0800213}
214
Colin Cross635c3b02016-05-18 15:37:25 -0700215type Module interface {
Colin Cross3f40fa42015-01-30 17:27:36 -0800216 blueprint.Module
217
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700218 // GenerateAndroidBuildActions is analogous to Blueprints' GenerateBuildActions,
219 // but GenerateAndroidBuildActions also has access to Android-specific information.
220 // For more information, see Module.GenerateBuildActions within Blueprint's module_ctx.go
Colin Cross635c3b02016-05-18 15:37:25 -0700221 GenerateAndroidBuildActions(ModuleContext)
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700222
Colin Cross1e676be2016-10-12 14:38:15 -0700223 DepsMutator(BottomUpMutatorContext)
Colin Cross3f40fa42015-01-30 17:27:36 -0800224
Colin Cross635c3b02016-05-18 15:37:25 -0700225 base() *ModuleBase
Inseob Kimeec88e12020-01-22 11:11:29 +0900226 Disable()
Dan Willemsen0effe062015-11-30 16:06:01 -0800227 Enabled() bool
Colin Crossa1ad8d12016-06-01 17:09:44 -0700228 Target() Target
Dan Willemsen782a2d12015-12-21 14:55:28 -0800229 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700230 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700231 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800232 InstallInRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900233 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700234 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700235 InstallBypassMake() bool
Colin Cross6e359402020-02-10 15:29:54 -0800236 InstallForceOS() *OsType
Colin Crossa2f296f2016-11-29 15:16:18 -0800237 SkipInstall()
Ulya Trafimovichb28cc372020-01-13 15:18:16 +0000238 IsSkipInstall() bool
Jiyong Park374510b2018-03-19 18:23:01 +0900239 ExportedToMake() bool
Inseob Kim8471cda2019-11-15 09:59:12 +0900240 InitRc() Paths
241 VintfFragments() Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800242 NoticeFiles() Paths
Colin Cross36242852017-06-23 15:06:31 -0700243
244 AddProperties(props ...interface{})
245 GetProperties() []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700246
Colin Crossae887032017-10-23 17:16:14 -0700247 BuildParamsForTests() []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800248 RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800249 VariablesForTests() map[string]string
Paul Duffine2453c72019-05-31 14:00:04 +0100250
Colin Cross9a362232019-07-01 15:32:45 -0700251 // String returns a string that includes the module name and variants for printing during debugging.
252 String() string
253
Paul Duffine2453c72019-05-31 14:00:04 +0100254 // Get the qualified module id for this module.
255 qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName
256
257 // Get information about the properties that can contain visibility rules.
258 visibilityProperties() []visibilityProperty
Paul Duffin63c6e182019-07-24 14:24:38 +0100259
Jiyong Park6a8cf5f2019-12-30 16:31:09 +0900260 RequiredModuleNames() []string
261 HostRequiredModuleNames() []string
262 TargetRequiredModuleNames() []string
Colin Cross897266e2020-02-13 13:22:08 -0800263
264 filesToInstall() InstallPaths
Paul Duffine2453c72019-05-31 14:00:04 +0100265}
266
267// Qualified id for a module
268type qualifiedModuleName struct {
269 // The package (i.e. directory) in which the module is defined, without trailing /
270 pkg string
271
272 // The name of the module, empty string if package.
273 name string
274}
275
276func (q qualifiedModuleName) String() string {
277 if q.name == "" {
278 return "//" + q.pkg
279 }
280 return "//" + q.pkg + ":" + q.name
281}
282
Paul Duffine484f472019-06-20 16:38:08 +0100283func (q qualifiedModuleName) isRootPackage() bool {
284 return q.pkg == "" && q.name == ""
285}
286
Paul Duffine2453c72019-05-31 14:00:04 +0100287// Get the id for the package containing this module.
288func (q qualifiedModuleName) getContainingPackageId() qualifiedModuleName {
289 pkg := q.pkg
290 if q.name == "" {
Paul Duffine484f472019-06-20 16:38:08 +0100291 if pkg == "" {
292 panic(fmt.Errorf("Cannot get containing package id of root package"))
293 }
294
295 index := strings.LastIndex(pkg, "/")
296 if index == -1 {
297 pkg = ""
298 } else {
299 pkg = pkg[:index]
300 }
Paul Duffine2453c72019-05-31 14:00:04 +0100301 }
302 return newPackageId(pkg)
303}
304
305func newPackageId(pkg string) qualifiedModuleName {
306 // A qualified id for a package module has no name.
307 return qualifiedModuleName{pkg: pkg, name: ""}
Colin Cross3f40fa42015-01-30 17:27:36 -0800308}
309
Colin Crossfc754582016-05-17 16:34:16 -0700310type nameProperties struct {
311 // The name of the module. Must be unique across all modules.
Nan Zhang0007d812017-11-07 10:57:05 -0800312 Name *string
Colin Crossfc754582016-05-17 16:34:16 -0700313}
314
315type commonProperties struct {
Dan Willemsen0effe062015-11-30 16:06:01 -0800316 // emit build rules for this module
Paul Duffin54d9bb72020-02-12 10:20:56 +0000317 //
318 // Disabling a module should only be done for those modules that cannot be built
319 // in the current environment. Modules that can build in the current environment
320 // but are not usually required (e.g. superceded by a prebuilt) should not be
321 // disabled as that will prevent them from being built by the checkbuild target
322 // and so prevent early detection of changes that have broken those modules.
Dan Willemsen0effe062015-11-30 16:06:01 -0800323 Enabled *bool `android:"arch_variant"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800324
Paul Duffin2e61fa62019-03-28 14:10:57 +0000325 // Controls the visibility of this module to other modules. Allowable values are one or more of
326 // these formats:
327 //
328 // ["//visibility:public"]: Anyone can use this module.
329 // ["//visibility:private"]: Only rules in the module's package (not its subpackages) can use
330 // this module.
Paul Duffin51084ff2020-05-05 19:19:22 +0100331 // ["//visibility:override"]: Discards any rules inherited from defaults or a creating module.
332 // Can only be used at the beginning of a list of visibility rules.
Paul Duffin2e61fa62019-03-28 14:10:57 +0000333 // ["//some/package:__pkg__", "//other/package:__pkg__"]: Only modules in some/package and
334 // other/package (defined in some/package/*.bp and other/package/*.bp) have access to
335 // this module. Note that sub-packages do not have access to the rule; for example,
336 // //some/package/foo:bar or //other/package/testing:bla wouldn't have access. __pkg__
337 // is a special module and must be used verbatim. It represents all of the modules in the
338 // package.
339 // ["//project:__subpackages__", "//other:__subpackages__"]: Only modules in packages project
340 // or other or in one of their sub-packages have access to this module. For example,
341 // //project:rule, //project/library:lib or //other/testing/internal:munge are allowed
342 // to depend on this rule (but not //independent:evil)
343 // ["//project"]: This is shorthand for ["//project:__pkg__"]
344 // [":__subpackages__"]: This is shorthand for ["//project:__subpackages__"] where
345 // //project is the module's package. e.g. using [":__subpackages__"] in
346 // packages/apps/Settings/Android.bp is equivalent to
347 // //packages/apps/Settings:__subpackages__.
348 // ["//visibility:legacy_public"]: The default visibility, behaves as //visibility:public
349 // for now. It is an error if it is used in a module.
Paul Duffine2453c72019-05-31 14:00:04 +0100350 //
351 // If a module does not specify the `visibility` property then it uses the
352 // `default_visibility` property of the `package` module in the module's package.
353 //
354 // If the `default_visibility` property is not set for the module's package then
Paul Duffine484f472019-06-20 16:38:08 +0100355 // it will use the `default_visibility` of its closest ancestor package for which
356 // a `default_visibility` property is specified.
357 //
358 // If no `default_visibility` property can be found then the module uses the
359 // global default of `//visibility:legacy_public`.
Paul Duffine2453c72019-05-31 14:00:04 +0100360 //
Paul Duffin95d53b52019-07-24 13:45:05 +0100361 // The `visibility` property has no effect on a defaults module although it does
362 // apply to any non-defaults module that uses it. To set the visibility of a
363 // defaults module, use the `defaults_visibility` property on the defaults module;
364 // not to be confused with the `default_visibility` property on the package module.
365 //
Paul Duffin2e61fa62019-03-28 14:10:57 +0000366 // See https://android.googlesource.com/platform/build/soong/+/master/README.md#visibility for
367 // more details.
368 Visibility []string
369
Colin Cross7d5136f2015-05-11 13:39:40 -0700370 // control whether this module compiles for 32-bit, 64-bit, or both. Possible values
Colin Cross3f40fa42015-01-30 17:27:36 -0800371 // are "32" (compile for 32-bit only), "64" (compile for 64-bit only), "both" (compile for both
372 // architectures), or "first" (compile for 64-bit on a 64-bit platform, and 32-bit on a 32-bit
373 // platform
Colin Cross7d716ba2017-11-01 10:38:29 -0700374 Compile_multilib *string `android:"arch_variant"`
Colin Cross69617d32016-09-06 10:39:07 -0700375
376 Target struct {
377 Host struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700378 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700379 }
380 Android struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700381 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700382 }
383 }
384
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000385 // If set to true then the archMutator will create variants for each arch specific target
386 // (e.g. 32/64) that the module is required to produce. If set to false then it will only
387 // create a variant for the architecture and will list the additional arch specific targets
388 // that the variant needs to produce in the CompileMultiTargets property.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700389 UseTargetVariants bool `blueprint:"mutated"`
390 Default_multilib string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800391
Dan Willemsen782a2d12015-12-21 14:55:28 -0800392 // whether this is a proprietary vendor module, and should be installed into /vendor
Colin Cross7d716ba2017-11-01 10:38:29 -0700393 Proprietary *bool
Dan Willemsen782a2d12015-12-21 14:55:28 -0800394
Colin Cross55708f32017-03-20 13:23:34 -0700395 // vendor who owns this module
Dan Willemsenefac4a82017-07-18 19:42:09 -0700396 Owner *string
Colin Cross55708f32017-03-20 13:23:34 -0700397
Jiyong Park2db76922017-11-08 16:03:48 +0900398 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
399 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
400 // Use `soc_specific` instead for better meaning.
Colin Cross7d716ba2017-11-01 10:38:29 -0700401 Vendor *bool
Dan Willemsenaa118f92017-04-06 12:49:58 -0700402
Jiyong Park2db76922017-11-08 16:03:48 +0900403 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
404 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
405 Soc_specific *bool
406
407 // whether this module is specific to a device, not only for SoC, but also for off-chip
408 // peripherals. When set to true, it is installed into /odm (or /vendor/odm if odm partition
409 // does not exist, or /system/vendor/odm if both odm and vendor partitions do not exist).
410 // This implies `soc_specific:true`.
411 Device_specific *bool
412
413 // whether this module is specific to a software configuration of a product (e.g. country,
Jaekyun Seok5cfbfbb2018-01-10 19:00:15 +0900414 // network operator, etc). When set to true, it is installed into /product (or
415 // /system/product if product partition does not exist).
Jiyong Park2db76922017-11-08 16:03:48 +0900416 Product_specific *bool
417
Justin Yund5f6c822019-06-25 16:47:17 +0900418 // whether this module extends system. When set to true, it is installed into /system_ext
419 // (or /system/system_ext if system_ext partition does not exist).
420 System_ext_specific *bool
421
Jiyong Parkf9332f12018-02-01 00:54:12 +0900422 // Whether this module is installed to recovery partition
423 Recovery *bool
424
Yifan Hong1b3348d2020-01-21 15:53:22 -0800425 // Whether this module is installed to ramdisk
426 Ramdisk *bool
427
dimitry1f33e402019-03-26 12:39:31 +0100428 // Whether this module is built for non-native architecures (also known as native bridge binary)
429 Native_bridge_supported *bool `android:"arch_variant"`
430
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700431 // init.rc files to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800432 Init_rc []string `android:"path"`
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700433
Steven Moreland57a23d22018-04-04 15:42:19 -0700434 // VINTF manifest fragments to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800435 Vintf_fragments []string `android:"path"`
Steven Moreland57a23d22018-04-04 15:42:19 -0700436
Chris Wolfe998306e2016-08-15 14:47:23 -0400437 // names of other modules to install if this module is installed
Colin Crossc602b7d2017-05-05 13:36:36 -0700438 Required []string `android:"arch_variant"`
Chris Wolfe998306e2016-08-15 14:47:23 -0400439
Sasha Smundakb6d23052019-04-01 18:37:36 -0700440 // names of other modules to install on host if this module is installed
441 Host_required []string `android:"arch_variant"`
442
443 // names of other modules to install on target if this module is installed
444 Target_required []string `android:"arch_variant"`
445
Colin Cross5aac3622017-08-31 15:07:09 -0700446 // relative path to a file to include in the list of notices for the device
Colin Cross27b922f2019-03-04 22:35:41 -0800447 Notice *string `android:"path"`
Colin Cross5aac3622017-08-31 15:07:09 -0700448
Dan Willemsen569edc52018-11-19 09:33:29 -0800449 Dist struct {
450 // copy the output of this module to the $DIST_DIR when `dist` is specified on the
451 // command line and any of these targets are also on the command line, or otherwise
452 // built
453 Targets []string `android:"arch_variant"`
454
455 // The name of the output artifact. This defaults to the basename of the output of
456 // the module.
457 Dest *string `android:"arch_variant"`
458
459 // The directory within the dist directory to store the artifact. Defaults to the
460 // top level directory ("").
461 Dir *string `android:"arch_variant"`
462
463 // A suffix to add to the artifact file name (before any extension).
464 Suffix *string `android:"arch_variant"`
465 } `android:"arch_variant"`
466
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000467 // The OsType of artifacts that this module variant is responsible for creating.
468 //
469 // Set by osMutator
470 CompileOS OsType `blueprint:"mutated"`
471
472 // The Target of artifacts that this module variant is responsible for creating.
473 //
474 // Set by archMutator
475 CompileTarget Target `blueprint:"mutated"`
476
477 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
478 // responsible for creating.
479 //
480 // By default this is nil as, where necessary, separate variants are created for the
481 // different multilib types supported and that information is encapsulated in the
482 // CompileTarget so the module variant simply needs to create artifacts for that.
483 //
484 // However, if UseTargetVariants is set to false (e.g. by
485 // InitAndroidMultiTargetsArchModule) then no separate variants are created for the
486 // multilib targets. Instead a single variant is created for the architecture and
487 // this contains the multilib specific targets that this variant should create.
488 //
489 // Set by archMutator
Colin Crossee0bc3b2018-10-02 22:01:37 -0700490 CompileMultiTargets []Target `blueprint:"mutated"`
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000491
492 // True if the module variant's CompileTarget is the primary target
493 //
494 // Set by archMutator
495 CompilePrimary bool `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800496
497 // Set by InitAndroidModule
498 HostOrDeviceSupported HostOrDeviceSupported `blueprint:"mutated"`
Dan Willemsen0b24c742016-10-04 15:13:37 -0700499 ArchSpecific bool `blueprint:"mutated"`
Colin Crossce75d2c2016-10-06 16:12:58 -0700500
Paul Duffin1356d8c2020-02-25 19:26:33 +0000501 // If set to true then a CommonOS variant will be created which will have dependencies
502 // on all its OsType specific variants. Used by sdk/module_exports to create a snapshot
503 // that covers all os and architecture variants.
504 //
505 // The OsType specific variants can be retrieved by calling
506 // GetOsSpecificVariantsOfCommonOSVariant
507 //
508 // Set at module initialization time by calling InitCommonOSAndroidMultiTargetsArchModule
509 CreateCommonOSVariant bool `blueprint:"mutated"`
510
511 // If set to true then this variant is the CommonOS variant that has dependencies on its
512 // OsType specific variants.
513 //
514 // Set by osMutator.
515 CommonOSVariant bool `blueprint:"mutated"`
516
Colin Crossce75d2c2016-10-06 16:12:58 -0700517 SkipInstall bool `blueprint:"mutated"`
Jeff Gaston088e29e2017-11-29 16:47:17 -0800518
519 NamespaceExportedToMake bool `blueprint:"mutated"`
Colin Cross6c4f21f2019-06-06 15:41:36 -0700520
521 MissingDeps []string `blueprint:"mutated"`
Colin Cross9a362232019-07-01 15:32:45 -0700522
523 // Name and variant strings stored by mutators to enable Module.String()
524 DebugName string `blueprint:"mutated"`
525 DebugMutators []string `blueprint:"mutated"`
526 DebugVariations []string `blueprint:"mutated"`
Colin Cross7228ecd2019-11-18 16:00:16 -0800527
528 // set by ImageMutator
529 ImageVariation string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800530}
531
532type hostAndDeviceProperties struct {
Colin Cross4e81d702018-11-09 10:36:55 -0800533 // If set to true, build a variant of the module for the host. Defaults to false.
534 Host_supported *bool
535
536 // If set to true, build a variant of the module for the device. Defaults to true.
Colin Crossa4190c12016-07-12 13:11:25 -0700537 Device_supported *bool
Colin Cross3f40fa42015-01-30 17:27:36 -0800538}
539
Colin Crossc472d572015-03-17 15:06:21 -0700540type Multilib string
541
542const (
Colin Cross6b4a32d2017-12-05 13:42:45 -0800543 MultilibBoth Multilib = "both"
544 MultilibFirst Multilib = "first"
545 MultilibCommon Multilib = "common"
546 MultilibCommonFirst Multilib = "common_first"
547 MultilibDefault Multilib = ""
Colin Crossc472d572015-03-17 15:06:21 -0700548)
549
Colin Crossa1ad8d12016-06-01 17:09:44 -0700550type HostOrDeviceSupported int
551
552const (
553 _ HostOrDeviceSupported = iota
Dan Albert0981b5c2018-08-02 13:46:35 -0700554
555 // Host and HostCross are built by default. Device is not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700556 HostSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700557
558 // Host is built by default. HostCross and Device are not supported.
Dan Albertc6345fb2016-10-20 01:36:11 -0700559 HostSupportedNoCross
Dan Albert0981b5c2018-08-02 13:46:35 -0700560
561 // Device is built by default. Host and HostCross are not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700562 DeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700563
564 // Device is built by default. Host and HostCross are supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700565 HostAndDeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700566
567 // Host, HostCross, and Device are built by default.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700568 HostAndDeviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700569
570 // Nothing is supported. This is not exposed to the user, but used to mark a
571 // host only module as unsupported when the module type is not supported on
572 // the host OS. E.g. benchmarks are supported on Linux but not Darwin.
Dan Willemsen0b24c742016-10-04 15:13:37 -0700573 NeitherHostNorDeviceSupported
Colin Crossa1ad8d12016-06-01 17:09:44 -0700574)
575
Jiyong Park2db76922017-11-08 16:03:48 +0900576type moduleKind int
577
578const (
579 platformModule moduleKind = iota
580 deviceSpecificModule
581 socSpecificModule
582 productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900583 systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900584)
585
586func (k moduleKind) String() string {
587 switch k {
588 case platformModule:
589 return "platform"
590 case deviceSpecificModule:
591 return "device-specific"
592 case socSpecificModule:
593 return "soc-specific"
594 case productSpecificModule:
595 return "product-specific"
Justin Yund5f6c822019-06-25 16:47:17 +0900596 case systemExtSpecificModule:
597 return "systemext-specific"
Jiyong Park2db76922017-11-08 16:03:48 +0900598 default:
599 panic(fmt.Errorf("unknown module kind %d", k))
600 }
601}
602
Colin Cross9d34f352019-11-22 16:03:51 -0800603func initAndroidModuleBase(m Module) {
604 m.base().module = m
605}
606
Colin Cross36242852017-06-23 15:06:31 -0700607func InitAndroidModule(m Module) {
Colin Cross9d34f352019-11-22 16:03:51 -0800608 initAndroidModuleBase(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800609 base := m.base()
Colin Cross5049f022015-03-18 13:28:46 -0700610
Colin Cross36242852017-06-23 15:06:31 -0700611 m.AddProperties(
Colin Crossfc754582016-05-17 16:34:16 -0700612 &base.nameProperties,
Colin Cross18c46802019-09-24 22:19:02 -0700613 &base.commonProperties)
614
Colin Crosseabaedd2020-02-06 17:01:55 -0800615 initProductVariableModule(m)
Colin Cross18c46802019-09-24 22:19:02 -0700616
Colin Crossa3a97412019-03-18 12:24:29 -0700617 base.generalProperties = m.GetProperties()
Pirama Arumuga Nainar955dc492018-04-17 14:58:42 -0700618 base.customizableProperties = m.GetProperties()
Paul Duffin63c6e182019-07-24 14:24:38 +0100619
620 // The default_visibility property needs to be checked and parsed by the visibility module during
Paul Duffin5ec73ec2020-05-01 17:52:01 +0100621 // its checking and parsing phases so make it the primary visibility property.
622 setPrimaryVisibilityProperty(m, "visibility", &base.commonProperties.Visibility)
Colin Cross5049f022015-03-18 13:28:46 -0700623}
624
Colin Cross36242852017-06-23 15:06:31 -0700625func InitAndroidArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
626 InitAndroidModule(m)
Colin Cross5049f022015-03-18 13:28:46 -0700627
628 base := m.base()
Colin Cross3f40fa42015-01-30 17:27:36 -0800629 base.commonProperties.HostOrDeviceSupported = hod
Colin Cross69617d32016-09-06 10:39:07 -0700630 base.commonProperties.Default_multilib = string(defaultMultilib)
Dan Willemsen0b24c742016-10-04 15:13:37 -0700631 base.commonProperties.ArchSpecific = true
Colin Crossee0bc3b2018-10-02 22:01:37 -0700632 base.commonProperties.UseTargetVariants = true
Colin Cross3f40fa42015-01-30 17:27:36 -0800633
Dan Willemsen218f6562015-07-08 18:13:11 -0700634 switch hod {
Nan Zhang1a0f09b2017-07-05 10:35:11 -0700635 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Cross36242852017-06-23 15:06:31 -0700636 m.AddProperties(&base.hostAndDeviceProperties)
Colin Cross3f40fa42015-01-30 17:27:36 -0800637 }
638
Colin Cross36242852017-06-23 15:06:31 -0700639 InitArchModule(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800640}
641
Colin Crossee0bc3b2018-10-02 22:01:37 -0700642func InitAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
643 InitAndroidArchModule(m, hod, defaultMultilib)
644 m.base().commonProperties.UseTargetVariants = false
645}
646
Paul Duffin1356d8c2020-02-25 19:26:33 +0000647// As InitAndroidMultiTargetsArchModule except it creates an additional CommonOS variant that
648// has dependencies on all the OsType specific variants.
649func InitCommonOSAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
650 InitAndroidArchModule(m, hod, defaultMultilib)
651 m.base().commonProperties.UseTargetVariants = false
652 m.base().commonProperties.CreateCommonOSVariant = true
653}
654
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800655// A ModuleBase object contains the properties that are common to all Android
Colin Cross3f40fa42015-01-30 17:27:36 -0800656// modules. It should be included as an anonymous field in every module
657// struct definition. InitAndroidModule should then be called from the module's
658// factory function, and the return values from InitAndroidModule should be
659// returned from the factory function.
660//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800661// The ModuleBase type is responsible for implementing the GenerateBuildActions
662// method to support the blueprint.Module interface. This method will then call
663// the module's GenerateAndroidBuildActions method once for each build variant
Colin Cross25de6c32019-06-06 14:29:25 -0700664// that is to be built. GenerateAndroidBuildActions is passed a ModuleContext
665// rather than the usual blueprint.ModuleContext.
666// ModuleContext exposes extra functionality specific to the Android build
Colin Cross3f40fa42015-01-30 17:27:36 -0800667// system including details about the particular build variant that is to be
668// generated.
669//
670// For example:
671//
672// import (
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800673// "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -0800674// )
675//
676// type myModule struct {
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800677// android.ModuleBase
Colin Cross3f40fa42015-01-30 17:27:36 -0800678// properties struct {
679// MyProperty string
680// }
681// }
682//
Colin Cross36242852017-06-23 15:06:31 -0700683// func NewMyModule() android.Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800684// m := &myModule{}
Colin Cross36242852017-06-23 15:06:31 -0700685// m.AddProperties(&m.properties)
686// android.InitAndroidModule(m)
687// return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800688// }
689//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800690// func (m *myModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800691// // Get the CPU architecture for the current build variant.
692// variantArch := ctx.Arch()
693//
694// // ...
695// }
Colin Cross635c3b02016-05-18 15:37:25 -0700696type ModuleBase struct {
Colin Cross3f40fa42015-01-30 17:27:36 -0800697 // Putting the curiously recurring thing pointing to the thing that contains
698 // the thing pattern to good use.
Colin Cross36242852017-06-23 15:06:31 -0700699 // TODO: remove this
Colin Cross635c3b02016-05-18 15:37:25 -0700700 module Module
Colin Cross3f40fa42015-01-30 17:27:36 -0800701
Colin Crossfc754582016-05-17 16:34:16 -0700702 nameProperties nameProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800703 commonProperties commonProperties
Colin Cross18c46802019-09-24 22:19:02 -0700704 variableProperties interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800705 hostAndDeviceProperties hostAndDeviceProperties
706 generalProperties []interface{}
Colin Crossc17727d2018-10-24 12:42:09 -0700707 archProperties [][]interface{}
Colin Crossa120ec12016-08-19 16:07:38 -0700708 customizableProperties []interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800709
Paul Duffin63c6e182019-07-24 14:24:38 +0100710 // Information about all the properties on the module that contains visibility rules that need
711 // checking.
712 visibilityPropertyInfo []visibilityProperty
713
714 // The primary visibility property, may be nil, that controls access to the module.
715 primaryVisibilityProperty visibilityProperty
716
Colin Cross3f40fa42015-01-30 17:27:36 -0800717 noAddressSanitizer bool
Colin Cross897266e2020-02-13 13:22:08 -0800718 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700719 checkbuildFiles Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800720 noticeFiles Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -0700721
722 // Used by buildTargetSingleton to create checkbuild and per-directory build targets
723 // Only set on the final variant of each module
Colin Cross0875c522017-11-28 17:34:01 -0800724 installTarget WritablePath
725 checkbuildTarget WritablePath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700726 blueprintDir string
Colin Crossa120ec12016-08-19 16:07:38 -0700727
Colin Cross178a5092016-09-13 13:42:32 -0700728 hooks hooks
Colin Cross36242852017-06-23 15:06:31 -0700729
730 registerProps []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700731
732 // For tests
Colin Crossae887032017-10-23 17:16:14 -0700733 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800734 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800735 variables map[string]string
Colin Crossa9d8bee2018-10-02 13:59:46 -0700736
Inseob Kim8471cda2019-11-15 09:59:12 +0900737 initRcPaths Paths
738 vintfFragmentsPaths Paths
739
Colin Crossa9d8bee2018-10-02 13:59:46 -0700740 prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool
Colin Cross36242852017-06-23 15:06:31 -0700741}
742
Colin Cross4157e882019-06-06 16:57:04 -0700743func (m *ModuleBase) DepsMutator(BottomUpMutatorContext) {}
Colin Cross5f692ec2019-02-01 16:53:07 -0800744
Colin Cross4157e882019-06-06 16:57:04 -0700745func (m *ModuleBase) AddProperties(props ...interface{}) {
746 m.registerProps = append(m.registerProps, props...)
Colin Cross36242852017-06-23 15:06:31 -0700747}
748
Colin Cross4157e882019-06-06 16:57:04 -0700749func (m *ModuleBase) GetProperties() []interface{} {
750 return m.registerProps
Colin Cross3f40fa42015-01-30 17:27:36 -0800751}
752
Colin Cross4157e882019-06-06 16:57:04 -0700753func (m *ModuleBase) BuildParamsForTests() []BuildParams {
754 return m.buildParams
Colin Crosscec81712017-07-13 14:43:27 -0700755}
756
Colin Cross4157e882019-06-06 16:57:04 -0700757func (m *ModuleBase) RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams {
758 return m.ruleParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800759}
760
Colin Cross4157e882019-06-06 16:57:04 -0700761func (m *ModuleBase) VariablesForTests() map[string]string {
762 return m.variables
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800763}
764
Colin Cross4157e882019-06-06 16:57:04 -0700765func (m *ModuleBase) Prefer32(prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool) {
766 m.prefer32 = prefer32
Colin Crossa9d8bee2018-10-02 13:59:46 -0700767}
768
Colin Crossce75d2c2016-10-06 16:12:58 -0700769// Name returns the name of the module. It may be overridden by individual module types, for
770// example prebuilts will prepend prebuilt_ to the name.
Colin Cross4157e882019-06-06 16:57:04 -0700771func (m *ModuleBase) Name() string {
772 return String(m.nameProperties.Name)
Colin Crossfc754582016-05-17 16:34:16 -0700773}
774
Colin Cross9a362232019-07-01 15:32:45 -0700775// String returns a string that includes the module name and variants for printing during debugging.
776func (m *ModuleBase) String() string {
777 sb := strings.Builder{}
778 sb.WriteString(m.commonProperties.DebugName)
779 sb.WriteString("{")
780 for i := range m.commonProperties.DebugMutators {
781 if i != 0 {
782 sb.WriteString(",")
783 }
784 sb.WriteString(m.commonProperties.DebugMutators[i])
785 sb.WriteString(":")
786 sb.WriteString(m.commonProperties.DebugVariations[i])
787 }
788 sb.WriteString("}")
789 return sb.String()
790}
791
Colin Crossce75d2c2016-10-06 16:12:58 -0700792// BaseModuleName returns the name of the module as specified in the blueprints file.
Colin Cross4157e882019-06-06 16:57:04 -0700793func (m *ModuleBase) BaseModuleName() string {
794 return String(m.nameProperties.Name)
Colin Crossce75d2c2016-10-06 16:12:58 -0700795}
796
Colin Cross4157e882019-06-06 16:57:04 -0700797func (m *ModuleBase) base() *ModuleBase {
798 return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800799}
800
Paul Duffine2453c72019-05-31 14:00:04 +0100801func (m *ModuleBase) qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName {
802 return qualifiedModuleName{pkg: ctx.ModuleDir(), name: ctx.ModuleName()}
803}
804
805func (m *ModuleBase) visibilityProperties() []visibilityProperty {
Paul Duffin63c6e182019-07-24 14:24:38 +0100806 return m.visibilityPropertyInfo
807}
808
Colin Cross4157e882019-06-06 16:57:04 -0700809func (m *ModuleBase) Target() Target {
810 return m.commonProperties.CompileTarget
Dan Willemsen490fd492015-11-24 17:53:15 -0800811}
812
Colin Cross4157e882019-06-06 16:57:04 -0700813func (m *ModuleBase) TargetPrimary() bool {
814 return m.commonProperties.CompilePrimary
Colin Cross8b74d172016-09-13 09:59:14 -0700815}
816
Colin Cross4157e882019-06-06 16:57:04 -0700817func (m *ModuleBase) MultiTargets() []Target {
818 return m.commonProperties.CompileMultiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -0700819}
820
Colin Cross4157e882019-06-06 16:57:04 -0700821func (m *ModuleBase) Os() OsType {
822 return m.Target().Os
Dan Willemsen490fd492015-11-24 17:53:15 -0800823}
824
Colin Cross4157e882019-06-06 16:57:04 -0700825func (m *ModuleBase) Host() bool {
826 return m.Os().Class == Host || m.Os().Class == HostCross
Dan Willemsen97750522016-02-09 17:43:51 -0800827}
828
Colin Cross4157e882019-06-06 16:57:04 -0700829func (m *ModuleBase) Arch() Arch {
830 return m.Target().Arch
Dan Willemsen97750522016-02-09 17:43:51 -0800831}
832
Colin Cross4157e882019-06-06 16:57:04 -0700833func (m *ModuleBase) ArchSpecific() bool {
834 return m.commonProperties.ArchSpecific
Dan Willemsen0b24c742016-10-04 15:13:37 -0700835}
836
Paul Duffin1356d8c2020-02-25 19:26:33 +0000837// True if the current variant is a CommonOS variant, false otherwise.
838func (m *ModuleBase) IsCommonOSVariant() bool {
839 return m.commonProperties.CommonOSVariant
840}
841
Colin Cross4157e882019-06-06 16:57:04 -0700842func (m *ModuleBase) OsClassSupported() []OsClass {
843 switch m.commonProperties.HostOrDeviceSupported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700844 case HostSupported:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700845 return []OsClass{Host, HostCross}
Dan Albertc6345fb2016-10-20 01:36:11 -0700846 case HostSupportedNoCross:
847 return []OsClass{Host}
Colin Crossa1ad8d12016-06-01 17:09:44 -0700848 case DeviceSupported:
849 return []OsClass{Device}
Dan Albert0981b5c2018-08-02 13:46:35 -0700850 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700851 var supported []OsClass
Colin Cross4157e882019-06-06 16:57:04 -0700852 if Bool(m.hostAndDeviceProperties.Host_supported) ||
853 (m.commonProperties.HostOrDeviceSupported == HostAndDeviceDefault &&
854 m.hostAndDeviceProperties.Host_supported == nil) {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700855 supported = append(supported, Host, HostCross)
856 }
Colin Cross4157e882019-06-06 16:57:04 -0700857 if m.hostAndDeviceProperties.Device_supported == nil ||
858 *m.hostAndDeviceProperties.Device_supported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700859 supported = append(supported, Device)
860 }
861 return supported
862 default:
863 return nil
864 }
Colin Cross3f40fa42015-01-30 17:27:36 -0800865}
866
Colin Cross4157e882019-06-06 16:57:04 -0700867func (m *ModuleBase) DeviceSupported() bool {
868 return m.commonProperties.HostOrDeviceSupported == DeviceSupported ||
869 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
870 (m.hostAndDeviceProperties.Device_supported == nil ||
871 *m.hostAndDeviceProperties.Device_supported)
Colin Cross3f40fa42015-01-30 17:27:36 -0800872}
873
Paul Duffine44358f2019-11-26 18:04:12 +0000874func (m *ModuleBase) HostSupported() bool {
875 return m.commonProperties.HostOrDeviceSupported == HostSupported ||
876 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
877 (m.hostAndDeviceProperties.Host_supported != nil &&
878 *m.hostAndDeviceProperties.Host_supported)
879}
880
Colin Cross4157e882019-06-06 16:57:04 -0700881func (m *ModuleBase) Platform() bool {
Justin Yund5f6c822019-06-25 16:47:17 +0900882 return !m.DeviceSpecific() && !m.SocSpecific() && !m.ProductSpecific() && !m.SystemExtSpecific()
Jiyong Parkc678ad32018-04-10 13:07:10 +0900883}
884
Colin Cross4157e882019-06-06 16:57:04 -0700885func (m *ModuleBase) DeviceSpecific() bool {
886 return Bool(m.commonProperties.Device_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900887}
888
Colin Cross4157e882019-06-06 16:57:04 -0700889func (m *ModuleBase) SocSpecific() bool {
890 return Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900891}
892
Colin Cross4157e882019-06-06 16:57:04 -0700893func (m *ModuleBase) ProductSpecific() bool {
894 return Bool(m.commonProperties.Product_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900895}
896
Justin Yund5f6c822019-06-25 16:47:17 +0900897func (m *ModuleBase) SystemExtSpecific() bool {
898 return Bool(m.commonProperties.System_ext_specific)
Dario Frenifd05a742018-05-29 13:28:54 +0100899}
900
Bill Peckhamfff3f8a2020-03-20 18:33:20 -0700901func (m *ModuleBase) PartitionTag(config DeviceConfig) string {
902 partition := "system"
903 if m.SocSpecific() {
904 // A SoC-specific module could be on the vendor partition at
905 // "vendor" or the system partition at "system/vendor".
906 if config.VendorPath() == "vendor" {
907 partition = "vendor"
908 }
909 } else if m.DeviceSpecific() {
910 // A device-specific module could be on the odm partition at
911 // "odm", the vendor partition at "vendor/odm", or the system
912 // partition at "system/vendor/odm".
913 if config.OdmPath() == "odm" {
914 partition = "odm"
Ramy Medhat944839a2020-03-31 22:14:52 -0400915 } else if strings.HasPrefix(config.OdmPath(), "vendor/") {
Bill Peckhamfff3f8a2020-03-20 18:33:20 -0700916 partition = "vendor"
917 }
918 } else if m.ProductSpecific() {
919 // A product-specific module could be on the product partition
920 // at "product" or the system partition at "system/product".
921 if config.ProductPath() == "product" {
922 partition = "product"
923 }
924 } else if m.SystemExtSpecific() {
925 // A system_ext-specific module could be on the system_ext
926 // partition at "system_ext" or the system partition at
927 // "system/system_ext".
928 if config.SystemExtPath() == "system_ext" {
929 partition = "system_ext"
930 }
931 }
932 return partition
933}
934
Colin Cross4157e882019-06-06 16:57:04 -0700935func (m *ModuleBase) Enabled() bool {
936 if m.commonProperties.Enabled == nil {
937 return !m.Os().DefaultDisabled
Dan Willemsen490fd492015-11-24 17:53:15 -0800938 }
Colin Cross4157e882019-06-06 16:57:04 -0700939 return *m.commonProperties.Enabled
Colin Cross3f40fa42015-01-30 17:27:36 -0800940}
941
Inseob Kimeec88e12020-01-22 11:11:29 +0900942func (m *ModuleBase) Disable() {
943 m.commonProperties.Enabled = proptools.BoolPtr(false)
944}
945
Colin Cross4157e882019-06-06 16:57:04 -0700946func (m *ModuleBase) SkipInstall() {
947 m.commonProperties.SkipInstall = true
Colin Crossce75d2c2016-10-06 16:12:58 -0700948}
949
Ulya Trafimovichb28cc372020-01-13 15:18:16 +0000950func (m *ModuleBase) IsSkipInstall() bool {
951 return m.commonProperties.SkipInstall == true
952}
953
Colin Cross4157e882019-06-06 16:57:04 -0700954func (m *ModuleBase) ExportedToMake() bool {
955 return m.commonProperties.NamespaceExportedToMake
Jiyong Park374510b2018-03-19 18:23:01 +0900956}
957
Colin Cross897266e2020-02-13 13:22:08 -0800958func (m *ModuleBase) computeInstallDeps(ctx blueprint.ModuleContext) InstallPaths {
Colin Cross3f40fa42015-01-30 17:27:36 -0800959
Colin Cross897266e2020-02-13 13:22:08 -0800960 var result InstallPaths
Colin Cross6b753602018-06-21 13:03:07 -0700961 // TODO(ccross): we need to use WalkDeps and have some way to know which dependencies require installation
Colin Cross897266e2020-02-13 13:22:08 -0800962 ctx.VisitDepsDepthFirst(func(m blueprint.Module) {
963 if a, ok := m.(Module); ok {
964 result = append(result, a.filesToInstall()...)
965 }
966 })
Colin Cross3f40fa42015-01-30 17:27:36 -0800967
968 return result
969}
970
Colin Cross897266e2020-02-13 13:22:08 -0800971func (m *ModuleBase) filesToInstall() InstallPaths {
Colin Cross4157e882019-06-06 16:57:04 -0700972 return m.installFiles
Colin Cross3f40fa42015-01-30 17:27:36 -0800973}
974
Colin Cross4157e882019-06-06 16:57:04 -0700975func (m *ModuleBase) NoAddressSanitizer() bool {
976 return m.noAddressSanitizer
Colin Cross3f40fa42015-01-30 17:27:36 -0800977}
978
Colin Cross4157e882019-06-06 16:57:04 -0700979func (m *ModuleBase) InstallInData() bool {
Dan Willemsen782a2d12015-12-21 14:55:28 -0800980 return false
981}
982
Jaewoong Jung0949f312019-09-11 10:25:18 -0700983func (m *ModuleBase) InstallInTestcases() bool {
984 return false
985}
986
Colin Cross4157e882019-06-06 16:57:04 -0700987func (m *ModuleBase) InstallInSanitizerDir() bool {
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700988 return false
989}
990
Yifan Hong1b3348d2020-01-21 15:53:22 -0800991func (m *ModuleBase) InstallInRamdisk() bool {
992 return Bool(m.commonProperties.Ramdisk)
993}
994
Colin Cross4157e882019-06-06 16:57:04 -0700995func (m *ModuleBase) InstallInRecovery() bool {
996 return Bool(m.commonProperties.Recovery)
Jiyong Parkf9332f12018-02-01 00:54:12 +0900997}
998
Colin Cross90ba5f42019-10-02 11:10:58 -0700999func (m *ModuleBase) InstallInRoot() bool {
1000 return false
1001}
1002
Colin Cross607d8582019-07-29 16:44:46 -07001003func (m *ModuleBase) InstallBypassMake() bool {
1004 return false
1005}
1006
Colin Cross6e359402020-02-10 15:29:54 -08001007func (m *ModuleBase) InstallForceOS() *OsType {
1008 return nil
1009}
1010
Colin Cross4157e882019-06-06 16:57:04 -07001011func (m *ModuleBase) Owner() string {
1012 return String(m.commonProperties.Owner)
Sundong Ahn4fd04bb2018-08-31 18:01:37 +09001013}
1014
Bob Badoura75b0572020-02-18 20:21:55 -08001015func (m *ModuleBase) NoticeFiles() Paths {
1016 return m.noticeFiles
Jiyong Park52818fc2019-03-18 12:01:38 +09001017}
1018
Colin Cross7228ecd2019-11-18 16:00:16 -08001019func (m *ModuleBase) setImageVariation(variant string) {
1020 m.commonProperties.ImageVariation = variant
1021}
1022
1023func (m *ModuleBase) ImageVariation() blueprint.Variation {
1024 return blueprint.Variation{
1025 Mutator: "image",
1026 Variation: m.base().commonProperties.ImageVariation,
1027 }
1028}
1029
Paul Duffin9b76c0b2020-03-12 10:24:35 +00001030func (m *ModuleBase) getVariationByMutatorName(mutator string) string {
1031 for i, v := range m.commonProperties.DebugMutators {
1032 if v == mutator {
1033 return m.commonProperties.DebugVariations[i]
1034 }
1035 }
1036
1037 return ""
1038}
1039
Yifan Hong1b3348d2020-01-21 15:53:22 -08001040func (m *ModuleBase) InRamdisk() bool {
1041 return m.base().commonProperties.ImageVariation == RamdiskVariation
1042}
1043
Colin Cross7228ecd2019-11-18 16:00:16 -08001044func (m *ModuleBase) InRecovery() bool {
1045 return m.base().commonProperties.ImageVariation == RecoveryVariation
1046}
1047
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09001048func (m *ModuleBase) RequiredModuleNames() []string {
1049 return m.base().commonProperties.Required
1050}
1051
1052func (m *ModuleBase) HostRequiredModuleNames() []string {
1053 return m.base().commonProperties.Host_required
1054}
1055
1056func (m *ModuleBase) TargetRequiredModuleNames() []string {
1057 return m.base().commonProperties.Target_required
1058}
1059
Inseob Kim8471cda2019-11-15 09:59:12 +09001060func (m *ModuleBase) InitRc() Paths {
1061 return append(Paths{}, m.initRcPaths...)
1062}
1063
1064func (m *ModuleBase) VintfFragments() Paths {
1065 return append(Paths{}, m.vintfFragmentsPaths...)
1066}
1067
Colin Cross4157e882019-06-06 16:57:04 -07001068func (m *ModuleBase) generateModuleTarget(ctx ModuleContext) {
Colin Cross897266e2020-02-13 13:22:08 -08001069 var allInstalledFiles InstallPaths
1070 var allCheckbuildFiles Paths
Colin Cross0875c522017-11-28 17:34:01 -08001071 ctx.VisitAllModuleVariants(func(module Module) {
1072 a := module.base()
Colin Crossc9404352015-03-26 16:10:12 -07001073 allInstalledFiles = append(allInstalledFiles, a.installFiles...)
1074 allCheckbuildFiles = append(allCheckbuildFiles, a.checkbuildFiles...)
Colin Cross3f40fa42015-01-30 17:27:36 -08001075 })
1076
Colin Cross0875c522017-11-28 17:34:01 -08001077 var deps Paths
Colin Cross9454bfa2015-03-17 13:24:18 -07001078
Jeff Gaston088e29e2017-11-29 16:47:17 -08001079 namespacePrefix := ctx.Namespace().(*Namespace).id
1080 if namespacePrefix != "" {
1081 namespacePrefix = namespacePrefix + "-"
1082 }
1083
Colin Cross3f40fa42015-01-30 17:27:36 -08001084 if len(allInstalledFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -08001085 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-install")
Colin Cross0875c522017-11-28 17:34:01 -08001086 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001087 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001088 Output: name,
Colin Cross897266e2020-02-13 13:22:08 -08001089 Implicits: allInstalledFiles.Paths(),
Colin Crossaabf6792017-11-29 00:27:14 -08001090 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross9454bfa2015-03-17 13:24:18 -07001091 })
1092 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -07001093 m.installTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -07001094 }
1095
1096 if len(allCheckbuildFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -08001097 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-checkbuild")
Colin Cross0875c522017-11-28 17:34:01 -08001098 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001099 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001100 Output: name,
1101 Implicits: allCheckbuildFiles,
Colin Cross9454bfa2015-03-17 13:24:18 -07001102 })
1103 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -07001104 m.checkbuildTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -07001105 }
1106
1107 if len(deps) > 0 {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001108 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08001109 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001110 suffix = "-soong"
1111 }
1112
Jeff Gaston088e29e2017-11-29 16:47:17 -08001113 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+suffix)
Colin Cross0875c522017-11-28 17:34:01 -08001114 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001115 Rule: blueprint.Phony,
Jeff Gaston088e29e2017-11-29 16:47:17 -08001116 Outputs: []WritablePath{name},
Colin Cross9454bfa2015-03-17 13:24:18 -07001117 Implicits: deps,
Colin Cross3f40fa42015-01-30 17:27:36 -08001118 })
Colin Cross1f8c52b2015-06-16 16:38:17 -07001119
Colin Cross4157e882019-06-06 16:57:04 -07001120 m.blueprintDir = ctx.ModuleDir()
Colin Cross3f40fa42015-01-30 17:27:36 -08001121 }
1122}
1123
Colin Crossc34d2322020-01-03 15:23:27 -08001124func determineModuleKind(m *ModuleBase, ctx blueprint.EarlyModuleContext) moduleKind {
Colin Cross4157e882019-06-06 16:57:04 -07001125 var socSpecific = Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
1126 var deviceSpecific = Bool(m.commonProperties.Device_specific)
1127 var productSpecific = Bool(m.commonProperties.Product_specific)
Justin Yund5f6c822019-06-25 16:47:17 +09001128 var systemExtSpecific = Bool(m.commonProperties.System_ext_specific)
Jiyong Park2db76922017-11-08 16:03:48 +09001129
Dario Frenifd05a742018-05-29 13:28:54 +01001130 msg := "conflicting value set here"
1131 if socSpecific && deviceSpecific {
1132 ctx.PropertyErrorf("device_specific", "a module cannot be specific to SoC and device at the same time.")
Colin Cross4157e882019-06-06 16:57:04 -07001133 if Bool(m.commonProperties.Vendor) {
Jiyong Park2db76922017-11-08 16:03:48 +09001134 ctx.PropertyErrorf("vendor", msg)
1135 }
Colin Cross4157e882019-06-06 16:57:04 -07001136 if Bool(m.commonProperties.Proprietary) {
Jiyong Park2db76922017-11-08 16:03:48 +09001137 ctx.PropertyErrorf("proprietary", msg)
1138 }
Colin Cross4157e882019-06-06 16:57:04 -07001139 if Bool(m.commonProperties.Soc_specific) {
Jiyong Park2db76922017-11-08 16:03:48 +09001140 ctx.PropertyErrorf("soc_specific", msg)
1141 }
1142 }
1143
Justin Yund5f6c822019-06-25 16:47:17 +09001144 if productSpecific && systemExtSpecific {
1145 ctx.PropertyErrorf("product_specific", "a module cannot be specific to product and system_ext at the same time.")
1146 ctx.PropertyErrorf("system_ext_specific", msg)
Dario Frenifd05a742018-05-29 13:28:54 +01001147 }
1148
Justin Yund5f6c822019-06-25 16:47:17 +09001149 if (socSpecific || deviceSpecific) && (productSpecific || systemExtSpecific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001150 if productSpecific {
1151 ctx.PropertyErrorf("product_specific", "a module cannot be specific to SoC or device and product at the same time.")
1152 } else {
Justin Yund5f6c822019-06-25 16:47:17 +09001153 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 +01001154 }
1155 if deviceSpecific {
1156 ctx.PropertyErrorf("device_specific", msg)
1157 } else {
Colin Cross4157e882019-06-06 16:57:04 -07001158 if Bool(m.commonProperties.Vendor) {
Dario Frenifd05a742018-05-29 13:28:54 +01001159 ctx.PropertyErrorf("vendor", msg)
1160 }
Colin Cross4157e882019-06-06 16:57:04 -07001161 if Bool(m.commonProperties.Proprietary) {
Dario Frenifd05a742018-05-29 13:28:54 +01001162 ctx.PropertyErrorf("proprietary", msg)
1163 }
Colin Cross4157e882019-06-06 16:57:04 -07001164 if Bool(m.commonProperties.Soc_specific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001165 ctx.PropertyErrorf("soc_specific", msg)
1166 }
1167 }
1168 }
1169
Jiyong Park2db76922017-11-08 16:03:48 +09001170 if productSpecific {
1171 return productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +09001172 } else if systemExtSpecific {
1173 return systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001174 } else if deviceSpecific {
1175 return deviceSpecificModule
1176 } else if socSpecific {
1177 return socSpecificModule
1178 } else {
1179 return platformModule
1180 }
1181}
1182
Colin Crossc34d2322020-01-03 15:23:27 -08001183func (m *ModuleBase) earlyModuleContextFactory(ctx blueprint.EarlyModuleContext) earlyModuleContext {
Colin Cross1184b642019-12-30 18:43:07 -08001184 return earlyModuleContext{
Colin Crossc34d2322020-01-03 15:23:27 -08001185 EarlyModuleContext: ctx,
1186 kind: determineModuleKind(m, ctx),
1187 config: ctx.Config().(Config),
Colin Cross3f40fa42015-01-30 17:27:36 -08001188 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001189}
1190
Colin Cross1184b642019-12-30 18:43:07 -08001191func (m *ModuleBase) baseModuleContextFactory(ctx blueprint.BaseModuleContext) baseModuleContext {
1192 return baseModuleContext{
1193 bp: ctx,
1194 earlyModuleContext: m.earlyModuleContextFactory(ctx),
1195 os: m.commonProperties.CompileOS,
1196 target: m.commonProperties.CompileTarget,
1197 targetPrimary: m.commonProperties.CompilePrimary,
1198 multiTargets: m.commonProperties.CompileMultiTargets,
1199 }
1200}
1201
Colin Cross4157e882019-06-06 16:57:04 -07001202func (m *ModuleBase) GenerateBuildActions(blueprintCtx blueprint.ModuleContext) {
Colin Cross25de6c32019-06-06 14:29:25 -07001203 ctx := &moduleContext{
Colin Cross0ea8ba82019-06-06 14:33:29 -07001204 module: m.module,
Colin Crossdc35e212019-06-06 16:13:11 -07001205 bp: blueprintCtx,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001206 baseModuleContext: m.baseModuleContextFactory(blueprintCtx),
1207 installDeps: m.computeInstallDeps(blueprintCtx),
1208 installFiles: m.installFiles,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001209 variables: make(map[string]string),
Colin Cross3f40fa42015-01-30 17:27:36 -08001210 }
1211
Colin Cross6c4f21f2019-06-06 15:41:36 -07001212 // Temporarily continue to call blueprintCtx.GetMissingDependencies() to maintain the previous behavior of never
1213 // reporting missing dependency errors in Blueprint when AllowMissingDependencies == true.
1214 // TODO: This will be removed once defaults modules handle missing dependency errors
1215 blueprintCtx.GetMissingDependencies()
1216
Colin Crossdc35e212019-06-06 16:13:11 -07001217 // For the final GenerateAndroidBuildActions pass, require that all visited dependencies Soong modules and
Paul Duffin1356d8c2020-02-25 19:26:33 +00001218 // are enabled. Unless the module is a CommonOS variant which may have dependencies on disabled variants
1219 // (because the dependencies are added before the modules are disabled). The
1220 // GetOsSpecificVariantsOfCommonOSVariant(...) method will ensure that the disabled variants are
1221 // ignored.
1222 ctx.baseModuleContext.strictVisitDeps = !m.IsCommonOSVariant()
Colin Crossdc35e212019-06-06 16:13:11 -07001223
Colin Cross4c83e5c2019-02-25 14:54:28 -08001224 if ctx.config.captureBuild {
1225 ctx.ruleParams = make(map[blueprint.Rule]blueprint.RuleParams)
1226 }
1227
Colin Cross67a5c132017-05-09 13:45:28 -07001228 desc := "//" + ctx.ModuleDir() + ":" + ctx.ModuleName() + " "
1229 var suffix []string
Colin Cross0875c522017-11-28 17:34:01 -08001230 if ctx.Os().Class != Device && ctx.Os().Class != Generic {
1231 suffix = append(suffix, ctx.Os().String())
Colin Cross67a5c132017-05-09 13:45:28 -07001232 }
Colin Cross0875c522017-11-28 17:34:01 -08001233 if !ctx.PrimaryArch() {
1234 suffix = append(suffix, ctx.Arch().ArchType.String())
Colin Cross67a5c132017-05-09 13:45:28 -07001235 }
Dan Willemsenb13a9482020-02-14 11:25:54 -08001236 if apex, ok := m.module.(ApexModule); ok && !apex.IsForPlatform() {
1237 suffix = append(suffix, apex.ApexName())
1238 }
Colin Cross67a5c132017-05-09 13:45:28 -07001239
1240 ctx.Variable(pctx, "moduleDesc", desc)
1241
1242 s := ""
1243 if len(suffix) > 0 {
1244 s = " [" + strings.Join(suffix, " ") + "]"
1245 }
1246 ctx.Variable(pctx, "moduleDescSuffix", s)
1247
Dan Willemsen569edc52018-11-19 09:33:29 -08001248 // Some common property checks for properties that will be used later in androidmk.go
Colin Cross4157e882019-06-06 16:57:04 -07001249 if m.commonProperties.Dist.Dest != nil {
1250 _, err := validateSafePath(*m.commonProperties.Dist.Dest)
Dan Willemsen569edc52018-11-19 09:33:29 -08001251 if err != nil {
1252 ctx.PropertyErrorf("dist.dest", "%s", err.Error())
1253 }
1254 }
Colin Cross4157e882019-06-06 16:57:04 -07001255 if m.commonProperties.Dist.Dir != nil {
1256 _, err := validateSafePath(*m.commonProperties.Dist.Dir)
Dan Willemsen569edc52018-11-19 09:33:29 -08001257 if err != nil {
1258 ctx.PropertyErrorf("dist.dir", "%s", err.Error())
1259 }
1260 }
Colin Cross4157e882019-06-06 16:57:04 -07001261 if m.commonProperties.Dist.Suffix != nil {
1262 if strings.Contains(*m.commonProperties.Dist.Suffix, "/") {
Dan Willemsen569edc52018-11-19 09:33:29 -08001263 ctx.PropertyErrorf("dist.suffix", "Suffix may not contain a '/' character.")
1264 }
1265 }
1266
Colin Cross4157e882019-06-06 16:57:04 -07001267 if m.Enabled() {
Jooyung Hand48f3c32019-08-23 11:18:57 +09001268 // ensure all direct android.Module deps are enabled
1269 ctx.VisitDirectDepsBlueprint(func(bm blueprint.Module) {
1270 if _, ok := bm.(Module); ok {
1271 ctx.validateAndroidModule(bm, ctx.baseModuleContext.strictVisitDeps)
1272 }
1273 })
1274
Bob Badoura75b0572020-02-18 20:21:55 -08001275 m.noticeFiles = make([]Path, 0)
1276 optPath := OptionalPath{}
1277 notice := proptools.StringDefault(m.commonProperties.Notice, "")
Colin Cross4157e882019-06-06 16:57:04 -07001278 if module := SrcIsModule(notice); module != "" {
Bob Badoura75b0572020-02-18 20:21:55 -08001279 optPath = ctx.ExpandOptionalSource(&notice, "notice")
1280 } else if notice != "" {
Jiyong Park52818fc2019-03-18 12:01:38 +09001281 noticePath := filepath.Join(ctx.ModuleDir(), notice)
Bob Badoura75b0572020-02-18 20:21:55 -08001282 optPath = ExistentPathForSource(ctx, noticePath)
1283 }
1284 if optPath.Valid() {
1285 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1286 } else {
1287 for _, notice = range []string{"LICENSE", "LICENCE", "NOTICE"} {
1288 noticePath := filepath.Join(ctx.ModuleDir(), notice)
1289 optPath = ExistentPathForSource(ctx, noticePath)
1290 if optPath.Valid() {
1291 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1292 }
1293 }
Jaewoong Jung62707f72018-11-16 13:26:43 -08001294 }
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001295
1296 m.module.GenerateAndroidBuildActions(ctx)
1297 if ctx.Failed() {
1298 return
1299 }
1300
1301 m.installFiles = append(m.installFiles, ctx.installFiles...)
1302 m.checkbuildFiles = append(m.checkbuildFiles, ctx.checkbuildFiles...)
Inseob Kim8471cda2019-11-15 09:59:12 +09001303 m.initRcPaths = PathsForModuleSrc(ctx, m.commonProperties.Init_rc)
1304 m.vintfFragmentsPaths = PathsForModuleSrc(ctx, m.commonProperties.Vintf_fragments)
Colin Crossdc35e212019-06-06 16:13:11 -07001305 } else if ctx.Config().AllowMissingDependencies() {
1306 // If the module is not enabled it will not create any build rules, nothing will call
1307 // ctx.GetMissingDependencies(), and blueprint will consider the missing dependencies to be unhandled
1308 // and report them as an error even when AllowMissingDependencies = true. Call
1309 // ctx.GetMissingDependencies() here to tell blueprint not to handle them.
1310 ctx.GetMissingDependencies()
Colin Cross3f40fa42015-01-30 17:27:36 -08001311 }
1312
Colin Cross4157e882019-06-06 16:57:04 -07001313 if m == ctx.FinalModule().(Module).base() {
1314 m.generateModuleTarget(ctx)
Colin Cross9b1d13d2016-09-19 15:18:11 -07001315 if ctx.Failed() {
1316 return
1317 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001318 }
Colin Crosscec81712017-07-13 14:43:27 -07001319
Colin Cross4157e882019-06-06 16:57:04 -07001320 m.buildParams = ctx.buildParams
1321 m.ruleParams = ctx.ruleParams
1322 m.variables = ctx.variables
Colin Cross3f40fa42015-01-30 17:27:36 -08001323}
1324
Colin Cross1184b642019-12-30 18:43:07 -08001325type earlyModuleContext struct {
Colin Crossc34d2322020-01-03 15:23:27 -08001326 blueprint.EarlyModuleContext
Colin Cross1184b642019-12-30 18:43:07 -08001327
1328 kind moduleKind
1329 config Config
1330}
1331
1332func (e *earlyModuleContext) Glob(globPattern string, excludes []string) Paths {
1333 ret, err := e.GlobWithDeps(globPattern, excludes)
1334 if err != nil {
1335 e.ModuleErrorf("glob: %s", err.Error())
1336 }
1337 return pathsForModuleSrcFromFullPath(e, ret, true)
1338}
1339
1340func (e *earlyModuleContext) GlobFiles(globPattern string, excludes []string) Paths {
1341 ret, err := e.GlobWithDeps(globPattern, excludes)
1342 if err != nil {
1343 e.ModuleErrorf("glob: %s", err.Error())
1344 }
1345 return pathsForModuleSrcFromFullPath(e, ret, false)
1346}
1347
Colin Cross988414c2020-01-11 01:11:46 +00001348func (b *earlyModuleContext) IsSymlink(path Path) bool {
1349 fileInfo, err := b.config.fs.Lstat(path.String())
1350 if err != nil {
1351 b.ModuleErrorf("os.Lstat(%q) failed: %s", path.String(), err)
1352 }
1353 return fileInfo.Mode()&os.ModeSymlink == os.ModeSymlink
1354}
1355
1356func (b *earlyModuleContext) Readlink(path Path) string {
1357 dest, err := b.config.fs.Readlink(path.String())
1358 if err != nil {
1359 b.ModuleErrorf("os.Readlink(%q) failed: %s", path.String(), err)
1360 }
1361 return dest
1362}
1363
Colin Cross1184b642019-12-30 18:43:07 -08001364func (e *earlyModuleContext) Module() Module {
Colin Crossc34d2322020-01-03 15:23:27 -08001365 module, _ := e.EarlyModuleContext.Module().(Module)
Colin Cross1184b642019-12-30 18:43:07 -08001366 return module
1367}
1368
1369func (e *earlyModuleContext) Config() Config {
Colin Crossc34d2322020-01-03 15:23:27 -08001370 return e.EarlyModuleContext.Config().(Config)
Colin Cross1184b642019-12-30 18:43:07 -08001371}
1372
1373func (e *earlyModuleContext) AConfig() Config {
1374 return e.config
1375}
1376
1377func (e *earlyModuleContext) DeviceConfig() DeviceConfig {
1378 return DeviceConfig{e.config.deviceConfig}
1379}
1380
1381func (e *earlyModuleContext) Platform() bool {
1382 return e.kind == platformModule
1383}
1384
1385func (e *earlyModuleContext) DeviceSpecific() bool {
1386 return e.kind == deviceSpecificModule
1387}
1388
1389func (e *earlyModuleContext) SocSpecific() bool {
1390 return e.kind == socSpecificModule
1391}
1392
1393func (e *earlyModuleContext) ProductSpecific() bool {
1394 return e.kind == productSpecificModule
1395}
1396
1397func (e *earlyModuleContext) SystemExtSpecific() bool {
1398 return e.kind == systemExtSpecificModule
1399}
1400
1401type baseModuleContext struct {
1402 bp blueprint.BaseModuleContext
1403 earlyModuleContext
Colin Crossfb0c16e2019-11-20 17:12:35 -08001404 os OsType
Colin Cross8b74d172016-09-13 09:59:14 -07001405 target Target
Colin Crossee0bc3b2018-10-02 22:01:37 -07001406 multiTargets []Target
Colin Cross8b74d172016-09-13 09:59:14 -07001407 targetPrimary bool
1408 debug bool
Colin Crossdc35e212019-06-06 16:13:11 -07001409
1410 walkPath []Module
Paul Duffinc5192442020-03-31 11:31:36 +01001411 tagPath []blueprint.DependencyTag
Colin Crossdc35e212019-06-06 16:13:11 -07001412
1413 strictVisitDeps bool // If true, enforce that all dependencies are enabled
Colin Crossf6566ed2015-03-24 11:13:38 -07001414}
1415
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001416func (b *baseModuleContext) OtherModuleName(m blueprint.Module) string {
1417 return b.bp.OtherModuleName(m)
1418}
1419func (b *baseModuleContext) OtherModuleDir(m blueprint.Module) string { return b.bp.OtherModuleDir(m) }
Colin Cross1184b642019-12-30 18:43:07 -08001420func (b *baseModuleContext) OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{}) {
Jooyung Hancd87c692020-02-26 02:05:18 +09001421 b.bp.OtherModuleErrorf(m, fmt, args...)
Colin Cross1184b642019-12-30 18:43:07 -08001422}
1423func (b *baseModuleContext) OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag {
1424 return b.bp.OtherModuleDependencyTag(m)
1425}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001426func (b *baseModuleContext) OtherModuleExists(name string) bool { return b.bp.OtherModuleExists(name) }
1427func (b *baseModuleContext) OtherModuleType(m blueprint.Module) string {
1428 return b.bp.OtherModuleType(m)
1429}
Colin Cross1184b642019-12-30 18:43:07 -08001430
1431func (b *baseModuleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1432 return b.bp.GetDirectDepWithTag(name, tag)
1433}
1434
Colin Cross25de6c32019-06-06 14:29:25 -07001435type moduleContext struct {
Colin Crossdc35e212019-06-06 16:13:11 -07001436 bp blueprint.ModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -07001437 baseModuleContext
Colin Cross897266e2020-02-13 13:22:08 -08001438 installDeps InstallPaths
1439 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001440 checkbuildFiles Paths
Colin Cross8d8f8e22016-08-03 11:57:50 -07001441 module Module
Colin Crosscec81712017-07-13 14:43:27 -07001442
1443 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001444 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001445 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001446 variables map[string]string
Colin Cross6ff51382015-12-17 16:39:19 -08001447}
1448
Colin Crossb88b3c52019-06-10 15:15:17 -07001449func (m *moduleContext) ninjaError(params BuildParams, err error) (PackageContext, BuildParams) {
1450 return pctx, BuildParams{
Colin Cross4b69c492019-06-07 13:06:06 -07001451 Rule: ErrorRule,
1452 Description: params.Description,
1453 Output: params.Output,
1454 Outputs: params.Outputs,
1455 ImplicitOutput: params.ImplicitOutput,
1456 ImplicitOutputs: params.ImplicitOutputs,
Colin Cross6ff51382015-12-17 16:39:19 -08001457 Args: map[string]string{
1458 "error": err.Error(),
1459 },
Colin Crossb88b3c52019-06-10 15:15:17 -07001460 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001461}
1462
Colin Cross25de6c32019-06-06 14:29:25 -07001463func (m *moduleContext) ModuleBuild(pctx PackageContext, params ModuleBuildParams) {
1464 m.Build(pctx, BuildParams(params))
Colin Cross3f40fa42015-01-30 17:27:36 -08001465}
1466
Colin Cross0875c522017-11-28 17:34:01 -08001467func convertBuildParams(params BuildParams) blueprint.BuildParams {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001468 bparams := blueprint.BuildParams{
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001469 Rule: params.Rule,
Colin Cross0875c522017-11-28 17:34:01 -08001470 Description: params.Description,
Colin Cross33bfb0a2016-11-21 17:23:08 -08001471 Deps: params.Deps,
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001472 Outputs: params.Outputs.Strings(),
1473 ImplicitOutputs: params.ImplicitOutputs.Strings(),
1474 Inputs: params.Inputs.Strings(),
1475 Implicits: params.Implicits.Strings(),
1476 OrderOnly: params.OrderOnly.Strings(),
1477 Args: params.Args,
1478 Optional: !params.Default,
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001479 }
1480
Colin Cross33bfb0a2016-11-21 17:23:08 -08001481 if params.Depfile != nil {
1482 bparams.Depfile = params.Depfile.String()
1483 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001484 if params.Output != nil {
1485 bparams.Outputs = append(bparams.Outputs, params.Output.String())
1486 }
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001487 if params.ImplicitOutput != nil {
1488 bparams.ImplicitOutputs = append(bparams.ImplicitOutputs, params.ImplicitOutput.String())
1489 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001490 if params.Input != nil {
1491 bparams.Inputs = append(bparams.Inputs, params.Input.String())
1492 }
1493 if params.Implicit != nil {
1494 bparams.Implicits = append(bparams.Implicits, params.Implicit.String())
1495 }
1496
Colin Cross0b9f31f2019-02-28 11:00:01 -08001497 bparams.Outputs = proptools.NinjaEscapeList(bparams.Outputs)
1498 bparams.ImplicitOutputs = proptools.NinjaEscapeList(bparams.ImplicitOutputs)
1499 bparams.Inputs = proptools.NinjaEscapeList(bparams.Inputs)
1500 bparams.Implicits = proptools.NinjaEscapeList(bparams.Implicits)
1501 bparams.OrderOnly = proptools.NinjaEscapeList(bparams.OrderOnly)
1502 bparams.Depfile = proptools.NinjaEscapeList([]string{bparams.Depfile})[0]
Colin Crossfe4bc362018-09-12 10:02:13 -07001503
Colin Cross0875c522017-11-28 17:34:01 -08001504 return bparams
1505}
1506
Colin Cross25de6c32019-06-06 14:29:25 -07001507func (m *moduleContext) Variable(pctx PackageContext, name, value string) {
1508 if m.config.captureBuild {
1509 m.variables[name] = value
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001510 }
1511
Colin Crossdc35e212019-06-06 16:13:11 -07001512 m.bp.Variable(pctx.PackageContext, name, value)
Colin Cross0875c522017-11-28 17:34:01 -08001513}
1514
Colin Cross25de6c32019-06-06 14:29:25 -07001515func (m *moduleContext) Rule(pctx PackageContext, name string, params blueprint.RuleParams,
Colin Cross0875c522017-11-28 17:34:01 -08001516 argNames ...string) blueprint.Rule {
1517
Ramy Medhat944839a2020-03-31 22:14:52 -04001518 if m.config.UseRemoteBuild() {
1519 if params.Pool == nil {
1520 // When USE_GOMA=true or USE_RBE=true are set and the rule is not supported by goma/RBE, restrict
1521 // jobs to the local parallelism value
1522 params.Pool = localPool
1523 } else if params.Pool == remotePool {
1524 // remotePool is a fake pool used to identify rule that are supported for remoting. If the rule's
1525 // pool is the remotePool, replace with nil so that ninja runs it at NINJA_REMOTE_NUM_JOBS
1526 // parallelism.
1527 params.Pool = nil
1528 }
Colin Cross2e2dbc22019-09-25 13:31:46 -07001529 }
1530
Colin Crossdc35e212019-06-06 16:13:11 -07001531 rule := m.bp.Rule(pctx.PackageContext, name, params, argNames...)
Colin Cross4c83e5c2019-02-25 14:54:28 -08001532
Colin Cross25de6c32019-06-06 14:29:25 -07001533 if m.config.captureBuild {
1534 m.ruleParams[rule] = params
Colin Cross4c83e5c2019-02-25 14:54:28 -08001535 }
1536
1537 return rule
Colin Cross0875c522017-11-28 17:34:01 -08001538}
1539
Colin Cross25de6c32019-06-06 14:29:25 -07001540func (m *moduleContext) Build(pctx PackageContext, params BuildParams) {
Colin Crossb88b3c52019-06-10 15:15:17 -07001541 if params.Description != "" {
1542 params.Description = "${moduleDesc}" + params.Description + "${moduleDescSuffix}"
1543 }
1544
1545 if missingDeps := m.GetMissingDependencies(); len(missingDeps) > 0 {
1546 pctx, params = m.ninjaError(params, fmt.Errorf("module %s missing dependencies: %s\n",
1547 m.ModuleName(), strings.Join(missingDeps, ", ")))
1548 }
1549
Colin Cross25de6c32019-06-06 14:29:25 -07001550 if m.config.captureBuild {
1551 m.buildParams = append(m.buildParams, params)
Colin Cross0875c522017-11-28 17:34:01 -08001552 }
1553
Colin Crossdc35e212019-06-06 16:13:11 -07001554 m.bp.Build(pctx.PackageContext, convertBuildParams(params))
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001555}
Colin Cross25de6c32019-06-06 14:29:25 -07001556func (m *moduleContext) GetMissingDependencies() []string {
Colin Cross6c4f21f2019-06-06 15:41:36 -07001557 var missingDeps []string
1558 missingDeps = append(missingDeps, m.Module().base().commonProperties.MissingDeps...)
Colin Crossdc35e212019-06-06 16:13:11 -07001559 missingDeps = append(missingDeps, m.bp.GetMissingDependencies()...)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001560 missingDeps = FirstUniqueStrings(missingDeps)
1561 return missingDeps
Colin Cross6ff51382015-12-17 16:39:19 -08001562}
1563
Colin Crossdc35e212019-06-06 16:13:11 -07001564func (b *baseModuleContext) AddMissingDependencies(deps []string) {
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001565 if deps != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001566 missingDeps := &b.Module().base().commonProperties.MissingDeps
Colin Cross6c4f21f2019-06-06 15:41:36 -07001567 *missingDeps = append(*missingDeps, deps...)
1568 *missingDeps = FirstUniqueStrings(*missingDeps)
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001569 }
1570}
1571
Colin Crossdc35e212019-06-06 16:13:11 -07001572func (b *baseModuleContext) validateAndroidModule(module blueprint.Module, strict bool) Module {
Colin Crossd11fcda2017-10-23 17:59:01 -07001573 aModule, _ := module.(Module)
Colin Crossdc35e212019-06-06 16:13:11 -07001574
1575 if !strict {
1576 return aModule
1577 }
1578
Colin Cross380c69a2019-06-10 17:49:58 +00001579 if aModule == nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001580 b.ModuleErrorf("module %q not an android module", b.OtherModuleName(module))
Colin Cross380c69a2019-06-10 17:49:58 +00001581 return nil
1582 }
1583
1584 if !aModule.Enabled() {
Colin Crossdc35e212019-06-06 16:13:11 -07001585 if b.Config().AllowMissingDependencies() {
1586 b.AddMissingDependencies([]string{b.OtherModuleName(aModule)})
Colin Cross380c69a2019-06-10 17:49:58 +00001587 } else {
Colin Crossdc35e212019-06-06 16:13:11 -07001588 b.ModuleErrorf("depends on disabled module %q", b.OtherModuleName(aModule))
Colin Cross380c69a2019-06-10 17:49:58 +00001589 }
1590 return nil
1591 }
Colin Crossd11fcda2017-10-23 17:59:01 -07001592 return aModule
1593}
1594
Colin Crossdc35e212019-06-06 16:13:11 -07001595func (b *baseModuleContext) getDirectDepInternal(name string, tag blueprint.DependencyTag) (blueprint.Module, blueprint.DependencyTag) {
Jiyong Parkf2976302019-04-17 21:47:37 +09001596 type dep struct {
1597 mod blueprint.Module
1598 tag blueprint.DependencyTag
1599 }
1600 var deps []dep
Colin Crossdc35e212019-06-06 16:13:11 -07001601 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001602 if aModule, _ := module.(Module); aModule != nil && aModule.base().BaseModuleName() == name {
Colin Cross1184b642019-12-30 18:43:07 -08001603 returnedTag := b.bp.OtherModuleDependencyTag(aModule)
Jiyong Parkf2976302019-04-17 21:47:37 +09001604 if tag == nil || returnedTag == tag {
1605 deps = append(deps, dep{aModule, returnedTag})
1606 }
1607 }
1608 })
1609 if len(deps) == 1 {
1610 return deps[0].mod, deps[0].tag
1611 } else if len(deps) >= 2 {
1612 panic(fmt.Errorf("Multiple dependencies having same BaseModuleName() %q found from %q",
Colin Crossdc35e212019-06-06 16:13:11 -07001613 name, b.ModuleName()))
Jiyong Parkf2976302019-04-17 21:47:37 +09001614 } else {
1615 return nil, nil
1616 }
1617}
1618
Colin Crossdc35e212019-06-06 16:13:11 -07001619func (b *baseModuleContext) GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module {
Colin Cross0ef08162019-05-01 15:50:51 -07001620 var deps []Module
Colin Crossdc35e212019-06-06 16:13:11 -07001621 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001622 if aModule, _ := module.(Module); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001623 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Cross0ef08162019-05-01 15:50:51 -07001624 deps = append(deps, aModule)
1625 }
1626 }
1627 })
1628 return deps
1629}
1630
Colin Cross25de6c32019-06-06 14:29:25 -07001631func (m *moduleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1632 module, _ := m.getDirectDepInternal(name, tag)
1633 return module
Jiyong Parkf2976302019-04-17 21:47:37 +09001634}
1635
Colin Crossdc35e212019-06-06 16:13:11 -07001636func (b *baseModuleContext) GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag) {
1637 return b.getDirectDepInternal(name, nil)
Jiyong Parkf2976302019-04-17 21:47:37 +09001638}
1639
Colin Crossdc35e212019-06-06 16:13:11 -07001640func (b *baseModuleContext) VisitDirectDepsBlueprint(visit func(blueprint.Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001641 b.bp.VisitDirectDeps(visit)
Colin Cross35143d02017-11-16 00:11:20 -08001642}
1643
Colin Crossdc35e212019-06-06 16:13:11 -07001644func (b *baseModuleContext) VisitDirectDeps(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001645 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001646 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001647 visit(aModule)
1648 }
1649 })
1650}
1651
Colin Crossdc35e212019-06-06 16:13:11 -07001652func (b *baseModuleContext) VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001653 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001654 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001655 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Crossee6143c2017-12-30 17:54:27 -08001656 visit(aModule)
1657 }
1658 }
1659 })
1660}
1661
Colin Crossdc35e212019-06-06 16:13:11 -07001662func (b *baseModuleContext) VisitDirectDepsIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001663 b.bp.VisitDirectDepsIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001664 // pred
1665 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001666 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001667 return pred(aModule)
1668 } else {
1669 return false
1670 }
1671 },
1672 // visit
1673 func(module blueprint.Module) {
1674 visit(module.(Module))
1675 })
1676}
1677
Colin Crossdc35e212019-06-06 16:13:11 -07001678func (b *baseModuleContext) VisitDepsDepthFirst(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001679 b.bp.VisitDepsDepthFirst(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001680 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001681 visit(aModule)
1682 }
1683 })
1684}
1685
Colin Crossdc35e212019-06-06 16:13:11 -07001686func (b *baseModuleContext) VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001687 b.bp.VisitDepsDepthFirstIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001688 // pred
1689 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001690 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001691 return pred(aModule)
1692 } else {
1693 return false
1694 }
1695 },
1696 // visit
1697 func(module blueprint.Module) {
1698 visit(module.(Module))
1699 })
1700}
1701
Colin Crossdc35e212019-06-06 16:13:11 -07001702func (b *baseModuleContext) WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool) {
Colin Cross1184b642019-12-30 18:43:07 -08001703 b.bp.WalkDeps(visit)
Alex Light778127a2019-02-27 14:19:50 -08001704}
1705
Colin Crossdc35e212019-06-06 16:13:11 -07001706func (b *baseModuleContext) WalkDeps(visit func(Module, Module) bool) {
1707 b.walkPath = []Module{b.Module()}
Paul Duffinc5192442020-03-31 11:31:36 +01001708 b.tagPath = []blueprint.DependencyTag{}
Colin Cross1184b642019-12-30 18:43:07 -08001709 b.bp.WalkDeps(func(child, parent blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001710 childAndroidModule, _ := child.(Module)
1711 parentAndroidModule, _ := parent.(Module)
Colin Crossd11fcda2017-10-23 17:59:01 -07001712 if childAndroidModule != nil && parentAndroidModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001713 // record walkPath before visit
1714 for b.walkPath[len(b.walkPath)-1] != parentAndroidModule {
1715 b.walkPath = b.walkPath[0 : len(b.walkPath)-1]
Paul Duffinc5192442020-03-31 11:31:36 +01001716 b.tagPath = b.tagPath[0 : len(b.tagPath)-1]
Colin Crossdc35e212019-06-06 16:13:11 -07001717 }
1718 b.walkPath = append(b.walkPath, childAndroidModule)
Paul Duffinc5192442020-03-31 11:31:36 +01001719 b.tagPath = append(b.tagPath, b.OtherModuleDependencyTag(childAndroidModule))
Colin Crossd11fcda2017-10-23 17:59:01 -07001720 return visit(childAndroidModule, parentAndroidModule)
1721 } else {
1722 return false
1723 }
1724 })
1725}
1726
Colin Crossdc35e212019-06-06 16:13:11 -07001727func (b *baseModuleContext) GetWalkPath() []Module {
1728 return b.walkPath
1729}
1730
Paul Duffinc5192442020-03-31 11:31:36 +01001731func (b *baseModuleContext) GetTagPath() []blueprint.DependencyTag {
1732 return b.tagPath
1733}
1734
Jiyong Park1c7e9622020-05-07 16:12:13 +09001735// A regexp for removing boilerplate from BaseDependencyTag from the string representation of
1736// a dependency tag.
1737var tagCleaner = regexp.MustCompile(`\QBaseDependencyTag:blueprint.BaseDependencyTag{}\E(, )?`)
1738
1739// PrettyPrintTag returns string representation of the tag, but prefers
1740// custom String() method if available.
1741func PrettyPrintTag(tag blueprint.DependencyTag) string {
1742 // Use tag's custom String() method if available.
1743 if stringer, ok := tag.(fmt.Stringer); ok {
1744 return stringer.String()
1745 }
1746
1747 // Otherwise, get a default string representation of the tag's struct.
1748 tagString := fmt.Sprintf("%#v", tag)
1749
1750 // Remove the boilerplate from BaseDependencyTag as it adds no value.
1751 tagString = tagCleaner.ReplaceAllString(tagString, "")
1752 return tagString
1753}
1754
1755func (b *baseModuleContext) GetPathString(skipFirst bool) string {
1756 sb := strings.Builder{}
1757 tagPath := b.GetTagPath()
1758 walkPath := b.GetWalkPath()
1759 if !skipFirst {
1760 sb.WriteString(walkPath[0].String())
1761 }
1762 for i, m := range walkPath[1:] {
1763 sb.WriteString("\n")
1764 sb.WriteString(fmt.Sprintf(" via tag %s\n", PrettyPrintTag(tagPath[i])))
1765 sb.WriteString(fmt.Sprintf(" -> %s", m.String()))
1766 }
1767 return sb.String()
1768}
1769
Colin Cross25de6c32019-06-06 14:29:25 -07001770func (m *moduleContext) VisitAllModuleVariants(visit func(Module)) {
Colin Crossdc35e212019-06-06 16:13:11 -07001771 m.bp.VisitAllModuleVariants(func(module blueprint.Module) {
Colin Cross0875c522017-11-28 17:34:01 -08001772 visit(module.(Module))
1773 })
1774}
1775
Colin Cross25de6c32019-06-06 14:29:25 -07001776func (m *moduleContext) PrimaryModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001777 return m.bp.PrimaryModule().(Module)
Colin Cross0875c522017-11-28 17:34:01 -08001778}
1779
Colin Cross25de6c32019-06-06 14:29:25 -07001780func (m *moduleContext) FinalModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001781 return m.bp.FinalModule().(Module)
1782}
1783
1784func (m *moduleContext) ModuleSubDir() string {
1785 return m.bp.ModuleSubDir()
Colin Cross0875c522017-11-28 17:34:01 -08001786}
1787
Colin Cross0ea8ba82019-06-06 14:33:29 -07001788func (b *baseModuleContext) Target() Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001789 return b.target
Colin Crossa1ad8d12016-06-01 17:09:44 -07001790}
1791
Colin Cross0ea8ba82019-06-06 14:33:29 -07001792func (b *baseModuleContext) TargetPrimary() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001793 return b.targetPrimary
Colin Cross8b74d172016-09-13 09:59:14 -07001794}
1795
Colin Cross0ea8ba82019-06-06 14:33:29 -07001796func (b *baseModuleContext) MultiTargets() []Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001797 return b.multiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07001798}
1799
Colin Cross0ea8ba82019-06-06 14:33:29 -07001800func (b *baseModuleContext) Arch() Arch {
Colin Cross25de6c32019-06-06 14:29:25 -07001801 return b.target.Arch
Colin Cross3f40fa42015-01-30 17:27:36 -08001802}
1803
Colin Cross0ea8ba82019-06-06 14:33:29 -07001804func (b *baseModuleContext) Os() OsType {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001805 return b.os
Dan Willemsen490fd492015-11-24 17:53:15 -08001806}
1807
Colin Cross0ea8ba82019-06-06 14:33:29 -07001808func (b *baseModuleContext) Host() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001809 return b.os.Class == Host || b.os.Class == HostCross
Colin Crossf6566ed2015-03-24 11:13:38 -07001810}
1811
Colin Cross0ea8ba82019-06-06 14:33:29 -07001812func (b *baseModuleContext) Device() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001813 return b.os.Class == Device
Colin Crossf6566ed2015-03-24 11:13:38 -07001814}
1815
Colin Cross0ea8ba82019-06-06 14:33:29 -07001816func (b *baseModuleContext) Darwin() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001817 return b.os == Darwin
Colin Cross0af4b842015-04-30 16:36:18 -07001818}
1819
Colin Cross0ea8ba82019-06-06 14:33:29 -07001820func (b *baseModuleContext) Fuchsia() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001821 return b.os == Fuchsia
Doug Horn21b94272019-01-16 12:06:11 -08001822}
1823
Colin Cross0ea8ba82019-06-06 14:33:29 -07001824func (b *baseModuleContext) Windows() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001825 return b.os == Windows
Colin Cross3edeee12017-04-04 12:59:48 -07001826}
1827
Colin Cross0ea8ba82019-06-06 14:33:29 -07001828func (b *baseModuleContext) Debug() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001829 return b.debug
Colin Crossf6566ed2015-03-24 11:13:38 -07001830}
1831
Colin Cross0ea8ba82019-06-06 14:33:29 -07001832func (b *baseModuleContext) PrimaryArch() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001833 if len(b.config.Targets[b.target.Os]) <= 1 {
Colin Cross67a5c132017-05-09 13:45:28 -07001834 return true
1835 }
Colin Cross25de6c32019-06-06 14:29:25 -07001836 return b.target.Arch.ArchType == b.config.Targets[b.target.Os][0].Arch.ArchType
Colin Cross1e7d3702016-08-24 15:25:47 -07001837}
1838
Jiyong Park5baac542018-08-28 09:55:37 +09001839// Makes this module a platform module, i.e. not specific to soc, device,
Justin Yund5f6c822019-06-25 16:47:17 +09001840// product, or system_ext.
Colin Cross4157e882019-06-06 16:57:04 -07001841func (m *ModuleBase) MakeAsPlatform() {
1842 m.commonProperties.Vendor = boolPtr(false)
1843 m.commonProperties.Proprietary = boolPtr(false)
1844 m.commonProperties.Soc_specific = boolPtr(false)
1845 m.commonProperties.Product_specific = boolPtr(false)
Justin Yund5f6c822019-06-25 16:47:17 +09001846 m.commonProperties.System_ext_specific = boolPtr(false)
Jiyong Park5baac542018-08-28 09:55:37 +09001847}
1848
Colin Cross4157e882019-06-06 16:57:04 -07001849func (m *ModuleBase) EnableNativeBridgeSupportByDefault() {
1850 m.commonProperties.Native_bridge_supported = boolPtr(true)
dimitry03dc3f62019-05-09 14:07:34 +02001851}
1852
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001853func (m *ModuleBase) MakeAsSystemExt() {
Jooyung Han91df2082019-11-20 01:49:42 +09001854 m.commonProperties.Vendor = boolPtr(false)
1855 m.commonProperties.Proprietary = boolPtr(false)
1856 m.commonProperties.Soc_specific = boolPtr(false)
1857 m.commonProperties.Product_specific = boolPtr(false)
1858 m.commonProperties.System_ext_specific = boolPtr(true)
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001859}
1860
Jooyung Han344d5432019-08-23 11:17:39 +09001861// IsNativeBridgeSupported returns true if "native_bridge_supported" is explicitly set as "true"
1862func (m *ModuleBase) IsNativeBridgeSupported() bool {
1863 return proptools.Bool(m.commonProperties.Native_bridge_supported)
1864}
1865
Colin Cross25de6c32019-06-06 14:29:25 -07001866func (m *moduleContext) InstallInData() bool {
1867 return m.module.InstallInData()
Dan Willemsen782a2d12015-12-21 14:55:28 -08001868}
1869
Jaewoong Jung0949f312019-09-11 10:25:18 -07001870func (m *moduleContext) InstallInTestcases() bool {
1871 return m.module.InstallInTestcases()
1872}
1873
Colin Cross25de6c32019-06-06 14:29:25 -07001874func (m *moduleContext) InstallInSanitizerDir() bool {
1875 return m.module.InstallInSanitizerDir()
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001876}
1877
Yifan Hong1b3348d2020-01-21 15:53:22 -08001878func (m *moduleContext) InstallInRamdisk() bool {
1879 return m.module.InstallInRamdisk()
1880}
1881
Colin Cross25de6c32019-06-06 14:29:25 -07001882func (m *moduleContext) InstallInRecovery() bool {
1883 return m.module.InstallInRecovery()
Jiyong Parkf9332f12018-02-01 00:54:12 +09001884}
1885
Colin Cross90ba5f42019-10-02 11:10:58 -07001886func (m *moduleContext) InstallInRoot() bool {
1887 return m.module.InstallInRoot()
1888}
1889
Colin Cross607d8582019-07-29 16:44:46 -07001890func (m *moduleContext) InstallBypassMake() bool {
1891 return m.module.InstallBypassMake()
1892}
1893
Colin Cross6e359402020-02-10 15:29:54 -08001894func (m *moduleContext) InstallForceOS() *OsType {
1895 return m.module.InstallForceOS()
1896}
1897
Colin Cross70dda7e2019-10-01 22:05:35 -07001898func (m *moduleContext) skipInstall(fullInstallPath InstallPath) bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001899 if m.module.base().commonProperties.SkipInstall {
Colin Cross893d8162017-04-26 17:34:03 -07001900 return true
1901 }
1902
Colin Cross3607f212018-05-07 15:28:05 -07001903 // We'll need a solution for choosing which of modules with the same name in different
1904 // namespaces to install. For now, reuse the list of namespaces exported to Make as the
1905 // list of namespaces to install in a Soong-only build.
Colin Cross25de6c32019-06-06 14:29:25 -07001906 if !m.module.base().commonProperties.NamespaceExportedToMake {
Colin Cross3607f212018-05-07 15:28:05 -07001907 return true
1908 }
1909
Colin Cross25de6c32019-06-06 14:29:25 -07001910 if m.Device() {
Colin Cross607d8582019-07-29 16:44:46 -07001911 if m.Config().EmbeddedInMake() && !m.InstallBypassMake() {
Colin Cross893d8162017-04-26 17:34:03 -07001912 return true
1913 }
1914
Colin Cross25de6c32019-06-06 14:29:25 -07001915 if m.Config().SkipMegaDeviceInstall(fullInstallPath.String()) {
Colin Cross893d8162017-04-26 17:34:03 -07001916 return true
1917 }
1918 }
1919
1920 return false
1921}
1922
Colin Cross70dda7e2019-10-01 22:05:35 -07001923func (m *moduleContext) InstallFile(installPath InstallPath, name string, srcPath Path,
1924 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001925 return m.installFile(installPath, name, srcPath, Cp, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001926}
1927
Colin Cross70dda7e2019-10-01 22:05:35 -07001928func (m *moduleContext) InstallExecutable(installPath InstallPath, name string, srcPath Path,
1929 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001930 return m.installFile(installPath, name, srcPath, CpExecutable, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001931}
1932
Colin Cross70dda7e2019-10-01 22:05:35 -07001933func (m *moduleContext) installFile(installPath InstallPath, name string, srcPath Path,
1934 rule blueprint.Rule, deps []Path) InstallPath {
Colin Cross35cec122015-04-02 14:37:16 -07001935
Colin Cross25de6c32019-06-06 14:29:25 -07001936 fullInstallPath := installPath.Join(m, name)
1937 m.module.base().hooks.runInstallHooks(m, fullInstallPath, false)
Colin Cross3f40fa42015-01-30 17:27:36 -08001938
Colin Cross25de6c32019-06-06 14:29:25 -07001939 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001940
Colin Cross897266e2020-02-13 13:22:08 -08001941 deps = append(deps, m.installDeps.Paths()...)
Colin Cross35cec122015-04-02 14:37:16 -07001942
Colin Cross89562dc2016-10-03 17:47:19 -07001943 var implicitDeps, orderOnlyDeps Paths
1944
Colin Cross25de6c32019-06-06 14:29:25 -07001945 if m.Host() {
Colin Cross89562dc2016-10-03 17:47:19 -07001946 // Installed host modules might be used during the build, depend directly on their
1947 // dependencies so their timestamp is updated whenever their dependency is updated
1948 implicitDeps = deps
1949 } else {
1950 orderOnlyDeps = deps
1951 }
1952
Colin Cross25de6c32019-06-06 14:29:25 -07001953 m.Build(pctx, BuildParams{
Colin Cross5c517922017-08-31 12:29:17 -07001954 Rule: rule,
Colin Cross67a5c132017-05-09 13:45:28 -07001955 Description: "install " + fullInstallPath.Base(),
1956 Output: fullInstallPath,
1957 Input: srcPath,
1958 Implicits: implicitDeps,
1959 OrderOnly: orderOnlyDeps,
Colin Cross25de6c32019-06-06 14:29:25 -07001960 Default: !m.Config().EmbeddedInMake(),
Dan Willemsen322acaf2016-01-12 23:07:05 -08001961 })
Colin Cross3f40fa42015-01-30 17:27:36 -08001962
Colin Cross25de6c32019-06-06 14:29:25 -07001963 m.installFiles = append(m.installFiles, fullInstallPath)
Dan Willemsen322acaf2016-01-12 23:07:05 -08001964 }
Colin Cross25de6c32019-06-06 14:29:25 -07001965 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross35cec122015-04-02 14:37:16 -07001966 return fullInstallPath
1967}
1968
Colin Cross70dda7e2019-10-01 22:05:35 -07001969func (m *moduleContext) InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001970 fullInstallPath := installPath.Join(m, name)
1971 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Colin Cross3854a602016-01-11 12:49:11 -08001972
Colin Cross25de6c32019-06-06 14:29:25 -07001973 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001974
Alex Lightfb4353d2019-01-17 13:57:45 -08001975 relPath, err := filepath.Rel(path.Dir(fullInstallPath.String()), srcPath.String())
1976 if err != nil {
1977 panic(fmt.Sprintf("Unable to generate symlink between %q and %q: %s", fullInstallPath.Base(), srcPath.Base(), err))
1978 }
Colin Cross25de6c32019-06-06 14:29:25 -07001979 m.Build(pctx, BuildParams{
Colin Cross67a5c132017-05-09 13:45:28 -07001980 Rule: Symlink,
1981 Description: "install symlink " + fullInstallPath.Base(),
1982 Output: fullInstallPath,
Dan Willemsen40efa1c2020-01-14 15:19:52 -08001983 Input: srcPath,
Colin Cross25de6c32019-06-06 14:29:25 -07001984 Default: !m.Config().EmbeddedInMake(),
Colin Cross12fc4972016-01-11 12:49:11 -08001985 Args: map[string]string{
Alex Lightfb4353d2019-01-17 13:57:45 -08001986 "fromPath": relPath,
Colin Cross12fc4972016-01-11 12:49:11 -08001987 },
1988 })
Colin Cross3854a602016-01-11 12:49:11 -08001989
Colin Cross25de6c32019-06-06 14:29:25 -07001990 m.installFiles = append(m.installFiles, fullInstallPath)
1991 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross12fc4972016-01-11 12:49:11 -08001992 }
Colin Cross3854a602016-01-11 12:49:11 -08001993 return fullInstallPath
1994}
1995
Jiyong Parkf1194352019-02-25 11:05:47 +09001996// installPath/name -> absPath where absPath might be a path that is available only at runtime
1997// (e.g. /apex/...)
Colin Cross70dda7e2019-10-01 22:05:35 -07001998func (m *moduleContext) InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001999 fullInstallPath := installPath.Join(m, name)
2000 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Jiyong Parkf1194352019-02-25 11:05:47 +09002001
Colin Cross25de6c32019-06-06 14:29:25 -07002002 if !m.skipInstall(fullInstallPath) {
2003 m.Build(pctx, BuildParams{
Jiyong Parkf1194352019-02-25 11:05:47 +09002004 Rule: Symlink,
2005 Description: "install symlink " + fullInstallPath.Base() + " -> " + absPath,
2006 Output: fullInstallPath,
Colin Cross25de6c32019-06-06 14:29:25 -07002007 Default: !m.Config().EmbeddedInMake(),
Jiyong Parkf1194352019-02-25 11:05:47 +09002008 Args: map[string]string{
2009 "fromPath": absPath,
2010 },
2011 })
2012
Colin Cross25de6c32019-06-06 14:29:25 -07002013 m.installFiles = append(m.installFiles, fullInstallPath)
Jiyong Parkf1194352019-02-25 11:05:47 +09002014 }
2015 return fullInstallPath
2016}
2017
Colin Cross25de6c32019-06-06 14:29:25 -07002018func (m *moduleContext) CheckbuildFile(srcPath Path) {
2019 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross3f40fa42015-01-30 17:27:36 -08002020}
2021
Dan Willemsen2ef08f42015-06-30 18:15:24 -07002022func findStringInSlice(str string, slice []string) int {
2023 for i, s := range slice {
2024 if s == str {
2025 return i
Colin Crossfce53272015-04-08 11:21:40 -07002026 }
2027 }
Dan Willemsen2ef08f42015-06-30 18:15:24 -07002028 return -1
2029}
2030
Colin Cross41955e82019-05-29 14:40:35 -07002031// SrcIsModule decodes module references in the format ":name" into the module name, or empty string if the input
2032// was not a module reference.
2033func SrcIsModule(s string) (module string) {
Colin Cross068e0fe2016-12-13 15:23:47 -08002034 if len(s) > 1 && s[0] == ':' {
2035 return s[1:]
2036 }
2037 return ""
2038}
2039
Colin Cross41955e82019-05-29 14:40:35 -07002040// SrcIsModule decodes module references in the format ":name{.tag}" into the module name and tag, ":name" into the
2041// module name and an empty string for the tag, or empty strings if the input was not a module reference.
2042func SrcIsModuleWithTag(s string) (module, tag string) {
2043 if len(s) > 1 && s[0] == ':' {
2044 module = s[1:]
2045 if tagStart := strings.IndexByte(module, '{'); tagStart > 0 {
2046 if module[len(module)-1] == '}' {
2047 tag = module[tagStart+1 : len(module)-1]
2048 module = module[:tagStart]
2049 return module, tag
2050 }
2051 }
2052 return module, ""
2053 }
2054 return "", ""
Colin Cross068e0fe2016-12-13 15:23:47 -08002055}
2056
Colin Cross41955e82019-05-29 14:40:35 -07002057type sourceOrOutputDependencyTag struct {
2058 blueprint.BaseDependencyTag
2059 tag string
2060}
2061
2062func sourceOrOutputDepTag(tag string) blueprint.DependencyTag {
2063 return sourceOrOutputDependencyTag{tag: tag}
2064}
2065
2066var SourceDepTag = sourceOrOutputDepTag("")
Colin Cross068e0fe2016-12-13 15:23:47 -08002067
Colin Cross366938f2017-12-11 16:29:02 -08002068// Adds necessary dependencies to satisfy filegroup or generated sources modules listed in srcFiles
2069// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002070//
2071// Deprecated: tag the property with `android:"path"` instead.
Colin Cross068e0fe2016-12-13 15:23:47 -08002072func ExtractSourcesDeps(ctx BottomUpMutatorContext, srcFiles []string) {
Nan Zhang2439eb72017-04-10 11:27:50 -07002073 set := make(map[string]bool)
2074
Colin Cross068e0fe2016-12-13 15:23:47 -08002075 for _, s := range srcFiles {
Colin Cross41955e82019-05-29 14:40:35 -07002076 if m, t := SrcIsModuleWithTag(s); m != "" {
2077 if _, found := set[s]; found {
2078 ctx.ModuleErrorf("found source dependency duplicate: %q!", s)
Nan Zhang2439eb72017-04-10 11:27:50 -07002079 } else {
Colin Cross41955e82019-05-29 14:40:35 -07002080 set[s] = true
2081 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Nan Zhang2439eb72017-04-10 11:27:50 -07002082 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002083 }
2084 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002085}
2086
Colin Cross366938f2017-12-11 16:29:02 -08002087// Adds necessary dependencies to satisfy filegroup or generated sources modules specified in s
2088// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002089//
2090// Deprecated: tag the property with `android:"path"` instead.
Colin Cross366938f2017-12-11 16:29:02 -08002091func ExtractSourceDeps(ctx BottomUpMutatorContext, s *string) {
2092 if s != nil {
Colin Cross41955e82019-05-29 14:40:35 -07002093 if m, t := SrcIsModuleWithTag(*s); m != "" {
2094 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Colin Cross366938f2017-12-11 16:29:02 -08002095 }
2096 }
2097}
2098
Colin Cross41955e82019-05-29 14:40:35 -07002099// A module that implements SourceFileProducer can be referenced from any property that is tagged with `android:"path"`
2100// 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 -08002101type SourceFileProducer interface {
2102 Srcs() Paths
2103}
2104
Colin Cross41955e82019-05-29 14:40:35 -07002105// A module that implements OutputFileProducer can be referenced from any property that is tagged with `android:"path"`
Roland Levillain97c1f342019-11-22 14:20:54 +00002106// 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 -07002107// listed in the property.
2108type OutputFileProducer interface {
2109 OutputFiles(tag string) (Paths, error)
2110}
2111
Colin Cross5e708052019-08-06 13:59:50 -07002112// OutputFilesForModule returns the paths from an OutputFileProducer with the given tag. On error, including if the
2113// module produced zero paths, it reports errors to the ctx and returns nil.
2114func OutputFilesForModule(ctx PathContext, module blueprint.Module, tag string) Paths {
2115 paths, err := outputFilesForModule(ctx, module, tag)
2116 if err != nil {
2117 reportPathError(ctx, err)
2118 return nil
2119 }
2120 return paths
2121}
2122
2123// OutputFileForModule returns the path from an OutputFileProducer with the given tag. On error, including if the
2124// module produced zero or multiple paths, it reports errors to the ctx and returns nil.
2125func OutputFileForModule(ctx PathContext, module blueprint.Module, tag string) Path {
2126 paths, err := outputFilesForModule(ctx, module, tag)
2127 if err != nil {
2128 reportPathError(ctx, err)
2129 return nil
2130 }
2131 if len(paths) > 1 {
2132 reportPathErrorf(ctx, "got multiple output files from module %q, expected exactly one",
2133 pathContextName(ctx, module))
2134 return nil
2135 }
2136 return paths[0]
2137}
2138
2139func outputFilesForModule(ctx PathContext, module blueprint.Module, tag string) (Paths, error) {
2140 if outputFileProducer, ok := module.(OutputFileProducer); ok {
2141 paths, err := outputFileProducer.OutputFiles(tag)
2142 if err != nil {
2143 return nil, fmt.Errorf("failed to get output file from module %q: %s",
2144 pathContextName(ctx, module), err.Error())
2145 }
2146 if len(paths) == 0 {
2147 return nil, fmt.Errorf("failed to get output files from module %q", pathContextName(ctx, module))
2148 }
2149 return paths, nil
2150 } else {
2151 return nil, fmt.Errorf("module %q is not an OutputFileProducer", pathContextName(ctx, module))
2152 }
2153}
2154
Colin Crossfe17f6f2019-03-28 19:30:56 -07002155type HostToolProvider interface {
2156 HostToolPath() OptionalPath
2157}
2158
Colin Cross27b922f2019-03-04 22:35:41 -08002159// Returns a list of paths expanded from globs and modules referenced using ":module" syntax. The property must
2160// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002161//
2162// Deprecated: use PathsForModuleSrc or PathsForModuleSrcExcludes instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002163func (m *moduleContext) ExpandSources(srcFiles, excludes []string) Paths {
2164 return PathsForModuleSrcExcludes(m, srcFiles, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07002165}
2166
Colin Cross2fafa3e2019-03-05 12:39:51 -08002167// Returns a single path expanded from globs and modules referenced using ":module" syntax. The property must
2168// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002169//
2170// Deprecated: use PathForModuleSrc instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002171func (m *moduleContext) ExpandSource(srcFile, prop string) Path {
2172 return PathForModuleSrc(m, srcFile)
Colin Cross2fafa3e2019-03-05 12:39:51 -08002173}
2174
2175// Returns an optional single path expanded from globs and modules referenced using ":module" syntax if
2176// the srcFile is non-nil. The property must be tagged with `android:"path" to support automatic source module
2177// dependency resolution.
Colin Cross25de6c32019-06-06 14:29:25 -07002178func (m *moduleContext) ExpandOptionalSource(srcFile *string, prop string) OptionalPath {
Colin Cross2fafa3e2019-03-05 12:39:51 -08002179 if srcFile != nil {
Colin Cross25de6c32019-06-06 14:29:25 -07002180 return OptionalPathForPath(PathForModuleSrc(m, *srcFile))
Colin Cross2fafa3e2019-03-05 12:39:51 -08002181 }
2182 return OptionalPath{}
2183}
2184
Colin Cross25de6c32019-06-06 14:29:25 -07002185func (m *moduleContext) RequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002186 return m.module.RequiredModuleNames()
Nan Zhang6d34b302017-02-04 17:47:46 -08002187}
2188
Colin Cross25de6c32019-06-06 14:29:25 -07002189func (m *moduleContext) HostRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002190 return m.module.HostRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002191}
2192
Colin Cross25de6c32019-06-06 14:29:25 -07002193func (m *moduleContext) TargetRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002194 return m.module.TargetRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002195}
2196
Colin Cross463a90e2015-06-17 14:20:06 -07002197func init() {
Colin Cross798bfce2016-10-12 14:28:16 -07002198 RegisterSingletonType("buildtarget", BuildTargetSingleton)
Colin Cross463a90e2015-06-17 14:20:06 -07002199}
2200
Colin Cross0875c522017-11-28 17:34:01 -08002201func BuildTargetSingleton() Singleton {
Colin Cross1f8c52b2015-06-16 16:38:17 -07002202 return &buildTargetSingleton{}
2203}
2204
Colin Cross87d8b562017-04-25 10:01:55 -07002205func parentDir(dir string) string {
2206 dir, _ = filepath.Split(dir)
2207 return filepath.Clean(dir)
2208}
2209
Colin Cross1f8c52b2015-06-16 16:38:17 -07002210type buildTargetSingleton struct{}
2211
Colin Cross0875c522017-11-28 17:34:01 -08002212func (c *buildTargetSingleton) GenerateBuildActions(ctx SingletonContext) {
2213 var checkbuildDeps Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07002214
Colin Cross0875c522017-11-28 17:34:01 -08002215 mmTarget := func(dir string) WritablePath {
2216 return PathForPhony(ctx,
2217 "MODULES-IN-"+strings.Replace(filepath.Clean(dir), "/", "-", -1))
Colin Cross87d8b562017-04-25 10:01:55 -07002218 }
2219
Colin Cross0875c522017-11-28 17:34:01 -08002220 modulesInDir := make(map[string]Paths)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002221
Colin Cross0875c522017-11-28 17:34:01 -08002222 ctx.VisitAllModules(func(module Module) {
2223 blueprintDir := module.base().blueprintDir
2224 installTarget := module.base().installTarget
2225 checkbuildTarget := module.base().checkbuildTarget
Colin Cross1f8c52b2015-06-16 16:38:17 -07002226
Colin Cross0875c522017-11-28 17:34:01 -08002227 if checkbuildTarget != nil {
2228 checkbuildDeps = append(checkbuildDeps, checkbuildTarget)
2229 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], checkbuildTarget)
2230 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002231
Colin Cross0875c522017-11-28 17:34:01 -08002232 if installTarget != nil {
2233 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], installTarget)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002234 }
2235 })
2236
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002237 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08002238 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002239 suffix = "-soong"
2240 }
2241
Colin Cross1f8c52b2015-06-16 16:38:17 -07002242 // Create a top-level checkbuild target that depends on all modules
Colin Cross0875c522017-11-28 17:34:01 -08002243 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07002244 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002245 Output: PathForPhony(ctx, "checkbuild"+suffix),
Colin Cross1f8c52b2015-06-16 16:38:17 -07002246 Implicits: checkbuildDeps,
Colin Cross1f8c52b2015-06-16 16:38:17 -07002247 })
2248
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002249 // Make will generate the MODULES-IN-* targets
Colin Crossaabf6792017-11-29 00:27:14 -08002250 if ctx.Config().EmbeddedInMake() {
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002251 return
2252 }
2253
Colin Cross87d8b562017-04-25 10:01:55 -07002254 // Ensure ancestor directories are in modulesInDir
Inseob Kim1a365c62019-06-08 15:47:51 +09002255 dirs := SortedStringKeys(modulesInDir)
Colin Cross87d8b562017-04-25 10:01:55 -07002256 for _, dir := range dirs {
2257 dir := parentDir(dir)
2258 for dir != "." && dir != "/" {
2259 if _, exists := modulesInDir[dir]; exists {
2260 break
2261 }
2262 modulesInDir[dir] = nil
2263 dir = parentDir(dir)
2264 }
2265 }
2266
2267 // Make directories build their direct subdirectories
Colin Cross87d8b562017-04-25 10:01:55 -07002268 for _, dir := range dirs {
2269 p := parentDir(dir)
2270 if p != "." && p != "/" {
2271 modulesInDir[p] = append(modulesInDir[p], mmTarget(dir))
2272 }
2273 }
2274
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002275 // Create a MODULES-IN-<directory> target that depends on all modules in a directory, and
2276 // depends on the MODULES-IN-* targets of all of its subdirectories that contain Android.bp
2277 // files.
Colin Cross1f8c52b2015-06-16 16:38:17 -07002278 for _, dir := range dirs {
Colin Cross0875c522017-11-28 17:34:01 -08002279 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07002280 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002281 Output: mmTarget(dir),
Colin Cross87d8b562017-04-25 10:01:55 -07002282 Implicits: modulesInDir[dir],
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002283 // HACK: checkbuild should be an optional build, but force it
2284 // enabled for now in standalone builds
Colin Crossaabf6792017-11-29 00:27:14 -08002285 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross1f8c52b2015-06-16 16:38:17 -07002286 })
2287 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002288
2289 // Create (host|host-cross|target)-<OS> phony rules to build a reduced checkbuild.
2290 osDeps := map[OsType]Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08002291 ctx.VisitAllModules(func(module Module) {
2292 if module.Enabled() {
2293 os := module.Target().Os
2294 osDeps[os] = append(osDeps[os], module.base().checkbuildFiles...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002295 }
2296 })
2297
Colin Cross0875c522017-11-28 17:34:01 -08002298 osClass := make(map[string]Paths)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002299 for os, deps := range osDeps {
2300 var className string
2301
2302 switch os.Class {
2303 case Host:
2304 className = "host"
2305 case HostCross:
2306 className = "host-cross"
2307 case Device:
2308 className = "target"
2309 default:
2310 continue
2311 }
2312
Colin Cross0875c522017-11-28 17:34:01 -08002313 name := PathForPhony(ctx, className+"-"+os.Name)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002314 osClass[className] = append(osClass[className], name)
2315
Colin Cross0875c522017-11-28 17:34:01 -08002316 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07002317 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002318 Output: name,
2319 Implicits: deps,
Dan Willemsen61d88b82017-09-20 17:29:08 -07002320 })
2321 }
2322
2323 // Wrap those into host|host-cross|target phony rules
Inseob Kim1a365c62019-06-08 15:47:51 +09002324 for _, class := range SortedStringKeys(osClass) {
Colin Cross0875c522017-11-28 17:34:01 -08002325 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07002326 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002327 Output: PathForPhony(ctx, class),
Dan Willemsen61d88b82017-09-20 17:29:08 -07002328 Implicits: osClass[class],
Dan Willemsen61d88b82017-09-20 17:29:08 -07002329 })
2330 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002331}
Colin Crossd779da42015-12-17 18:00:23 -08002332
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002333// Collect information for opening IDE project files in java/jdeps.go.
2334type IDEInfo interface {
2335 IDEInfo(ideInfo *IdeInfo)
2336 BaseModuleName() string
2337}
2338
2339// Extract the base module name from the Import name.
2340// Often the Import name has a prefix "prebuilt_".
2341// Remove the prefix explicitly if needed
2342// until we find a better solution to get the Import name.
2343type IDECustomizedModuleName interface {
2344 IDECustomizedModuleName() string
2345}
2346
2347type IdeInfo struct {
2348 Deps []string `json:"dependencies,omitempty"`
2349 Srcs []string `json:"srcs,omitempty"`
2350 Aidl_include_dirs []string `json:"aidl_include_dirs,omitempty"`
2351 Jarjar_rules []string `json:"jarjar_rules,omitempty"`
2352 Jars []string `json:"jars,omitempty"`
2353 Classes []string `json:"class,omitempty"`
2354 Installed_paths []string `json:"installed,omitempty"`
patricktu18c82ff2019-05-10 15:48:50 +08002355 SrcJars []string `json:"srcjars,omitempty"`
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002356}