blob: 7e64f0adf7a46967d1ba7fb2ed9f5da34d76bb44 [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
Colin Crossc2d24052020-05-13 11:05:02 -0700901// RequiresStableAPIs returns true if the module will be installed to a partition that may
902// be updated separately from the system image.
903func (m *ModuleBase) RequiresStableAPIs(ctx BaseModuleContext) bool {
904 return m.SocSpecific() || m.DeviceSpecific() ||
905 (m.ProductSpecific() && ctx.Config().EnforceProductPartitionInterface())
906}
907
Bill Peckhamfff3f8a2020-03-20 18:33:20 -0700908func (m *ModuleBase) PartitionTag(config DeviceConfig) string {
909 partition := "system"
910 if m.SocSpecific() {
911 // A SoC-specific module could be on the vendor partition at
912 // "vendor" or the system partition at "system/vendor".
913 if config.VendorPath() == "vendor" {
914 partition = "vendor"
915 }
916 } else if m.DeviceSpecific() {
917 // A device-specific module could be on the odm partition at
918 // "odm", the vendor partition at "vendor/odm", or the system
919 // partition at "system/vendor/odm".
920 if config.OdmPath() == "odm" {
921 partition = "odm"
Ramy Medhat944839a2020-03-31 22:14:52 -0400922 } else if strings.HasPrefix(config.OdmPath(), "vendor/") {
Bill Peckhamfff3f8a2020-03-20 18:33:20 -0700923 partition = "vendor"
924 }
925 } else if m.ProductSpecific() {
926 // A product-specific module could be on the product partition
927 // at "product" or the system partition at "system/product".
928 if config.ProductPath() == "product" {
929 partition = "product"
930 }
931 } else if m.SystemExtSpecific() {
932 // A system_ext-specific module could be on the system_ext
933 // partition at "system_ext" or the system partition at
934 // "system/system_ext".
935 if config.SystemExtPath() == "system_ext" {
936 partition = "system_ext"
937 }
938 }
939 return partition
940}
941
Colin Cross4157e882019-06-06 16:57:04 -0700942func (m *ModuleBase) Enabled() bool {
943 if m.commonProperties.Enabled == nil {
944 return !m.Os().DefaultDisabled
Dan Willemsen490fd492015-11-24 17:53:15 -0800945 }
Colin Cross4157e882019-06-06 16:57:04 -0700946 return *m.commonProperties.Enabled
Colin Cross3f40fa42015-01-30 17:27:36 -0800947}
948
Inseob Kimeec88e12020-01-22 11:11:29 +0900949func (m *ModuleBase) Disable() {
950 m.commonProperties.Enabled = proptools.BoolPtr(false)
951}
952
Colin Cross4157e882019-06-06 16:57:04 -0700953func (m *ModuleBase) SkipInstall() {
954 m.commonProperties.SkipInstall = true
Colin Crossce75d2c2016-10-06 16:12:58 -0700955}
956
Ulya Trafimovichb28cc372020-01-13 15:18:16 +0000957func (m *ModuleBase) IsSkipInstall() bool {
958 return m.commonProperties.SkipInstall == true
959}
960
Colin Cross4157e882019-06-06 16:57:04 -0700961func (m *ModuleBase) ExportedToMake() bool {
962 return m.commonProperties.NamespaceExportedToMake
Jiyong Park374510b2018-03-19 18:23:01 +0900963}
964
Colin Cross897266e2020-02-13 13:22:08 -0800965func (m *ModuleBase) computeInstallDeps(ctx blueprint.ModuleContext) InstallPaths {
Colin Cross3f40fa42015-01-30 17:27:36 -0800966
Colin Cross897266e2020-02-13 13:22:08 -0800967 var result InstallPaths
Colin Cross6b753602018-06-21 13:03:07 -0700968 // TODO(ccross): we need to use WalkDeps and have some way to know which dependencies require installation
Colin Cross897266e2020-02-13 13:22:08 -0800969 ctx.VisitDepsDepthFirst(func(m blueprint.Module) {
970 if a, ok := m.(Module); ok {
971 result = append(result, a.filesToInstall()...)
972 }
973 })
Colin Cross3f40fa42015-01-30 17:27:36 -0800974
975 return result
976}
977
Colin Cross897266e2020-02-13 13:22:08 -0800978func (m *ModuleBase) filesToInstall() InstallPaths {
Colin Cross4157e882019-06-06 16:57:04 -0700979 return m.installFiles
Colin Cross3f40fa42015-01-30 17:27:36 -0800980}
981
Colin Cross4157e882019-06-06 16:57:04 -0700982func (m *ModuleBase) NoAddressSanitizer() bool {
983 return m.noAddressSanitizer
Colin Cross3f40fa42015-01-30 17:27:36 -0800984}
985
Colin Cross4157e882019-06-06 16:57:04 -0700986func (m *ModuleBase) InstallInData() bool {
Dan Willemsen782a2d12015-12-21 14:55:28 -0800987 return false
988}
989
Jaewoong Jung0949f312019-09-11 10:25:18 -0700990func (m *ModuleBase) InstallInTestcases() bool {
991 return false
992}
993
Colin Cross4157e882019-06-06 16:57:04 -0700994func (m *ModuleBase) InstallInSanitizerDir() bool {
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700995 return false
996}
997
Yifan Hong1b3348d2020-01-21 15:53:22 -0800998func (m *ModuleBase) InstallInRamdisk() bool {
999 return Bool(m.commonProperties.Ramdisk)
1000}
1001
Colin Cross4157e882019-06-06 16:57:04 -07001002func (m *ModuleBase) InstallInRecovery() bool {
1003 return Bool(m.commonProperties.Recovery)
Jiyong Parkf9332f12018-02-01 00:54:12 +09001004}
1005
Colin Cross90ba5f42019-10-02 11:10:58 -07001006func (m *ModuleBase) InstallInRoot() bool {
1007 return false
1008}
1009
Colin Cross607d8582019-07-29 16:44:46 -07001010func (m *ModuleBase) InstallBypassMake() bool {
1011 return false
1012}
1013
Colin Cross6e359402020-02-10 15:29:54 -08001014func (m *ModuleBase) InstallForceOS() *OsType {
1015 return nil
1016}
1017
Colin Cross4157e882019-06-06 16:57:04 -07001018func (m *ModuleBase) Owner() string {
1019 return String(m.commonProperties.Owner)
Sundong Ahn4fd04bb2018-08-31 18:01:37 +09001020}
1021
Bob Badoura75b0572020-02-18 20:21:55 -08001022func (m *ModuleBase) NoticeFiles() Paths {
1023 return m.noticeFiles
Jiyong Park52818fc2019-03-18 12:01:38 +09001024}
1025
Colin Cross7228ecd2019-11-18 16:00:16 -08001026func (m *ModuleBase) setImageVariation(variant string) {
1027 m.commonProperties.ImageVariation = variant
1028}
1029
1030func (m *ModuleBase) ImageVariation() blueprint.Variation {
1031 return blueprint.Variation{
1032 Mutator: "image",
1033 Variation: m.base().commonProperties.ImageVariation,
1034 }
1035}
1036
Paul Duffin9b76c0b2020-03-12 10:24:35 +00001037func (m *ModuleBase) getVariationByMutatorName(mutator string) string {
1038 for i, v := range m.commonProperties.DebugMutators {
1039 if v == mutator {
1040 return m.commonProperties.DebugVariations[i]
1041 }
1042 }
1043
1044 return ""
1045}
1046
Yifan Hong1b3348d2020-01-21 15:53:22 -08001047func (m *ModuleBase) InRamdisk() bool {
1048 return m.base().commonProperties.ImageVariation == RamdiskVariation
1049}
1050
Colin Cross7228ecd2019-11-18 16:00:16 -08001051func (m *ModuleBase) InRecovery() bool {
1052 return m.base().commonProperties.ImageVariation == RecoveryVariation
1053}
1054
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09001055func (m *ModuleBase) RequiredModuleNames() []string {
1056 return m.base().commonProperties.Required
1057}
1058
1059func (m *ModuleBase) HostRequiredModuleNames() []string {
1060 return m.base().commonProperties.Host_required
1061}
1062
1063func (m *ModuleBase) TargetRequiredModuleNames() []string {
1064 return m.base().commonProperties.Target_required
1065}
1066
Inseob Kim8471cda2019-11-15 09:59:12 +09001067func (m *ModuleBase) InitRc() Paths {
1068 return append(Paths{}, m.initRcPaths...)
1069}
1070
1071func (m *ModuleBase) VintfFragments() Paths {
1072 return append(Paths{}, m.vintfFragmentsPaths...)
1073}
1074
Colin Cross4157e882019-06-06 16:57:04 -07001075func (m *ModuleBase) generateModuleTarget(ctx ModuleContext) {
Colin Cross897266e2020-02-13 13:22:08 -08001076 var allInstalledFiles InstallPaths
1077 var allCheckbuildFiles Paths
Colin Cross0875c522017-11-28 17:34:01 -08001078 ctx.VisitAllModuleVariants(func(module Module) {
1079 a := module.base()
Colin Crossc9404352015-03-26 16:10:12 -07001080 allInstalledFiles = append(allInstalledFiles, a.installFiles...)
1081 allCheckbuildFiles = append(allCheckbuildFiles, a.checkbuildFiles...)
Colin Cross3f40fa42015-01-30 17:27:36 -08001082 })
1083
Colin Cross0875c522017-11-28 17:34:01 -08001084 var deps Paths
Colin Cross9454bfa2015-03-17 13:24:18 -07001085
Jeff Gaston088e29e2017-11-29 16:47:17 -08001086 namespacePrefix := ctx.Namespace().(*Namespace).id
1087 if namespacePrefix != "" {
1088 namespacePrefix = namespacePrefix + "-"
1089 }
1090
Colin Cross3f40fa42015-01-30 17:27:36 -08001091 if len(allInstalledFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -08001092 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-install")
Colin Cross0875c522017-11-28 17:34:01 -08001093 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001094 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001095 Output: name,
Colin Cross897266e2020-02-13 13:22:08 -08001096 Implicits: allInstalledFiles.Paths(),
Colin Crossaabf6792017-11-29 00:27:14 -08001097 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross9454bfa2015-03-17 13:24:18 -07001098 })
1099 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -07001100 m.installTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -07001101 }
1102
1103 if len(allCheckbuildFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -08001104 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-checkbuild")
Colin Cross0875c522017-11-28 17:34:01 -08001105 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001106 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001107 Output: name,
1108 Implicits: allCheckbuildFiles,
Colin Cross9454bfa2015-03-17 13:24:18 -07001109 })
1110 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -07001111 m.checkbuildTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -07001112 }
1113
1114 if len(deps) > 0 {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001115 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08001116 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001117 suffix = "-soong"
1118 }
1119
Jeff Gaston088e29e2017-11-29 16:47:17 -08001120 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+suffix)
Colin Cross0875c522017-11-28 17:34:01 -08001121 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001122 Rule: blueprint.Phony,
Jeff Gaston088e29e2017-11-29 16:47:17 -08001123 Outputs: []WritablePath{name},
Colin Cross9454bfa2015-03-17 13:24:18 -07001124 Implicits: deps,
Colin Cross3f40fa42015-01-30 17:27:36 -08001125 })
Colin Cross1f8c52b2015-06-16 16:38:17 -07001126
Colin Cross4157e882019-06-06 16:57:04 -07001127 m.blueprintDir = ctx.ModuleDir()
Colin Cross3f40fa42015-01-30 17:27:36 -08001128 }
1129}
1130
Colin Crossc34d2322020-01-03 15:23:27 -08001131func determineModuleKind(m *ModuleBase, ctx blueprint.EarlyModuleContext) moduleKind {
Colin Cross4157e882019-06-06 16:57:04 -07001132 var socSpecific = Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
1133 var deviceSpecific = Bool(m.commonProperties.Device_specific)
1134 var productSpecific = Bool(m.commonProperties.Product_specific)
Justin Yund5f6c822019-06-25 16:47:17 +09001135 var systemExtSpecific = Bool(m.commonProperties.System_ext_specific)
Jiyong Park2db76922017-11-08 16:03:48 +09001136
Dario Frenifd05a742018-05-29 13:28:54 +01001137 msg := "conflicting value set here"
1138 if socSpecific && deviceSpecific {
1139 ctx.PropertyErrorf("device_specific", "a module cannot be specific to SoC and device at the same time.")
Colin Cross4157e882019-06-06 16:57:04 -07001140 if Bool(m.commonProperties.Vendor) {
Jiyong Park2db76922017-11-08 16:03:48 +09001141 ctx.PropertyErrorf("vendor", msg)
1142 }
Colin Cross4157e882019-06-06 16:57:04 -07001143 if Bool(m.commonProperties.Proprietary) {
Jiyong Park2db76922017-11-08 16:03:48 +09001144 ctx.PropertyErrorf("proprietary", msg)
1145 }
Colin Cross4157e882019-06-06 16:57:04 -07001146 if Bool(m.commonProperties.Soc_specific) {
Jiyong Park2db76922017-11-08 16:03:48 +09001147 ctx.PropertyErrorf("soc_specific", msg)
1148 }
1149 }
1150
Justin Yund5f6c822019-06-25 16:47:17 +09001151 if productSpecific && systemExtSpecific {
1152 ctx.PropertyErrorf("product_specific", "a module cannot be specific to product and system_ext at the same time.")
1153 ctx.PropertyErrorf("system_ext_specific", msg)
Dario Frenifd05a742018-05-29 13:28:54 +01001154 }
1155
Justin Yund5f6c822019-06-25 16:47:17 +09001156 if (socSpecific || deviceSpecific) && (productSpecific || systemExtSpecific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001157 if productSpecific {
1158 ctx.PropertyErrorf("product_specific", "a module cannot be specific to SoC or device and product at the same time.")
1159 } else {
Justin Yund5f6c822019-06-25 16:47:17 +09001160 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 +01001161 }
1162 if deviceSpecific {
1163 ctx.PropertyErrorf("device_specific", msg)
1164 } else {
Colin Cross4157e882019-06-06 16:57:04 -07001165 if Bool(m.commonProperties.Vendor) {
Dario Frenifd05a742018-05-29 13:28:54 +01001166 ctx.PropertyErrorf("vendor", msg)
1167 }
Colin Cross4157e882019-06-06 16:57:04 -07001168 if Bool(m.commonProperties.Proprietary) {
Dario Frenifd05a742018-05-29 13:28:54 +01001169 ctx.PropertyErrorf("proprietary", msg)
1170 }
Colin Cross4157e882019-06-06 16:57:04 -07001171 if Bool(m.commonProperties.Soc_specific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001172 ctx.PropertyErrorf("soc_specific", msg)
1173 }
1174 }
1175 }
1176
Jiyong Park2db76922017-11-08 16:03:48 +09001177 if productSpecific {
1178 return productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +09001179 } else if systemExtSpecific {
1180 return systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001181 } else if deviceSpecific {
1182 return deviceSpecificModule
1183 } else if socSpecific {
1184 return socSpecificModule
1185 } else {
1186 return platformModule
1187 }
1188}
1189
Colin Crossc34d2322020-01-03 15:23:27 -08001190func (m *ModuleBase) earlyModuleContextFactory(ctx blueprint.EarlyModuleContext) earlyModuleContext {
Colin Cross1184b642019-12-30 18:43:07 -08001191 return earlyModuleContext{
Colin Crossc34d2322020-01-03 15:23:27 -08001192 EarlyModuleContext: ctx,
1193 kind: determineModuleKind(m, ctx),
1194 config: ctx.Config().(Config),
Colin Cross3f40fa42015-01-30 17:27:36 -08001195 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001196}
1197
Colin Cross1184b642019-12-30 18:43:07 -08001198func (m *ModuleBase) baseModuleContextFactory(ctx blueprint.BaseModuleContext) baseModuleContext {
1199 return baseModuleContext{
1200 bp: ctx,
1201 earlyModuleContext: m.earlyModuleContextFactory(ctx),
1202 os: m.commonProperties.CompileOS,
1203 target: m.commonProperties.CompileTarget,
1204 targetPrimary: m.commonProperties.CompilePrimary,
1205 multiTargets: m.commonProperties.CompileMultiTargets,
1206 }
1207}
1208
Colin Cross4157e882019-06-06 16:57:04 -07001209func (m *ModuleBase) GenerateBuildActions(blueprintCtx blueprint.ModuleContext) {
Colin Cross25de6c32019-06-06 14:29:25 -07001210 ctx := &moduleContext{
Colin Cross0ea8ba82019-06-06 14:33:29 -07001211 module: m.module,
Colin Crossdc35e212019-06-06 16:13:11 -07001212 bp: blueprintCtx,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001213 baseModuleContext: m.baseModuleContextFactory(blueprintCtx),
1214 installDeps: m.computeInstallDeps(blueprintCtx),
1215 installFiles: m.installFiles,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001216 variables: make(map[string]string),
Colin Cross3f40fa42015-01-30 17:27:36 -08001217 }
1218
Colin Cross6c4f21f2019-06-06 15:41:36 -07001219 // Temporarily continue to call blueprintCtx.GetMissingDependencies() to maintain the previous behavior of never
1220 // reporting missing dependency errors in Blueprint when AllowMissingDependencies == true.
1221 // TODO: This will be removed once defaults modules handle missing dependency errors
1222 blueprintCtx.GetMissingDependencies()
1223
Colin Crossdc35e212019-06-06 16:13:11 -07001224 // For the final GenerateAndroidBuildActions pass, require that all visited dependencies Soong modules and
Paul Duffin1356d8c2020-02-25 19:26:33 +00001225 // are enabled. Unless the module is a CommonOS variant which may have dependencies on disabled variants
1226 // (because the dependencies are added before the modules are disabled). The
1227 // GetOsSpecificVariantsOfCommonOSVariant(...) method will ensure that the disabled variants are
1228 // ignored.
1229 ctx.baseModuleContext.strictVisitDeps = !m.IsCommonOSVariant()
Colin Crossdc35e212019-06-06 16:13:11 -07001230
Colin Cross4c83e5c2019-02-25 14:54:28 -08001231 if ctx.config.captureBuild {
1232 ctx.ruleParams = make(map[blueprint.Rule]blueprint.RuleParams)
1233 }
1234
Colin Cross67a5c132017-05-09 13:45:28 -07001235 desc := "//" + ctx.ModuleDir() + ":" + ctx.ModuleName() + " "
1236 var suffix []string
Colin Cross0875c522017-11-28 17:34:01 -08001237 if ctx.Os().Class != Device && ctx.Os().Class != Generic {
1238 suffix = append(suffix, ctx.Os().String())
Colin Cross67a5c132017-05-09 13:45:28 -07001239 }
Colin Cross0875c522017-11-28 17:34:01 -08001240 if !ctx.PrimaryArch() {
1241 suffix = append(suffix, ctx.Arch().ArchType.String())
Colin Cross67a5c132017-05-09 13:45:28 -07001242 }
Dan Willemsenb13a9482020-02-14 11:25:54 -08001243 if apex, ok := m.module.(ApexModule); ok && !apex.IsForPlatform() {
1244 suffix = append(suffix, apex.ApexName())
1245 }
Colin Cross67a5c132017-05-09 13:45:28 -07001246
1247 ctx.Variable(pctx, "moduleDesc", desc)
1248
1249 s := ""
1250 if len(suffix) > 0 {
1251 s = " [" + strings.Join(suffix, " ") + "]"
1252 }
1253 ctx.Variable(pctx, "moduleDescSuffix", s)
1254
Dan Willemsen569edc52018-11-19 09:33:29 -08001255 // Some common property checks for properties that will be used later in androidmk.go
Colin Cross4157e882019-06-06 16:57:04 -07001256 if m.commonProperties.Dist.Dest != nil {
1257 _, err := validateSafePath(*m.commonProperties.Dist.Dest)
Dan Willemsen569edc52018-11-19 09:33:29 -08001258 if err != nil {
1259 ctx.PropertyErrorf("dist.dest", "%s", err.Error())
1260 }
1261 }
Colin Cross4157e882019-06-06 16:57:04 -07001262 if m.commonProperties.Dist.Dir != nil {
1263 _, err := validateSafePath(*m.commonProperties.Dist.Dir)
Dan Willemsen569edc52018-11-19 09:33:29 -08001264 if err != nil {
1265 ctx.PropertyErrorf("dist.dir", "%s", err.Error())
1266 }
1267 }
Colin Cross4157e882019-06-06 16:57:04 -07001268 if m.commonProperties.Dist.Suffix != nil {
1269 if strings.Contains(*m.commonProperties.Dist.Suffix, "/") {
Dan Willemsen569edc52018-11-19 09:33:29 -08001270 ctx.PropertyErrorf("dist.suffix", "Suffix may not contain a '/' character.")
1271 }
1272 }
1273
Colin Cross4157e882019-06-06 16:57:04 -07001274 if m.Enabled() {
Jooyung Hand48f3c32019-08-23 11:18:57 +09001275 // ensure all direct android.Module deps are enabled
1276 ctx.VisitDirectDepsBlueprint(func(bm blueprint.Module) {
1277 if _, ok := bm.(Module); ok {
1278 ctx.validateAndroidModule(bm, ctx.baseModuleContext.strictVisitDeps)
1279 }
1280 })
1281
Bob Badoura75b0572020-02-18 20:21:55 -08001282 m.noticeFiles = make([]Path, 0)
1283 optPath := OptionalPath{}
1284 notice := proptools.StringDefault(m.commonProperties.Notice, "")
Colin Cross4157e882019-06-06 16:57:04 -07001285 if module := SrcIsModule(notice); module != "" {
Bob Badoura75b0572020-02-18 20:21:55 -08001286 optPath = ctx.ExpandOptionalSource(&notice, "notice")
1287 } else if notice != "" {
Jiyong Park52818fc2019-03-18 12:01:38 +09001288 noticePath := filepath.Join(ctx.ModuleDir(), notice)
Bob Badoura75b0572020-02-18 20:21:55 -08001289 optPath = ExistentPathForSource(ctx, noticePath)
1290 }
1291 if optPath.Valid() {
1292 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1293 } else {
1294 for _, notice = range []string{"LICENSE", "LICENCE", "NOTICE"} {
1295 noticePath := filepath.Join(ctx.ModuleDir(), notice)
1296 optPath = ExistentPathForSource(ctx, noticePath)
1297 if optPath.Valid() {
1298 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1299 }
1300 }
Jaewoong Jung62707f72018-11-16 13:26:43 -08001301 }
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001302
1303 m.module.GenerateAndroidBuildActions(ctx)
1304 if ctx.Failed() {
1305 return
1306 }
1307
1308 m.installFiles = append(m.installFiles, ctx.installFiles...)
1309 m.checkbuildFiles = append(m.checkbuildFiles, ctx.checkbuildFiles...)
Inseob Kim8471cda2019-11-15 09:59:12 +09001310 m.initRcPaths = PathsForModuleSrc(ctx, m.commonProperties.Init_rc)
1311 m.vintfFragmentsPaths = PathsForModuleSrc(ctx, m.commonProperties.Vintf_fragments)
Colin Crossdc35e212019-06-06 16:13:11 -07001312 } else if ctx.Config().AllowMissingDependencies() {
1313 // If the module is not enabled it will not create any build rules, nothing will call
1314 // ctx.GetMissingDependencies(), and blueprint will consider the missing dependencies to be unhandled
1315 // and report them as an error even when AllowMissingDependencies = true. Call
1316 // ctx.GetMissingDependencies() here to tell blueprint not to handle them.
1317 ctx.GetMissingDependencies()
Colin Cross3f40fa42015-01-30 17:27:36 -08001318 }
1319
Colin Cross4157e882019-06-06 16:57:04 -07001320 if m == ctx.FinalModule().(Module).base() {
1321 m.generateModuleTarget(ctx)
Colin Cross9b1d13d2016-09-19 15:18:11 -07001322 if ctx.Failed() {
1323 return
1324 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001325 }
Colin Crosscec81712017-07-13 14:43:27 -07001326
Colin Cross4157e882019-06-06 16:57:04 -07001327 m.buildParams = ctx.buildParams
1328 m.ruleParams = ctx.ruleParams
1329 m.variables = ctx.variables
Colin Cross3f40fa42015-01-30 17:27:36 -08001330}
1331
Colin Cross1184b642019-12-30 18:43:07 -08001332type earlyModuleContext struct {
Colin Crossc34d2322020-01-03 15:23:27 -08001333 blueprint.EarlyModuleContext
Colin Cross1184b642019-12-30 18:43:07 -08001334
1335 kind moduleKind
1336 config Config
1337}
1338
1339func (e *earlyModuleContext) Glob(globPattern string, excludes []string) Paths {
1340 ret, err := e.GlobWithDeps(globPattern, excludes)
1341 if err != nil {
1342 e.ModuleErrorf("glob: %s", err.Error())
1343 }
1344 return pathsForModuleSrcFromFullPath(e, ret, true)
1345}
1346
1347func (e *earlyModuleContext) GlobFiles(globPattern string, excludes []string) Paths {
1348 ret, err := e.GlobWithDeps(globPattern, excludes)
1349 if err != nil {
1350 e.ModuleErrorf("glob: %s", err.Error())
1351 }
1352 return pathsForModuleSrcFromFullPath(e, ret, false)
1353}
1354
Colin Cross988414c2020-01-11 01:11:46 +00001355func (b *earlyModuleContext) IsSymlink(path Path) bool {
1356 fileInfo, err := b.config.fs.Lstat(path.String())
1357 if err != nil {
1358 b.ModuleErrorf("os.Lstat(%q) failed: %s", path.String(), err)
1359 }
1360 return fileInfo.Mode()&os.ModeSymlink == os.ModeSymlink
1361}
1362
1363func (b *earlyModuleContext) Readlink(path Path) string {
1364 dest, err := b.config.fs.Readlink(path.String())
1365 if err != nil {
1366 b.ModuleErrorf("os.Readlink(%q) failed: %s", path.String(), err)
1367 }
1368 return dest
1369}
1370
Colin Cross1184b642019-12-30 18:43:07 -08001371func (e *earlyModuleContext) Module() Module {
Colin Crossc34d2322020-01-03 15:23:27 -08001372 module, _ := e.EarlyModuleContext.Module().(Module)
Colin Cross1184b642019-12-30 18:43:07 -08001373 return module
1374}
1375
1376func (e *earlyModuleContext) Config() Config {
Colin Crossc34d2322020-01-03 15:23:27 -08001377 return e.EarlyModuleContext.Config().(Config)
Colin Cross1184b642019-12-30 18:43:07 -08001378}
1379
1380func (e *earlyModuleContext) AConfig() Config {
1381 return e.config
1382}
1383
1384func (e *earlyModuleContext) DeviceConfig() DeviceConfig {
1385 return DeviceConfig{e.config.deviceConfig}
1386}
1387
1388func (e *earlyModuleContext) Platform() bool {
1389 return e.kind == platformModule
1390}
1391
1392func (e *earlyModuleContext) DeviceSpecific() bool {
1393 return e.kind == deviceSpecificModule
1394}
1395
1396func (e *earlyModuleContext) SocSpecific() bool {
1397 return e.kind == socSpecificModule
1398}
1399
1400func (e *earlyModuleContext) ProductSpecific() bool {
1401 return e.kind == productSpecificModule
1402}
1403
1404func (e *earlyModuleContext) SystemExtSpecific() bool {
1405 return e.kind == systemExtSpecificModule
1406}
1407
1408type baseModuleContext struct {
1409 bp blueprint.BaseModuleContext
1410 earlyModuleContext
Colin Crossfb0c16e2019-11-20 17:12:35 -08001411 os OsType
Colin Cross8b74d172016-09-13 09:59:14 -07001412 target Target
Colin Crossee0bc3b2018-10-02 22:01:37 -07001413 multiTargets []Target
Colin Cross8b74d172016-09-13 09:59:14 -07001414 targetPrimary bool
1415 debug bool
Colin Crossdc35e212019-06-06 16:13:11 -07001416
1417 walkPath []Module
Paul Duffinc5192442020-03-31 11:31:36 +01001418 tagPath []blueprint.DependencyTag
Colin Crossdc35e212019-06-06 16:13:11 -07001419
1420 strictVisitDeps bool // If true, enforce that all dependencies are enabled
Colin Crossf6566ed2015-03-24 11:13:38 -07001421}
1422
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001423func (b *baseModuleContext) OtherModuleName(m blueprint.Module) string {
1424 return b.bp.OtherModuleName(m)
1425}
1426func (b *baseModuleContext) OtherModuleDir(m blueprint.Module) string { return b.bp.OtherModuleDir(m) }
Colin Cross1184b642019-12-30 18:43:07 -08001427func (b *baseModuleContext) OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{}) {
Jooyung Hancd87c692020-02-26 02:05:18 +09001428 b.bp.OtherModuleErrorf(m, fmt, args...)
Colin Cross1184b642019-12-30 18:43:07 -08001429}
1430func (b *baseModuleContext) OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag {
1431 return b.bp.OtherModuleDependencyTag(m)
1432}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001433func (b *baseModuleContext) OtherModuleExists(name string) bool { return b.bp.OtherModuleExists(name) }
1434func (b *baseModuleContext) OtherModuleType(m blueprint.Module) string {
1435 return b.bp.OtherModuleType(m)
1436}
Colin Cross1184b642019-12-30 18:43:07 -08001437
1438func (b *baseModuleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1439 return b.bp.GetDirectDepWithTag(name, tag)
1440}
1441
Colin Cross25de6c32019-06-06 14:29:25 -07001442type moduleContext struct {
Colin Crossdc35e212019-06-06 16:13:11 -07001443 bp blueprint.ModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -07001444 baseModuleContext
Colin Cross897266e2020-02-13 13:22:08 -08001445 installDeps InstallPaths
1446 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001447 checkbuildFiles Paths
Colin Cross8d8f8e22016-08-03 11:57:50 -07001448 module Module
Colin Crosscec81712017-07-13 14:43:27 -07001449
1450 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001451 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001452 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001453 variables map[string]string
Colin Cross6ff51382015-12-17 16:39:19 -08001454}
1455
Colin Crossb88b3c52019-06-10 15:15:17 -07001456func (m *moduleContext) ninjaError(params BuildParams, err error) (PackageContext, BuildParams) {
1457 return pctx, BuildParams{
Colin Cross4b69c492019-06-07 13:06:06 -07001458 Rule: ErrorRule,
1459 Description: params.Description,
1460 Output: params.Output,
1461 Outputs: params.Outputs,
1462 ImplicitOutput: params.ImplicitOutput,
1463 ImplicitOutputs: params.ImplicitOutputs,
Colin Cross6ff51382015-12-17 16:39:19 -08001464 Args: map[string]string{
1465 "error": err.Error(),
1466 },
Colin Crossb88b3c52019-06-10 15:15:17 -07001467 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001468}
1469
Colin Cross25de6c32019-06-06 14:29:25 -07001470func (m *moduleContext) ModuleBuild(pctx PackageContext, params ModuleBuildParams) {
1471 m.Build(pctx, BuildParams(params))
Colin Cross3f40fa42015-01-30 17:27:36 -08001472}
1473
Colin Cross0875c522017-11-28 17:34:01 -08001474func convertBuildParams(params BuildParams) blueprint.BuildParams {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001475 bparams := blueprint.BuildParams{
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001476 Rule: params.Rule,
Colin Cross0875c522017-11-28 17:34:01 -08001477 Description: params.Description,
Colin Cross33bfb0a2016-11-21 17:23:08 -08001478 Deps: params.Deps,
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001479 Outputs: params.Outputs.Strings(),
1480 ImplicitOutputs: params.ImplicitOutputs.Strings(),
1481 Inputs: params.Inputs.Strings(),
1482 Implicits: params.Implicits.Strings(),
1483 OrderOnly: params.OrderOnly.Strings(),
1484 Args: params.Args,
1485 Optional: !params.Default,
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001486 }
1487
Colin Cross33bfb0a2016-11-21 17:23:08 -08001488 if params.Depfile != nil {
1489 bparams.Depfile = params.Depfile.String()
1490 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001491 if params.Output != nil {
1492 bparams.Outputs = append(bparams.Outputs, params.Output.String())
1493 }
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001494 if params.ImplicitOutput != nil {
1495 bparams.ImplicitOutputs = append(bparams.ImplicitOutputs, params.ImplicitOutput.String())
1496 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001497 if params.Input != nil {
1498 bparams.Inputs = append(bparams.Inputs, params.Input.String())
1499 }
1500 if params.Implicit != nil {
1501 bparams.Implicits = append(bparams.Implicits, params.Implicit.String())
1502 }
1503
Colin Cross0b9f31f2019-02-28 11:00:01 -08001504 bparams.Outputs = proptools.NinjaEscapeList(bparams.Outputs)
1505 bparams.ImplicitOutputs = proptools.NinjaEscapeList(bparams.ImplicitOutputs)
1506 bparams.Inputs = proptools.NinjaEscapeList(bparams.Inputs)
1507 bparams.Implicits = proptools.NinjaEscapeList(bparams.Implicits)
1508 bparams.OrderOnly = proptools.NinjaEscapeList(bparams.OrderOnly)
1509 bparams.Depfile = proptools.NinjaEscapeList([]string{bparams.Depfile})[0]
Colin Crossfe4bc362018-09-12 10:02:13 -07001510
Colin Cross0875c522017-11-28 17:34:01 -08001511 return bparams
1512}
1513
Colin Cross25de6c32019-06-06 14:29:25 -07001514func (m *moduleContext) Variable(pctx PackageContext, name, value string) {
1515 if m.config.captureBuild {
1516 m.variables[name] = value
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001517 }
1518
Colin Crossdc35e212019-06-06 16:13:11 -07001519 m.bp.Variable(pctx.PackageContext, name, value)
Colin Cross0875c522017-11-28 17:34:01 -08001520}
1521
Colin Cross25de6c32019-06-06 14:29:25 -07001522func (m *moduleContext) Rule(pctx PackageContext, name string, params blueprint.RuleParams,
Colin Cross0875c522017-11-28 17:34:01 -08001523 argNames ...string) blueprint.Rule {
1524
Ramy Medhat944839a2020-03-31 22:14:52 -04001525 if m.config.UseRemoteBuild() {
1526 if params.Pool == nil {
1527 // When USE_GOMA=true or USE_RBE=true are set and the rule is not supported by goma/RBE, restrict
1528 // jobs to the local parallelism value
1529 params.Pool = localPool
1530 } else if params.Pool == remotePool {
1531 // remotePool is a fake pool used to identify rule that are supported for remoting. If the rule's
1532 // pool is the remotePool, replace with nil so that ninja runs it at NINJA_REMOTE_NUM_JOBS
1533 // parallelism.
1534 params.Pool = nil
1535 }
Colin Cross2e2dbc22019-09-25 13:31:46 -07001536 }
1537
Colin Crossdc35e212019-06-06 16:13:11 -07001538 rule := m.bp.Rule(pctx.PackageContext, name, params, argNames...)
Colin Cross4c83e5c2019-02-25 14:54:28 -08001539
Colin Cross25de6c32019-06-06 14:29:25 -07001540 if m.config.captureBuild {
1541 m.ruleParams[rule] = params
Colin Cross4c83e5c2019-02-25 14:54:28 -08001542 }
1543
1544 return rule
Colin Cross0875c522017-11-28 17:34:01 -08001545}
1546
Colin Cross25de6c32019-06-06 14:29:25 -07001547func (m *moduleContext) Build(pctx PackageContext, params BuildParams) {
Colin Crossb88b3c52019-06-10 15:15:17 -07001548 if params.Description != "" {
1549 params.Description = "${moduleDesc}" + params.Description + "${moduleDescSuffix}"
1550 }
1551
1552 if missingDeps := m.GetMissingDependencies(); len(missingDeps) > 0 {
1553 pctx, params = m.ninjaError(params, fmt.Errorf("module %s missing dependencies: %s\n",
1554 m.ModuleName(), strings.Join(missingDeps, ", ")))
1555 }
1556
Colin Cross25de6c32019-06-06 14:29:25 -07001557 if m.config.captureBuild {
1558 m.buildParams = append(m.buildParams, params)
Colin Cross0875c522017-11-28 17:34:01 -08001559 }
1560
Colin Crossdc35e212019-06-06 16:13:11 -07001561 m.bp.Build(pctx.PackageContext, convertBuildParams(params))
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001562}
Colin Cross25de6c32019-06-06 14:29:25 -07001563func (m *moduleContext) GetMissingDependencies() []string {
Colin Cross6c4f21f2019-06-06 15:41:36 -07001564 var missingDeps []string
1565 missingDeps = append(missingDeps, m.Module().base().commonProperties.MissingDeps...)
Colin Crossdc35e212019-06-06 16:13:11 -07001566 missingDeps = append(missingDeps, m.bp.GetMissingDependencies()...)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001567 missingDeps = FirstUniqueStrings(missingDeps)
1568 return missingDeps
Colin Cross6ff51382015-12-17 16:39:19 -08001569}
1570
Colin Crossdc35e212019-06-06 16:13:11 -07001571func (b *baseModuleContext) AddMissingDependencies(deps []string) {
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001572 if deps != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001573 missingDeps := &b.Module().base().commonProperties.MissingDeps
Colin Cross6c4f21f2019-06-06 15:41:36 -07001574 *missingDeps = append(*missingDeps, deps...)
1575 *missingDeps = FirstUniqueStrings(*missingDeps)
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001576 }
1577}
1578
Colin Crossdc35e212019-06-06 16:13:11 -07001579func (b *baseModuleContext) validateAndroidModule(module blueprint.Module, strict bool) Module {
Colin Crossd11fcda2017-10-23 17:59:01 -07001580 aModule, _ := module.(Module)
Colin Crossdc35e212019-06-06 16:13:11 -07001581
1582 if !strict {
1583 return aModule
1584 }
1585
Colin Cross380c69a2019-06-10 17:49:58 +00001586 if aModule == nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001587 b.ModuleErrorf("module %q not an android module", b.OtherModuleName(module))
Colin Cross380c69a2019-06-10 17:49:58 +00001588 return nil
1589 }
1590
1591 if !aModule.Enabled() {
Colin Crossdc35e212019-06-06 16:13:11 -07001592 if b.Config().AllowMissingDependencies() {
1593 b.AddMissingDependencies([]string{b.OtherModuleName(aModule)})
Colin Cross380c69a2019-06-10 17:49:58 +00001594 } else {
Colin Crossdc35e212019-06-06 16:13:11 -07001595 b.ModuleErrorf("depends on disabled module %q", b.OtherModuleName(aModule))
Colin Cross380c69a2019-06-10 17:49:58 +00001596 }
1597 return nil
1598 }
Colin Crossd11fcda2017-10-23 17:59:01 -07001599 return aModule
1600}
1601
Colin Crossdc35e212019-06-06 16:13:11 -07001602func (b *baseModuleContext) getDirectDepInternal(name string, tag blueprint.DependencyTag) (blueprint.Module, blueprint.DependencyTag) {
Jiyong Parkf2976302019-04-17 21:47:37 +09001603 type dep struct {
1604 mod blueprint.Module
1605 tag blueprint.DependencyTag
1606 }
1607 var deps []dep
Colin Crossdc35e212019-06-06 16:13:11 -07001608 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001609 if aModule, _ := module.(Module); aModule != nil && aModule.base().BaseModuleName() == name {
Colin Cross1184b642019-12-30 18:43:07 -08001610 returnedTag := b.bp.OtherModuleDependencyTag(aModule)
Jiyong Parkf2976302019-04-17 21:47:37 +09001611 if tag == nil || returnedTag == tag {
1612 deps = append(deps, dep{aModule, returnedTag})
1613 }
1614 }
1615 })
1616 if len(deps) == 1 {
1617 return deps[0].mod, deps[0].tag
1618 } else if len(deps) >= 2 {
1619 panic(fmt.Errorf("Multiple dependencies having same BaseModuleName() %q found from %q",
Colin Crossdc35e212019-06-06 16:13:11 -07001620 name, b.ModuleName()))
Jiyong Parkf2976302019-04-17 21:47:37 +09001621 } else {
1622 return nil, nil
1623 }
1624}
1625
Colin Crossdc35e212019-06-06 16:13:11 -07001626func (b *baseModuleContext) GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module {
Colin Cross0ef08162019-05-01 15:50:51 -07001627 var deps []Module
Colin Crossdc35e212019-06-06 16:13:11 -07001628 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001629 if aModule, _ := module.(Module); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001630 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Cross0ef08162019-05-01 15:50:51 -07001631 deps = append(deps, aModule)
1632 }
1633 }
1634 })
1635 return deps
1636}
1637
Colin Cross25de6c32019-06-06 14:29:25 -07001638func (m *moduleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1639 module, _ := m.getDirectDepInternal(name, tag)
1640 return module
Jiyong Parkf2976302019-04-17 21:47:37 +09001641}
1642
Colin Crossdc35e212019-06-06 16:13:11 -07001643func (b *baseModuleContext) GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag) {
1644 return b.getDirectDepInternal(name, nil)
Jiyong Parkf2976302019-04-17 21:47:37 +09001645}
1646
Colin Crossdc35e212019-06-06 16:13:11 -07001647func (b *baseModuleContext) VisitDirectDepsBlueprint(visit func(blueprint.Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001648 b.bp.VisitDirectDeps(visit)
Colin Cross35143d02017-11-16 00:11:20 -08001649}
1650
Colin Crossdc35e212019-06-06 16:13:11 -07001651func (b *baseModuleContext) VisitDirectDeps(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001652 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001653 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001654 visit(aModule)
1655 }
1656 })
1657}
1658
Colin Crossdc35e212019-06-06 16:13:11 -07001659func (b *baseModuleContext) VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001660 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001661 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001662 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Crossee6143c2017-12-30 17:54:27 -08001663 visit(aModule)
1664 }
1665 }
1666 })
1667}
1668
Colin Crossdc35e212019-06-06 16:13:11 -07001669func (b *baseModuleContext) VisitDirectDepsIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001670 b.bp.VisitDirectDepsIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001671 // pred
1672 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001673 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001674 return pred(aModule)
1675 } else {
1676 return false
1677 }
1678 },
1679 // visit
1680 func(module blueprint.Module) {
1681 visit(module.(Module))
1682 })
1683}
1684
Colin Crossdc35e212019-06-06 16:13:11 -07001685func (b *baseModuleContext) VisitDepsDepthFirst(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001686 b.bp.VisitDepsDepthFirst(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001687 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001688 visit(aModule)
1689 }
1690 })
1691}
1692
Colin Crossdc35e212019-06-06 16:13:11 -07001693func (b *baseModuleContext) VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001694 b.bp.VisitDepsDepthFirstIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001695 // pred
1696 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001697 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001698 return pred(aModule)
1699 } else {
1700 return false
1701 }
1702 },
1703 // visit
1704 func(module blueprint.Module) {
1705 visit(module.(Module))
1706 })
1707}
1708
Colin Crossdc35e212019-06-06 16:13:11 -07001709func (b *baseModuleContext) WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool) {
Colin Cross1184b642019-12-30 18:43:07 -08001710 b.bp.WalkDeps(visit)
Alex Light778127a2019-02-27 14:19:50 -08001711}
1712
Colin Crossdc35e212019-06-06 16:13:11 -07001713func (b *baseModuleContext) WalkDeps(visit func(Module, Module) bool) {
1714 b.walkPath = []Module{b.Module()}
Paul Duffinc5192442020-03-31 11:31:36 +01001715 b.tagPath = []blueprint.DependencyTag{}
Colin Cross1184b642019-12-30 18:43:07 -08001716 b.bp.WalkDeps(func(child, parent blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001717 childAndroidModule, _ := child.(Module)
1718 parentAndroidModule, _ := parent.(Module)
Colin Crossd11fcda2017-10-23 17:59:01 -07001719 if childAndroidModule != nil && parentAndroidModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001720 // record walkPath before visit
1721 for b.walkPath[len(b.walkPath)-1] != parentAndroidModule {
1722 b.walkPath = b.walkPath[0 : len(b.walkPath)-1]
Paul Duffinc5192442020-03-31 11:31:36 +01001723 b.tagPath = b.tagPath[0 : len(b.tagPath)-1]
Colin Crossdc35e212019-06-06 16:13:11 -07001724 }
1725 b.walkPath = append(b.walkPath, childAndroidModule)
Paul Duffinc5192442020-03-31 11:31:36 +01001726 b.tagPath = append(b.tagPath, b.OtherModuleDependencyTag(childAndroidModule))
Colin Crossd11fcda2017-10-23 17:59:01 -07001727 return visit(childAndroidModule, parentAndroidModule)
1728 } else {
1729 return false
1730 }
1731 })
1732}
1733
Colin Crossdc35e212019-06-06 16:13:11 -07001734func (b *baseModuleContext) GetWalkPath() []Module {
1735 return b.walkPath
1736}
1737
Paul Duffinc5192442020-03-31 11:31:36 +01001738func (b *baseModuleContext) GetTagPath() []blueprint.DependencyTag {
1739 return b.tagPath
1740}
1741
Jiyong Park1c7e9622020-05-07 16:12:13 +09001742// A regexp for removing boilerplate from BaseDependencyTag from the string representation of
1743// a dependency tag.
1744var tagCleaner = regexp.MustCompile(`\QBaseDependencyTag:blueprint.BaseDependencyTag{}\E(, )?`)
1745
1746// PrettyPrintTag returns string representation of the tag, but prefers
1747// custom String() method if available.
1748func PrettyPrintTag(tag blueprint.DependencyTag) string {
1749 // Use tag's custom String() method if available.
1750 if stringer, ok := tag.(fmt.Stringer); ok {
1751 return stringer.String()
1752 }
1753
1754 // Otherwise, get a default string representation of the tag's struct.
1755 tagString := fmt.Sprintf("%#v", tag)
1756
1757 // Remove the boilerplate from BaseDependencyTag as it adds no value.
1758 tagString = tagCleaner.ReplaceAllString(tagString, "")
1759 return tagString
1760}
1761
1762func (b *baseModuleContext) GetPathString(skipFirst bool) string {
1763 sb := strings.Builder{}
1764 tagPath := b.GetTagPath()
1765 walkPath := b.GetWalkPath()
1766 if !skipFirst {
1767 sb.WriteString(walkPath[0].String())
1768 }
1769 for i, m := range walkPath[1:] {
1770 sb.WriteString("\n")
1771 sb.WriteString(fmt.Sprintf(" via tag %s\n", PrettyPrintTag(tagPath[i])))
1772 sb.WriteString(fmt.Sprintf(" -> %s", m.String()))
1773 }
1774 return sb.String()
1775}
1776
Colin Cross25de6c32019-06-06 14:29:25 -07001777func (m *moduleContext) VisitAllModuleVariants(visit func(Module)) {
Colin Crossdc35e212019-06-06 16:13:11 -07001778 m.bp.VisitAllModuleVariants(func(module blueprint.Module) {
Colin Cross0875c522017-11-28 17:34:01 -08001779 visit(module.(Module))
1780 })
1781}
1782
Colin Cross25de6c32019-06-06 14:29:25 -07001783func (m *moduleContext) PrimaryModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001784 return m.bp.PrimaryModule().(Module)
Colin Cross0875c522017-11-28 17:34:01 -08001785}
1786
Colin Cross25de6c32019-06-06 14:29:25 -07001787func (m *moduleContext) FinalModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001788 return m.bp.FinalModule().(Module)
1789}
1790
1791func (m *moduleContext) ModuleSubDir() string {
1792 return m.bp.ModuleSubDir()
Colin Cross0875c522017-11-28 17:34:01 -08001793}
1794
Colin Cross0ea8ba82019-06-06 14:33:29 -07001795func (b *baseModuleContext) Target() Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001796 return b.target
Colin Crossa1ad8d12016-06-01 17:09:44 -07001797}
1798
Colin Cross0ea8ba82019-06-06 14:33:29 -07001799func (b *baseModuleContext) TargetPrimary() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001800 return b.targetPrimary
Colin Cross8b74d172016-09-13 09:59:14 -07001801}
1802
Colin Cross0ea8ba82019-06-06 14:33:29 -07001803func (b *baseModuleContext) MultiTargets() []Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001804 return b.multiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07001805}
1806
Colin Cross0ea8ba82019-06-06 14:33:29 -07001807func (b *baseModuleContext) Arch() Arch {
Colin Cross25de6c32019-06-06 14:29:25 -07001808 return b.target.Arch
Colin Cross3f40fa42015-01-30 17:27:36 -08001809}
1810
Colin Cross0ea8ba82019-06-06 14:33:29 -07001811func (b *baseModuleContext) Os() OsType {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001812 return b.os
Dan Willemsen490fd492015-11-24 17:53:15 -08001813}
1814
Colin Cross0ea8ba82019-06-06 14:33:29 -07001815func (b *baseModuleContext) Host() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001816 return b.os.Class == Host || b.os.Class == HostCross
Colin Crossf6566ed2015-03-24 11:13:38 -07001817}
1818
Colin Cross0ea8ba82019-06-06 14:33:29 -07001819func (b *baseModuleContext) Device() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001820 return b.os.Class == Device
Colin Crossf6566ed2015-03-24 11:13:38 -07001821}
1822
Colin Cross0ea8ba82019-06-06 14:33:29 -07001823func (b *baseModuleContext) Darwin() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001824 return b.os == Darwin
Colin Cross0af4b842015-04-30 16:36:18 -07001825}
1826
Colin Cross0ea8ba82019-06-06 14:33:29 -07001827func (b *baseModuleContext) Fuchsia() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001828 return b.os == Fuchsia
Doug Horn21b94272019-01-16 12:06:11 -08001829}
1830
Colin Cross0ea8ba82019-06-06 14:33:29 -07001831func (b *baseModuleContext) Windows() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001832 return b.os == Windows
Colin Cross3edeee12017-04-04 12:59:48 -07001833}
1834
Colin Cross0ea8ba82019-06-06 14:33:29 -07001835func (b *baseModuleContext) Debug() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001836 return b.debug
Colin Crossf6566ed2015-03-24 11:13:38 -07001837}
1838
Colin Cross0ea8ba82019-06-06 14:33:29 -07001839func (b *baseModuleContext) PrimaryArch() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001840 if len(b.config.Targets[b.target.Os]) <= 1 {
Colin Cross67a5c132017-05-09 13:45:28 -07001841 return true
1842 }
Colin Cross25de6c32019-06-06 14:29:25 -07001843 return b.target.Arch.ArchType == b.config.Targets[b.target.Os][0].Arch.ArchType
Colin Cross1e7d3702016-08-24 15:25:47 -07001844}
1845
Jiyong Park5baac542018-08-28 09:55:37 +09001846// Makes this module a platform module, i.e. not specific to soc, device,
Justin Yund5f6c822019-06-25 16:47:17 +09001847// product, or system_ext.
Colin Cross4157e882019-06-06 16:57:04 -07001848func (m *ModuleBase) MakeAsPlatform() {
1849 m.commonProperties.Vendor = boolPtr(false)
1850 m.commonProperties.Proprietary = boolPtr(false)
1851 m.commonProperties.Soc_specific = boolPtr(false)
1852 m.commonProperties.Product_specific = boolPtr(false)
Justin Yund5f6c822019-06-25 16:47:17 +09001853 m.commonProperties.System_ext_specific = boolPtr(false)
Jiyong Park5baac542018-08-28 09:55:37 +09001854}
1855
Colin Cross4157e882019-06-06 16:57:04 -07001856func (m *ModuleBase) EnableNativeBridgeSupportByDefault() {
1857 m.commonProperties.Native_bridge_supported = boolPtr(true)
dimitry03dc3f62019-05-09 14:07:34 +02001858}
1859
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001860func (m *ModuleBase) MakeAsSystemExt() {
Jooyung Han91df2082019-11-20 01:49:42 +09001861 m.commonProperties.Vendor = boolPtr(false)
1862 m.commonProperties.Proprietary = boolPtr(false)
1863 m.commonProperties.Soc_specific = boolPtr(false)
1864 m.commonProperties.Product_specific = boolPtr(false)
1865 m.commonProperties.System_ext_specific = boolPtr(true)
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001866}
1867
Jooyung Han344d5432019-08-23 11:17:39 +09001868// IsNativeBridgeSupported returns true if "native_bridge_supported" is explicitly set as "true"
1869func (m *ModuleBase) IsNativeBridgeSupported() bool {
1870 return proptools.Bool(m.commonProperties.Native_bridge_supported)
1871}
1872
Colin Cross25de6c32019-06-06 14:29:25 -07001873func (m *moduleContext) InstallInData() bool {
1874 return m.module.InstallInData()
Dan Willemsen782a2d12015-12-21 14:55:28 -08001875}
1876
Jaewoong Jung0949f312019-09-11 10:25:18 -07001877func (m *moduleContext) InstallInTestcases() bool {
1878 return m.module.InstallInTestcases()
1879}
1880
Colin Cross25de6c32019-06-06 14:29:25 -07001881func (m *moduleContext) InstallInSanitizerDir() bool {
1882 return m.module.InstallInSanitizerDir()
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001883}
1884
Yifan Hong1b3348d2020-01-21 15:53:22 -08001885func (m *moduleContext) InstallInRamdisk() bool {
1886 return m.module.InstallInRamdisk()
1887}
1888
Colin Cross25de6c32019-06-06 14:29:25 -07001889func (m *moduleContext) InstallInRecovery() bool {
1890 return m.module.InstallInRecovery()
Jiyong Parkf9332f12018-02-01 00:54:12 +09001891}
1892
Colin Cross90ba5f42019-10-02 11:10:58 -07001893func (m *moduleContext) InstallInRoot() bool {
1894 return m.module.InstallInRoot()
1895}
1896
Colin Cross607d8582019-07-29 16:44:46 -07001897func (m *moduleContext) InstallBypassMake() bool {
1898 return m.module.InstallBypassMake()
1899}
1900
Colin Cross6e359402020-02-10 15:29:54 -08001901func (m *moduleContext) InstallForceOS() *OsType {
1902 return m.module.InstallForceOS()
1903}
1904
Colin Cross70dda7e2019-10-01 22:05:35 -07001905func (m *moduleContext) skipInstall(fullInstallPath InstallPath) bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001906 if m.module.base().commonProperties.SkipInstall {
Colin Cross893d8162017-04-26 17:34:03 -07001907 return true
1908 }
1909
Colin Cross3607f212018-05-07 15:28:05 -07001910 // We'll need a solution for choosing which of modules with the same name in different
1911 // namespaces to install. For now, reuse the list of namespaces exported to Make as the
1912 // list of namespaces to install in a Soong-only build.
Colin Cross25de6c32019-06-06 14:29:25 -07001913 if !m.module.base().commonProperties.NamespaceExportedToMake {
Colin Cross3607f212018-05-07 15:28:05 -07001914 return true
1915 }
1916
Colin Cross25de6c32019-06-06 14:29:25 -07001917 if m.Device() {
Colin Cross607d8582019-07-29 16:44:46 -07001918 if m.Config().EmbeddedInMake() && !m.InstallBypassMake() {
Colin Cross893d8162017-04-26 17:34:03 -07001919 return true
1920 }
1921
Colin Cross25de6c32019-06-06 14:29:25 -07001922 if m.Config().SkipMegaDeviceInstall(fullInstallPath.String()) {
Colin Cross893d8162017-04-26 17:34:03 -07001923 return true
1924 }
1925 }
1926
1927 return false
1928}
1929
Colin Cross70dda7e2019-10-01 22:05:35 -07001930func (m *moduleContext) InstallFile(installPath InstallPath, name string, srcPath Path,
1931 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001932 return m.installFile(installPath, name, srcPath, Cp, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001933}
1934
Colin Cross70dda7e2019-10-01 22:05:35 -07001935func (m *moduleContext) InstallExecutable(installPath InstallPath, name string, srcPath Path,
1936 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001937 return m.installFile(installPath, name, srcPath, CpExecutable, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001938}
1939
Colin Cross70dda7e2019-10-01 22:05:35 -07001940func (m *moduleContext) installFile(installPath InstallPath, name string, srcPath Path,
1941 rule blueprint.Rule, deps []Path) InstallPath {
Colin Cross35cec122015-04-02 14:37:16 -07001942
Colin Cross25de6c32019-06-06 14:29:25 -07001943 fullInstallPath := installPath.Join(m, name)
1944 m.module.base().hooks.runInstallHooks(m, fullInstallPath, false)
Colin Cross3f40fa42015-01-30 17:27:36 -08001945
Colin Cross25de6c32019-06-06 14:29:25 -07001946 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001947
Colin Cross897266e2020-02-13 13:22:08 -08001948 deps = append(deps, m.installDeps.Paths()...)
Colin Cross35cec122015-04-02 14:37:16 -07001949
Colin Cross89562dc2016-10-03 17:47:19 -07001950 var implicitDeps, orderOnlyDeps Paths
1951
Colin Cross25de6c32019-06-06 14:29:25 -07001952 if m.Host() {
Colin Cross89562dc2016-10-03 17:47:19 -07001953 // Installed host modules might be used during the build, depend directly on their
1954 // dependencies so their timestamp is updated whenever their dependency is updated
1955 implicitDeps = deps
1956 } else {
1957 orderOnlyDeps = deps
1958 }
1959
Colin Cross25de6c32019-06-06 14:29:25 -07001960 m.Build(pctx, BuildParams{
Colin Cross5c517922017-08-31 12:29:17 -07001961 Rule: rule,
Colin Cross67a5c132017-05-09 13:45:28 -07001962 Description: "install " + fullInstallPath.Base(),
1963 Output: fullInstallPath,
1964 Input: srcPath,
1965 Implicits: implicitDeps,
1966 OrderOnly: orderOnlyDeps,
Colin Cross25de6c32019-06-06 14:29:25 -07001967 Default: !m.Config().EmbeddedInMake(),
Dan Willemsen322acaf2016-01-12 23:07:05 -08001968 })
Colin Cross3f40fa42015-01-30 17:27:36 -08001969
Colin Cross25de6c32019-06-06 14:29:25 -07001970 m.installFiles = append(m.installFiles, fullInstallPath)
Dan Willemsen322acaf2016-01-12 23:07:05 -08001971 }
Colin Cross25de6c32019-06-06 14:29:25 -07001972 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross35cec122015-04-02 14:37:16 -07001973 return fullInstallPath
1974}
1975
Colin Cross70dda7e2019-10-01 22:05:35 -07001976func (m *moduleContext) InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001977 fullInstallPath := installPath.Join(m, name)
1978 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Colin Cross3854a602016-01-11 12:49:11 -08001979
Colin Cross25de6c32019-06-06 14:29:25 -07001980 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001981
Alex Lightfb4353d2019-01-17 13:57:45 -08001982 relPath, err := filepath.Rel(path.Dir(fullInstallPath.String()), srcPath.String())
1983 if err != nil {
1984 panic(fmt.Sprintf("Unable to generate symlink between %q and %q: %s", fullInstallPath.Base(), srcPath.Base(), err))
1985 }
Colin Cross25de6c32019-06-06 14:29:25 -07001986 m.Build(pctx, BuildParams{
Colin Cross67a5c132017-05-09 13:45:28 -07001987 Rule: Symlink,
1988 Description: "install symlink " + fullInstallPath.Base(),
1989 Output: fullInstallPath,
Dan Willemsen40efa1c2020-01-14 15:19:52 -08001990 Input: srcPath,
Colin Cross25de6c32019-06-06 14:29:25 -07001991 Default: !m.Config().EmbeddedInMake(),
Colin Cross12fc4972016-01-11 12:49:11 -08001992 Args: map[string]string{
Alex Lightfb4353d2019-01-17 13:57:45 -08001993 "fromPath": relPath,
Colin Cross12fc4972016-01-11 12:49:11 -08001994 },
1995 })
Colin Cross3854a602016-01-11 12:49:11 -08001996
Colin Cross25de6c32019-06-06 14:29:25 -07001997 m.installFiles = append(m.installFiles, fullInstallPath)
1998 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross12fc4972016-01-11 12:49:11 -08001999 }
Colin Cross3854a602016-01-11 12:49:11 -08002000 return fullInstallPath
2001}
2002
Jiyong Parkf1194352019-02-25 11:05:47 +09002003// installPath/name -> absPath where absPath might be a path that is available only at runtime
2004// (e.g. /apex/...)
Colin Cross70dda7e2019-10-01 22:05:35 -07002005func (m *moduleContext) InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002006 fullInstallPath := installPath.Join(m, name)
2007 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Jiyong Parkf1194352019-02-25 11:05:47 +09002008
Colin Cross25de6c32019-06-06 14:29:25 -07002009 if !m.skipInstall(fullInstallPath) {
2010 m.Build(pctx, BuildParams{
Jiyong Parkf1194352019-02-25 11:05:47 +09002011 Rule: Symlink,
2012 Description: "install symlink " + fullInstallPath.Base() + " -> " + absPath,
2013 Output: fullInstallPath,
Colin Cross25de6c32019-06-06 14:29:25 -07002014 Default: !m.Config().EmbeddedInMake(),
Jiyong Parkf1194352019-02-25 11:05:47 +09002015 Args: map[string]string{
2016 "fromPath": absPath,
2017 },
2018 })
2019
Colin Cross25de6c32019-06-06 14:29:25 -07002020 m.installFiles = append(m.installFiles, fullInstallPath)
Jiyong Parkf1194352019-02-25 11:05:47 +09002021 }
2022 return fullInstallPath
2023}
2024
Colin Cross25de6c32019-06-06 14:29:25 -07002025func (m *moduleContext) CheckbuildFile(srcPath Path) {
2026 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross3f40fa42015-01-30 17:27:36 -08002027}
2028
Dan Willemsen2ef08f42015-06-30 18:15:24 -07002029func findStringInSlice(str string, slice []string) int {
2030 for i, s := range slice {
2031 if s == str {
2032 return i
Colin Crossfce53272015-04-08 11:21:40 -07002033 }
2034 }
Dan Willemsen2ef08f42015-06-30 18:15:24 -07002035 return -1
2036}
2037
Colin Cross41955e82019-05-29 14:40:35 -07002038// SrcIsModule decodes module references in the format ":name" into the module name, or empty string if the input
2039// was not a module reference.
2040func SrcIsModule(s string) (module string) {
Colin Cross068e0fe2016-12-13 15:23:47 -08002041 if len(s) > 1 && s[0] == ':' {
2042 return s[1:]
2043 }
2044 return ""
2045}
2046
Colin Cross41955e82019-05-29 14:40:35 -07002047// SrcIsModule decodes module references in the format ":name{.tag}" into the module name and tag, ":name" into the
2048// module name and an empty string for the tag, or empty strings if the input was not a module reference.
2049func SrcIsModuleWithTag(s string) (module, tag string) {
2050 if len(s) > 1 && s[0] == ':' {
2051 module = s[1:]
2052 if tagStart := strings.IndexByte(module, '{'); tagStart > 0 {
2053 if module[len(module)-1] == '}' {
2054 tag = module[tagStart+1 : len(module)-1]
2055 module = module[:tagStart]
2056 return module, tag
2057 }
2058 }
2059 return module, ""
2060 }
2061 return "", ""
Colin Cross068e0fe2016-12-13 15:23:47 -08002062}
2063
Colin Cross41955e82019-05-29 14:40:35 -07002064type sourceOrOutputDependencyTag struct {
2065 blueprint.BaseDependencyTag
2066 tag string
2067}
2068
2069func sourceOrOutputDepTag(tag string) blueprint.DependencyTag {
2070 return sourceOrOutputDependencyTag{tag: tag}
2071}
2072
2073var SourceDepTag = sourceOrOutputDepTag("")
Colin Cross068e0fe2016-12-13 15:23:47 -08002074
Colin Cross366938f2017-12-11 16:29:02 -08002075// Adds necessary dependencies to satisfy filegroup or generated sources modules listed in srcFiles
2076// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002077//
2078// Deprecated: tag the property with `android:"path"` instead.
Colin Cross068e0fe2016-12-13 15:23:47 -08002079func ExtractSourcesDeps(ctx BottomUpMutatorContext, srcFiles []string) {
Nan Zhang2439eb72017-04-10 11:27:50 -07002080 set := make(map[string]bool)
2081
Colin Cross068e0fe2016-12-13 15:23:47 -08002082 for _, s := range srcFiles {
Colin Cross41955e82019-05-29 14:40:35 -07002083 if m, t := SrcIsModuleWithTag(s); m != "" {
2084 if _, found := set[s]; found {
2085 ctx.ModuleErrorf("found source dependency duplicate: %q!", s)
Nan Zhang2439eb72017-04-10 11:27:50 -07002086 } else {
Colin Cross41955e82019-05-29 14:40:35 -07002087 set[s] = true
2088 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Nan Zhang2439eb72017-04-10 11:27:50 -07002089 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002090 }
2091 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002092}
2093
Colin Cross366938f2017-12-11 16:29:02 -08002094// Adds necessary dependencies to satisfy filegroup or generated sources modules specified in s
2095// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002096//
2097// Deprecated: tag the property with `android:"path"` instead.
Colin Cross366938f2017-12-11 16:29:02 -08002098func ExtractSourceDeps(ctx BottomUpMutatorContext, s *string) {
2099 if s != nil {
Colin Cross41955e82019-05-29 14:40:35 -07002100 if m, t := SrcIsModuleWithTag(*s); m != "" {
2101 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Colin Cross366938f2017-12-11 16:29:02 -08002102 }
2103 }
2104}
2105
Colin Cross41955e82019-05-29 14:40:35 -07002106// A module that implements SourceFileProducer can be referenced from any property that is tagged with `android:"path"`
2107// 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 -08002108type SourceFileProducer interface {
2109 Srcs() Paths
2110}
2111
Colin Cross41955e82019-05-29 14:40:35 -07002112// A module that implements OutputFileProducer can be referenced from any property that is tagged with `android:"path"`
Roland Levillain97c1f342019-11-22 14:20:54 +00002113// 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 -07002114// listed in the property.
2115type OutputFileProducer interface {
2116 OutputFiles(tag string) (Paths, error)
2117}
2118
Colin Cross5e708052019-08-06 13:59:50 -07002119// OutputFilesForModule returns the paths from an OutputFileProducer with the given tag. On error, including if the
2120// module produced zero paths, it reports errors to the ctx and returns nil.
2121func OutputFilesForModule(ctx PathContext, module blueprint.Module, tag string) Paths {
2122 paths, err := outputFilesForModule(ctx, module, tag)
2123 if err != nil {
2124 reportPathError(ctx, err)
2125 return nil
2126 }
2127 return paths
2128}
2129
2130// OutputFileForModule returns the path from an OutputFileProducer with the given tag. On error, including if the
2131// module produced zero or multiple paths, it reports errors to the ctx and returns nil.
2132func OutputFileForModule(ctx PathContext, module blueprint.Module, tag string) Path {
2133 paths, err := outputFilesForModule(ctx, module, tag)
2134 if err != nil {
2135 reportPathError(ctx, err)
2136 return nil
2137 }
2138 if len(paths) > 1 {
2139 reportPathErrorf(ctx, "got multiple output files from module %q, expected exactly one",
2140 pathContextName(ctx, module))
2141 return nil
2142 }
2143 return paths[0]
2144}
2145
2146func outputFilesForModule(ctx PathContext, module blueprint.Module, tag string) (Paths, error) {
2147 if outputFileProducer, ok := module.(OutputFileProducer); ok {
2148 paths, err := outputFileProducer.OutputFiles(tag)
2149 if err != nil {
2150 return nil, fmt.Errorf("failed to get output file from module %q: %s",
2151 pathContextName(ctx, module), err.Error())
2152 }
2153 if len(paths) == 0 {
2154 return nil, fmt.Errorf("failed to get output files from module %q", pathContextName(ctx, module))
2155 }
2156 return paths, nil
2157 } else {
2158 return nil, fmt.Errorf("module %q is not an OutputFileProducer", pathContextName(ctx, module))
2159 }
2160}
2161
Colin Crossfe17f6f2019-03-28 19:30:56 -07002162type HostToolProvider interface {
2163 HostToolPath() OptionalPath
2164}
2165
Colin Cross27b922f2019-03-04 22:35:41 -08002166// Returns a list of paths expanded from globs and modules referenced using ":module" syntax. The property must
2167// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002168//
2169// Deprecated: use PathsForModuleSrc or PathsForModuleSrcExcludes instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002170func (m *moduleContext) ExpandSources(srcFiles, excludes []string) Paths {
2171 return PathsForModuleSrcExcludes(m, srcFiles, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07002172}
2173
Colin Cross2fafa3e2019-03-05 12:39:51 -08002174// Returns a single path expanded from globs and modules referenced using ":module" syntax. The property must
2175// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002176//
2177// Deprecated: use PathForModuleSrc instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002178func (m *moduleContext) ExpandSource(srcFile, prop string) Path {
2179 return PathForModuleSrc(m, srcFile)
Colin Cross2fafa3e2019-03-05 12:39:51 -08002180}
2181
2182// Returns an optional single path expanded from globs and modules referenced using ":module" syntax if
2183// the srcFile is non-nil. The property must be tagged with `android:"path" to support automatic source module
2184// dependency resolution.
Colin Cross25de6c32019-06-06 14:29:25 -07002185func (m *moduleContext) ExpandOptionalSource(srcFile *string, prop string) OptionalPath {
Colin Cross2fafa3e2019-03-05 12:39:51 -08002186 if srcFile != nil {
Colin Cross25de6c32019-06-06 14:29:25 -07002187 return OptionalPathForPath(PathForModuleSrc(m, *srcFile))
Colin Cross2fafa3e2019-03-05 12:39:51 -08002188 }
2189 return OptionalPath{}
2190}
2191
Colin Cross25de6c32019-06-06 14:29:25 -07002192func (m *moduleContext) RequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002193 return m.module.RequiredModuleNames()
Nan Zhang6d34b302017-02-04 17:47:46 -08002194}
2195
Colin Cross25de6c32019-06-06 14:29:25 -07002196func (m *moduleContext) HostRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002197 return m.module.HostRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002198}
2199
Colin Cross25de6c32019-06-06 14:29:25 -07002200func (m *moduleContext) TargetRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002201 return m.module.TargetRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002202}
2203
Colin Cross463a90e2015-06-17 14:20:06 -07002204func init() {
Colin Cross798bfce2016-10-12 14:28:16 -07002205 RegisterSingletonType("buildtarget", BuildTargetSingleton)
Colin Cross463a90e2015-06-17 14:20:06 -07002206}
2207
Colin Cross0875c522017-11-28 17:34:01 -08002208func BuildTargetSingleton() Singleton {
Colin Cross1f8c52b2015-06-16 16:38:17 -07002209 return &buildTargetSingleton{}
2210}
2211
Colin Cross87d8b562017-04-25 10:01:55 -07002212func parentDir(dir string) string {
2213 dir, _ = filepath.Split(dir)
2214 return filepath.Clean(dir)
2215}
2216
Colin Cross1f8c52b2015-06-16 16:38:17 -07002217type buildTargetSingleton struct{}
2218
Colin Cross0875c522017-11-28 17:34:01 -08002219func (c *buildTargetSingleton) GenerateBuildActions(ctx SingletonContext) {
2220 var checkbuildDeps Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07002221
Colin Cross0875c522017-11-28 17:34:01 -08002222 mmTarget := func(dir string) WritablePath {
2223 return PathForPhony(ctx,
2224 "MODULES-IN-"+strings.Replace(filepath.Clean(dir), "/", "-", -1))
Colin Cross87d8b562017-04-25 10:01:55 -07002225 }
2226
Colin Cross0875c522017-11-28 17:34:01 -08002227 modulesInDir := make(map[string]Paths)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002228
Colin Cross0875c522017-11-28 17:34:01 -08002229 ctx.VisitAllModules(func(module Module) {
2230 blueprintDir := module.base().blueprintDir
2231 installTarget := module.base().installTarget
2232 checkbuildTarget := module.base().checkbuildTarget
Colin Cross1f8c52b2015-06-16 16:38:17 -07002233
Colin Cross0875c522017-11-28 17:34:01 -08002234 if checkbuildTarget != nil {
2235 checkbuildDeps = append(checkbuildDeps, checkbuildTarget)
2236 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], checkbuildTarget)
2237 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002238
Colin Cross0875c522017-11-28 17:34:01 -08002239 if installTarget != nil {
2240 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], installTarget)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002241 }
2242 })
2243
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002244 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08002245 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002246 suffix = "-soong"
2247 }
2248
Colin Cross1f8c52b2015-06-16 16:38:17 -07002249 // Create a top-level checkbuild target that depends on all modules
Colin Cross0875c522017-11-28 17:34:01 -08002250 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07002251 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002252 Output: PathForPhony(ctx, "checkbuild"+suffix),
Colin Cross1f8c52b2015-06-16 16:38:17 -07002253 Implicits: checkbuildDeps,
Colin Cross1f8c52b2015-06-16 16:38:17 -07002254 })
2255
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002256 // Make will generate the MODULES-IN-* targets
Colin Crossaabf6792017-11-29 00:27:14 -08002257 if ctx.Config().EmbeddedInMake() {
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002258 return
2259 }
2260
Colin Cross87d8b562017-04-25 10:01:55 -07002261 // Ensure ancestor directories are in modulesInDir
Inseob Kim1a365c62019-06-08 15:47:51 +09002262 dirs := SortedStringKeys(modulesInDir)
Colin Cross87d8b562017-04-25 10:01:55 -07002263 for _, dir := range dirs {
2264 dir := parentDir(dir)
2265 for dir != "." && dir != "/" {
2266 if _, exists := modulesInDir[dir]; exists {
2267 break
2268 }
2269 modulesInDir[dir] = nil
2270 dir = parentDir(dir)
2271 }
2272 }
2273
2274 // Make directories build their direct subdirectories
Colin Cross87d8b562017-04-25 10:01:55 -07002275 for _, dir := range dirs {
2276 p := parentDir(dir)
2277 if p != "." && p != "/" {
2278 modulesInDir[p] = append(modulesInDir[p], mmTarget(dir))
2279 }
2280 }
2281
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002282 // Create a MODULES-IN-<directory> target that depends on all modules in a directory, and
2283 // depends on the MODULES-IN-* targets of all of its subdirectories that contain Android.bp
2284 // files.
Colin Cross1f8c52b2015-06-16 16:38:17 -07002285 for _, dir := range dirs {
Colin Cross0875c522017-11-28 17:34:01 -08002286 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07002287 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002288 Output: mmTarget(dir),
Colin Cross87d8b562017-04-25 10:01:55 -07002289 Implicits: modulesInDir[dir],
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002290 // HACK: checkbuild should be an optional build, but force it
2291 // enabled for now in standalone builds
Colin Crossaabf6792017-11-29 00:27:14 -08002292 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross1f8c52b2015-06-16 16:38:17 -07002293 })
2294 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002295
2296 // Create (host|host-cross|target)-<OS> phony rules to build a reduced checkbuild.
2297 osDeps := map[OsType]Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08002298 ctx.VisitAllModules(func(module Module) {
2299 if module.Enabled() {
2300 os := module.Target().Os
2301 osDeps[os] = append(osDeps[os], module.base().checkbuildFiles...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002302 }
2303 })
2304
Colin Cross0875c522017-11-28 17:34:01 -08002305 osClass := make(map[string]Paths)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002306 for os, deps := range osDeps {
2307 var className string
2308
2309 switch os.Class {
2310 case Host:
2311 className = "host"
2312 case HostCross:
2313 className = "host-cross"
2314 case Device:
2315 className = "target"
2316 default:
2317 continue
2318 }
2319
Colin Cross0875c522017-11-28 17:34:01 -08002320 name := PathForPhony(ctx, className+"-"+os.Name)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002321 osClass[className] = append(osClass[className], name)
2322
Colin Cross0875c522017-11-28 17:34:01 -08002323 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07002324 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002325 Output: name,
2326 Implicits: deps,
Dan Willemsen61d88b82017-09-20 17:29:08 -07002327 })
2328 }
2329
2330 // Wrap those into host|host-cross|target phony rules
Inseob Kim1a365c62019-06-08 15:47:51 +09002331 for _, class := range SortedStringKeys(osClass) {
Colin Cross0875c522017-11-28 17:34:01 -08002332 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07002333 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002334 Output: PathForPhony(ctx, class),
Dan Willemsen61d88b82017-09-20 17:29:08 -07002335 Implicits: osClass[class],
Dan Willemsen61d88b82017-09-20 17:29:08 -07002336 })
2337 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002338}
Colin Crossd779da42015-12-17 18:00:23 -08002339
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002340// Collect information for opening IDE project files in java/jdeps.go.
2341type IDEInfo interface {
2342 IDEInfo(ideInfo *IdeInfo)
2343 BaseModuleName() string
2344}
2345
2346// Extract the base module name from the Import name.
2347// Often the Import name has a prefix "prebuilt_".
2348// Remove the prefix explicitly if needed
2349// until we find a better solution to get the Import name.
2350type IDECustomizedModuleName interface {
2351 IDECustomizedModuleName() string
2352}
2353
2354type IdeInfo struct {
2355 Deps []string `json:"dependencies,omitempty"`
2356 Srcs []string `json:"srcs,omitempty"`
2357 Aidl_include_dirs []string `json:"aidl_include_dirs,omitempty"`
2358 Jarjar_rules []string `json:"jarjar_rules,omitempty"`
2359 Jars []string `json:"jars,omitempty"`
2360 Classes []string `json:"class,omitempty"`
2361 Installed_paths []string `json:"installed,omitempty"`
patricktu18c82ff2019-05-10 15:48:50 +08002362 SrcJars []string `json:"srcjars,omitempty"`
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002363}