blob: e431adaf4daed59b44e452d9fc495cc355e92c76 [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
260 // Get the visibility rules that control the visibility of this module.
261 visibility() []string
Jiyong Park6a8cf5f2019-12-30 16:31:09 +0900262
263 RequiredModuleNames() []string
264 HostRequiredModuleNames() []string
265 TargetRequiredModuleNames() []string
Colin Cross897266e2020-02-13 13:22:08 -0800266
267 filesToInstall() InstallPaths
Paul Duffine2453c72019-05-31 14:00:04 +0100268}
269
270// Qualified id for a module
271type qualifiedModuleName struct {
272 // The package (i.e. directory) in which the module is defined, without trailing /
273 pkg string
274
275 // The name of the module, empty string if package.
276 name string
277}
278
279func (q qualifiedModuleName) String() string {
280 if q.name == "" {
281 return "//" + q.pkg
282 }
283 return "//" + q.pkg + ":" + q.name
284}
285
Paul Duffine484f472019-06-20 16:38:08 +0100286func (q qualifiedModuleName) isRootPackage() bool {
287 return q.pkg == "" && q.name == ""
288}
289
Paul Duffine2453c72019-05-31 14:00:04 +0100290// Get the id for the package containing this module.
291func (q qualifiedModuleName) getContainingPackageId() qualifiedModuleName {
292 pkg := q.pkg
293 if q.name == "" {
Paul Duffine484f472019-06-20 16:38:08 +0100294 if pkg == "" {
295 panic(fmt.Errorf("Cannot get containing package id of root package"))
296 }
297
298 index := strings.LastIndex(pkg, "/")
299 if index == -1 {
300 pkg = ""
301 } else {
302 pkg = pkg[:index]
303 }
Paul Duffine2453c72019-05-31 14:00:04 +0100304 }
305 return newPackageId(pkg)
306}
307
308func newPackageId(pkg string) qualifiedModuleName {
309 // A qualified id for a package module has no name.
310 return qualifiedModuleName{pkg: pkg, name: ""}
Colin Cross3f40fa42015-01-30 17:27:36 -0800311}
312
Colin Crossfc754582016-05-17 16:34:16 -0700313type nameProperties struct {
314 // The name of the module. Must be unique across all modules.
Nan Zhang0007d812017-11-07 10:57:05 -0800315 Name *string
Colin Crossfc754582016-05-17 16:34:16 -0700316}
317
318type commonProperties struct {
Dan Willemsen0effe062015-11-30 16:06:01 -0800319 // emit build rules for this module
Paul Duffin54d9bb72020-02-12 10:20:56 +0000320 //
321 // Disabling a module should only be done for those modules that cannot be built
322 // in the current environment. Modules that can build in the current environment
323 // but are not usually required (e.g. superceded by a prebuilt) should not be
324 // disabled as that will prevent them from being built by the checkbuild target
325 // and so prevent early detection of changes that have broken those modules.
Dan Willemsen0effe062015-11-30 16:06:01 -0800326 Enabled *bool `android:"arch_variant"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800327
Paul Duffin2e61fa62019-03-28 14:10:57 +0000328 // Controls the visibility of this module to other modules. Allowable values are one or more of
329 // these formats:
330 //
331 // ["//visibility:public"]: Anyone can use this module.
332 // ["//visibility:private"]: Only rules in the module's package (not its subpackages) can use
333 // this module.
334 // ["//some/package:__pkg__", "//other/package:__pkg__"]: Only modules in some/package and
335 // other/package (defined in some/package/*.bp and other/package/*.bp) have access to
336 // this module. Note that sub-packages do not have access to the rule; for example,
337 // //some/package/foo:bar or //other/package/testing:bla wouldn't have access. __pkg__
338 // is a special module and must be used verbatim. It represents all of the modules in the
339 // package.
340 // ["//project:__subpackages__", "//other:__subpackages__"]: Only modules in packages project
341 // or other or in one of their sub-packages have access to this module. For example,
342 // //project:rule, //project/library:lib or //other/testing/internal:munge are allowed
343 // to depend on this rule (but not //independent:evil)
344 // ["//project"]: This is shorthand for ["//project:__pkg__"]
345 // [":__subpackages__"]: This is shorthand for ["//project:__subpackages__"] where
346 // //project is the module's package. e.g. using [":__subpackages__"] in
347 // packages/apps/Settings/Android.bp is equivalent to
348 // //packages/apps/Settings:__subpackages__.
349 // ["//visibility:legacy_public"]: The default visibility, behaves as //visibility:public
350 // for now. It is an error if it is used in a module.
Paul Duffine2453c72019-05-31 14:00:04 +0100351 //
352 // If a module does not specify the `visibility` property then it uses the
353 // `default_visibility` property of the `package` module in the module's package.
354 //
355 // If the `default_visibility` property is not set for the module's package then
Paul Duffine484f472019-06-20 16:38:08 +0100356 // it will use the `default_visibility` of its closest ancestor package for which
357 // a `default_visibility` property is specified.
358 //
359 // If no `default_visibility` property can be found then the module uses the
360 // global default of `//visibility:legacy_public`.
Paul Duffine2453c72019-05-31 14:00:04 +0100361 //
Paul Duffin95d53b52019-07-24 13:45:05 +0100362 // The `visibility` property has no effect on a defaults module although it does
363 // apply to any non-defaults module that uses it. To set the visibility of a
364 // defaults module, use the `defaults_visibility` property on the defaults module;
365 // not to be confused with the `default_visibility` property on the package module.
366 //
Paul Duffin2e61fa62019-03-28 14:10:57 +0000367 // See https://android.googlesource.com/platform/build/soong/+/master/README.md#visibility for
368 // more details.
369 Visibility []string
370
Colin Cross7d5136f2015-05-11 13:39:40 -0700371 // control whether this module compiles for 32-bit, 64-bit, or both. Possible values
Colin Cross3f40fa42015-01-30 17:27:36 -0800372 // are "32" (compile for 32-bit only), "64" (compile for 64-bit only), "both" (compile for both
373 // architectures), or "first" (compile for 64-bit on a 64-bit platform, and 32-bit on a 32-bit
374 // platform
Colin Cross7d716ba2017-11-01 10:38:29 -0700375 Compile_multilib *string `android:"arch_variant"`
Colin Cross69617d32016-09-06 10:39:07 -0700376
377 Target struct {
378 Host struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700379 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700380 }
381 Android struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700382 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700383 }
384 }
385
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000386 // If set to true then the archMutator will create variants for each arch specific target
387 // (e.g. 32/64) that the module is required to produce. If set to false then it will only
388 // create a variant for the architecture and will list the additional arch specific targets
389 // that the variant needs to produce in the CompileMultiTargets property.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700390 UseTargetVariants bool `blueprint:"mutated"`
391 Default_multilib string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800392
Dan Willemsen782a2d12015-12-21 14:55:28 -0800393 // whether this is a proprietary vendor module, and should be installed into /vendor
Colin Cross7d716ba2017-11-01 10:38:29 -0700394 Proprietary *bool
Dan Willemsen782a2d12015-12-21 14:55:28 -0800395
Colin Cross55708f32017-03-20 13:23:34 -0700396 // vendor who owns this module
Dan Willemsenefac4a82017-07-18 19:42:09 -0700397 Owner *string
Colin Cross55708f32017-03-20 13:23:34 -0700398
Jiyong Park2db76922017-11-08 16:03:48 +0900399 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
400 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
401 // Use `soc_specific` instead for better meaning.
Colin Cross7d716ba2017-11-01 10:38:29 -0700402 Vendor *bool
Dan Willemsenaa118f92017-04-06 12:49:58 -0700403
Jiyong Park2db76922017-11-08 16:03:48 +0900404 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
405 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
406 Soc_specific *bool
407
408 // whether this module is specific to a device, not only for SoC, but also for off-chip
409 // peripherals. When set to true, it is installed into /odm (or /vendor/odm if odm partition
410 // does not exist, or /system/vendor/odm if both odm and vendor partitions do not exist).
411 // This implies `soc_specific:true`.
412 Device_specific *bool
413
414 // whether this module is specific to a software configuration of a product (e.g. country,
Jaekyun Seok5cfbfbb2018-01-10 19:00:15 +0900415 // network operator, etc). When set to true, it is installed into /product (or
416 // /system/product if product partition does not exist).
Jiyong Park2db76922017-11-08 16:03:48 +0900417 Product_specific *bool
418
Justin Yund5f6c822019-06-25 16:47:17 +0900419 // whether this module extends system. When set to true, it is installed into /system_ext
420 // (or /system/system_ext if system_ext partition does not exist).
421 System_ext_specific *bool
422
Jiyong Parkf9332f12018-02-01 00:54:12 +0900423 // Whether this module is installed to recovery partition
424 Recovery *bool
425
Yifan Hong1b3348d2020-01-21 15:53:22 -0800426 // Whether this module is installed to ramdisk
427 Ramdisk *bool
428
dimitry1f33e402019-03-26 12:39:31 +0100429 // Whether this module is built for non-native architecures (also known as native bridge binary)
430 Native_bridge_supported *bool `android:"arch_variant"`
431
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700432 // init.rc files to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800433 Init_rc []string `android:"path"`
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700434
Steven Moreland57a23d22018-04-04 15:42:19 -0700435 // VINTF manifest fragments to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800436 Vintf_fragments []string `android:"path"`
Steven Moreland57a23d22018-04-04 15:42:19 -0700437
Chris Wolfe998306e2016-08-15 14:47:23 -0400438 // names of other modules to install if this module is installed
Colin Crossc602b7d2017-05-05 13:36:36 -0700439 Required []string `android:"arch_variant"`
Chris Wolfe998306e2016-08-15 14:47:23 -0400440
Sasha Smundakb6d23052019-04-01 18:37:36 -0700441 // names of other modules to install on host if this module is installed
442 Host_required []string `android:"arch_variant"`
443
444 // names of other modules to install on target if this module is installed
445 Target_required []string `android:"arch_variant"`
446
Colin Cross5aac3622017-08-31 15:07:09 -0700447 // relative path to a file to include in the list of notices for the device
Colin Cross27b922f2019-03-04 22:35:41 -0800448 Notice *string `android:"path"`
Colin Cross5aac3622017-08-31 15:07:09 -0700449
Dan Willemsen569edc52018-11-19 09:33:29 -0800450 Dist struct {
451 // copy the output of this module to the $DIST_DIR when `dist` is specified on the
452 // command line and any of these targets are also on the command line, or otherwise
453 // built
454 Targets []string `android:"arch_variant"`
455
456 // The name of the output artifact. This defaults to the basename of the output of
457 // the module.
458 Dest *string `android:"arch_variant"`
459
460 // The directory within the dist directory to store the artifact. Defaults to the
461 // top level directory ("").
462 Dir *string `android:"arch_variant"`
463
464 // A suffix to add to the artifact file name (before any extension).
465 Suffix *string `android:"arch_variant"`
466 } `android:"arch_variant"`
467
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000468 // The OsType of artifacts that this module variant is responsible for creating.
469 //
470 // Set by osMutator
471 CompileOS OsType `blueprint:"mutated"`
472
473 // The Target of artifacts that this module variant is responsible for creating.
474 //
475 // Set by archMutator
476 CompileTarget Target `blueprint:"mutated"`
477
478 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
479 // responsible for creating.
480 //
481 // By default this is nil as, where necessary, separate variants are created for the
482 // different multilib types supported and that information is encapsulated in the
483 // CompileTarget so the module variant simply needs to create artifacts for that.
484 //
485 // However, if UseTargetVariants is set to false (e.g. by
486 // InitAndroidMultiTargetsArchModule) then no separate variants are created for the
487 // multilib targets. Instead a single variant is created for the architecture and
488 // this contains the multilib specific targets that this variant should create.
489 //
490 // Set by archMutator
Colin Crossee0bc3b2018-10-02 22:01:37 -0700491 CompileMultiTargets []Target `blueprint:"mutated"`
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000492
493 // True if the module variant's CompileTarget is the primary target
494 //
495 // Set by archMutator
496 CompilePrimary bool `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800497
498 // Set by InitAndroidModule
499 HostOrDeviceSupported HostOrDeviceSupported `blueprint:"mutated"`
Dan Willemsen0b24c742016-10-04 15:13:37 -0700500 ArchSpecific bool `blueprint:"mutated"`
Colin Crossce75d2c2016-10-06 16:12:58 -0700501
Paul Duffin1356d8c2020-02-25 19:26:33 +0000502 // If set to true then a CommonOS variant will be created which will have dependencies
503 // on all its OsType specific variants. Used by sdk/module_exports to create a snapshot
504 // that covers all os and architecture variants.
505 //
506 // The OsType specific variants can be retrieved by calling
507 // GetOsSpecificVariantsOfCommonOSVariant
508 //
509 // Set at module initialization time by calling InitCommonOSAndroidMultiTargetsArchModule
510 CreateCommonOSVariant bool `blueprint:"mutated"`
511
512 // If set to true then this variant is the CommonOS variant that has dependencies on its
513 // OsType specific variants.
514 //
515 // Set by osMutator.
516 CommonOSVariant bool `blueprint:"mutated"`
517
Colin Crossce75d2c2016-10-06 16:12:58 -0700518 SkipInstall bool `blueprint:"mutated"`
Jeff Gaston088e29e2017-11-29 16:47:17 -0800519
520 NamespaceExportedToMake bool `blueprint:"mutated"`
Colin Cross6c4f21f2019-06-06 15:41:36 -0700521
522 MissingDeps []string `blueprint:"mutated"`
Colin Cross9a362232019-07-01 15:32:45 -0700523
524 // Name and variant strings stored by mutators to enable Module.String()
525 DebugName string `blueprint:"mutated"`
526 DebugMutators []string `blueprint:"mutated"`
527 DebugVariations []string `blueprint:"mutated"`
Colin Cross7228ecd2019-11-18 16:00:16 -0800528
529 // set by ImageMutator
530 ImageVariation string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800531}
532
533type hostAndDeviceProperties struct {
Colin Cross4e81d702018-11-09 10:36:55 -0800534 // If set to true, build a variant of the module for the host. Defaults to false.
535 Host_supported *bool
536
537 // If set to true, build a variant of the module for the device. Defaults to true.
Colin Crossa4190c12016-07-12 13:11:25 -0700538 Device_supported *bool
Colin Cross3f40fa42015-01-30 17:27:36 -0800539}
540
Colin Crossc472d572015-03-17 15:06:21 -0700541type Multilib string
542
543const (
Colin Cross6b4a32d2017-12-05 13:42:45 -0800544 MultilibBoth Multilib = "both"
545 MultilibFirst Multilib = "first"
546 MultilibCommon Multilib = "common"
547 MultilibCommonFirst Multilib = "common_first"
548 MultilibDefault Multilib = ""
Colin Crossc472d572015-03-17 15:06:21 -0700549)
550
Colin Crossa1ad8d12016-06-01 17:09:44 -0700551type HostOrDeviceSupported int
552
553const (
554 _ HostOrDeviceSupported = iota
Dan Albert0981b5c2018-08-02 13:46:35 -0700555
556 // Host and HostCross are built by default. Device is not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700557 HostSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700558
559 // Host is built by default. HostCross and Device are not supported.
Dan Albertc6345fb2016-10-20 01:36:11 -0700560 HostSupportedNoCross
Dan Albert0981b5c2018-08-02 13:46:35 -0700561
562 // Device is built by default. Host and HostCross are not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700563 DeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700564
565 // Device is built by default. Host and HostCross are supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700566 HostAndDeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700567
568 // Host, HostCross, and Device are built by default.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700569 HostAndDeviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700570
571 // Nothing is supported. This is not exposed to the user, but used to mark a
572 // host only module as unsupported when the module type is not supported on
573 // the host OS. E.g. benchmarks are supported on Linux but not Darwin.
Dan Willemsen0b24c742016-10-04 15:13:37 -0700574 NeitherHostNorDeviceSupported
Colin Crossa1ad8d12016-06-01 17:09:44 -0700575)
576
Jiyong Park2db76922017-11-08 16:03:48 +0900577type moduleKind int
578
579const (
580 platformModule moduleKind = iota
581 deviceSpecificModule
582 socSpecificModule
583 productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900584 systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900585)
586
587func (k moduleKind) String() string {
588 switch k {
589 case platformModule:
590 return "platform"
591 case deviceSpecificModule:
592 return "device-specific"
593 case socSpecificModule:
594 return "soc-specific"
595 case productSpecificModule:
596 return "product-specific"
Justin Yund5f6c822019-06-25 16:47:17 +0900597 case systemExtSpecificModule:
598 return "systemext-specific"
Jiyong Park2db76922017-11-08 16:03:48 +0900599 default:
600 panic(fmt.Errorf("unknown module kind %d", k))
601 }
602}
603
Colin Cross9d34f352019-11-22 16:03:51 -0800604func initAndroidModuleBase(m Module) {
605 m.base().module = m
606}
607
Colin Cross36242852017-06-23 15:06:31 -0700608func InitAndroidModule(m Module) {
Colin Cross9d34f352019-11-22 16:03:51 -0800609 initAndroidModuleBase(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800610 base := m.base()
Colin Cross5049f022015-03-18 13:28:46 -0700611
Colin Cross36242852017-06-23 15:06:31 -0700612 m.AddProperties(
Colin Crossfc754582016-05-17 16:34:16 -0700613 &base.nameProperties,
Colin Cross18c46802019-09-24 22:19:02 -0700614 &base.commonProperties)
615
Colin Crosseabaedd2020-02-06 17:01:55 -0800616 initProductVariableModule(m)
Colin Cross18c46802019-09-24 22:19:02 -0700617
Colin Crossa3a97412019-03-18 12:24:29 -0700618 base.generalProperties = m.GetProperties()
Pirama Arumuga Nainar955dc492018-04-17 14:58:42 -0700619 base.customizableProperties = m.GetProperties()
Paul Duffin63c6e182019-07-24 14:24:38 +0100620
621 // The default_visibility property needs to be checked and parsed by the visibility module during
Paul Duffin5ec73ec2020-05-01 17:52:01 +0100622 // its checking and parsing phases so make it the primary visibility property.
623 setPrimaryVisibilityProperty(m, "visibility", &base.commonProperties.Visibility)
Colin Cross5049f022015-03-18 13:28:46 -0700624}
625
Colin Cross36242852017-06-23 15:06:31 -0700626func InitAndroidArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
627 InitAndroidModule(m)
Colin Cross5049f022015-03-18 13:28:46 -0700628
629 base := m.base()
Colin Cross3f40fa42015-01-30 17:27:36 -0800630 base.commonProperties.HostOrDeviceSupported = hod
Colin Cross69617d32016-09-06 10:39:07 -0700631 base.commonProperties.Default_multilib = string(defaultMultilib)
Dan Willemsen0b24c742016-10-04 15:13:37 -0700632 base.commonProperties.ArchSpecific = true
Colin Crossee0bc3b2018-10-02 22:01:37 -0700633 base.commonProperties.UseTargetVariants = true
Colin Cross3f40fa42015-01-30 17:27:36 -0800634
Dan Willemsen218f6562015-07-08 18:13:11 -0700635 switch hod {
Nan Zhang1a0f09b2017-07-05 10:35:11 -0700636 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Cross36242852017-06-23 15:06:31 -0700637 m.AddProperties(&base.hostAndDeviceProperties)
Colin Cross3f40fa42015-01-30 17:27:36 -0800638 }
639
Colin Cross36242852017-06-23 15:06:31 -0700640 InitArchModule(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800641}
642
Colin Crossee0bc3b2018-10-02 22:01:37 -0700643func InitAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
644 InitAndroidArchModule(m, hod, defaultMultilib)
645 m.base().commonProperties.UseTargetVariants = false
646}
647
Paul Duffin1356d8c2020-02-25 19:26:33 +0000648// As InitAndroidMultiTargetsArchModule except it creates an additional CommonOS variant that
649// has dependencies on all the OsType specific variants.
650func InitCommonOSAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
651 InitAndroidArchModule(m, hod, defaultMultilib)
652 m.base().commonProperties.UseTargetVariants = false
653 m.base().commonProperties.CreateCommonOSVariant = true
654}
655
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800656// A ModuleBase object contains the properties that are common to all Android
Colin Cross3f40fa42015-01-30 17:27:36 -0800657// modules. It should be included as an anonymous field in every module
658// struct definition. InitAndroidModule should then be called from the module's
659// factory function, and the return values from InitAndroidModule should be
660// returned from the factory function.
661//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800662// The ModuleBase type is responsible for implementing the GenerateBuildActions
663// method to support the blueprint.Module interface. This method will then call
664// the module's GenerateAndroidBuildActions method once for each build variant
Colin Cross25de6c32019-06-06 14:29:25 -0700665// that is to be built. GenerateAndroidBuildActions is passed a ModuleContext
666// rather than the usual blueprint.ModuleContext.
667// ModuleContext exposes extra functionality specific to the Android build
Colin Cross3f40fa42015-01-30 17:27:36 -0800668// system including details about the particular build variant that is to be
669// generated.
670//
671// For example:
672//
673// import (
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800674// "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -0800675// )
676//
677// type myModule struct {
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800678// android.ModuleBase
Colin Cross3f40fa42015-01-30 17:27:36 -0800679// properties struct {
680// MyProperty string
681// }
682// }
683//
Colin Cross36242852017-06-23 15:06:31 -0700684// func NewMyModule() android.Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800685// m := &myModule{}
Colin Cross36242852017-06-23 15:06:31 -0700686// m.AddProperties(&m.properties)
687// android.InitAndroidModule(m)
688// return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800689// }
690//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800691// func (m *myModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800692// // Get the CPU architecture for the current build variant.
693// variantArch := ctx.Arch()
694//
695// // ...
696// }
Colin Cross635c3b02016-05-18 15:37:25 -0700697type ModuleBase struct {
Colin Cross3f40fa42015-01-30 17:27:36 -0800698 // Putting the curiously recurring thing pointing to the thing that contains
699 // the thing pattern to good use.
Colin Cross36242852017-06-23 15:06:31 -0700700 // TODO: remove this
Colin Cross635c3b02016-05-18 15:37:25 -0700701 module Module
Colin Cross3f40fa42015-01-30 17:27:36 -0800702
Colin Crossfc754582016-05-17 16:34:16 -0700703 nameProperties nameProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800704 commonProperties commonProperties
Colin Cross18c46802019-09-24 22:19:02 -0700705 variableProperties interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800706 hostAndDeviceProperties hostAndDeviceProperties
707 generalProperties []interface{}
Colin Crossc17727d2018-10-24 12:42:09 -0700708 archProperties [][]interface{}
Colin Crossa120ec12016-08-19 16:07:38 -0700709 customizableProperties []interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800710
Paul Duffin63c6e182019-07-24 14:24:38 +0100711 // Information about all the properties on the module that contains visibility rules that need
712 // checking.
713 visibilityPropertyInfo []visibilityProperty
714
715 // The primary visibility property, may be nil, that controls access to the module.
716 primaryVisibilityProperty visibilityProperty
717
Colin Cross3f40fa42015-01-30 17:27:36 -0800718 noAddressSanitizer bool
Colin Cross897266e2020-02-13 13:22:08 -0800719 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700720 checkbuildFiles Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800721 noticeFiles Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -0700722
723 // Used by buildTargetSingleton to create checkbuild and per-directory build targets
724 // Only set on the final variant of each module
Colin Cross0875c522017-11-28 17:34:01 -0800725 installTarget WritablePath
726 checkbuildTarget WritablePath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700727 blueprintDir string
Colin Crossa120ec12016-08-19 16:07:38 -0700728
Colin Cross178a5092016-09-13 13:42:32 -0700729 hooks hooks
Colin Cross36242852017-06-23 15:06:31 -0700730
731 registerProps []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700732
733 // For tests
Colin Crossae887032017-10-23 17:16:14 -0700734 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800735 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800736 variables map[string]string
Colin Crossa9d8bee2018-10-02 13:59:46 -0700737
Inseob Kim8471cda2019-11-15 09:59:12 +0900738 initRcPaths Paths
739 vintfFragmentsPaths Paths
740
Colin Crossa9d8bee2018-10-02 13:59:46 -0700741 prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool
Colin Cross36242852017-06-23 15:06:31 -0700742}
743
Colin Cross4157e882019-06-06 16:57:04 -0700744func (m *ModuleBase) DepsMutator(BottomUpMutatorContext) {}
Colin Cross5f692ec2019-02-01 16:53:07 -0800745
Colin Cross4157e882019-06-06 16:57:04 -0700746func (m *ModuleBase) AddProperties(props ...interface{}) {
747 m.registerProps = append(m.registerProps, props...)
Colin Cross36242852017-06-23 15:06:31 -0700748}
749
Colin Cross4157e882019-06-06 16:57:04 -0700750func (m *ModuleBase) GetProperties() []interface{} {
751 return m.registerProps
Colin Cross3f40fa42015-01-30 17:27:36 -0800752}
753
Colin Cross4157e882019-06-06 16:57:04 -0700754func (m *ModuleBase) BuildParamsForTests() []BuildParams {
755 return m.buildParams
Colin Crosscec81712017-07-13 14:43:27 -0700756}
757
Colin Cross4157e882019-06-06 16:57:04 -0700758func (m *ModuleBase) RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams {
759 return m.ruleParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800760}
761
Colin Cross4157e882019-06-06 16:57:04 -0700762func (m *ModuleBase) VariablesForTests() map[string]string {
763 return m.variables
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800764}
765
Colin Cross4157e882019-06-06 16:57:04 -0700766func (m *ModuleBase) Prefer32(prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool) {
767 m.prefer32 = prefer32
Colin Crossa9d8bee2018-10-02 13:59:46 -0700768}
769
Colin Crossce75d2c2016-10-06 16:12:58 -0700770// Name returns the name of the module. It may be overridden by individual module types, for
771// example prebuilts will prepend prebuilt_ to the name.
Colin Cross4157e882019-06-06 16:57:04 -0700772func (m *ModuleBase) Name() string {
773 return String(m.nameProperties.Name)
Colin Crossfc754582016-05-17 16:34:16 -0700774}
775
Colin Cross9a362232019-07-01 15:32:45 -0700776// String returns a string that includes the module name and variants for printing during debugging.
777func (m *ModuleBase) String() string {
778 sb := strings.Builder{}
779 sb.WriteString(m.commonProperties.DebugName)
780 sb.WriteString("{")
781 for i := range m.commonProperties.DebugMutators {
782 if i != 0 {
783 sb.WriteString(",")
784 }
785 sb.WriteString(m.commonProperties.DebugMutators[i])
786 sb.WriteString(":")
787 sb.WriteString(m.commonProperties.DebugVariations[i])
788 }
789 sb.WriteString("}")
790 return sb.String()
791}
792
Colin Crossce75d2c2016-10-06 16:12:58 -0700793// BaseModuleName returns the name of the module as specified in the blueprints file.
Colin Cross4157e882019-06-06 16:57:04 -0700794func (m *ModuleBase) BaseModuleName() string {
795 return String(m.nameProperties.Name)
Colin Crossce75d2c2016-10-06 16:12:58 -0700796}
797
Colin Cross4157e882019-06-06 16:57:04 -0700798func (m *ModuleBase) base() *ModuleBase {
799 return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800800}
801
Paul Duffine2453c72019-05-31 14:00:04 +0100802func (m *ModuleBase) qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName {
803 return qualifiedModuleName{pkg: ctx.ModuleDir(), name: ctx.ModuleName()}
804}
805
806func (m *ModuleBase) visibilityProperties() []visibilityProperty {
Paul Duffin63c6e182019-07-24 14:24:38 +0100807 return m.visibilityPropertyInfo
808}
809
810func (m *ModuleBase) visibility() []string {
811 // The soong_namespace module does not initialize the primaryVisibilityProperty.
812 if m.primaryVisibilityProperty != nil {
813 return m.primaryVisibilityProperty.getStrings()
814 } else {
815 return nil
Paul Duffine2453c72019-05-31 14:00:04 +0100816 }
817}
818
Colin Cross4157e882019-06-06 16:57:04 -0700819func (m *ModuleBase) Target() Target {
820 return m.commonProperties.CompileTarget
Dan Willemsen490fd492015-11-24 17:53:15 -0800821}
822
Colin Cross4157e882019-06-06 16:57:04 -0700823func (m *ModuleBase) TargetPrimary() bool {
824 return m.commonProperties.CompilePrimary
Colin Cross8b74d172016-09-13 09:59:14 -0700825}
826
Colin Cross4157e882019-06-06 16:57:04 -0700827func (m *ModuleBase) MultiTargets() []Target {
828 return m.commonProperties.CompileMultiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -0700829}
830
Colin Cross4157e882019-06-06 16:57:04 -0700831func (m *ModuleBase) Os() OsType {
832 return m.Target().Os
Dan Willemsen490fd492015-11-24 17:53:15 -0800833}
834
Colin Cross4157e882019-06-06 16:57:04 -0700835func (m *ModuleBase) Host() bool {
836 return m.Os().Class == Host || m.Os().Class == HostCross
Dan Willemsen97750522016-02-09 17:43:51 -0800837}
838
Colin Cross4157e882019-06-06 16:57:04 -0700839func (m *ModuleBase) Arch() Arch {
840 return m.Target().Arch
Dan Willemsen97750522016-02-09 17:43:51 -0800841}
842
Colin Cross4157e882019-06-06 16:57:04 -0700843func (m *ModuleBase) ArchSpecific() bool {
844 return m.commonProperties.ArchSpecific
Dan Willemsen0b24c742016-10-04 15:13:37 -0700845}
846
Paul Duffin1356d8c2020-02-25 19:26:33 +0000847// True if the current variant is a CommonOS variant, false otherwise.
848func (m *ModuleBase) IsCommonOSVariant() bool {
849 return m.commonProperties.CommonOSVariant
850}
851
Colin Cross4157e882019-06-06 16:57:04 -0700852func (m *ModuleBase) OsClassSupported() []OsClass {
853 switch m.commonProperties.HostOrDeviceSupported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700854 case HostSupported:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700855 return []OsClass{Host, HostCross}
Dan Albertc6345fb2016-10-20 01:36:11 -0700856 case HostSupportedNoCross:
857 return []OsClass{Host}
Colin Crossa1ad8d12016-06-01 17:09:44 -0700858 case DeviceSupported:
859 return []OsClass{Device}
Dan Albert0981b5c2018-08-02 13:46:35 -0700860 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700861 var supported []OsClass
Colin Cross4157e882019-06-06 16:57:04 -0700862 if Bool(m.hostAndDeviceProperties.Host_supported) ||
863 (m.commonProperties.HostOrDeviceSupported == HostAndDeviceDefault &&
864 m.hostAndDeviceProperties.Host_supported == nil) {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700865 supported = append(supported, Host, HostCross)
866 }
Colin Cross4157e882019-06-06 16:57:04 -0700867 if m.hostAndDeviceProperties.Device_supported == nil ||
868 *m.hostAndDeviceProperties.Device_supported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700869 supported = append(supported, Device)
870 }
871 return supported
872 default:
873 return nil
874 }
Colin Cross3f40fa42015-01-30 17:27:36 -0800875}
876
Colin Cross4157e882019-06-06 16:57:04 -0700877func (m *ModuleBase) DeviceSupported() bool {
878 return m.commonProperties.HostOrDeviceSupported == DeviceSupported ||
879 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
880 (m.hostAndDeviceProperties.Device_supported == nil ||
881 *m.hostAndDeviceProperties.Device_supported)
Colin Cross3f40fa42015-01-30 17:27:36 -0800882}
883
Paul Duffine44358f2019-11-26 18:04:12 +0000884func (m *ModuleBase) HostSupported() bool {
885 return m.commonProperties.HostOrDeviceSupported == HostSupported ||
886 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
887 (m.hostAndDeviceProperties.Host_supported != nil &&
888 *m.hostAndDeviceProperties.Host_supported)
889}
890
Colin Cross4157e882019-06-06 16:57:04 -0700891func (m *ModuleBase) Platform() bool {
Justin Yund5f6c822019-06-25 16:47:17 +0900892 return !m.DeviceSpecific() && !m.SocSpecific() && !m.ProductSpecific() && !m.SystemExtSpecific()
Jiyong Parkc678ad32018-04-10 13:07:10 +0900893}
894
Colin Cross4157e882019-06-06 16:57:04 -0700895func (m *ModuleBase) DeviceSpecific() bool {
896 return Bool(m.commonProperties.Device_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900897}
898
Colin Cross4157e882019-06-06 16:57:04 -0700899func (m *ModuleBase) SocSpecific() bool {
900 return Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900901}
902
Colin Cross4157e882019-06-06 16:57:04 -0700903func (m *ModuleBase) ProductSpecific() bool {
904 return Bool(m.commonProperties.Product_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900905}
906
Justin Yund5f6c822019-06-25 16:47:17 +0900907func (m *ModuleBase) SystemExtSpecific() bool {
908 return Bool(m.commonProperties.System_ext_specific)
Dario Frenifd05a742018-05-29 13:28:54 +0100909}
910
Bill Peckhamfff3f8a2020-03-20 18:33:20 -0700911func (m *ModuleBase) PartitionTag(config DeviceConfig) string {
912 partition := "system"
913 if m.SocSpecific() {
914 // A SoC-specific module could be on the vendor partition at
915 // "vendor" or the system partition at "system/vendor".
916 if config.VendorPath() == "vendor" {
917 partition = "vendor"
918 }
919 } else if m.DeviceSpecific() {
920 // A device-specific module could be on the odm partition at
921 // "odm", the vendor partition at "vendor/odm", or the system
922 // partition at "system/vendor/odm".
923 if config.OdmPath() == "odm" {
924 partition = "odm"
Ramy Medhat944839a2020-03-31 22:14:52 -0400925 } else if strings.HasPrefix(config.OdmPath(), "vendor/") {
Bill Peckhamfff3f8a2020-03-20 18:33:20 -0700926 partition = "vendor"
927 }
928 } else if m.ProductSpecific() {
929 // A product-specific module could be on the product partition
930 // at "product" or the system partition at "system/product".
931 if config.ProductPath() == "product" {
932 partition = "product"
933 }
934 } else if m.SystemExtSpecific() {
935 // A system_ext-specific module could be on the system_ext
936 // partition at "system_ext" or the system partition at
937 // "system/system_ext".
938 if config.SystemExtPath() == "system_ext" {
939 partition = "system_ext"
940 }
941 }
942 return partition
943}
944
Colin Cross4157e882019-06-06 16:57:04 -0700945func (m *ModuleBase) Enabled() bool {
946 if m.commonProperties.Enabled == nil {
947 return !m.Os().DefaultDisabled
Dan Willemsen490fd492015-11-24 17:53:15 -0800948 }
Colin Cross4157e882019-06-06 16:57:04 -0700949 return *m.commonProperties.Enabled
Colin Cross3f40fa42015-01-30 17:27:36 -0800950}
951
Inseob Kimeec88e12020-01-22 11:11:29 +0900952func (m *ModuleBase) Disable() {
953 m.commonProperties.Enabled = proptools.BoolPtr(false)
954}
955
Colin Cross4157e882019-06-06 16:57:04 -0700956func (m *ModuleBase) SkipInstall() {
957 m.commonProperties.SkipInstall = true
Colin Crossce75d2c2016-10-06 16:12:58 -0700958}
959
Ulya Trafimovichb28cc372020-01-13 15:18:16 +0000960func (m *ModuleBase) IsSkipInstall() bool {
961 return m.commonProperties.SkipInstall == true
962}
963
Colin Cross4157e882019-06-06 16:57:04 -0700964func (m *ModuleBase) ExportedToMake() bool {
965 return m.commonProperties.NamespaceExportedToMake
Jiyong Park374510b2018-03-19 18:23:01 +0900966}
967
Colin Cross897266e2020-02-13 13:22:08 -0800968func (m *ModuleBase) computeInstallDeps(ctx blueprint.ModuleContext) InstallPaths {
Colin Cross3f40fa42015-01-30 17:27:36 -0800969
Colin Cross897266e2020-02-13 13:22:08 -0800970 var result InstallPaths
Colin Cross6b753602018-06-21 13:03:07 -0700971 // TODO(ccross): we need to use WalkDeps and have some way to know which dependencies require installation
Colin Cross897266e2020-02-13 13:22:08 -0800972 ctx.VisitDepsDepthFirst(func(m blueprint.Module) {
973 if a, ok := m.(Module); ok {
974 result = append(result, a.filesToInstall()...)
975 }
976 })
Colin Cross3f40fa42015-01-30 17:27:36 -0800977
978 return result
979}
980
Colin Cross897266e2020-02-13 13:22:08 -0800981func (m *ModuleBase) filesToInstall() InstallPaths {
Colin Cross4157e882019-06-06 16:57:04 -0700982 return m.installFiles
Colin Cross3f40fa42015-01-30 17:27:36 -0800983}
984
Colin Cross4157e882019-06-06 16:57:04 -0700985func (m *ModuleBase) NoAddressSanitizer() bool {
986 return m.noAddressSanitizer
Colin Cross3f40fa42015-01-30 17:27:36 -0800987}
988
Colin Cross4157e882019-06-06 16:57:04 -0700989func (m *ModuleBase) InstallInData() bool {
Dan Willemsen782a2d12015-12-21 14:55:28 -0800990 return false
991}
992
Jaewoong Jung0949f312019-09-11 10:25:18 -0700993func (m *ModuleBase) InstallInTestcases() bool {
994 return false
995}
996
Colin Cross4157e882019-06-06 16:57:04 -0700997func (m *ModuleBase) InstallInSanitizerDir() bool {
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700998 return false
999}
1000
Yifan Hong1b3348d2020-01-21 15:53:22 -08001001func (m *ModuleBase) InstallInRamdisk() bool {
1002 return Bool(m.commonProperties.Ramdisk)
1003}
1004
Colin Cross4157e882019-06-06 16:57:04 -07001005func (m *ModuleBase) InstallInRecovery() bool {
1006 return Bool(m.commonProperties.Recovery)
Jiyong Parkf9332f12018-02-01 00:54:12 +09001007}
1008
Colin Cross90ba5f42019-10-02 11:10:58 -07001009func (m *ModuleBase) InstallInRoot() bool {
1010 return false
1011}
1012
Colin Cross607d8582019-07-29 16:44:46 -07001013func (m *ModuleBase) InstallBypassMake() bool {
1014 return false
1015}
1016
Colin Cross6e359402020-02-10 15:29:54 -08001017func (m *ModuleBase) InstallForceOS() *OsType {
1018 return nil
1019}
1020
Colin Cross4157e882019-06-06 16:57:04 -07001021func (m *ModuleBase) Owner() string {
1022 return String(m.commonProperties.Owner)
Sundong Ahn4fd04bb2018-08-31 18:01:37 +09001023}
1024
Bob Badoura75b0572020-02-18 20:21:55 -08001025func (m *ModuleBase) NoticeFiles() Paths {
1026 return m.noticeFiles
Jiyong Park52818fc2019-03-18 12:01:38 +09001027}
1028
Colin Cross7228ecd2019-11-18 16:00:16 -08001029func (m *ModuleBase) setImageVariation(variant string) {
1030 m.commonProperties.ImageVariation = variant
1031}
1032
1033func (m *ModuleBase) ImageVariation() blueprint.Variation {
1034 return blueprint.Variation{
1035 Mutator: "image",
1036 Variation: m.base().commonProperties.ImageVariation,
1037 }
1038}
1039
Paul Duffin9b76c0b2020-03-12 10:24:35 +00001040func (m *ModuleBase) getVariationByMutatorName(mutator string) string {
1041 for i, v := range m.commonProperties.DebugMutators {
1042 if v == mutator {
1043 return m.commonProperties.DebugVariations[i]
1044 }
1045 }
1046
1047 return ""
1048}
1049
Yifan Hong1b3348d2020-01-21 15:53:22 -08001050func (m *ModuleBase) InRamdisk() bool {
1051 return m.base().commonProperties.ImageVariation == RamdiskVariation
1052}
1053
Colin Cross7228ecd2019-11-18 16:00:16 -08001054func (m *ModuleBase) InRecovery() bool {
1055 return m.base().commonProperties.ImageVariation == RecoveryVariation
1056}
1057
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09001058func (m *ModuleBase) RequiredModuleNames() []string {
1059 return m.base().commonProperties.Required
1060}
1061
1062func (m *ModuleBase) HostRequiredModuleNames() []string {
1063 return m.base().commonProperties.Host_required
1064}
1065
1066func (m *ModuleBase) TargetRequiredModuleNames() []string {
1067 return m.base().commonProperties.Target_required
1068}
1069
Inseob Kim8471cda2019-11-15 09:59:12 +09001070func (m *ModuleBase) InitRc() Paths {
1071 return append(Paths{}, m.initRcPaths...)
1072}
1073
1074func (m *ModuleBase) VintfFragments() Paths {
1075 return append(Paths{}, m.vintfFragmentsPaths...)
1076}
1077
Colin Cross4157e882019-06-06 16:57:04 -07001078func (m *ModuleBase) generateModuleTarget(ctx ModuleContext) {
Colin Cross897266e2020-02-13 13:22:08 -08001079 var allInstalledFiles InstallPaths
1080 var allCheckbuildFiles Paths
Colin Cross0875c522017-11-28 17:34:01 -08001081 ctx.VisitAllModuleVariants(func(module Module) {
1082 a := module.base()
Colin Crossc9404352015-03-26 16:10:12 -07001083 allInstalledFiles = append(allInstalledFiles, a.installFiles...)
1084 allCheckbuildFiles = append(allCheckbuildFiles, a.checkbuildFiles...)
Colin Cross3f40fa42015-01-30 17:27:36 -08001085 })
1086
Colin Cross0875c522017-11-28 17:34:01 -08001087 var deps Paths
Colin Cross9454bfa2015-03-17 13:24:18 -07001088
Jeff Gaston088e29e2017-11-29 16:47:17 -08001089 namespacePrefix := ctx.Namespace().(*Namespace).id
1090 if namespacePrefix != "" {
1091 namespacePrefix = namespacePrefix + "-"
1092 }
1093
Colin Cross3f40fa42015-01-30 17:27:36 -08001094 if len(allInstalledFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -08001095 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-install")
Colin Cross0875c522017-11-28 17:34:01 -08001096 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001097 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001098 Output: name,
Colin Cross897266e2020-02-13 13:22:08 -08001099 Implicits: allInstalledFiles.Paths(),
Colin Crossaabf6792017-11-29 00:27:14 -08001100 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross9454bfa2015-03-17 13:24:18 -07001101 })
1102 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -07001103 m.installTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -07001104 }
1105
1106 if len(allCheckbuildFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -08001107 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-checkbuild")
Colin Cross0875c522017-11-28 17:34:01 -08001108 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001109 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001110 Output: name,
1111 Implicits: allCheckbuildFiles,
Colin Cross9454bfa2015-03-17 13:24:18 -07001112 })
1113 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -07001114 m.checkbuildTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -07001115 }
1116
1117 if len(deps) > 0 {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001118 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08001119 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001120 suffix = "-soong"
1121 }
1122
Jeff Gaston088e29e2017-11-29 16:47:17 -08001123 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+suffix)
Colin Cross0875c522017-11-28 17:34:01 -08001124 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001125 Rule: blueprint.Phony,
Jeff Gaston088e29e2017-11-29 16:47:17 -08001126 Outputs: []WritablePath{name},
Colin Cross9454bfa2015-03-17 13:24:18 -07001127 Implicits: deps,
Colin Cross3f40fa42015-01-30 17:27:36 -08001128 })
Colin Cross1f8c52b2015-06-16 16:38:17 -07001129
Colin Cross4157e882019-06-06 16:57:04 -07001130 m.blueprintDir = ctx.ModuleDir()
Colin Cross3f40fa42015-01-30 17:27:36 -08001131 }
1132}
1133
Colin Crossc34d2322020-01-03 15:23:27 -08001134func determineModuleKind(m *ModuleBase, ctx blueprint.EarlyModuleContext) moduleKind {
Colin Cross4157e882019-06-06 16:57:04 -07001135 var socSpecific = Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
1136 var deviceSpecific = Bool(m.commonProperties.Device_specific)
1137 var productSpecific = Bool(m.commonProperties.Product_specific)
Justin Yund5f6c822019-06-25 16:47:17 +09001138 var systemExtSpecific = Bool(m.commonProperties.System_ext_specific)
Jiyong Park2db76922017-11-08 16:03:48 +09001139
Dario Frenifd05a742018-05-29 13:28:54 +01001140 msg := "conflicting value set here"
1141 if socSpecific && deviceSpecific {
1142 ctx.PropertyErrorf("device_specific", "a module cannot be specific to SoC and device at the same time.")
Colin Cross4157e882019-06-06 16:57:04 -07001143 if Bool(m.commonProperties.Vendor) {
Jiyong Park2db76922017-11-08 16:03:48 +09001144 ctx.PropertyErrorf("vendor", msg)
1145 }
Colin Cross4157e882019-06-06 16:57:04 -07001146 if Bool(m.commonProperties.Proprietary) {
Jiyong Park2db76922017-11-08 16:03:48 +09001147 ctx.PropertyErrorf("proprietary", msg)
1148 }
Colin Cross4157e882019-06-06 16:57:04 -07001149 if Bool(m.commonProperties.Soc_specific) {
Jiyong Park2db76922017-11-08 16:03:48 +09001150 ctx.PropertyErrorf("soc_specific", msg)
1151 }
1152 }
1153
Justin Yund5f6c822019-06-25 16:47:17 +09001154 if productSpecific && systemExtSpecific {
1155 ctx.PropertyErrorf("product_specific", "a module cannot be specific to product and system_ext at the same time.")
1156 ctx.PropertyErrorf("system_ext_specific", msg)
Dario Frenifd05a742018-05-29 13:28:54 +01001157 }
1158
Justin Yund5f6c822019-06-25 16:47:17 +09001159 if (socSpecific || deviceSpecific) && (productSpecific || systemExtSpecific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001160 if productSpecific {
1161 ctx.PropertyErrorf("product_specific", "a module cannot be specific to SoC or device and product at the same time.")
1162 } else {
Justin Yund5f6c822019-06-25 16:47:17 +09001163 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 +01001164 }
1165 if deviceSpecific {
1166 ctx.PropertyErrorf("device_specific", msg)
1167 } else {
Colin Cross4157e882019-06-06 16:57:04 -07001168 if Bool(m.commonProperties.Vendor) {
Dario Frenifd05a742018-05-29 13:28:54 +01001169 ctx.PropertyErrorf("vendor", msg)
1170 }
Colin Cross4157e882019-06-06 16:57:04 -07001171 if Bool(m.commonProperties.Proprietary) {
Dario Frenifd05a742018-05-29 13:28:54 +01001172 ctx.PropertyErrorf("proprietary", msg)
1173 }
Colin Cross4157e882019-06-06 16:57:04 -07001174 if Bool(m.commonProperties.Soc_specific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001175 ctx.PropertyErrorf("soc_specific", msg)
1176 }
1177 }
1178 }
1179
Jiyong Park2db76922017-11-08 16:03:48 +09001180 if productSpecific {
1181 return productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +09001182 } else if systemExtSpecific {
1183 return systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001184 } else if deviceSpecific {
1185 return deviceSpecificModule
1186 } else if socSpecific {
1187 return socSpecificModule
1188 } else {
1189 return platformModule
1190 }
1191}
1192
Colin Crossc34d2322020-01-03 15:23:27 -08001193func (m *ModuleBase) earlyModuleContextFactory(ctx blueprint.EarlyModuleContext) earlyModuleContext {
Colin Cross1184b642019-12-30 18:43:07 -08001194 return earlyModuleContext{
Colin Crossc34d2322020-01-03 15:23:27 -08001195 EarlyModuleContext: ctx,
1196 kind: determineModuleKind(m, ctx),
1197 config: ctx.Config().(Config),
Colin Cross3f40fa42015-01-30 17:27:36 -08001198 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001199}
1200
Colin Cross1184b642019-12-30 18:43:07 -08001201func (m *ModuleBase) baseModuleContextFactory(ctx blueprint.BaseModuleContext) baseModuleContext {
1202 return baseModuleContext{
1203 bp: ctx,
1204 earlyModuleContext: m.earlyModuleContextFactory(ctx),
1205 os: m.commonProperties.CompileOS,
1206 target: m.commonProperties.CompileTarget,
1207 targetPrimary: m.commonProperties.CompilePrimary,
1208 multiTargets: m.commonProperties.CompileMultiTargets,
1209 }
1210}
1211
Colin Cross4157e882019-06-06 16:57:04 -07001212func (m *ModuleBase) GenerateBuildActions(blueprintCtx blueprint.ModuleContext) {
Colin Cross25de6c32019-06-06 14:29:25 -07001213 ctx := &moduleContext{
Colin Cross0ea8ba82019-06-06 14:33:29 -07001214 module: m.module,
Colin Crossdc35e212019-06-06 16:13:11 -07001215 bp: blueprintCtx,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001216 baseModuleContext: m.baseModuleContextFactory(blueprintCtx),
1217 installDeps: m.computeInstallDeps(blueprintCtx),
1218 installFiles: m.installFiles,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001219 variables: make(map[string]string),
Colin Cross3f40fa42015-01-30 17:27:36 -08001220 }
1221
Colin Cross6c4f21f2019-06-06 15:41:36 -07001222 // Temporarily continue to call blueprintCtx.GetMissingDependencies() to maintain the previous behavior of never
1223 // reporting missing dependency errors in Blueprint when AllowMissingDependencies == true.
1224 // TODO: This will be removed once defaults modules handle missing dependency errors
1225 blueprintCtx.GetMissingDependencies()
1226
Colin Crossdc35e212019-06-06 16:13:11 -07001227 // For the final GenerateAndroidBuildActions pass, require that all visited dependencies Soong modules and
Paul Duffin1356d8c2020-02-25 19:26:33 +00001228 // are enabled. Unless the module is a CommonOS variant which may have dependencies on disabled variants
1229 // (because the dependencies are added before the modules are disabled). The
1230 // GetOsSpecificVariantsOfCommonOSVariant(...) method will ensure that the disabled variants are
1231 // ignored.
1232 ctx.baseModuleContext.strictVisitDeps = !m.IsCommonOSVariant()
Colin Crossdc35e212019-06-06 16:13:11 -07001233
Colin Cross4c83e5c2019-02-25 14:54:28 -08001234 if ctx.config.captureBuild {
1235 ctx.ruleParams = make(map[blueprint.Rule]blueprint.RuleParams)
1236 }
1237
Colin Cross67a5c132017-05-09 13:45:28 -07001238 desc := "//" + ctx.ModuleDir() + ":" + ctx.ModuleName() + " "
1239 var suffix []string
Colin Cross0875c522017-11-28 17:34:01 -08001240 if ctx.Os().Class != Device && ctx.Os().Class != Generic {
1241 suffix = append(suffix, ctx.Os().String())
Colin Cross67a5c132017-05-09 13:45:28 -07001242 }
Colin Cross0875c522017-11-28 17:34:01 -08001243 if !ctx.PrimaryArch() {
1244 suffix = append(suffix, ctx.Arch().ArchType.String())
Colin Cross67a5c132017-05-09 13:45:28 -07001245 }
Dan Willemsenb13a9482020-02-14 11:25:54 -08001246 if apex, ok := m.module.(ApexModule); ok && !apex.IsForPlatform() {
1247 suffix = append(suffix, apex.ApexName())
1248 }
Colin Cross67a5c132017-05-09 13:45:28 -07001249
1250 ctx.Variable(pctx, "moduleDesc", desc)
1251
1252 s := ""
1253 if len(suffix) > 0 {
1254 s = " [" + strings.Join(suffix, " ") + "]"
1255 }
1256 ctx.Variable(pctx, "moduleDescSuffix", s)
1257
Dan Willemsen569edc52018-11-19 09:33:29 -08001258 // Some common property checks for properties that will be used later in androidmk.go
Colin Cross4157e882019-06-06 16:57:04 -07001259 if m.commonProperties.Dist.Dest != nil {
1260 _, err := validateSafePath(*m.commonProperties.Dist.Dest)
Dan Willemsen569edc52018-11-19 09:33:29 -08001261 if err != nil {
1262 ctx.PropertyErrorf("dist.dest", "%s", err.Error())
1263 }
1264 }
Colin Cross4157e882019-06-06 16:57:04 -07001265 if m.commonProperties.Dist.Dir != nil {
1266 _, err := validateSafePath(*m.commonProperties.Dist.Dir)
Dan Willemsen569edc52018-11-19 09:33:29 -08001267 if err != nil {
1268 ctx.PropertyErrorf("dist.dir", "%s", err.Error())
1269 }
1270 }
Colin Cross4157e882019-06-06 16:57:04 -07001271 if m.commonProperties.Dist.Suffix != nil {
1272 if strings.Contains(*m.commonProperties.Dist.Suffix, "/") {
Dan Willemsen569edc52018-11-19 09:33:29 -08001273 ctx.PropertyErrorf("dist.suffix", "Suffix may not contain a '/' character.")
1274 }
1275 }
1276
Colin Cross4157e882019-06-06 16:57:04 -07001277 if m.Enabled() {
Jooyung Hand48f3c32019-08-23 11:18:57 +09001278 // ensure all direct android.Module deps are enabled
1279 ctx.VisitDirectDepsBlueprint(func(bm blueprint.Module) {
1280 if _, ok := bm.(Module); ok {
1281 ctx.validateAndroidModule(bm, ctx.baseModuleContext.strictVisitDeps)
1282 }
1283 })
1284
Bob Badoura75b0572020-02-18 20:21:55 -08001285 m.noticeFiles = make([]Path, 0)
1286 optPath := OptionalPath{}
1287 notice := proptools.StringDefault(m.commonProperties.Notice, "")
Colin Cross4157e882019-06-06 16:57:04 -07001288 if module := SrcIsModule(notice); module != "" {
Bob Badoura75b0572020-02-18 20:21:55 -08001289 optPath = ctx.ExpandOptionalSource(&notice, "notice")
1290 } else if notice != "" {
Jiyong Park52818fc2019-03-18 12:01:38 +09001291 noticePath := filepath.Join(ctx.ModuleDir(), notice)
Bob Badoura75b0572020-02-18 20:21:55 -08001292 optPath = ExistentPathForSource(ctx, noticePath)
1293 }
1294 if optPath.Valid() {
1295 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1296 } else {
1297 for _, notice = range []string{"LICENSE", "LICENCE", "NOTICE"} {
1298 noticePath := filepath.Join(ctx.ModuleDir(), notice)
1299 optPath = ExistentPathForSource(ctx, noticePath)
1300 if optPath.Valid() {
1301 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1302 }
1303 }
Jaewoong Jung62707f72018-11-16 13:26:43 -08001304 }
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001305
1306 m.module.GenerateAndroidBuildActions(ctx)
1307 if ctx.Failed() {
1308 return
1309 }
1310
1311 m.installFiles = append(m.installFiles, ctx.installFiles...)
1312 m.checkbuildFiles = append(m.checkbuildFiles, ctx.checkbuildFiles...)
Inseob Kim8471cda2019-11-15 09:59:12 +09001313 m.initRcPaths = PathsForModuleSrc(ctx, m.commonProperties.Init_rc)
1314 m.vintfFragmentsPaths = PathsForModuleSrc(ctx, m.commonProperties.Vintf_fragments)
Colin Crossdc35e212019-06-06 16:13:11 -07001315 } else if ctx.Config().AllowMissingDependencies() {
1316 // If the module is not enabled it will not create any build rules, nothing will call
1317 // ctx.GetMissingDependencies(), and blueprint will consider the missing dependencies to be unhandled
1318 // and report them as an error even when AllowMissingDependencies = true. Call
1319 // ctx.GetMissingDependencies() here to tell blueprint not to handle them.
1320 ctx.GetMissingDependencies()
Colin Cross3f40fa42015-01-30 17:27:36 -08001321 }
1322
Colin Cross4157e882019-06-06 16:57:04 -07001323 if m == ctx.FinalModule().(Module).base() {
1324 m.generateModuleTarget(ctx)
Colin Cross9b1d13d2016-09-19 15:18:11 -07001325 if ctx.Failed() {
1326 return
1327 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001328 }
Colin Crosscec81712017-07-13 14:43:27 -07001329
Colin Cross4157e882019-06-06 16:57:04 -07001330 m.buildParams = ctx.buildParams
1331 m.ruleParams = ctx.ruleParams
1332 m.variables = ctx.variables
Colin Cross3f40fa42015-01-30 17:27:36 -08001333}
1334
Colin Cross1184b642019-12-30 18:43:07 -08001335type earlyModuleContext struct {
Colin Crossc34d2322020-01-03 15:23:27 -08001336 blueprint.EarlyModuleContext
Colin Cross1184b642019-12-30 18:43:07 -08001337
1338 kind moduleKind
1339 config Config
1340}
1341
1342func (e *earlyModuleContext) Glob(globPattern string, excludes []string) Paths {
1343 ret, err := e.GlobWithDeps(globPattern, excludes)
1344 if err != nil {
1345 e.ModuleErrorf("glob: %s", err.Error())
1346 }
1347 return pathsForModuleSrcFromFullPath(e, ret, true)
1348}
1349
1350func (e *earlyModuleContext) GlobFiles(globPattern string, excludes []string) Paths {
1351 ret, err := e.GlobWithDeps(globPattern, excludes)
1352 if err != nil {
1353 e.ModuleErrorf("glob: %s", err.Error())
1354 }
1355 return pathsForModuleSrcFromFullPath(e, ret, false)
1356}
1357
Colin Cross988414c2020-01-11 01:11:46 +00001358func (b *earlyModuleContext) IsSymlink(path Path) bool {
1359 fileInfo, err := b.config.fs.Lstat(path.String())
1360 if err != nil {
1361 b.ModuleErrorf("os.Lstat(%q) failed: %s", path.String(), err)
1362 }
1363 return fileInfo.Mode()&os.ModeSymlink == os.ModeSymlink
1364}
1365
1366func (b *earlyModuleContext) Readlink(path Path) string {
1367 dest, err := b.config.fs.Readlink(path.String())
1368 if err != nil {
1369 b.ModuleErrorf("os.Readlink(%q) failed: %s", path.String(), err)
1370 }
1371 return dest
1372}
1373
Colin Cross1184b642019-12-30 18:43:07 -08001374func (e *earlyModuleContext) Module() Module {
Colin Crossc34d2322020-01-03 15:23:27 -08001375 module, _ := e.EarlyModuleContext.Module().(Module)
Colin Cross1184b642019-12-30 18:43:07 -08001376 return module
1377}
1378
1379func (e *earlyModuleContext) Config() Config {
Colin Crossc34d2322020-01-03 15:23:27 -08001380 return e.EarlyModuleContext.Config().(Config)
Colin Cross1184b642019-12-30 18:43:07 -08001381}
1382
1383func (e *earlyModuleContext) AConfig() Config {
1384 return e.config
1385}
1386
1387func (e *earlyModuleContext) DeviceConfig() DeviceConfig {
1388 return DeviceConfig{e.config.deviceConfig}
1389}
1390
1391func (e *earlyModuleContext) Platform() bool {
1392 return e.kind == platformModule
1393}
1394
1395func (e *earlyModuleContext) DeviceSpecific() bool {
1396 return e.kind == deviceSpecificModule
1397}
1398
1399func (e *earlyModuleContext) SocSpecific() bool {
1400 return e.kind == socSpecificModule
1401}
1402
1403func (e *earlyModuleContext) ProductSpecific() bool {
1404 return e.kind == productSpecificModule
1405}
1406
1407func (e *earlyModuleContext) SystemExtSpecific() bool {
1408 return e.kind == systemExtSpecificModule
1409}
1410
1411type baseModuleContext struct {
1412 bp blueprint.BaseModuleContext
1413 earlyModuleContext
Colin Crossfb0c16e2019-11-20 17:12:35 -08001414 os OsType
Colin Cross8b74d172016-09-13 09:59:14 -07001415 target Target
Colin Crossee0bc3b2018-10-02 22:01:37 -07001416 multiTargets []Target
Colin Cross8b74d172016-09-13 09:59:14 -07001417 targetPrimary bool
1418 debug bool
Colin Crossdc35e212019-06-06 16:13:11 -07001419
1420 walkPath []Module
Paul Duffinc5192442020-03-31 11:31:36 +01001421 tagPath []blueprint.DependencyTag
Colin Crossdc35e212019-06-06 16:13:11 -07001422
1423 strictVisitDeps bool // If true, enforce that all dependencies are enabled
Colin Crossf6566ed2015-03-24 11:13:38 -07001424}
1425
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001426func (b *baseModuleContext) OtherModuleName(m blueprint.Module) string {
1427 return b.bp.OtherModuleName(m)
1428}
1429func (b *baseModuleContext) OtherModuleDir(m blueprint.Module) string { return b.bp.OtherModuleDir(m) }
Colin Cross1184b642019-12-30 18:43:07 -08001430func (b *baseModuleContext) OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{}) {
Jooyung Hancd87c692020-02-26 02:05:18 +09001431 b.bp.OtherModuleErrorf(m, fmt, args...)
Colin Cross1184b642019-12-30 18:43:07 -08001432}
1433func (b *baseModuleContext) OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag {
1434 return b.bp.OtherModuleDependencyTag(m)
1435}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001436func (b *baseModuleContext) OtherModuleExists(name string) bool { return b.bp.OtherModuleExists(name) }
1437func (b *baseModuleContext) OtherModuleType(m blueprint.Module) string {
1438 return b.bp.OtherModuleType(m)
1439}
Colin Cross1184b642019-12-30 18:43:07 -08001440
1441func (b *baseModuleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1442 return b.bp.GetDirectDepWithTag(name, tag)
1443}
1444
Colin Cross25de6c32019-06-06 14:29:25 -07001445type moduleContext struct {
Colin Crossdc35e212019-06-06 16:13:11 -07001446 bp blueprint.ModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -07001447 baseModuleContext
Colin Cross897266e2020-02-13 13:22:08 -08001448 installDeps InstallPaths
1449 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001450 checkbuildFiles Paths
Colin Cross8d8f8e22016-08-03 11:57:50 -07001451 module Module
Colin Crosscec81712017-07-13 14:43:27 -07001452
1453 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001454 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001455 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001456 variables map[string]string
Colin Cross6ff51382015-12-17 16:39:19 -08001457}
1458
Colin Crossb88b3c52019-06-10 15:15:17 -07001459func (m *moduleContext) ninjaError(params BuildParams, err error) (PackageContext, BuildParams) {
1460 return pctx, BuildParams{
Colin Cross4b69c492019-06-07 13:06:06 -07001461 Rule: ErrorRule,
1462 Description: params.Description,
1463 Output: params.Output,
1464 Outputs: params.Outputs,
1465 ImplicitOutput: params.ImplicitOutput,
1466 ImplicitOutputs: params.ImplicitOutputs,
Colin Cross6ff51382015-12-17 16:39:19 -08001467 Args: map[string]string{
1468 "error": err.Error(),
1469 },
Colin Crossb88b3c52019-06-10 15:15:17 -07001470 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001471}
1472
Colin Cross25de6c32019-06-06 14:29:25 -07001473func (m *moduleContext) ModuleBuild(pctx PackageContext, params ModuleBuildParams) {
1474 m.Build(pctx, BuildParams(params))
Colin Cross3f40fa42015-01-30 17:27:36 -08001475}
1476
Colin Cross0875c522017-11-28 17:34:01 -08001477func convertBuildParams(params BuildParams) blueprint.BuildParams {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001478 bparams := blueprint.BuildParams{
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001479 Rule: params.Rule,
Colin Cross0875c522017-11-28 17:34:01 -08001480 Description: params.Description,
Colin Cross33bfb0a2016-11-21 17:23:08 -08001481 Deps: params.Deps,
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001482 Outputs: params.Outputs.Strings(),
1483 ImplicitOutputs: params.ImplicitOutputs.Strings(),
1484 Inputs: params.Inputs.Strings(),
1485 Implicits: params.Implicits.Strings(),
1486 OrderOnly: params.OrderOnly.Strings(),
1487 Args: params.Args,
1488 Optional: !params.Default,
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001489 }
1490
Colin Cross33bfb0a2016-11-21 17:23:08 -08001491 if params.Depfile != nil {
1492 bparams.Depfile = params.Depfile.String()
1493 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001494 if params.Output != nil {
1495 bparams.Outputs = append(bparams.Outputs, params.Output.String())
1496 }
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001497 if params.ImplicitOutput != nil {
1498 bparams.ImplicitOutputs = append(bparams.ImplicitOutputs, params.ImplicitOutput.String())
1499 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001500 if params.Input != nil {
1501 bparams.Inputs = append(bparams.Inputs, params.Input.String())
1502 }
1503 if params.Implicit != nil {
1504 bparams.Implicits = append(bparams.Implicits, params.Implicit.String())
1505 }
1506
Colin Cross0b9f31f2019-02-28 11:00:01 -08001507 bparams.Outputs = proptools.NinjaEscapeList(bparams.Outputs)
1508 bparams.ImplicitOutputs = proptools.NinjaEscapeList(bparams.ImplicitOutputs)
1509 bparams.Inputs = proptools.NinjaEscapeList(bparams.Inputs)
1510 bparams.Implicits = proptools.NinjaEscapeList(bparams.Implicits)
1511 bparams.OrderOnly = proptools.NinjaEscapeList(bparams.OrderOnly)
1512 bparams.Depfile = proptools.NinjaEscapeList([]string{bparams.Depfile})[0]
Colin Crossfe4bc362018-09-12 10:02:13 -07001513
Colin Cross0875c522017-11-28 17:34:01 -08001514 return bparams
1515}
1516
Colin Cross25de6c32019-06-06 14:29:25 -07001517func (m *moduleContext) Variable(pctx PackageContext, name, value string) {
1518 if m.config.captureBuild {
1519 m.variables[name] = value
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001520 }
1521
Colin Crossdc35e212019-06-06 16:13:11 -07001522 m.bp.Variable(pctx.PackageContext, name, value)
Colin Cross0875c522017-11-28 17:34:01 -08001523}
1524
Colin Cross25de6c32019-06-06 14:29:25 -07001525func (m *moduleContext) Rule(pctx PackageContext, name string, params blueprint.RuleParams,
Colin Cross0875c522017-11-28 17:34:01 -08001526 argNames ...string) blueprint.Rule {
1527
Ramy Medhat944839a2020-03-31 22:14:52 -04001528 if m.config.UseRemoteBuild() {
1529 if params.Pool == nil {
1530 // When USE_GOMA=true or USE_RBE=true are set and the rule is not supported by goma/RBE, restrict
1531 // jobs to the local parallelism value
1532 params.Pool = localPool
1533 } else if params.Pool == remotePool {
1534 // remotePool is a fake pool used to identify rule that are supported for remoting. If the rule's
1535 // pool is the remotePool, replace with nil so that ninja runs it at NINJA_REMOTE_NUM_JOBS
1536 // parallelism.
1537 params.Pool = nil
1538 }
Colin Cross2e2dbc22019-09-25 13:31:46 -07001539 }
1540
Colin Crossdc35e212019-06-06 16:13:11 -07001541 rule := m.bp.Rule(pctx.PackageContext, name, params, argNames...)
Colin Cross4c83e5c2019-02-25 14:54:28 -08001542
Colin Cross25de6c32019-06-06 14:29:25 -07001543 if m.config.captureBuild {
1544 m.ruleParams[rule] = params
Colin Cross4c83e5c2019-02-25 14:54:28 -08001545 }
1546
1547 return rule
Colin Cross0875c522017-11-28 17:34:01 -08001548}
1549
Colin Cross25de6c32019-06-06 14:29:25 -07001550func (m *moduleContext) Build(pctx PackageContext, params BuildParams) {
Colin Crossb88b3c52019-06-10 15:15:17 -07001551 if params.Description != "" {
1552 params.Description = "${moduleDesc}" + params.Description + "${moduleDescSuffix}"
1553 }
1554
1555 if missingDeps := m.GetMissingDependencies(); len(missingDeps) > 0 {
1556 pctx, params = m.ninjaError(params, fmt.Errorf("module %s missing dependencies: %s\n",
1557 m.ModuleName(), strings.Join(missingDeps, ", ")))
1558 }
1559
Colin Cross25de6c32019-06-06 14:29:25 -07001560 if m.config.captureBuild {
1561 m.buildParams = append(m.buildParams, params)
Colin Cross0875c522017-11-28 17:34:01 -08001562 }
1563
Colin Crossdc35e212019-06-06 16:13:11 -07001564 m.bp.Build(pctx.PackageContext, convertBuildParams(params))
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001565}
Colin Cross25de6c32019-06-06 14:29:25 -07001566func (m *moduleContext) GetMissingDependencies() []string {
Colin Cross6c4f21f2019-06-06 15:41:36 -07001567 var missingDeps []string
1568 missingDeps = append(missingDeps, m.Module().base().commonProperties.MissingDeps...)
Colin Crossdc35e212019-06-06 16:13:11 -07001569 missingDeps = append(missingDeps, m.bp.GetMissingDependencies()...)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001570 missingDeps = FirstUniqueStrings(missingDeps)
1571 return missingDeps
Colin Cross6ff51382015-12-17 16:39:19 -08001572}
1573
Colin Crossdc35e212019-06-06 16:13:11 -07001574func (b *baseModuleContext) AddMissingDependencies(deps []string) {
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001575 if deps != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001576 missingDeps := &b.Module().base().commonProperties.MissingDeps
Colin Cross6c4f21f2019-06-06 15:41:36 -07001577 *missingDeps = append(*missingDeps, deps...)
1578 *missingDeps = FirstUniqueStrings(*missingDeps)
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001579 }
1580}
1581
Colin Crossdc35e212019-06-06 16:13:11 -07001582func (b *baseModuleContext) validateAndroidModule(module blueprint.Module, strict bool) Module {
Colin Crossd11fcda2017-10-23 17:59:01 -07001583 aModule, _ := module.(Module)
Colin Crossdc35e212019-06-06 16:13:11 -07001584
1585 if !strict {
1586 return aModule
1587 }
1588
Colin Cross380c69a2019-06-10 17:49:58 +00001589 if aModule == nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001590 b.ModuleErrorf("module %q not an android module", b.OtherModuleName(module))
Colin Cross380c69a2019-06-10 17:49:58 +00001591 return nil
1592 }
1593
1594 if !aModule.Enabled() {
Colin Crossdc35e212019-06-06 16:13:11 -07001595 if b.Config().AllowMissingDependencies() {
1596 b.AddMissingDependencies([]string{b.OtherModuleName(aModule)})
Colin Cross380c69a2019-06-10 17:49:58 +00001597 } else {
Colin Crossdc35e212019-06-06 16:13:11 -07001598 b.ModuleErrorf("depends on disabled module %q", b.OtherModuleName(aModule))
Colin Cross380c69a2019-06-10 17:49:58 +00001599 }
1600 return nil
1601 }
Colin Crossd11fcda2017-10-23 17:59:01 -07001602 return aModule
1603}
1604
Colin Crossdc35e212019-06-06 16:13:11 -07001605func (b *baseModuleContext) getDirectDepInternal(name string, tag blueprint.DependencyTag) (blueprint.Module, blueprint.DependencyTag) {
Jiyong Parkf2976302019-04-17 21:47:37 +09001606 type dep struct {
1607 mod blueprint.Module
1608 tag blueprint.DependencyTag
1609 }
1610 var deps []dep
Colin Crossdc35e212019-06-06 16:13:11 -07001611 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001612 if aModule, _ := module.(Module); aModule != nil && aModule.base().BaseModuleName() == name {
Colin Cross1184b642019-12-30 18:43:07 -08001613 returnedTag := b.bp.OtherModuleDependencyTag(aModule)
Jiyong Parkf2976302019-04-17 21:47:37 +09001614 if tag == nil || returnedTag == tag {
1615 deps = append(deps, dep{aModule, returnedTag})
1616 }
1617 }
1618 })
1619 if len(deps) == 1 {
1620 return deps[0].mod, deps[0].tag
1621 } else if len(deps) >= 2 {
1622 panic(fmt.Errorf("Multiple dependencies having same BaseModuleName() %q found from %q",
Colin Crossdc35e212019-06-06 16:13:11 -07001623 name, b.ModuleName()))
Jiyong Parkf2976302019-04-17 21:47:37 +09001624 } else {
1625 return nil, nil
1626 }
1627}
1628
Colin Crossdc35e212019-06-06 16:13:11 -07001629func (b *baseModuleContext) GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module {
Colin Cross0ef08162019-05-01 15:50:51 -07001630 var deps []Module
Colin Crossdc35e212019-06-06 16:13:11 -07001631 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001632 if aModule, _ := module.(Module); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001633 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Cross0ef08162019-05-01 15:50:51 -07001634 deps = append(deps, aModule)
1635 }
1636 }
1637 })
1638 return deps
1639}
1640
Colin Cross25de6c32019-06-06 14:29:25 -07001641func (m *moduleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1642 module, _ := m.getDirectDepInternal(name, tag)
1643 return module
Jiyong Parkf2976302019-04-17 21:47:37 +09001644}
1645
Colin Crossdc35e212019-06-06 16:13:11 -07001646func (b *baseModuleContext) GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag) {
1647 return b.getDirectDepInternal(name, nil)
Jiyong Parkf2976302019-04-17 21:47:37 +09001648}
1649
Colin Crossdc35e212019-06-06 16:13:11 -07001650func (b *baseModuleContext) VisitDirectDepsBlueprint(visit func(blueprint.Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001651 b.bp.VisitDirectDeps(visit)
Colin Cross35143d02017-11-16 00:11:20 -08001652}
1653
Colin Crossdc35e212019-06-06 16:13:11 -07001654func (b *baseModuleContext) VisitDirectDeps(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001655 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001656 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001657 visit(aModule)
1658 }
1659 })
1660}
1661
Colin Crossdc35e212019-06-06 16:13:11 -07001662func (b *baseModuleContext) VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001663 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001664 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001665 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Crossee6143c2017-12-30 17:54:27 -08001666 visit(aModule)
1667 }
1668 }
1669 })
1670}
1671
Colin Crossdc35e212019-06-06 16:13:11 -07001672func (b *baseModuleContext) VisitDirectDepsIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001673 b.bp.VisitDirectDepsIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001674 // pred
1675 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001676 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001677 return pred(aModule)
1678 } else {
1679 return false
1680 }
1681 },
1682 // visit
1683 func(module blueprint.Module) {
1684 visit(module.(Module))
1685 })
1686}
1687
Colin Crossdc35e212019-06-06 16:13:11 -07001688func (b *baseModuleContext) VisitDepsDepthFirst(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001689 b.bp.VisitDepsDepthFirst(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001690 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001691 visit(aModule)
1692 }
1693 })
1694}
1695
Colin Crossdc35e212019-06-06 16:13:11 -07001696func (b *baseModuleContext) VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001697 b.bp.VisitDepsDepthFirstIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001698 // pred
1699 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001700 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001701 return pred(aModule)
1702 } else {
1703 return false
1704 }
1705 },
1706 // visit
1707 func(module blueprint.Module) {
1708 visit(module.(Module))
1709 })
1710}
1711
Colin Crossdc35e212019-06-06 16:13:11 -07001712func (b *baseModuleContext) WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool) {
Colin Cross1184b642019-12-30 18:43:07 -08001713 b.bp.WalkDeps(visit)
Alex Light778127a2019-02-27 14:19:50 -08001714}
1715
Colin Crossdc35e212019-06-06 16:13:11 -07001716func (b *baseModuleContext) WalkDeps(visit func(Module, Module) bool) {
1717 b.walkPath = []Module{b.Module()}
Paul Duffinc5192442020-03-31 11:31:36 +01001718 b.tagPath = []blueprint.DependencyTag{}
Colin Cross1184b642019-12-30 18:43:07 -08001719 b.bp.WalkDeps(func(child, parent blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001720 childAndroidModule, _ := child.(Module)
1721 parentAndroidModule, _ := parent.(Module)
Colin Crossd11fcda2017-10-23 17:59:01 -07001722 if childAndroidModule != nil && parentAndroidModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001723 // record walkPath before visit
1724 for b.walkPath[len(b.walkPath)-1] != parentAndroidModule {
1725 b.walkPath = b.walkPath[0 : len(b.walkPath)-1]
Paul Duffinc5192442020-03-31 11:31:36 +01001726 b.tagPath = b.tagPath[0 : len(b.tagPath)-1]
Colin Crossdc35e212019-06-06 16:13:11 -07001727 }
1728 b.walkPath = append(b.walkPath, childAndroidModule)
Paul Duffinc5192442020-03-31 11:31:36 +01001729 b.tagPath = append(b.tagPath, b.OtherModuleDependencyTag(childAndroidModule))
Colin Crossd11fcda2017-10-23 17:59:01 -07001730 return visit(childAndroidModule, parentAndroidModule)
1731 } else {
1732 return false
1733 }
1734 })
1735}
1736
Colin Crossdc35e212019-06-06 16:13:11 -07001737func (b *baseModuleContext) GetWalkPath() []Module {
1738 return b.walkPath
1739}
1740
Paul Duffinc5192442020-03-31 11:31:36 +01001741func (b *baseModuleContext) GetTagPath() []blueprint.DependencyTag {
1742 return b.tagPath
1743}
1744
Jiyong Park1c7e9622020-05-07 16:12:13 +09001745// A regexp for removing boilerplate from BaseDependencyTag from the string representation of
1746// a dependency tag.
1747var tagCleaner = regexp.MustCompile(`\QBaseDependencyTag:blueprint.BaseDependencyTag{}\E(, )?`)
1748
1749// PrettyPrintTag returns string representation of the tag, but prefers
1750// custom String() method if available.
1751func PrettyPrintTag(tag blueprint.DependencyTag) string {
1752 // Use tag's custom String() method if available.
1753 if stringer, ok := tag.(fmt.Stringer); ok {
1754 return stringer.String()
1755 }
1756
1757 // Otherwise, get a default string representation of the tag's struct.
1758 tagString := fmt.Sprintf("%#v", tag)
1759
1760 // Remove the boilerplate from BaseDependencyTag as it adds no value.
1761 tagString = tagCleaner.ReplaceAllString(tagString, "")
1762 return tagString
1763}
1764
1765func (b *baseModuleContext) GetPathString(skipFirst bool) string {
1766 sb := strings.Builder{}
1767 tagPath := b.GetTagPath()
1768 walkPath := b.GetWalkPath()
1769 if !skipFirst {
1770 sb.WriteString(walkPath[0].String())
1771 }
1772 for i, m := range walkPath[1:] {
1773 sb.WriteString("\n")
1774 sb.WriteString(fmt.Sprintf(" via tag %s\n", PrettyPrintTag(tagPath[i])))
1775 sb.WriteString(fmt.Sprintf(" -> %s", m.String()))
1776 }
1777 return sb.String()
1778}
1779
Colin Cross25de6c32019-06-06 14:29:25 -07001780func (m *moduleContext) VisitAllModuleVariants(visit func(Module)) {
Colin Crossdc35e212019-06-06 16:13:11 -07001781 m.bp.VisitAllModuleVariants(func(module blueprint.Module) {
Colin Cross0875c522017-11-28 17:34:01 -08001782 visit(module.(Module))
1783 })
1784}
1785
Colin Cross25de6c32019-06-06 14:29:25 -07001786func (m *moduleContext) PrimaryModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001787 return m.bp.PrimaryModule().(Module)
Colin Cross0875c522017-11-28 17:34:01 -08001788}
1789
Colin Cross25de6c32019-06-06 14:29:25 -07001790func (m *moduleContext) FinalModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001791 return m.bp.FinalModule().(Module)
1792}
1793
1794func (m *moduleContext) ModuleSubDir() string {
1795 return m.bp.ModuleSubDir()
Colin Cross0875c522017-11-28 17:34:01 -08001796}
1797
Colin Cross0ea8ba82019-06-06 14:33:29 -07001798func (b *baseModuleContext) Target() Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001799 return b.target
Colin Crossa1ad8d12016-06-01 17:09:44 -07001800}
1801
Colin Cross0ea8ba82019-06-06 14:33:29 -07001802func (b *baseModuleContext) TargetPrimary() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001803 return b.targetPrimary
Colin Cross8b74d172016-09-13 09:59:14 -07001804}
1805
Colin Cross0ea8ba82019-06-06 14:33:29 -07001806func (b *baseModuleContext) MultiTargets() []Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001807 return b.multiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07001808}
1809
Colin Cross0ea8ba82019-06-06 14:33:29 -07001810func (b *baseModuleContext) Arch() Arch {
Colin Cross25de6c32019-06-06 14:29:25 -07001811 return b.target.Arch
Colin Cross3f40fa42015-01-30 17:27:36 -08001812}
1813
Colin Cross0ea8ba82019-06-06 14:33:29 -07001814func (b *baseModuleContext) Os() OsType {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001815 return b.os
Dan Willemsen490fd492015-11-24 17:53:15 -08001816}
1817
Colin Cross0ea8ba82019-06-06 14:33:29 -07001818func (b *baseModuleContext) Host() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001819 return b.os.Class == Host || b.os.Class == HostCross
Colin Crossf6566ed2015-03-24 11:13:38 -07001820}
1821
Colin Cross0ea8ba82019-06-06 14:33:29 -07001822func (b *baseModuleContext) Device() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001823 return b.os.Class == Device
Colin Crossf6566ed2015-03-24 11:13:38 -07001824}
1825
Colin Cross0ea8ba82019-06-06 14:33:29 -07001826func (b *baseModuleContext) Darwin() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001827 return b.os == Darwin
Colin Cross0af4b842015-04-30 16:36:18 -07001828}
1829
Colin Cross0ea8ba82019-06-06 14:33:29 -07001830func (b *baseModuleContext) Fuchsia() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001831 return b.os == Fuchsia
Doug Horn21b94272019-01-16 12:06:11 -08001832}
1833
Colin Cross0ea8ba82019-06-06 14:33:29 -07001834func (b *baseModuleContext) Windows() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001835 return b.os == Windows
Colin Cross3edeee12017-04-04 12:59:48 -07001836}
1837
Colin Cross0ea8ba82019-06-06 14:33:29 -07001838func (b *baseModuleContext) Debug() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001839 return b.debug
Colin Crossf6566ed2015-03-24 11:13:38 -07001840}
1841
Colin Cross0ea8ba82019-06-06 14:33:29 -07001842func (b *baseModuleContext) PrimaryArch() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001843 if len(b.config.Targets[b.target.Os]) <= 1 {
Colin Cross67a5c132017-05-09 13:45:28 -07001844 return true
1845 }
Colin Cross25de6c32019-06-06 14:29:25 -07001846 return b.target.Arch.ArchType == b.config.Targets[b.target.Os][0].Arch.ArchType
Colin Cross1e7d3702016-08-24 15:25:47 -07001847}
1848
Jiyong Park5baac542018-08-28 09:55:37 +09001849// Makes this module a platform module, i.e. not specific to soc, device,
Justin Yund5f6c822019-06-25 16:47:17 +09001850// product, or system_ext.
Colin Cross4157e882019-06-06 16:57:04 -07001851func (m *ModuleBase) MakeAsPlatform() {
1852 m.commonProperties.Vendor = boolPtr(false)
1853 m.commonProperties.Proprietary = boolPtr(false)
1854 m.commonProperties.Soc_specific = boolPtr(false)
1855 m.commonProperties.Product_specific = boolPtr(false)
Justin Yund5f6c822019-06-25 16:47:17 +09001856 m.commonProperties.System_ext_specific = boolPtr(false)
Jiyong Park5baac542018-08-28 09:55:37 +09001857}
1858
Colin Cross4157e882019-06-06 16:57:04 -07001859func (m *ModuleBase) EnableNativeBridgeSupportByDefault() {
1860 m.commonProperties.Native_bridge_supported = boolPtr(true)
dimitry03dc3f62019-05-09 14:07:34 +02001861}
1862
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001863func (m *ModuleBase) MakeAsSystemExt() {
Jooyung Han91df2082019-11-20 01:49:42 +09001864 m.commonProperties.Vendor = boolPtr(false)
1865 m.commonProperties.Proprietary = boolPtr(false)
1866 m.commonProperties.Soc_specific = boolPtr(false)
1867 m.commonProperties.Product_specific = boolPtr(false)
1868 m.commonProperties.System_ext_specific = boolPtr(true)
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001869}
1870
Jooyung Han344d5432019-08-23 11:17:39 +09001871// IsNativeBridgeSupported returns true if "native_bridge_supported" is explicitly set as "true"
1872func (m *ModuleBase) IsNativeBridgeSupported() bool {
1873 return proptools.Bool(m.commonProperties.Native_bridge_supported)
1874}
1875
Colin Cross25de6c32019-06-06 14:29:25 -07001876func (m *moduleContext) InstallInData() bool {
1877 return m.module.InstallInData()
Dan Willemsen782a2d12015-12-21 14:55:28 -08001878}
1879
Jaewoong Jung0949f312019-09-11 10:25:18 -07001880func (m *moduleContext) InstallInTestcases() bool {
1881 return m.module.InstallInTestcases()
1882}
1883
Colin Cross25de6c32019-06-06 14:29:25 -07001884func (m *moduleContext) InstallInSanitizerDir() bool {
1885 return m.module.InstallInSanitizerDir()
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001886}
1887
Yifan Hong1b3348d2020-01-21 15:53:22 -08001888func (m *moduleContext) InstallInRamdisk() bool {
1889 return m.module.InstallInRamdisk()
1890}
1891
Colin Cross25de6c32019-06-06 14:29:25 -07001892func (m *moduleContext) InstallInRecovery() bool {
1893 return m.module.InstallInRecovery()
Jiyong Parkf9332f12018-02-01 00:54:12 +09001894}
1895
Colin Cross90ba5f42019-10-02 11:10:58 -07001896func (m *moduleContext) InstallInRoot() bool {
1897 return m.module.InstallInRoot()
1898}
1899
Colin Cross607d8582019-07-29 16:44:46 -07001900func (m *moduleContext) InstallBypassMake() bool {
1901 return m.module.InstallBypassMake()
1902}
1903
Colin Cross6e359402020-02-10 15:29:54 -08001904func (m *moduleContext) InstallForceOS() *OsType {
1905 return m.module.InstallForceOS()
1906}
1907
Colin Cross70dda7e2019-10-01 22:05:35 -07001908func (m *moduleContext) skipInstall(fullInstallPath InstallPath) bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001909 if m.module.base().commonProperties.SkipInstall {
Colin Cross893d8162017-04-26 17:34:03 -07001910 return true
1911 }
1912
Colin Cross3607f212018-05-07 15:28:05 -07001913 // We'll need a solution for choosing which of modules with the same name in different
1914 // namespaces to install. For now, reuse the list of namespaces exported to Make as the
1915 // list of namespaces to install in a Soong-only build.
Colin Cross25de6c32019-06-06 14:29:25 -07001916 if !m.module.base().commonProperties.NamespaceExportedToMake {
Colin Cross3607f212018-05-07 15:28:05 -07001917 return true
1918 }
1919
Colin Cross25de6c32019-06-06 14:29:25 -07001920 if m.Device() {
Colin Cross607d8582019-07-29 16:44:46 -07001921 if m.Config().EmbeddedInMake() && !m.InstallBypassMake() {
Colin Cross893d8162017-04-26 17:34:03 -07001922 return true
1923 }
1924
Colin Cross25de6c32019-06-06 14:29:25 -07001925 if m.Config().SkipMegaDeviceInstall(fullInstallPath.String()) {
Colin Cross893d8162017-04-26 17:34:03 -07001926 return true
1927 }
1928 }
1929
1930 return false
1931}
1932
Colin Cross70dda7e2019-10-01 22:05:35 -07001933func (m *moduleContext) InstallFile(installPath InstallPath, name string, srcPath Path,
1934 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001935 return m.installFile(installPath, name, srcPath, Cp, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001936}
1937
Colin Cross70dda7e2019-10-01 22:05:35 -07001938func (m *moduleContext) InstallExecutable(installPath InstallPath, name string, srcPath Path,
1939 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001940 return m.installFile(installPath, name, srcPath, CpExecutable, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001941}
1942
Colin Cross70dda7e2019-10-01 22:05:35 -07001943func (m *moduleContext) installFile(installPath InstallPath, name string, srcPath Path,
1944 rule blueprint.Rule, deps []Path) InstallPath {
Colin Cross35cec122015-04-02 14:37:16 -07001945
Colin Cross25de6c32019-06-06 14:29:25 -07001946 fullInstallPath := installPath.Join(m, name)
1947 m.module.base().hooks.runInstallHooks(m, fullInstallPath, false)
Colin Cross3f40fa42015-01-30 17:27:36 -08001948
Colin Cross25de6c32019-06-06 14:29:25 -07001949 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001950
Colin Cross897266e2020-02-13 13:22:08 -08001951 deps = append(deps, m.installDeps.Paths()...)
Colin Cross35cec122015-04-02 14:37:16 -07001952
Colin Cross89562dc2016-10-03 17:47:19 -07001953 var implicitDeps, orderOnlyDeps Paths
1954
Colin Cross25de6c32019-06-06 14:29:25 -07001955 if m.Host() {
Colin Cross89562dc2016-10-03 17:47:19 -07001956 // Installed host modules might be used during the build, depend directly on their
1957 // dependencies so their timestamp is updated whenever their dependency is updated
1958 implicitDeps = deps
1959 } else {
1960 orderOnlyDeps = deps
1961 }
1962
Colin Cross25de6c32019-06-06 14:29:25 -07001963 m.Build(pctx, BuildParams{
Colin Cross5c517922017-08-31 12:29:17 -07001964 Rule: rule,
Colin Cross67a5c132017-05-09 13:45:28 -07001965 Description: "install " + fullInstallPath.Base(),
1966 Output: fullInstallPath,
1967 Input: srcPath,
1968 Implicits: implicitDeps,
1969 OrderOnly: orderOnlyDeps,
Colin Cross25de6c32019-06-06 14:29:25 -07001970 Default: !m.Config().EmbeddedInMake(),
Dan Willemsen322acaf2016-01-12 23:07:05 -08001971 })
Colin Cross3f40fa42015-01-30 17:27:36 -08001972
Colin Cross25de6c32019-06-06 14:29:25 -07001973 m.installFiles = append(m.installFiles, fullInstallPath)
Dan Willemsen322acaf2016-01-12 23:07:05 -08001974 }
Colin Cross25de6c32019-06-06 14:29:25 -07001975 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross35cec122015-04-02 14:37:16 -07001976 return fullInstallPath
1977}
1978
Colin Cross70dda7e2019-10-01 22:05:35 -07001979func (m *moduleContext) InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001980 fullInstallPath := installPath.Join(m, name)
1981 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Colin Cross3854a602016-01-11 12:49:11 -08001982
Colin Cross25de6c32019-06-06 14:29:25 -07001983 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001984
Alex Lightfb4353d2019-01-17 13:57:45 -08001985 relPath, err := filepath.Rel(path.Dir(fullInstallPath.String()), srcPath.String())
1986 if err != nil {
1987 panic(fmt.Sprintf("Unable to generate symlink between %q and %q: %s", fullInstallPath.Base(), srcPath.Base(), err))
1988 }
Colin Cross25de6c32019-06-06 14:29:25 -07001989 m.Build(pctx, BuildParams{
Colin Cross67a5c132017-05-09 13:45:28 -07001990 Rule: Symlink,
1991 Description: "install symlink " + fullInstallPath.Base(),
1992 Output: fullInstallPath,
Dan Willemsen40efa1c2020-01-14 15:19:52 -08001993 Input: srcPath,
Colin Cross25de6c32019-06-06 14:29:25 -07001994 Default: !m.Config().EmbeddedInMake(),
Colin Cross12fc4972016-01-11 12:49:11 -08001995 Args: map[string]string{
Alex Lightfb4353d2019-01-17 13:57:45 -08001996 "fromPath": relPath,
Colin Cross12fc4972016-01-11 12:49:11 -08001997 },
1998 })
Colin Cross3854a602016-01-11 12:49:11 -08001999
Colin Cross25de6c32019-06-06 14:29:25 -07002000 m.installFiles = append(m.installFiles, fullInstallPath)
2001 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross12fc4972016-01-11 12:49:11 -08002002 }
Colin Cross3854a602016-01-11 12:49:11 -08002003 return fullInstallPath
2004}
2005
Jiyong Parkf1194352019-02-25 11:05:47 +09002006// installPath/name -> absPath where absPath might be a path that is available only at runtime
2007// (e.g. /apex/...)
Colin Cross70dda7e2019-10-01 22:05:35 -07002008func (m *moduleContext) InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002009 fullInstallPath := installPath.Join(m, name)
2010 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Jiyong Parkf1194352019-02-25 11:05:47 +09002011
Colin Cross25de6c32019-06-06 14:29:25 -07002012 if !m.skipInstall(fullInstallPath) {
2013 m.Build(pctx, BuildParams{
Jiyong Parkf1194352019-02-25 11:05:47 +09002014 Rule: Symlink,
2015 Description: "install symlink " + fullInstallPath.Base() + " -> " + absPath,
2016 Output: fullInstallPath,
Colin Cross25de6c32019-06-06 14:29:25 -07002017 Default: !m.Config().EmbeddedInMake(),
Jiyong Parkf1194352019-02-25 11:05:47 +09002018 Args: map[string]string{
2019 "fromPath": absPath,
2020 },
2021 })
2022
Colin Cross25de6c32019-06-06 14:29:25 -07002023 m.installFiles = append(m.installFiles, fullInstallPath)
Jiyong Parkf1194352019-02-25 11:05:47 +09002024 }
2025 return fullInstallPath
2026}
2027
Colin Cross25de6c32019-06-06 14:29:25 -07002028func (m *moduleContext) CheckbuildFile(srcPath Path) {
2029 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross3f40fa42015-01-30 17:27:36 -08002030}
2031
Dan Willemsen2ef08f42015-06-30 18:15:24 -07002032func findStringInSlice(str string, slice []string) int {
2033 for i, s := range slice {
2034 if s == str {
2035 return i
Colin Crossfce53272015-04-08 11:21:40 -07002036 }
2037 }
Dan Willemsen2ef08f42015-06-30 18:15:24 -07002038 return -1
2039}
2040
Colin Cross41955e82019-05-29 14:40:35 -07002041// SrcIsModule decodes module references in the format ":name" into the module name, or empty string if the input
2042// was not a module reference.
2043func SrcIsModule(s string) (module string) {
Colin Cross068e0fe2016-12-13 15:23:47 -08002044 if len(s) > 1 && s[0] == ':' {
2045 return s[1:]
2046 }
2047 return ""
2048}
2049
Colin Cross41955e82019-05-29 14:40:35 -07002050// SrcIsModule decodes module references in the format ":name{.tag}" into the module name and tag, ":name" into the
2051// module name and an empty string for the tag, or empty strings if the input was not a module reference.
2052func SrcIsModuleWithTag(s string) (module, tag string) {
2053 if len(s) > 1 && s[0] == ':' {
2054 module = s[1:]
2055 if tagStart := strings.IndexByte(module, '{'); tagStart > 0 {
2056 if module[len(module)-1] == '}' {
2057 tag = module[tagStart+1 : len(module)-1]
2058 module = module[:tagStart]
2059 return module, tag
2060 }
2061 }
2062 return module, ""
2063 }
2064 return "", ""
Colin Cross068e0fe2016-12-13 15:23:47 -08002065}
2066
Colin Cross41955e82019-05-29 14:40:35 -07002067type sourceOrOutputDependencyTag struct {
2068 blueprint.BaseDependencyTag
2069 tag string
2070}
2071
2072func sourceOrOutputDepTag(tag string) blueprint.DependencyTag {
2073 return sourceOrOutputDependencyTag{tag: tag}
2074}
2075
2076var SourceDepTag = sourceOrOutputDepTag("")
Colin Cross068e0fe2016-12-13 15:23:47 -08002077
Colin Cross366938f2017-12-11 16:29:02 -08002078// Adds necessary dependencies to satisfy filegroup or generated sources modules listed in srcFiles
2079// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002080//
2081// Deprecated: tag the property with `android:"path"` instead.
Colin Cross068e0fe2016-12-13 15:23:47 -08002082func ExtractSourcesDeps(ctx BottomUpMutatorContext, srcFiles []string) {
Nan Zhang2439eb72017-04-10 11:27:50 -07002083 set := make(map[string]bool)
2084
Colin Cross068e0fe2016-12-13 15:23:47 -08002085 for _, s := range srcFiles {
Colin Cross41955e82019-05-29 14:40:35 -07002086 if m, t := SrcIsModuleWithTag(s); m != "" {
2087 if _, found := set[s]; found {
2088 ctx.ModuleErrorf("found source dependency duplicate: %q!", s)
Nan Zhang2439eb72017-04-10 11:27:50 -07002089 } else {
Colin Cross41955e82019-05-29 14:40:35 -07002090 set[s] = true
2091 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Nan Zhang2439eb72017-04-10 11:27:50 -07002092 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002093 }
2094 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002095}
2096
Colin Cross366938f2017-12-11 16:29:02 -08002097// Adds necessary dependencies to satisfy filegroup or generated sources modules specified in s
2098// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002099//
2100// Deprecated: tag the property with `android:"path"` instead.
Colin Cross366938f2017-12-11 16:29:02 -08002101func ExtractSourceDeps(ctx BottomUpMutatorContext, s *string) {
2102 if s != nil {
Colin Cross41955e82019-05-29 14:40:35 -07002103 if m, t := SrcIsModuleWithTag(*s); m != "" {
2104 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Colin Cross366938f2017-12-11 16:29:02 -08002105 }
2106 }
2107}
2108
Colin Cross41955e82019-05-29 14:40:35 -07002109// A module that implements SourceFileProducer can be referenced from any property that is tagged with `android:"path"`
2110// 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 -08002111type SourceFileProducer interface {
2112 Srcs() Paths
2113}
2114
Colin Cross41955e82019-05-29 14:40:35 -07002115// A module that implements OutputFileProducer can be referenced from any property that is tagged with `android:"path"`
Roland Levillain97c1f342019-11-22 14:20:54 +00002116// 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 -07002117// listed in the property.
2118type OutputFileProducer interface {
2119 OutputFiles(tag string) (Paths, error)
2120}
2121
Colin Cross5e708052019-08-06 13:59:50 -07002122// OutputFilesForModule returns the paths from an OutputFileProducer with the given tag. On error, including if the
2123// module produced zero paths, it reports errors to the ctx and returns nil.
2124func OutputFilesForModule(ctx PathContext, module blueprint.Module, tag string) Paths {
2125 paths, err := outputFilesForModule(ctx, module, tag)
2126 if err != nil {
2127 reportPathError(ctx, err)
2128 return nil
2129 }
2130 return paths
2131}
2132
2133// OutputFileForModule returns the path from an OutputFileProducer with the given tag. On error, including if the
2134// module produced zero or multiple paths, it reports errors to the ctx and returns nil.
2135func OutputFileForModule(ctx PathContext, module blueprint.Module, tag string) Path {
2136 paths, err := outputFilesForModule(ctx, module, tag)
2137 if err != nil {
2138 reportPathError(ctx, err)
2139 return nil
2140 }
2141 if len(paths) > 1 {
2142 reportPathErrorf(ctx, "got multiple output files from module %q, expected exactly one",
2143 pathContextName(ctx, module))
2144 return nil
2145 }
2146 return paths[0]
2147}
2148
2149func outputFilesForModule(ctx PathContext, module blueprint.Module, tag string) (Paths, error) {
2150 if outputFileProducer, ok := module.(OutputFileProducer); ok {
2151 paths, err := outputFileProducer.OutputFiles(tag)
2152 if err != nil {
2153 return nil, fmt.Errorf("failed to get output file from module %q: %s",
2154 pathContextName(ctx, module), err.Error())
2155 }
2156 if len(paths) == 0 {
2157 return nil, fmt.Errorf("failed to get output files from module %q", pathContextName(ctx, module))
2158 }
2159 return paths, nil
2160 } else {
2161 return nil, fmt.Errorf("module %q is not an OutputFileProducer", pathContextName(ctx, module))
2162 }
2163}
2164
Colin Crossfe17f6f2019-03-28 19:30:56 -07002165type HostToolProvider interface {
2166 HostToolPath() OptionalPath
2167}
2168
Colin Cross27b922f2019-03-04 22:35:41 -08002169// Returns a list of paths expanded from globs and modules referenced using ":module" syntax. The property must
2170// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002171//
2172// Deprecated: use PathsForModuleSrc or PathsForModuleSrcExcludes instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002173func (m *moduleContext) ExpandSources(srcFiles, excludes []string) Paths {
2174 return PathsForModuleSrcExcludes(m, srcFiles, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07002175}
2176
Colin Cross2fafa3e2019-03-05 12:39:51 -08002177// Returns a single path expanded from globs and modules referenced using ":module" syntax. The property must
2178// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002179//
2180// Deprecated: use PathForModuleSrc instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002181func (m *moduleContext) ExpandSource(srcFile, prop string) Path {
2182 return PathForModuleSrc(m, srcFile)
Colin Cross2fafa3e2019-03-05 12:39:51 -08002183}
2184
2185// Returns an optional single path expanded from globs and modules referenced using ":module" syntax if
2186// the srcFile is non-nil. The property must be tagged with `android:"path" to support automatic source module
2187// dependency resolution.
Colin Cross25de6c32019-06-06 14:29:25 -07002188func (m *moduleContext) ExpandOptionalSource(srcFile *string, prop string) OptionalPath {
Colin Cross2fafa3e2019-03-05 12:39:51 -08002189 if srcFile != nil {
Colin Cross25de6c32019-06-06 14:29:25 -07002190 return OptionalPathForPath(PathForModuleSrc(m, *srcFile))
Colin Cross2fafa3e2019-03-05 12:39:51 -08002191 }
2192 return OptionalPath{}
2193}
2194
Colin Cross25de6c32019-06-06 14:29:25 -07002195func (m *moduleContext) RequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002196 return m.module.RequiredModuleNames()
Nan Zhang6d34b302017-02-04 17:47:46 -08002197}
2198
Colin Cross25de6c32019-06-06 14:29:25 -07002199func (m *moduleContext) HostRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002200 return m.module.HostRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002201}
2202
Colin Cross25de6c32019-06-06 14:29:25 -07002203func (m *moduleContext) TargetRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002204 return m.module.TargetRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002205}
2206
Colin Cross463a90e2015-06-17 14:20:06 -07002207func init() {
Colin Cross798bfce2016-10-12 14:28:16 -07002208 RegisterSingletonType("buildtarget", BuildTargetSingleton)
Colin Cross463a90e2015-06-17 14:20:06 -07002209}
2210
Colin Cross0875c522017-11-28 17:34:01 -08002211func BuildTargetSingleton() Singleton {
Colin Cross1f8c52b2015-06-16 16:38:17 -07002212 return &buildTargetSingleton{}
2213}
2214
Colin Cross87d8b562017-04-25 10:01:55 -07002215func parentDir(dir string) string {
2216 dir, _ = filepath.Split(dir)
2217 return filepath.Clean(dir)
2218}
2219
Colin Cross1f8c52b2015-06-16 16:38:17 -07002220type buildTargetSingleton struct{}
2221
Colin Cross0875c522017-11-28 17:34:01 -08002222func (c *buildTargetSingleton) GenerateBuildActions(ctx SingletonContext) {
2223 var checkbuildDeps Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07002224
Colin Cross0875c522017-11-28 17:34:01 -08002225 mmTarget := func(dir string) WritablePath {
2226 return PathForPhony(ctx,
2227 "MODULES-IN-"+strings.Replace(filepath.Clean(dir), "/", "-", -1))
Colin Cross87d8b562017-04-25 10:01:55 -07002228 }
2229
Colin Cross0875c522017-11-28 17:34:01 -08002230 modulesInDir := make(map[string]Paths)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002231
Colin Cross0875c522017-11-28 17:34:01 -08002232 ctx.VisitAllModules(func(module Module) {
2233 blueprintDir := module.base().blueprintDir
2234 installTarget := module.base().installTarget
2235 checkbuildTarget := module.base().checkbuildTarget
Colin Cross1f8c52b2015-06-16 16:38:17 -07002236
Colin Cross0875c522017-11-28 17:34:01 -08002237 if checkbuildTarget != nil {
2238 checkbuildDeps = append(checkbuildDeps, checkbuildTarget)
2239 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], checkbuildTarget)
2240 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002241
Colin Cross0875c522017-11-28 17:34:01 -08002242 if installTarget != nil {
2243 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], installTarget)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002244 }
2245 })
2246
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002247 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08002248 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002249 suffix = "-soong"
2250 }
2251
Colin Cross1f8c52b2015-06-16 16:38:17 -07002252 // Create a top-level checkbuild target that depends on all modules
Colin Cross0875c522017-11-28 17:34:01 -08002253 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07002254 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002255 Output: PathForPhony(ctx, "checkbuild"+suffix),
Colin Cross1f8c52b2015-06-16 16:38:17 -07002256 Implicits: checkbuildDeps,
Colin Cross1f8c52b2015-06-16 16:38:17 -07002257 })
2258
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002259 // Make will generate the MODULES-IN-* targets
Colin Crossaabf6792017-11-29 00:27:14 -08002260 if ctx.Config().EmbeddedInMake() {
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002261 return
2262 }
2263
Colin Cross87d8b562017-04-25 10:01:55 -07002264 // Ensure ancestor directories are in modulesInDir
Inseob Kim1a365c62019-06-08 15:47:51 +09002265 dirs := SortedStringKeys(modulesInDir)
Colin Cross87d8b562017-04-25 10:01:55 -07002266 for _, dir := range dirs {
2267 dir := parentDir(dir)
2268 for dir != "." && dir != "/" {
2269 if _, exists := modulesInDir[dir]; exists {
2270 break
2271 }
2272 modulesInDir[dir] = nil
2273 dir = parentDir(dir)
2274 }
2275 }
2276
2277 // Make directories build their direct subdirectories
Colin Cross87d8b562017-04-25 10:01:55 -07002278 for _, dir := range dirs {
2279 p := parentDir(dir)
2280 if p != "." && p != "/" {
2281 modulesInDir[p] = append(modulesInDir[p], mmTarget(dir))
2282 }
2283 }
2284
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002285 // Create a MODULES-IN-<directory> target that depends on all modules in a directory, and
2286 // depends on the MODULES-IN-* targets of all of its subdirectories that contain Android.bp
2287 // files.
Colin Cross1f8c52b2015-06-16 16:38:17 -07002288 for _, dir := range dirs {
Colin Cross0875c522017-11-28 17:34:01 -08002289 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07002290 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002291 Output: mmTarget(dir),
Colin Cross87d8b562017-04-25 10:01:55 -07002292 Implicits: modulesInDir[dir],
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002293 // HACK: checkbuild should be an optional build, but force it
2294 // enabled for now in standalone builds
Colin Crossaabf6792017-11-29 00:27:14 -08002295 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross1f8c52b2015-06-16 16:38:17 -07002296 })
2297 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002298
2299 // Create (host|host-cross|target)-<OS> phony rules to build a reduced checkbuild.
2300 osDeps := map[OsType]Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08002301 ctx.VisitAllModules(func(module Module) {
2302 if module.Enabled() {
2303 os := module.Target().Os
2304 osDeps[os] = append(osDeps[os], module.base().checkbuildFiles...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002305 }
2306 })
2307
Colin Cross0875c522017-11-28 17:34:01 -08002308 osClass := make(map[string]Paths)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002309 for os, deps := range osDeps {
2310 var className string
2311
2312 switch os.Class {
2313 case Host:
2314 className = "host"
2315 case HostCross:
2316 className = "host-cross"
2317 case Device:
2318 className = "target"
2319 default:
2320 continue
2321 }
2322
Colin Cross0875c522017-11-28 17:34:01 -08002323 name := PathForPhony(ctx, className+"-"+os.Name)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002324 osClass[className] = append(osClass[className], name)
2325
Colin Cross0875c522017-11-28 17:34:01 -08002326 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07002327 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002328 Output: name,
2329 Implicits: deps,
Dan Willemsen61d88b82017-09-20 17:29:08 -07002330 })
2331 }
2332
2333 // Wrap those into host|host-cross|target phony rules
Inseob Kim1a365c62019-06-08 15:47:51 +09002334 for _, class := range SortedStringKeys(osClass) {
Colin Cross0875c522017-11-28 17:34:01 -08002335 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07002336 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002337 Output: PathForPhony(ctx, class),
Dan Willemsen61d88b82017-09-20 17:29:08 -07002338 Implicits: osClass[class],
Dan Willemsen61d88b82017-09-20 17:29:08 -07002339 })
2340 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002341}
Colin Crossd779da42015-12-17 18:00:23 -08002342
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002343// Collect information for opening IDE project files in java/jdeps.go.
2344type IDEInfo interface {
2345 IDEInfo(ideInfo *IdeInfo)
2346 BaseModuleName() string
2347}
2348
2349// Extract the base module name from the Import name.
2350// Often the Import name has a prefix "prebuilt_".
2351// Remove the prefix explicitly if needed
2352// until we find a better solution to get the Import name.
2353type IDECustomizedModuleName interface {
2354 IDECustomizedModuleName() string
2355}
2356
2357type IdeInfo struct {
2358 Deps []string `json:"dependencies,omitempty"`
2359 Srcs []string `json:"srcs,omitempty"`
2360 Aidl_include_dirs []string `json:"aidl_include_dirs,omitempty"`
2361 Jarjar_rules []string `json:"jarjar_rules,omitempty"`
2362 Jars []string `json:"jars,omitempty"`
2363 Classes []string `json:"class,omitempty"`
2364 Installed_paths []string `json:"installed,omitempty"`
patricktu18c82ff2019-05-10 15:48:50 +08002365 SrcJars []string `json:"srcjars,omitempty"`
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002366}