blob: 0bf48d59717af6b1e9a41adace80d097d1ba8b6a [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"
Colin Cross6ff51382015-12-17 16:39:19 -080022 "strings"
Colin Crossaabf6792017-11-29 00:27:14 -080023 "text/scanner"
Colin Crossf6566ed2015-03-24 11:13:38 -070024
25 "github.com/google/blueprint"
Colin Crossfe4bc362018-09-12 10:02:13 -070026 "github.com/google/blueprint/proptools"
Colin Cross3f40fa42015-01-30 17:27:36 -080027)
28
29var (
30 DeviceSharedLibrary = "shared_library"
31 DeviceStaticLibrary = "static_library"
32 DeviceExecutable = "executable"
33 HostSharedLibrary = "host_shared_library"
34 HostStaticLibrary = "host_static_library"
35 HostExecutable = "host_executable"
36)
37
Colin Crossae887032017-10-23 17:16:14 -070038type BuildParams struct {
Dan Willemsen9f3c5742016-11-03 14:28:31 -070039 Rule blueprint.Rule
Colin Cross33bfb0a2016-11-21 17:23:08 -080040 Deps blueprint.Deps
41 Depfile WritablePath
Colin Cross67a5c132017-05-09 13:45:28 -070042 Description string
Dan Willemsen9f3c5742016-11-03 14:28:31 -070043 Output WritablePath
44 Outputs WritablePaths
45 ImplicitOutput WritablePath
46 ImplicitOutputs WritablePaths
47 Input Path
48 Inputs Paths
49 Implicit Path
50 Implicits Paths
51 OrderOnly Paths
52 Default bool
53 Args map[string]string
Dan Willemsen34cc69e2015-09-23 15:26:20 -070054}
55
Colin Crossae887032017-10-23 17:16:14 -070056type ModuleBuildParams BuildParams
57
Colin Cross1184b642019-12-30 18:43:07 -080058// EarlyModuleContext provides methods that can be called early, as soon as the properties have
59// been parsed into the module and before any mutators have run.
60type EarlyModuleContext interface {
61 Module() Module
62 ModuleName() string
63 ModuleDir() string
64 ModuleType() string
Colin Cross9d34f352019-11-22 16:03:51 -080065 BlueprintsFile() string
Colin Cross1184b642019-12-30 18:43:07 -080066
67 ContainsProperty(name string) bool
68 Errorf(pos scanner.Position, fmt string, args ...interface{})
69 ModuleErrorf(fmt string, args ...interface{})
70 PropertyErrorf(property, fmt string, args ...interface{})
71 Failed() bool
72
73 AddNinjaFileDeps(deps ...string)
74
75 DeviceSpecific() bool
76 SocSpecific() bool
77 ProductSpecific() bool
78 SystemExtSpecific() bool
79 Platform() bool
80
81 Config() Config
82 DeviceConfig() DeviceConfig
83
84 // Deprecated: use Config()
85 AConfig() Config
86
87 // GlobWithDeps returns a list of files that match the specified pattern but do not match any
88 // of the patterns in excludes. It also adds efficient dependencies to rerun the primary
89 // builder whenever a file matching the pattern as added or removed, without rerunning if a
90 // file that does not match the pattern is added to a searched directory.
91 GlobWithDeps(pattern string, excludes []string) ([]string, error)
92
93 Glob(globPattern string, excludes []string) Paths
94 GlobFiles(globPattern string, excludes []string) Paths
Colin Cross988414c2020-01-11 01:11:46 +000095 IsSymlink(path Path) bool
96 Readlink(path Path) string
Colin Cross1184b642019-12-30 18:43:07 -080097}
98
Colin Cross0ea8ba82019-06-06 14:33:29 -070099// BaseModuleContext is the same as blueprint.BaseModuleContext except that Config() returns
Colin Crossdc35e212019-06-06 16:13:11 -0700100// a Config instead of an interface{}, and some methods have been wrapped to use an android.Module
101// instead of a blueprint.Module, plus some extra methods that return Android-specific information
Colin Cross0ea8ba82019-06-06 14:33:29 -0700102// about the current module.
103type BaseModuleContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800104 EarlyModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -0700105
Colin Crossdc35e212019-06-06 16:13:11 -0700106 OtherModuleName(m blueprint.Module) string
107 OtherModuleDir(m blueprint.Module) string
108 OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{})
109 OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag
110 OtherModuleExists(name string) bool
Jiyong Park9e6c2422019-08-09 20:39:45 +0900111 OtherModuleType(m blueprint.Module) string
Colin Crossdc35e212019-06-06 16:13:11 -0700112
113 GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module
114 GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module
115 GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag)
116
117 VisitDirectDepsBlueprint(visit func(blueprint.Module))
118 VisitDirectDeps(visit func(Module))
119 VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module))
120 VisitDirectDepsIf(pred func(Module) bool, visit func(Module))
121 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
122 VisitDepsDepthFirst(visit func(Module))
123 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
124 VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module))
125 WalkDeps(visit func(Module, Module) bool)
126 WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool)
127 // GetWalkPath is supposed to be called in visit function passed in WalkDeps()
128 // and returns a top-down dependency path from a start module to current child module.
129 GetWalkPath() []Module
130
Paul Duffinf0207962020-03-31 11:31:36 +0100131 // GetTagPath is supposed to be called in visit function passed in WalkDeps()
132 // and returns a top-down dependency tags path from a start module to current child module.
133 // It has one less entry than GetWalkPath() as it contains the dependency tags that
134 // exist between each adjacent pair of modules in the GetWalkPath().
135 // GetTagPath()[i] is the tag between GetWalkPath()[i] and GetWalkPath()[i+1]
136 GetTagPath() []blueprint.DependencyTag
137
Colin Crossdc35e212019-06-06 16:13:11 -0700138 AddMissingDependencies(missingDeps []string)
139
Colin Crossa1ad8d12016-06-01 17:09:44 -0700140 Target() Target
Colin Cross8b74d172016-09-13 09:59:14 -0700141 TargetPrimary() bool
Paul Duffin28d70c72020-02-25 15:50:49 +0000142
143 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
144 // responsible for creating.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700145 MultiTargets() []Target
Colin Crossf6566ed2015-03-24 11:13:38 -0700146 Arch() Arch
Colin Crossa1ad8d12016-06-01 17:09:44 -0700147 Os() OsType
Colin Crossf6566ed2015-03-24 11:13:38 -0700148 Host() bool
149 Device() bool
Colin Cross0af4b842015-04-30 16:36:18 -0700150 Darwin() bool
Doug Horn21b94272019-01-16 12:06:11 -0800151 Fuchsia() bool
Colin Cross3edeee12017-04-04 12:59:48 -0700152 Windows() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700153 Debug() bool
Colin Cross1e7d3702016-08-24 15:25:47 -0700154 PrimaryArch() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700155}
156
Colin Cross1184b642019-12-30 18:43:07 -0800157// Deprecated: use EarlyModuleContext instead
Colin Cross635c3b02016-05-18 15:37:25 -0700158type BaseContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800159 EarlyModuleContext
Colin Crossaabf6792017-11-29 00:27:14 -0800160}
161
Colin Cross635c3b02016-05-18 15:37:25 -0700162type ModuleContext interface {
Colin Crossaabf6792017-11-29 00:27:14 -0800163 BaseModuleContext
Colin Cross3f40fa42015-01-30 17:27:36 -0800164
Colin Crossae887032017-10-23 17:16:14 -0700165 // Deprecated: use ModuleContext.Build instead.
Colin Cross0875c522017-11-28 17:34:01 -0800166 ModuleBuild(pctx PackageContext, params ModuleBuildParams)
Colin Cross8f101b42015-06-17 15:09:06 -0700167
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700168 ExpandSources(srcFiles, excludes []string) Paths
Colin Cross366938f2017-12-11 16:29:02 -0800169 ExpandSource(srcFile, prop string) Path
Colin Cross2383f3b2018-02-06 14:40:13 -0800170 ExpandOptionalSource(srcFile *string, prop string) OptionalPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700171
Colin Cross70dda7e2019-10-01 22:05:35 -0700172 InstallExecutable(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
173 InstallFile(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
174 InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath
175 InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700176 CheckbuildFile(srcPath Path)
Dan Willemsen6553f5e2016-03-10 18:14:25 -0800177
Colin Cross8d8f8e22016-08-03 11:57:50 -0700178 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700179 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700180 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800181 InstallInRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900182 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700183 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700184 InstallBypassMake() bool
Nan Zhang6d34b302017-02-04 17:47:46 -0800185
186 RequiredModuleNames() []string
Sasha Smundakb6d23052019-04-01 18:37:36 -0700187 HostRequiredModuleNames() []string
188 TargetRequiredModuleNames() []string
Colin Cross3f68a132017-10-23 17:10:29 -0700189
Colin Cross3f68a132017-10-23 17:10:29 -0700190 ModuleSubDir() string
191
Colin Cross0875c522017-11-28 17:34:01 -0800192 Variable(pctx PackageContext, name, value string)
193 Rule(pctx PackageContext, name string, params blueprint.RuleParams, argNames ...string) blueprint.Rule
Colin Crossae887032017-10-23 17:16:14 -0700194 // Similar to blueprint.ModuleContext.Build, but takes Paths instead of []string,
195 // and performs more verification.
Colin Cross0875c522017-11-28 17:34:01 -0800196 Build(pctx PackageContext, params BuildParams)
Colin Cross98552072020-06-04 13:25:17 -0700197 // Phony creates a Make-style phony rule, a rule with no commands that can depend on other
198 // phony rules or real files. Phony can be called on the same name multiple times to add
199 // additional dependencies.
200 Phony(phony string, deps ...Path)
Colin Cross3f68a132017-10-23 17:10:29 -0700201
Colin Cross0875c522017-11-28 17:34:01 -0800202 PrimaryModule() Module
203 FinalModule() Module
204 VisitAllModuleVariants(visit func(Module))
Colin Cross3f68a132017-10-23 17:10:29 -0700205
206 GetMissingDependencies() []string
Jeff Gaston088e29e2017-11-29 16:47:17 -0800207 Namespace() blueprint.Namespace
Colin Cross3f40fa42015-01-30 17:27:36 -0800208}
209
Colin Cross635c3b02016-05-18 15:37:25 -0700210type Module interface {
Colin Cross3f40fa42015-01-30 17:27:36 -0800211 blueprint.Module
212
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700213 // GenerateAndroidBuildActions is analogous to Blueprints' GenerateBuildActions,
214 // but GenerateAndroidBuildActions also has access to Android-specific information.
215 // For more information, see Module.GenerateBuildActions within Blueprint's module_ctx.go
Colin Cross635c3b02016-05-18 15:37:25 -0700216 GenerateAndroidBuildActions(ModuleContext)
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700217
Colin Cross1e676be2016-10-12 14:38:15 -0700218 DepsMutator(BottomUpMutatorContext)
Colin Cross3f40fa42015-01-30 17:27:36 -0800219
Colin Cross635c3b02016-05-18 15:37:25 -0700220 base() *ModuleBase
Inseob Kimeec88e12020-01-22 11:11:29 +0900221 Disable()
Dan Willemsen0effe062015-11-30 16:06:01 -0800222 Enabled() bool
Colin Crossa1ad8d12016-06-01 17:09:44 -0700223 Target() Target
Dan Willemsen782a2d12015-12-21 14:55:28 -0800224 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700225 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700226 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800227 InstallInRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900228 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700229 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700230 InstallBypassMake() bool
Colin Crossa2f296f2016-11-29 15:16:18 -0800231 SkipInstall()
Ulya Trafimovichcc21bba2020-01-13 15:18:16 +0000232 IsSkipInstall() bool
Jiyong Park374510b2018-03-19 18:23:01 +0900233 ExportedToMake() bool
Inseob Kim8471cda2019-11-15 09:59:12 +0900234 InitRc() Paths
235 VintfFragments() Paths
Jiyong Park52818fc2019-03-18 12:01:38 +0900236 NoticeFile() OptionalPath
Colin Cross36242852017-06-23 15:06:31 -0700237
238 AddProperties(props ...interface{})
239 GetProperties() []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700240
Colin Crossae887032017-10-23 17:16:14 -0700241 BuildParamsForTests() []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800242 RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800243 VariablesForTests() map[string]string
Paul Duffine2453c72019-05-31 14:00:04 +0100244
Colin Cross9a362232019-07-01 15:32:45 -0700245 // String returns a string that includes the module name and variants for printing during debugging.
246 String() string
247
Paul Duffine2453c72019-05-31 14:00:04 +0100248 // Get the qualified module id for this module.
249 qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName
250
251 // Get information about the properties that can contain visibility rules.
252 visibilityProperties() []visibilityProperty
Paul Duffin63c6e182019-07-24 14:24:38 +0100253
Jiyong Park6a8cf5f2019-12-30 16:31:09 +0900254 RequiredModuleNames() []string
255 HostRequiredModuleNames() []string
256 TargetRequiredModuleNames() []string
Paul Duffine2453c72019-05-31 14:00:04 +0100257}
258
259// Qualified id for a module
260type qualifiedModuleName struct {
261 // The package (i.e. directory) in which the module is defined, without trailing /
262 pkg string
263
264 // The name of the module, empty string if package.
265 name string
266}
267
268func (q qualifiedModuleName) String() string {
269 if q.name == "" {
270 return "//" + q.pkg
271 }
272 return "//" + q.pkg + ":" + q.name
273}
274
Paul Duffine484f472019-06-20 16:38:08 +0100275func (q qualifiedModuleName) isRootPackage() bool {
276 return q.pkg == "" && q.name == ""
277}
278
Paul Duffine2453c72019-05-31 14:00:04 +0100279// Get the id for the package containing this module.
280func (q qualifiedModuleName) getContainingPackageId() qualifiedModuleName {
281 pkg := q.pkg
282 if q.name == "" {
Paul Duffine484f472019-06-20 16:38:08 +0100283 if pkg == "" {
284 panic(fmt.Errorf("Cannot get containing package id of root package"))
285 }
286
287 index := strings.LastIndex(pkg, "/")
288 if index == -1 {
289 pkg = ""
290 } else {
291 pkg = pkg[:index]
292 }
Paul Duffine2453c72019-05-31 14:00:04 +0100293 }
294 return newPackageId(pkg)
295}
296
297func newPackageId(pkg string) qualifiedModuleName {
298 // A qualified id for a package module has no name.
299 return qualifiedModuleName{pkg: pkg, name: ""}
Colin Cross3f40fa42015-01-30 17:27:36 -0800300}
301
Colin Crossfc754582016-05-17 16:34:16 -0700302type nameProperties struct {
303 // The name of the module. Must be unique across all modules.
Nan Zhang0007d812017-11-07 10:57:05 -0800304 Name *string
Colin Crossfc754582016-05-17 16:34:16 -0700305}
306
307type commonProperties struct {
Dan Willemsen0effe062015-11-30 16:06:01 -0800308 // emit build rules for this module
Paul Duffin54d9bb72020-02-12 10:20:56 +0000309 //
310 // Disabling a module should only be done for those modules that cannot be built
311 // in the current environment. Modules that can build in the current environment
312 // but are not usually required (e.g. superceded by a prebuilt) should not be
313 // disabled as that will prevent them from being built by the checkbuild target
314 // and so prevent early detection of changes that have broken those modules.
Dan Willemsen0effe062015-11-30 16:06:01 -0800315 Enabled *bool `android:"arch_variant"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800316
Paul Duffin2e61fa62019-03-28 14:10:57 +0000317 // Controls the visibility of this module to other modules. Allowable values are one or more of
318 // these formats:
319 //
320 // ["//visibility:public"]: Anyone can use this module.
321 // ["//visibility:private"]: Only rules in the module's package (not its subpackages) can use
322 // this module.
Paul Duffin31c43e72020-05-05 19:19:22 +0100323 // ["//visibility:override"]: Discards any rules inherited from defaults or a creating module.
324 // Can only be used at the beginning of a list of visibility rules.
Paul Duffin2e61fa62019-03-28 14:10:57 +0000325 // ["//some/package:__pkg__", "//other/package:__pkg__"]: Only modules in some/package and
326 // other/package (defined in some/package/*.bp and other/package/*.bp) have access to
327 // this module. Note that sub-packages do not have access to the rule; for example,
328 // //some/package/foo:bar or //other/package/testing:bla wouldn't have access. __pkg__
329 // is a special module and must be used verbatim. It represents all of the modules in the
330 // package.
331 // ["//project:__subpackages__", "//other:__subpackages__"]: Only modules in packages project
332 // or other or in one of their sub-packages have access to this module. For example,
333 // //project:rule, //project/library:lib or //other/testing/internal:munge are allowed
334 // to depend on this rule (but not //independent:evil)
335 // ["//project"]: This is shorthand for ["//project:__pkg__"]
336 // [":__subpackages__"]: This is shorthand for ["//project:__subpackages__"] where
337 // //project is the module's package. e.g. using [":__subpackages__"] in
338 // packages/apps/Settings/Android.bp is equivalent to
339 // //packages/apps/Settings:__subpackages__.
340 // ["//visibility:legacy_public"]: The default visibility, behaves as //visibility:public
341 // for now. It is an error if it is used in a module.
Paul Duffine2453c72019-05-31 14:00:04 +0100342 //
343 // If a module does not specify the `visibility` property then it uses the
344 // `default_visibility` property of the `package` module in the module's package.
345 //
346 // If the `default_visibility` property is not set for the module's package then
Paul Duffine484f472019-06-20 16:38:08 +0100347 // it will use the `default_visibility` of its closest ancestor package for which
348 // a `default_visibility` property is specified.
349 //
350 // If no `default_visibility` property can be found then the module uses the
351 // global default of `//visibility:legacy_public`.
Paul Duffine2453c72019-05-31 14:00:04 +0100352 //
Paul Duffin95d53b52019-07-24 13:45:05 +0100353 // The `visibility` property has no effect on a defaults module although it does
354 // apply to any non-defaults module that uses it. To set the visibility of a
355 // defaults module, use the `defaults_visibility` property on the defaults module;
356 // not to be confused with the `default_visibility` property on the package module.
357 //
Paul Duffin2e61fa62019-03-28 14:10:57 +0000358 // See https://android.googlesource.com/platform/build/soong/+/master/README.md#visibility for
359 // more details.
360 Visibility []string
361
Colin Cross7d5136f2015-05-11 13:39:40 -0700362 // control whether this module compiles for 32-bit, 64-bit, or both. Possible values
Colin Cross3f40fa42015-01-30 17:27:36 -0800363 // are "32" (compile for 32-bit only), "64" (compile for 64-bit only), "both" (compile for both
364 // architectures), or "first" (compile for 64-bit on a 64-bit platform, and 32-bit on a 32-bit
365 // platform
Colin Cross7d716ba2017-11-01 10:38:29 -0700366 Compile_multilib *string `android:"arch_variant"`
Colin Cross69617d32016-09-06 10:39:07 -0700367
368 Target struct {
369 Host struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700370 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700371 }
372 Android struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700373 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700374 }
375 }
376
Paul Duffin28d70c72020-02-25 15:50:49 +0000377 // If set to true then the archMutator will create variants for each arch specific target
378 // (e.g. 32/64) that the module is required to produce. If set to false then it will only
379 // create a variant for the architecture and will list the additional arch specific targets
380 // that the variant needs to produce in the CompileMultiTargets property.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700381 UseTargetVariants bool `blueprint:"mutated"`
382 Default_multilib string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800383
Dan Willemsen782a2d12015-12-21 14:55:28 -0800384 // whether this is a proprietary vendor module, and should be installed into /vendor
Colin Cross7d716ba2017-11-01 10:38:29 -0700385 Proprietary *bool
Dan Willemsen782a2d12015-12-21 14:55:28 -0800386
Colin Cross55708f32017-03-20 13:23:34 -0700387 // vendor who owns this module
Dan Willemsenefac4a82017-07-18 19:42:09 -0700388 Owner *string
Colin Cross55708f32017-03-20 13:23:34 -0700389
Jiyong Park2db76922017-11-08 16:03:48 +0900390 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
391 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
392 // Use `soc_specific` instead for better meaning.
Colin Cross7d716ba2017-11-01 10:38:29 -0700393 Vendor *bool
Dan Willemsenaa118f92017-04-06 12:49:58 -0700394
Jiyong Park2db76922017-11-08 16:03:48 +0900395 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
396 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
397 Soc_specific *bool
398
399 // whether this module is specific to a device, not only for SoC, but also for off-chip
400 // peripherals. When set to true, it is installed into /odm (or /vendor/odm if odm partition
401 // does not exist, or /system/vendor/odm if both odm and vendor partitions do not exist).
402 // This implies `soc_specific:true`.
403 Device_specific *bool
404
405 // whether this module is specific to a software configuration of a product (e.g. country,
Jaekyun Seok5cfbfbb2018-01-10 19:00:15 +0900406 // network operator, etc). When set to true, it is installed into /product (or
407 // /system/product if product partition does not exist).
Jiyong Park2db76922017-11-08 16:03:48 +0900408 Product_specific *bool
409
Justin Yund5f6c822019-06-25 16:47:17 +0900410 // whether this module extends system. When set to true, it is installed into /system_ext
411 // (or /system/system_ext if system_ext partition does not exist).
412 System_ext_specific *bool
413
Jiyong Parkf9332f12018-02-01 00:54:12 +0900414 // Whether this module is installed to recovery partition
415 Recovery *bool
416
Yifan Hong1b3348d2020-01-21 15:53:22 -0800417 // Whether this module is installed to ramdisk
418 Ramdisk *bool
419
dimitry1f33e402019-03-26 12:39:31 +0100420 // Whether this module is built for non-native architecures (also known as native bridge binary)
421 Native_bridge_supported *bool `android:"arch_variant"`
422
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700423 // init.rc files to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800424 Init_rc []string `android:"path"`
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700425
Steven Moreland57a23d22018-04-04 15:42:19 -0700426 // VINTF manifest fragments to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800427 Vintf_fragments []string `android:"path"`
Steven Moreland57a23d22018-04-04 15:42:19 -0700428
Chris Wolfe998306e2016-08-15 14:47:23 -0400429 // names of other modules to install if this module is installed
Colin Crossc602b7d2017-05-05 13:36:36 -0700430 Required []string `android:"arch_variant"`
Chris Wolfe998306e2016-08-15 14:47:23 -0400431
Sasha Smundakb6d23052019-04-01 18:37:36 -0700432 // names of other modules to install on host if this module is installed
433 Host_required []string `android:"arch_variant"`
434
435 // names of other modules to install on target if this module is installed
436 Target_required []string `android:"arch_variant"`
437
Colin Cross5aac3622017-08-31 15:07:09 -0700438 // relative path to a file to include in the list of notices for the device
Colin Cross27b922f2019-03-04 22:35:41 -0800439 Notice *string `android:"path"`
Colin Cross5aac3622017-08-31 15:07:09 -0700440
Dan Willemsen569edc52018-11-19 09:33:29 -0800441 Dist struct {
442 // copy the output of this module to the $DIST_DIR when `dist` is specified on the
443 // command line and any of these targets are also on the command line, or otherwise
444 // built
445 Targets []string `android:"arch_variant"`
446
447 // The name of the output artifact. This defaults to the basename of the output of
448 // the module.
449 Dest *string `android:"arch_variant"`
450
451 // The directory within the dist directory to store the artifact. Defaults to the
452 // top level directory ("").
453 Dir *string `android:"arch_variant"`
454
455 // A suffix to add to the artifact file name (before any extension).
456 Suffix *string `android:"arch_variant"`
457 } `android:"arch_variant"`
458
Paul Duffin28d70c72020-02-25 15:50:49 +0000459 // The OsType of artifacts that this module variant is responsible for creating.
460 //
461 // Set by osMutator
462 CompileOS OsType `blueprint:"mutated"`
463
464 // The Target of artifacts that this module variant is responsible for creating.
465 //
466 // Set by archMutator
467 CompileTarget Target `blueprint:"mutated"`
468
469 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
470 // responsible for creating.
471 //
472 // By default this is nil as, where necessary, separate variants are created for the
473 // different multilib types supported and that information is encapsulated in the
474 // CompileTarget so the module variant simply needs to create artifacts for that.
475 //
476 // However, if UseTargetVariants is set to false (e.g. by
477 // InitAndroidMultiTargetsArchModule) then no separate variants are created for the
478 // multilib targets. Instead a single variant is created for the architecture and
479 // this contains the multilib specific targets that this variant should create.
480 //
481 // Set by archMutator
Colin Crossee0bc3b2018-10-02 22:01:37 -0700482 CompileMultiTargets []Target `blueprint:"mutated"`
Paul Duffin28d70c72020-02-25 15:50:49 +0000483
484 // True if the module variant's CompileTarget is the primary target
485 //
486 // Set by archMutator
487 CompilePrimary bool `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800488
489 // Set by InitAndroidModule
490 HostOrDeviceSupported HostOrDeviceSupported `blueprint:"mutated"`
Dan Willemsen0b24c742016-10-04 15:13:37 -0700491 ArchSpecific bool `blueprint:"mutated"`
Colin Crossce75d2c2016-10-06 16:12:58 -0700492
Paul Duffinb0cbec32020-02-25 19:26:33 +0000493 // If set to true then a CommonOS variant will be created which will have dependencies
494 // on all its OsType specific variants. Used by sdk/module_exports to create a snapshot
495 // that covers all os and architecture variants.
496 //
497 // The OsType specific variants can be retrieved by calling
498 // GetOsSpecificVariantsOfCommonOSVariant
499 //
500 // Set at module initialization time by calling InitCommonOSAndroidMultiTargetsArchModule
501 CreateCommonOSVariant bool `blueprint:"mutated"`
502
503 // If set to true then this variant is the CommonOS variant that has dependencies on its
504 // OsType specific variants.
505 //
506 // Set by osMutator.
507 CommonOSVariant bool `blueprint:"mutated"`
508
Colin Crossce75d2c2016-10-06 16:12:58 -0700509 SkipInstall bool `blueprint:"mutated"`
Jeff Gaston088e29e2017-11-29 16:47:17 -0800510
511 NamespaceExportedToMake bool `blueprint:"mutated"`
Colin Cross6c4f21f2019-06-06 15:41:36 -0700512
513 MissingDeps []string `blueprint:"mutated"`
Colin Cross9a362232019-07-01 15:32:45 -0700514
515 // Name and variant strings stored by mutators to enable Module.String()
516 DebugName string `blueprint:"mutated"`
517 DebugMutators []string `blueprint:"mutated"`
518 DebugVariations []string `blueprint:"mutated"`
Colin Cross7228ecd2019-11-18 16:00:16 -0800519
520 // set by ImageMutator
521 ImageVariation string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800522}
523
524type hostAndDeviceProperties struct {
Colin Cross4e81d702018-11-09 10:36:55 -0800525 // If set to true, build a variant of the module for the host. Defaults to false.
526 Host_supported *bool
527
528 // If set to true, build a variant of the module for the device. Defaults to true.
Colin Crossa4190c12016-07-12 13:11:25 -0700529 Device_supported *bool
Colin Cross3f40fa42015-01-30 17:27:36 -0800530}
531
Colin Crossc472d572015-03-17 15:06:21 -0700532type Multilib string
533
534const (
Colin Cross6b4a32d2017-12-05 13:42:45 -0800535 MultilibBoth Multilib = "both"
536 MultilibFirst Multilib = "first"
537 MultilibCommon Multilib = "common"
538 MultilibCommonFirst Multilib = "common_first"
539 MultilibDefault Multilib = ""
Colin Crossc472d572015-03-17 15:06:21 -0700540)
541
Colin Crossa1ad8d12016-06-01 17:09:44 -0700542type HostOrDeviceSupported int
543
544const (
545 _ HostOrDeviceSupported = iota
Dan Albert0981b5c2018-08-02 13:46:35 -0700546
547 // Host and HostCross are built by default. Device is not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700548 HostSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700549
550 // Host is built by default. HostCross and Device are not supported.
Dan Albertc6345fb2016-10-20 01:36:11 -0700551 HostSupportedNoCross
Dan Albert0981b5c2018-08-02 13:46:35 -0700552
553 // Device is built by default. Host and HostCross are not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700554 DeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700555
556 // Device is built by default. Host and HostCross are supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700557 HostAndDeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700558
559 // Host, HostCross, and Device are built by default.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700560 HostAndDeviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700561
562 // Nothing is supported. This is not exposed to the user, but used to mark a
563 // host only module as unsupported when the module type is not supported on
564 // the host OS. E.g. benchmarks are supported on Linux but not Darwin.
Dan Willemsen0b24c742016-10-04 15:13:37 -0700565 NeitherHostNorDeviceSupported
Colin Crossa1ad8d12016-06-01 17:09:44 -0700566)
567
Jiyong Park2db76922017-11-08 16:03:48 +0900568type moduleKind int
569
570const (
571 platformModule moduleKind = iota
572 deviceSpecificModule
573 socSpecificModule
574 productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900575 systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900576)
577
578func (k moduleKind) String() string {
579 switch k {
580 case platformModule:
581 return "platform"
582 case deviceSpecificModule:
583 return "device-specific"
584 case socSpecificModule:
585 return "soc-specific"
586 case productSpecificModule:
587 return "product-specific"
Justin Yund5f6c822019-06-25 16:47:17 +0900588 case systemExtSpecificModule:
589 return "systemext-specific"
Jiyong Park2db76922017-11-08 16:03:48 +0900590 default:
591 panic(fmt.Errorf("unknown module kind %d", k))
592 }
593}
594
Colin Cross9d34f352019-11-22 16:03:51 -0800595func initAndroidModuleBase(m Module) {
596 m.base().module = m
597}
598
Colin Cross36242852017-06-23 15:06:31 -0700599func InitAndroidModule(m Module) {
Colin Cross9d34f352019-11-22 16:03:51 -0800600 initAndroidModuleBase(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800601 base := m.base()
Colin Cross5049f022015-03-18 13:28:46 -0700602
Colin Cross36242852017-06-23 15:06:31 -0700603 m.AddProperties(
Colin Crossfc754582016-05-17 16:34:16 -0700604 &base.nameProperties,
Colin Cross18c46802019-09-24 22:19:02 -0700605 &base.commonProperties)
606
Colin Crosseabaedd2020-02-06 17:01:55 -0800607 initProductVariableModule(m)
Colin Cross18c46802019-09-24 22:19:02 -0700608
Colin Crossa3a97412019-03-18 12:24:29 -0700609 base.generalProperties = m.GetProperties()
Pirama Arumuga Nainar955dc492018-04-17 14:58:42 -0700610 base.customizableProperties = m.GetProperties()
Paul Duffin63c6e182019-07-24 14:24:38 +0100611
612 // The default_visibility property needs to be checked and parsed by the visibility module during
Paul Duffinabc9a642020-05-01 17:52:01 +0100613 // its checking and parsing phases so make it the primary visibility property.
614 setPrimaryVisibilityProperty(m, "visibility", &base.commonProperties.Visibility)
Colin Cross5049f022015-03-18 13:28:46 -0700615}
616
Colin Cross36242852017-06-23 15:06:31 -0700617func InitAndroidArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
618 InitAndroidModule(m)
Colin Cross5049f022015-03-18 13:28:46 -0700619
620 base := m.base()
Colin Cross3f40fa42015-01-30 17:27:36 -0800621 base.commonProperties.HostOrDeviceSupported = hod
Colin Cross69617d32016-09-06 10:39:07 -0700622 base.commonProperties.Default_multilib = string(defaultMultilib)
Dan Willemsen0b24c742016-10-04 15:13:37 -0700623 base.commonProperties.ArchSpecific = true
Colin Crossee0bc3b2018-10-02 22:01:37 -0700624 base.commonProperties.UseTargetVariants = true
Colin Cross3f40fa42015-01-30 17:27:36 -0800625
Dan Willemsen218f6562015-07-08 18:13:11 -0700626 switch hod {
Nan Zhang1a0f09b2017-07-05 10:35:11 -0700627 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Cross36242852017-06-23 15:06:31 -0700628 m.AddProperties(&base.hostAndDeviceProperties)
Colin Cross3f40fa42015-01-30 17:27:36 -0800629 }
630
Colin Cross36242852017-06-23 15:06:31 -0700631 InitArchModule(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800632}
633
Colin Crossee0bc3b2018-10-02 22:01:37 -0700634func InitAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
635 InitAndroidArchModule(m, hod, defaultMultilib)
636 m.base().commonProperties.UseTargetVariants = false
637}
638
Paul Duffinb0cbec32020-02-25 19:26:33 +0000639// As InitAndroidMultiTargetsArchModule except it creates an additional CommonOS variant that
640// has dependencies on all the OsType specific variants.
641func InitCommonOSAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
642 InitAndroidArchModule(m, hod, defaultMultilib)
643 m.base().commonProperties.UseTargetVariants = false
644 m.base().commonProperties.CreateCommonOSVariant = true
645}
646
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800647// A ModuleBase object contains the properties that are common to all Android
Colin Cross3f40fa42015-01-30 17:27:36 -0800648// modules. It should be included as an anonymous field in every module
649// struct definition. InitAndroidModule should then be called from the module's
650// factory function, and the return values from InitAndroidModule should be
651// returned from the factory function.
652//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800653// The ModuleBase type is responsible for implementing the GenerateBuildActions
654// method to support the blueprint.Module interface. This method will then call
655// the module's GenerateAndroidBuildActions method once for each build variant
Colin Cross25de6c32019-06-06 14:29:25 -0700656// that is to be built. GenerateAndroidBuildActions is passed a ModuleContext
657// rather than the usual blueprint.ModuleContext.
658// ModuleContext exposes extra functionality specific to the Android build
Colin Cross3f40fa42015-01-30 17:27:36 -0800659// system including details about the particular build variant that is to be
660// generated.
661//
662// For example:
663//
664// import (
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800665// "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -0800666// )
667//
668// type myModule struct {
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800669// android.ModuleBase
Colin Cross3f40fa42015-01-30 17:27:36 -0800670// properties struct {
671// MyProperty string
672// }
673// }
674//
Colin Cross36242852017-06-23 15:06:31 -0700675// func NewMyModule() android.Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800676// m := &myModule{}
Colin Cross36242852017-06-23 15:06:31 -0700677// m.AddProperties(&m.properties)
678// android.InitAndroidModule(m)
679// return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800680// }
681//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800682// func (m *myModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800683// // Get the CPU architecture for the current build variant.
684// variantArch := ctx.Arch()
685//
686// // ...
687// }
Colin Cross635c3b02016-05-18 15:37:25 -0700688type ModuleBase struct {
Colin Cross3f40fa42015-01-30 17:27:36 -0800689 // Putting the curiously recurring thing pointing to the thing that contains
690 // the thing pattern to good use.
Colin Cross36242852017-06-23 15:06:31 -0700691 // TODO: remove this
Colin Cross635c3b02016-05-18 15:37:25 -0700692 module Module
Colin Cross3f40fa42015-01-30 17:27:36 -0800693
Colin Crossfc754582016-05-17 16:34:16 -0700694 nameProperties nameProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800695 commonProperties commonProperties
Colin Cross18c46802019-09-24 22:19:02 -0700696 variableProperties interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800697 hostAndDeviceProperties hostAndDeviceProperties
698 generalProperties []interface{}
Colin Crossc17727d2018-10-24 12:42:09 -0700699 archProperties [][]interface{}
Colin Crossa120ec12016-08-19 16:07:38 -0700700 customizableProperties []interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800701
Paul Duffin63c6e182019-07-24 14:24:38 +0100702 // Information about all the properties on the module that contains visibility rules that need
703 // checking.
704 visibilityPropertyInfo []visibilityProperty
705
706 // The primary visibility property, may be nil, that controls access to the module.
707 primaryVisibilityProperty visibilityProperty
708
Colin Cross3f40fa42015-01-30 17:27:36 -0800709 noAddressSanitizer bool
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700710 installFiles Paths
711 checkbuildFiles Paths
Jiyong Park52818fc2019-03-18 12:01:38 +0900712 noticeFile OptionalPath
Colin Cross98552072020-06-04 13:25:17 -0700713 phonies map[string]Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -0700714
715 // Used by buildTargetSingleton to create checkbuild and per-directory build targets
716 // Only set on the final variant of each module
Colin Cross0875c522017-11-28 17:34:01 -0800717 installTarget WritablePath
718 checkbuildTarget WritablePath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700719 blueprintDir string
Colin Crossa120ec12016-08-19 16:07:38 -0700720
Colin Cross178a5092016-09-13 13:42:32 -0700721 hooks hooks
Colin Cross36242852017-06-23 15:06:31 -0700722
723 registerProps []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700724
725 // For tests
Colin Crossae887032017-10-23 17:16:14 -0700726 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800727 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800728 variables map[string]string
Colin Crossa9d8bee2018-10-02 13:59:46 -0700729
Inseob Kim8471cda2019-11-15 09:59:12 +0900730 initRcPaths Paths
731 vintfFragmentsPaths Paths
732
Colin Crossa9d8bee2018-10-02 13:59:46 -0700733 prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool
Colin Cross36242852017-06-23 15:06:31 -0700734}
735
Colin Cross4157e882019-06-06 16:57:04 -0700736func (m *ModuleBase) DepsMutator(BottomUpMutatorContext) {}
Colin Cross5f692ec2019-02-01 16:53:07 -0800737
Colin Cross4157e882019-06-06 16:57:04 -0700738func (m *ModuleBase) AddProperties(props ...interface{}) {
739 m.registerProps = append(m.registerProps, props...)
Colin Cross36242852017-06-23 15:06:31 -0700740}
741
Colin Cross4157e882019-06-06 16:57:04 -0700742func (m *ModuleBase) GetProperties() []interface{} {
743 return m.registerProps
Colin Cross3f40fa42015-01-30 17:27:36 -0800744}
745
Colin Cross4157e882019-06-06 16:57:04 -0700746func (m *ModuleBase) BuildParamsForTests() []BuildParams {
747 return m.buildParams
Colin Crosscec81712017-07-13 14:43:27 -0700748}
749
Colin Cross4157e882019-06-06 16:57:04 -0700750func (m *ModuleBase) RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams {
751 return m.ruleParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800752}
753
Colin Cross4157e882019-06-06 16:57:04 -0700754func (m *ModuleBase) VariablesForTests() map[string]string {
755 return m.variables
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800756}
757
Colin Cross4157e882019-06-06 16:57:04 -0700758func (m *ModuleBase) Prefer32(prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool) {
759 m.prefer32 = prefer32
Colin Crossa9d8bee2018-10-02 13:59:46 -0700760}
761
Colin Crossce75d2c2016-10-06 16:12:58 -0700762// Name returns the name of the module. It may be overridden by individual module types, for
763// example prebuilts will prepend prebuilt_ to the name.
Colin Cross4157e882019-06-06 16:57:04 -0700764func (m *ModuleBase) Name() string {
765 return String(m.nameProperties.Name)
Colin Crossfc754582016-05-17 16:34:16 -0700766}
767
Colin Cross9a362232019-07-01 15:32:45 -0700768// String returns a string that includes the module name and variants for printing during debugging.
769func (m *ModuleBase) String() string {
770 sb := strings.Builder{}
771 sb.WriteString(m.commonProperties.DebugName)
772 sb.WriteString("{")
773 for i := range m.commonProperties.DebugMutators {
774 if i != 0 {
775 sb.WriteString(",")
776 }
777 sb.WriteString(m.commonProperties.DebugMutators[i])
778 sb.WriteString(":")
779 sb.WriteString(m.commonProperties.DebugVariations[i])
780 }
781 sb.WriteString("}")
782 return sb.String()
783}
784
Colin Crossce75d2c2016-10-06 16:12:58 -0700785// BaseModuleName returns the name of the module as specified in the blueprints file.
Colin Cross4157e882019-06-06 16:57:04 -0700786func (m *ModuleBase) BaseModuleName() string {
787 return String(m.nameProperties.Name)
Colin Crossce75d2c2016-10-06 16:12:58 -0700788}
789
Colin Cross4157e882019-06-06 16:57:04 -0700790func (m *ModuleBase) base() *ModuleBase {
791 return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800792}
793
Paul Duffine2453c72019-05-31 14:00:04 +0100794func (m *ModuleBase) qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName {
795 return qualifiedModuleName{pkg: ctx.ModuleDir(), name: ctx.ModuleName()}
796}
797
798func (m *ModuleBase) visibilityProperties() []visibilityProperty {
Paul Duffin63c6e182019-07-24 14:24:38 +0100799 return m.visibilityPropertyInfo
800}
801
Colin Cross4157e882019-06-06 16:57:04 -0700802func (m *ModuleBase) Target() Target {
803 return m.commonProperties.CompileTarget
Dan Willemsen490fd492015-11-24 17:53:15 -0800804}
805
Colin Cross4157e882019-06-06 16:57:04 -0700806func (m *ModuleBase) TargetPrimary() bool {
807 return m.commonProperties.CompilePrimary
Colin Cross8b74d172016-09-13 09:59:14 -0700808}
809
Colin Cross4157e882019-06-06 16:57:04 -0700810func (m *ModuleBase) MultiTargets() []Target {
811 return m.commonProperties.CompileMultiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -0700812}
813
Colin Cross4157e882019-06-06 16:57:04 -0700814func (m *ModuleBase) Os() OsType {
815 return m.Target().Os
Dan Willemsen490fd492015-11-24 17:53:15 -0800816}
817
Colin Cross4157e882019-06-06 16:57:04 -0700818func (m *ModuleBase) Host() bool {
819 return m.Os().Class == Host || m.Os().Class == HostCross
Dan Willemsen97750522016-02-09 17:43:51 -0800820}
821
Colin Cross4157e882019-06-06 16:57:04 -0700822func (m *ModuleBase) Arch() Arch {
823 return m.Target().Arch
Dan Willemsen97750522016-02-09 17:43:51 -0800824}
825
Colin Cross4157e882019-06-06 16:57:04 -0700826func (m *ModuleBase) ArchSpecific() bool {
827 return m.commonProperties.ArchSpecific
Dan Willemsen0b24c742016-10-04 15:13:37 -0700828}
829
Paul Duffinb0cbec32020-02-25 19:26:33 +0000830// True if the current variant is a CommonOS variant, false otherwise.
831func (m *ModuleBase) IsCommonOSVariant() bool {
832 return m.commonProperties.CommonOSVariant
833}
834
Colin Cross4157e882019-06-06 16:57:04 -0700835func (m *ModuleBase) OsClassSupported() []OsClass {
836 switch m.commonProperties.HostOrDeviceSupported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700837 case HostSupported:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700838 return []OsClass{Host, HostCross}
Dan Albertc6345fb2016-10-20 01:36:11 -0700839 case HostSupportedNoCross:
840 return []OsClass{Host}
Colin Crossa1ad8d12016-06-01 17:09:44 -0700841 case DeviceSupported:
842 return []OsClass{Device}
Dan Albert0981b5c2018-08-02 13:46:35 -0700843 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700844 var supported []OsClass
Colin Cross4157e882019-06-06 16:57:04 -0700845 if Bool(m.hostAndDeviceProperties.Host_supported) ||
846 (m.commonProperties.HostOrDeviceSupported == HostAndDeviceDefault &&
847 m.hostAndDeviceProperties.Host_supported == nil) {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700848 supported = append(supported, Host, HostCross)
849 }
Colin Cross4157e882019-06-06 16:57:04 -0700850 if m.hostAndDeviceProperties.Device_supported == nil ||
851 *m.hostAndDeviceProperties.Device_supported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700852 supported = append(supported, Device)
853 }
854 return supported
855 default:
856 return nil
857 }
Colin Cross3f40fa42015-01-30 17:27:36 -0800858}
859
Colin Cross4157e882019-06-06 16:57:04 -0700860func (m *ModuleBase) DeviceSupported() bool {
861 return m.commonProperties.HostOrDeviceSupported == DeviceSupported ||
862 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
863 (m.hostAndDeviceProperties.Device_supported == nil ||
864 *m.hostAndDeviceProperties.Device_supported)
Colin Cross3f40fa42015-01-30 17:27:36 -0800865}
866
Paul Duffine44358f2019-11-26 18:04:12 +0000867func (m *ModuleBase) HostSupported() bool {
868 return m.commonProperties.HostOrDeviceSupported == HostSupported ||
869 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
870 (m.hostAndDeviceProperties.Host_supported != nil &&
871 *m.hostAndDeviceProperties.Host_supported)
872}
873
Colin Cross4157e882019-06-06 16:57:04 -0700874func (m *ModuleBase) Platform() bool {
Justin Yund5f6c822019-06-25 16:47:17 +0900875 return !m.DeviceSpecific() && !m.SocSpecific() && !m.ProductSpecific() && !m.SystemExtSpecific()
Jiyong Parkc678ad32018-04-10 13:07:10 +0900876}
877
Colin Cross4157e882019-06-06 16:57:04 -0700878func (m *ModuleBase) DeviceSpecific() bool {
879 return Bool(m.commonProperties.Device_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900880}
881
Colin Cross4157e882019-06-06 16:57:04 -0700882func (m *ModuleBase) SocSpecific() bool {
883 return Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900884}
885
Colin Cross4157e882019-06-06 16:57:04 -0700886func (m *ModuleBase) ProductSpecific() bool {
887 return Bool(m.commonProperties.Product_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900888}
889
Justin Yund5f6c822019-06-25 16:47:17 +0900890func (m *ModuleBase) SystemExtSpecific() bool {
891 return Bool(m.commonProperties.System_ext_specific)
Dario Frenifd05a742018-05-29 13:28:54 +0100892}
893
Colin Crosseb032962020-05-13 11:05:02 -0700894// RequiresStableAPIs returns true if the module will be installed to a partition that may
895// be updated separately from the system image.
896func (m *ModuleBase) RequiresStableAPIs(ctx BaseModuleContext) bool {
897 return m.SocSpecific() || m.DeviceSpecific() ||
898 (m.ProductSpecific() && ctx.Config().EnforceProductPartitionInterface())
899}
900
Bill Peckham1c610cf2020-03-20 18:33:20 -0700901func (m *ModuleBase) PartitionTag(config DeviceConfig) string {
902 partition := "system"
903 if m.SocSpecific() {
904 // A SoC-specific module could be on the vendor partition at
905 // "vendor" or the system partition at "system/vendor".
906 if config.VendorPath() == "vendor" {
907 partition = "vendor"
908 }
909 } else if m.DeviceSpecific() {
910 // A device-specific module could be on the odm partition at
911 // "odm", the vendor partition at "vendor/odm", or the system
912 // partition at "system/vendor/odm".
913 if config.OdmPath() == "odm" {
914 partition = "odm"
Ulya Trafimovichcc21bba2020-01-13 15:18:16 +0000915 } else if strings.HasPrefix(config.OdmPath(), "vendor/") {
Bill Peckham1c610cf2020-03-20 18:33:20 -0700916 partition = "vendor"
917 }
918 } else if m.ProductSpecific() {
919 // A product-specific module could be on the product partition
920 // at "product" or the system partition at "system/product".
921 if config.ProductPath() == "product" {
922 partition = "product"
923 }
924 } else if m.SystemExtSpecific() {
925 // A system_ext-specific module could be on the system_ext
926 // partition at "system_ext" or the system partition at
927 // "system/system_ext".
928 if config.SystemExtPath() == "system_ext" {
929 partition = "system_ext"
930 }
931 }
932 return partition
933}
934
Colin Cross4157e882019-06-06 16:57:04 -0700935func (m *ModuleBase) Enabled() bool {
936 if m.commonProperties.Enabled == nil {
937 return !m.Os().DefaultDisabled
Dan Willemsen490fd492015-11-24 17:53:15 -0800938 }
Colin Cross4157e882019-06-06 16:57:04 -0700939 return *m.commonProperties.Enabled
Colin Cross3f40fa42015-01-30 17:27:36 -0800940}
941
Inseob Kimeec88e12020-01-22 11:11:29 +0900942func (m *ModuleBase) Disable() {
943 m.commonProperties.Enabled = proptools.BoolPtr(false)
944}
945
Colin Cross4157e882019-06-06 16:57:04 -0700946func (m *ModuleBase) SkipInstall() {
947 m.commonProperties.SkipInstall = true
Colin Crossce75d2c2016-10-06 16:12:58 -0700948}
949
Ulya Trafimovichcc21bba2020-01-13 15:18:16 +0000950func (m *ModuleBase) IsSkipInstall() bool {
951 return m.commonProperties.SkipInstall == true
952}
953
Colin Cross4157e882019-06-06 16:57:04 -0700954func (m *ModuleBase) ExportedToMake() bool {
955 return m.commonProperties.NamespaceExportedToMake
Jiyong Park374510b2018-03-19 18:23:01 +0900956}
957
Colin Cross4157e882019-06-06 16:57:04 -0700958func (m *ModuleBase) computeInstallDeps(
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700959 ctx blueprint.ModuleContext) Paths {
Colin Cross3f40fa42015-01-30 17:27:36 -0800960
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700961 result := Paths{}
Colin Cross6b753602018-06-21 13:03:07 -0700962 // TODO(ccross): we need to use WalkDeps and have some way to know which dependencies require installation
Colin Cross3f40fa42015-01-30 17:27:36 -0800963 ctx.VisitDepsDepthFirstIf(isFileInstaller,
964 func(m blueprint.Module) {
965 fileInstaller := m.(fileInstaller)
966 files := fileInstaller.filesToInstall()
967 result = append(result, files...)
968 })
969
970 return result
971}
972
Colin Cross4157e882019-06-06 16:57:04 -0700973func (m *ModuleBase) filesToInstall() Paths {
974 return m.installFiles
Colin Cross3f40fa42015-01-30 17:27:36 -0800975}
976
Colin Cross4157e882019-06-06 16:57:04 -0700977func (m *ModuleBase) NoAddressSanitizer() bool {
978 return m.noAddressSanitizer
Colin Cross3f40fa42015-01-30 17:27:36 -0800979}
980
Colin Cross4157e882019-06-06 16:57:04 -0700981func (m *ModuleBase) InstallInData() bool {
Dan Willemsen782a2d12015-12-21 14:55:28 -0800982 return false
983}
984
Jaewoong Jung0949f312019-09-11 10:25:18 -0700985func (m *ModuleBase) InstallInTestcases() bool {
986 return false
987}
988
Colin Cross4157e882019-06-06 16:57:04 -0700989func (m *ModuleBase) InstallInSanitizerDir() bool {
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700990 return false
991}
992
Yifan Hong1b3348d2020-01-21 15:53:22 -0800993func (m *ModuleBase) InstallInRamdisk() bool {
994 return Bool(m.commonProperties.Ramdisk)
995}
996
Colin Cross4157e882019-06-06 16:57:04 -0700997func (m *ModuleBase) InstallInRecovery() bool {
998 return Bool(m.commonProperties.Recovery)
Jiyong Parkf9332f12018-02-01 00:54:12 +0900999}
1000
Colin Cross90ba5f42019-10-02 11:10:58 -07001001func (m *ModuleBase) InstallInRoot() bool {
1002 return false
1003}
1004
Colin Cross607d8582019-07-29 16:44:46 -07001005func (m *ModuleBase) InstallBypassMake() bool {
1006 return false
1007}
1008
Colin Cross4157e882019-06-06 16:57:04 -07001009func (m *ModuleBase) Owner() string {
1010 return String(m.commonProperties.Owner)
Sundong Ahn4fd04bb2018-08-31 18:01:37 +09001011}
1012
Colin Cross4157e882019-06-06 16:57:04 -07001013func (m *ModuleBase) NoticeFile() OptionalPath {
1014 return m.noticeFile
Jiyong Park52818fc2019-03-18 12:01:38 +09001015}
1016
Colin Cross7228ecd2019-11-18 16:00:16 -08001017func (m *ModuleBase) setImageVariation(variant string) {
1018 m.commonProperties.ImageVariation = variant
1019}
1020
1021func (m *ModuleBase) ImageVariation() blueprint.Variation {
1022 return blueprint.Variation{
1023 Mutator: "image",
1024 Variation: m.base().commonProperties.ImageVariation,
1025 }
1026}
1027
Paul Duffin6cb8f172020-03-12 10:24:35 +00001028func (m *ModuleBase) getVariationByMutatorName(mutator string) string {
1029 for i, v := range m.commonProperties.DebugMutators {
1030 if v == mutator {
1031 return m.commonProperties.DebugVariations[i]
1032 }
1033 }
1034
1035 return ""
1036}
1037
Yifan Hong1b3348d2020-01-21 15:53:22 -08001038func (m *ModuleBase) InRamdisk() bool {
1039 return m.base().commonProperties.ImageVariation == RamdiskVariation
1040}
1041
Colin Cross7228ecd2019-11-18 16:00:16 -08001042func (m *ModuleBase) InRecovery() bool {
1043 return m.base().commonProperties.ImageVariation == RecoveryVariation
1044}
1045
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09001046func (m *ModuleBase) RequiredModuleNames() []string {
1047 return m.base().commonProperties.Required
1048}
1049
1050func (m *ModuleBase) HostRequiredModuleNames() []string {
1051 return m.base().commonProperties.Host_required
1052}
1053
1054func (m *ModuleBase) TargetRequiredModuleNames() []string {
1055 return m.base().commonProperties.Target_required
1056}
1057
Inseob Kim8471cda2019-11-15 09:59:12 +09001058func (m *ModuleBase) InitRc() Paths {
1059 return append(Paths{}, m.initRcPaths...)
1060}
1061
1062func (m *ModuleBase) VintfFragments() Paths {
1063 return append(Paths{}, m.vintfFragmentsPaths...)
1064}
1065
Colin Cross4157e882019-06-06 16:57:04 -07001066func (m *ModuleBase) generateModuleTarget(ctx ModuleContext) {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001067 allInstalledFiles := Paths{}
1068 allCheckbuildFiles := Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08001069 ctx.VisitAllModuleVariants(func(module Module) {
1070 a := module.base()
Colin Crossc9404352015-03-26 16:10:12 -07001071 allInstalledFiles = append(allInstalledFiles, a.installFiles...)
1072 allCheckbuildFiles = append(allCheckbuildFiles, a.checkbuildFiles...)
Colin Cross3f40fa42015-01-30 17:27:36 -08001073 })
1074
Colin Cross0875c522017-11-28 17:34:01 -08001075 var deps Paths
Colin Cross9454bfa2015-03-17 13:24:18 -07001076
Jeff Gaston088e29e2017-11-29 16:47:17 -08001077 namespacePrefix := ctx.Namespace().(*Namespace).id
1078 if namespacePrefix != "" {
1079 namespacePrefix = namespacePrefix + "-"
1080 }
1081
Colin Cross3f40fa42015-01-30 17:27:36 -08001082 if len(allInstalledFiles) > 0 {
Colin Cross98552072020-06-04 13:25:17 -07001083 name := namespacePrefix + ctx.ModuleName() + "-install"
1084 ctx.Phony(name, allInstalledFiles...)
1085 m.installTarget = PathForPhony(ctx, name)
1086 deps = append(deps, m.installTarget)
Colin Cross9454bfa2015-03-17 13:24:18 -07001087 }
1088
1089 if len(allCheckbuildFiles) > 0 {
Colin Cross98552072020-06-04 13:25:17 -07001090 name := namespacePrefix + ctx.ModuleName() + "-checkbuild"
1091 ctx.Phony(name, allCheckbuildFiles...)
1092 m.checkbuildTarget = PathForPhony(ctx, name)
1093 deps = append(deps, m.checkbuildTarget)
Colin Cross9454bfa2015-03-17 13:24:18 -07001094 }
1095
1096 if len(deps) > 0 {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001097 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08001098 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001099 suffix = "-soong"
1100 }
1101
Colin Cross98552072020-06-04 13:25:17 -07001102 ctx.Phony(namespacePrefix+ctx.ModuleName()+suffix, deps...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07001103
Colin Cross4157e882019-06-06 16:57:04 -07001104 m.blueprintDir = ctx.ModuleDir()
Colin Cross3f40fa42015-01-30 17:27:36 -08001105 }
1106}
1107
Colin Crossc34d2322020-01-03 15:23:27 -08001108func determineModuleKind(m *ModuleBase, ctx blueprint.EarlyModuleContext) moduleKind {
Colin Cross4157e882019-06-06 16:57:04 -07001109 var socSpecific = Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
1110 var deviceSpecific = Bool(m.commonProperties.Device_specific)
1111 var productSpecific = Bool(m.commonProperties.Product_specific)
Justin Yund5f6c822019-06-25 16:47:17 +09001112 var systemExtSpecific = Bool(m.commonProperties.System_ext_specific)
Jiyong Park2db76922017-11-08 16:03:48 +09001113
Dario Frenifd05a742018-05-29 13:28:54 +01001114 msg := "conflicting value set here"
1115 if socSpecific && deviceSpecific {
1116 ctx.PropertyErrorf("device_specific", "a module cannot be specific to SoC and device at the same time.")
Colin Cross4157e882019-06-06 16:57:04 -07001117 if Bool(m.commonProperties.Vendor) {
Jiyong Park2db76922017-11-08 16:03:48 +09001118 ctx.PropertyErrorf("vendor", msg)
1119 }
Colin Cross4157e882019-06-06 16:57:04 -07001120 if Bool(m.commonProperties.Proprietary) {
Jiyong Park2db76922017-11-08 16:03:48 +09001121 ctx.PropertyErrorf("proprietary", msg)
1122 }
Colin Cross4157e882019-06-06 16:57:04 -07001123 if Bool(m.commonProperties.Soc_specific) {
Jiyong Park2db76922017-11-08 16:03:48 +09001124 ctx.PropertyErrorf("soc_specific", msg)
1125 }
1126 }
1127
Justin Yund5f6c822019-06-25 16:47:17 +09001128 if productSpecific && systemExtSpecific {
1129 ctx.PropertyErrorf("product_specific", "a module cannot be specific to product and system_ext at the same time.")
1130 ctx.PropertyErrorf("system_ext_specific", msg)
Dario Frenifd05a742018-05-29 13:28:54 +01001131 }
1132
Justin Yund5f6c822019-06-25 16:47:17 +09001133 if (socSpecific || deviceSpecific) && (productSpecific || systemExtSpecific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001134 if productSpecific {
1135 ctx.PropertyErrorf("product_specific", "a module cannot be specific to SoC or device and product at the same time.")
1136 } else {
Justin Yund5f6c822019-06-25 16:47:17 +09001137 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 +01001138 }
1139 if deviceSpecific {
1140 ctx.PropertyErrorf("device_specific", msg)
1141 } else {
Colin Cross4157e882019-06-06 16:57:04 -07001142 if Bool(m.commonProperties.Vendor) {
Dario Frenifd05a742018-05-29 13:28:54 +01001143 ctx.PropertyErrorf("vendor", msg)
1144 }
Colin Cross4157e882019-06-06 16:57:04 -07001145 if Bool(m.commonProperties.Proprietary) {
Dario Frenifd05a742018-05-29 13:28:54 +01001146 ctx.PropertyErrorf("proprietary", msg)
1147 }
Colin Cross4157e882019-06-06 16:57:04 -07001148 if Bool(m.commonProperties.Soc_specific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001149 ctx.PropertyErrorf("soc_specific", msg)
1150 }
1151 }
1152 }
1153
Jiyong Park2db76922017-11-08 16:03:48 +09001154 if productSpecific {
1155 return productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +09001156 } else if systemExtSpecific {
1157 return systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001158 } else if deviceSpecific {
1159 return deviceSpecificModule
1160 } else if socSpecific {
1161 return socSpecificModule
1162 } else {
1163 return platformModule
1164 }
1165}
1166
Colin Crossc34d2322020-01-03 15:23:27 -08001167func (m *ModuleBase) earlyModuleContextFactory(ctx blueprint.EarlyModuleContext) earlyModuleContext {
Colin Cross1184b642019-12-30 18:43:07 -08001168 return earlyModuleContext{
Colin Crossc34d2322020-01-03 15:23:27 -08001169 EarlyModuleContext: ctx,
1170 kind: determineModuleKind(m, ctx),
1171 config: ctx.Config().(Config),
Colin Cross3f40fa42015-01-30 17:27:36 -08001172 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001173}
1174
Colin Cross1184b642019-12-30 18:43:07 -08001175func (m *ModuleBase) baseModuleContextFactory(ctx blueprint.BaseModuleContext) baseModuleContext {
1176 return baseModuleContext{
1177 bp: ctx,
1178 earlyModuleContext: m.earlyModuleContextFactory(ctx),
1179 os: m.commonProperties.CompileOS,
1180 target: m.commonProperties.CompileTarget,
1181 targetPrimary: m.commonProperties.CompilePrimary,
1182 multiTargets: m.commonProperties.CompileMultiTargets,
1183 }
1184}
1185
Colin Cross4157e882019-06-06 16:57:04 -07001186func (m *ModuleBase) GenerateBuildActions(blueprintCtx blueprint.ModuleContext) {
Colin Cross25de6c32019-06-06 14:29:25 -07001187 ctx := &moduleContext{
Colin Cross0ea8ba82019-06-06 14:33:29 -07001188 module: m.module,
Colin Crossdc35e212019-06-06 16:13:11 -07001189 bp: blueprintCtx,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001190 baseModuleContext: m.baseModuleContextFactory(blueprintCtx),
1191 installDeps: m.computeInstallDeps(blueprintCtx),
1192 installFiles: m.installFiles,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001193 variables: make(map[string]string),
Colin Cross3f40fa42015-01-30 17:27:36 -08001194 }
1195
Colin Cross6c4f21f2019-06-06 15:41:36 -07001196 // Temporarily continue to call blueprintCtx.GetMissingDependencies() to maintain the previous behavior of never
1197 // reporting missing dependency errors in Blueprint when AllowMissingDependencies == true.
1198 // TODO: This will be removed once defaults modules handle missing dependency errors
1199 blueprintCtx.GetMissingDependencies()
1200
Colin Crossdc35e212019-06-06 16:13:11 -07001201 // For the final GenerateAndroidBuildActions pass, require that all visited dependencies Soong modules and
Paul Duffinb0cbec32020-02-25 19:26:33 +00001202 // are enabled. Unless the module is a CommonOS variant which may have dependencies on disabled variants
1203 // (because the dependencies are added before the modules are disabled). The
1204 // GetOsSpecificVariantsOfCommonOSVariant(...) method will ensure that the disabled variants are
1205 // ignored.
1206 ctx.baseModuleContext.strictVisitDeps = !m.IsCommonOSVariant()
Colin Crossdc35e212019-06-06 16:13:11 -07001207
Colin Cross4c83e5c2019-02-25 14:54:28 -08001208 if ctx.config.captureBuild {
1209 ctx.ruleParams = make(map[blueprint.Rule]blueprint.RuleParams)
1210 }
1211
Colin Cross67a5c132017-05-09 13:45:28 -07001212 desc := "//" + ctx.ModuleDir() + ":" + ctx.ModuleName() + " "
1213 var suffix []string
Colin Cross0875c522017-11-28 17:34:01 -08001214 if ctx.Os().Class != Device && ctx.Os().Class != Generic {
1215 suffix = append(suffix, ctx.Os().String())
Colin Cross67a5c132017-05-09 13:45:28 -07001216 }
Colin Cross0875c522017-11-28 17:34:01 -08001217 if !ctx.PrimaryArch() {
1218 suffix = append(suffix, ctx.Arch().ArchType.String())
Colin Cross67a5c132017-05-09 13:45:28 -07001219 }
Dan Willemsenb13a9482020-02-14 11:25:54 -08001220 if apex, ok := m.module.(ApexModule); ok && !apex.IsForPlatform() {
1221 suffix = append(suffix, apex.ApexName())
1222 }
Colin Cross67a5c132017-05-09 13:45:28 -07001223
1224 ctx.Variable(pctx, "moduleDesc", desc)
1225
1226 s := ""
1227 if len(suffix) > 0 {
1228 s = " [" + strings.Join(suffix, " ") + "]"
1229 }
1230 ctx.Variable(pctx, "moduleDescSuffix", s)
1231
Dan Willemsen569edc52018-11-19 09:33:29 -08001232 // Some common property checks for properties that will be used later in androidmk.go
Colin Cross4157e882019-06-06 16:57:04 -07001233 if m.commonProperties.Dist.Dest != nil {
1234 _, err := validateSafePath(*m.commonProperties.Dist.Dest)
Dan Willemsen569edc52018-11-19 09:33:29 -08001235 if err != nil {
1236 ctx.PropertyErrorf("dist.dest", "%s", err.Error())
1237 }
1238 }
Colin Cross4157e882019-06-06 16:57:04 -07001239 if m.commonProperties.Dist.Dir != nil {
1240 _, err := validateSafePath(*m.commonProperties.Dist.Dir)
Dan Willemsen569edc52018-11-19 09:33:29 -08001241 if err != nil {
1242 ctx.PropertyErrorf("dist.dir", "%s", err.Error())
1243 }
1244 }
Colin Cross4157e882019-06-06 16:57:04 -07001245 if m.commonProperties.Dist.Suffix != nil {
1246 if strings.Contains(*m.commonProperties.Dist.Suffix, "/") {
Dan Willemsen569edc52018-11-19 09:33:29 -08001247 ctx.PropertyErrorf("dist.suffix", "Suffix may not contain a '/' character.")
1248 }
1249 }
1250
Colin Cross4157e882019-06-06 16:57:04 -07001251 if m.Enabled() {
Jooyung Hand48f3c32019-08-23 11:18:57 +09001252 // ensure all direct android.Module deps are enabled
1253 ctx.VisitDirectDepsBlueprint(func(bm blueprint.Module) {
1254 if _, ok := bm.(Module); ok {
1255 ctx.validateAndroidModule(bm, ctx.baseModuleContext.strictVisitDeps)
1256 }
1257 })
1258
Colin Cross4157e882019-06-06 16:57:04 -07001259 notice := proptools.StringDefault(m.commonProperties.Notice, "NOTICE")
1260 if module := SrcIsModule(notice); module != "" {
1261 m.noticeFile = ctx.ExpandOptionalSource(&notice, "notice")
Jiyong Park52818fc2019-03-18 12:01:38 +09001262 } else {
1263 noticePath := filepath.Join(ctx.ModuleDir(), notice)
Colin Cross4157e882019-06-06 16:57:04 -07001264 m.noticeFile = ExistentPathForSource(ctx, noticePath)
Jaewoong Jung62707f72018-11-16 13:26:43 -08001265 }
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001266
1267 m.module.GenerateAndroidBuildActions(ctx)
1268 if ctx.Failed() {
1269 return
1270 }
1271
1272 m.installFiles = append(m.installFiles, ctx.installFiles...)
1273 m.checkbuildFiles = append(m.checkbuildFiles, ctx.checkbuildFiles...)
Inseob Kim8471cda2019-11-15 09:59:12 +09001274 m.initRcPaths = PathsForModuleSrc(ctx, m.commonProperties.Init_rc)
1275 m.vintfFragmentsPaths = PathsForModuleSrc(ctx, m.commonProperties.Vintf_fragments)
Colin Cross98552072020-06-04 13:25:17 -07001276 for k, v := range ctx.phonies {
1277 m.phonies[k] = append(m.phonies[k], v...)
1278 }
Colin Crossdc35e212019-06-06 16:13:11 -07001279 } else if ctx.Config().AllowMissingDependencies() {
1280 // If the module is not enabled it will not create any build rules, nothing will call
1281 // ctx.GetMissingDependencies(), and blueprint will consider the missing dependencies to be unhandled
1282 // and report them as an error even when AllowMissingDependencies = true. Call
1283 // ctx.GetMissingDependencies() here to tell blueprint not to handle them.
1284 ctx.GetMissingDependencies()
Colin Cross3f40fa42015-01-30 17:27:36 -08001285 }
1286
Colin Cross4157e882019-06-06 16:57:04 -07001287 if m == ctx.FinalModule().(Module).base() {
1288 m.generateModuleTarget(ctx)
Colin Cross9b1d13d2016-09-19 15:18:11 -07001289 if ctx.Failed() {
1290 return
1291 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001292 }
Colin Crosscec81712017-07-13 14:43:27 -07001293
Colin Cross4157e882019-06-06 16:57:04 -07001294 m.buildParams = ctx.buildParams
1295 m.ruleParams = ctx.ruleParams
1296 m.variables = ctx.variables
Colin Cross3f40fa42015-01-30 17:27:36 -08001297}
1298
Colin Cross1184b642019-12-30 18:43:07 -08001299type earlyModuleContext struct {
Colin Crossc34d2322020-01-03 15:23:27 -08001300 blueprint.EarlyModuleContext
Colin Cross1184b642019-12-30 18:43:07 -08001301
1302 kind moduleKind
1303 config Config
1304}
1305
1306func (e *earlyModuleContext) Glob(globPattern string, excludes []string) Paths {
1307 ret, err := e.GlobWithDeps(globPattern, excludes)
1308 if err != nil {
1309 e.ModuleErrorf("glob: %s", err.Error())
1310 }
1311 return pathsForModuleSrcFromFullPath(e, ret, true)
1312}
1313
1314func (e *earlyModuleContext) GlobFiles(globPattern string, excludes []string) Paths {
1315 ret, err := e.GlobWithDeps(globPattern, excludes)
1316 if err != nil {
1317 e.ModuleErrorf("glob: %s", err.Error())
1318 }
1319 return pathsForModuleSrcFromFullPath(e, ret, false)
1320}
1321
Colin Cross988414c2020-01-11 01:11:46 +00001322func (b *earlyModuleContext) IsSymlink(path Path) bool {
1323 fileInfo, err := b.config.fs.Lstat(path.String())
1324 if err != nil {
1325 b.ModuleErrorf("os.Lstat(%q) failed: %s", path.String(), err)
1326 }
1327 return fileInfo.Mode()&os.ModeSymlink == os.ModeSymlink
1328}
1329
1330func (b *earlyModuleContext) Readlink(path Path) string {
1331 dest, err := b.config.fs.Readlink(path.String())
1332 if err != nil {
1333 b.ModuleErrorf("os.Readlink(%q) failed: %s", path.String(), err)
1334 }
1335 return dest
1336}
1337
Colin Cross1184b642019-12-30 18:43:07 -08001338func (e *earlyModuleContext) Module() Module {
Colin Crossc34d2322020-01-03 15:23:27 -08001339 module, _ := e.EarlyModuleContext.Module().(Module)
Colin Cross1184b642019-12-30 18:43:07 -08001340 return module
1341}
1342
1343func (e *earlyModuleContext) Config() Config {
Colin Crossc34d2322020-01-03 15:23:27 -08001344 return e.EarlyModuleContext.Config().(Config)
Colin Cross1184b642019-12-30 18:43:07 -08001345}
1346
1347func (e *earlyModuleContext) AConfig() Config {
1348 return e.config
1349}
1350
1351func (e *earlyModuleContext) DeviceConfig() DeviceConfig {
1352 return DeviceConfig{e.config.deviceConfig}
1353}
1354
1355func (e *earlyModuleContext) Platform() bool {
1356 return e.kind == platformModule
1357}
1358
1359func (e *earlyModuleContext) DeviceSpecific() bool {
1360 return e.kind == deviceSpecificModule
1361}
1362
1363func (e *earlyModuleContext) SocSpecific() bool {
1364 return e.kind == socSpecificModule
1365}
1366
1367func (e *earlyModuleContext) ProductSpecific() bool {
1368 return e.kind == productSpecificModule
1369}
1370
1371func (e *earlyModuleContext) SystemExtSpecific() bool {
1372 return e.kind == systemExtSpecificModule
1373}
1374
1375type baseModuleContext struct {
1376 bp blueprint.BaseModuleContext
1377 earlyModuleContext
Colin Crossfb0c16e2019-11-20 17:12:35 -08001378 os OsType
Colin Cross8b74d172016-09-13 09:59:14 -07001379 target Target
Colin Crossee0bc3b2018-10-02 22:01:37 -07001380 multiTargets []Target
Colin Cross8b74d172016-09-13 09:59:14 -07001381 targetPrimary bool
1382 debug bool
Colin Crossdc35e212019-06-06 16:13:11 -07001383
1384 walkPath []Module
Paul Duffinf0207962020-03-31 11:31:36 +01001385 tagPath []blueprint.DependencyTag
Colin Crossdc35e212019-06-06 16:13:11 -07001386
1387 strictVisitDeps bool // If true, enforce that all dependencies are enabled
Colin Crossf6566ed2015-03-24 11:13:38 -07001388}
1389
Ulya Trafimovichcc21bba2020-01-13 15:18:16 +00001390func (b *baseModuleContext) OtherModuleName(m blueprint.Module) string {
1391 return b.bp.OtherModuleName(m)
1392}
1393func (b *baseModuleContext) OtherModuleDir(m blueprint.Module) string { return b.bp.OtherModuleDir(m) }
Colin Cross1184b642019-12-30 18:43:07 -08001394func (b *baseModuleContext) OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{}) {
Jooyung Han67b141d2020-02-26 02:05:18 +09001395 b.bp.OtherModuleErrorf(m, fmt, args...)
Colin Cross1184b642019-12-30 18:43:07 -08001396}
1397func (b *baseModuleContext) OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag {
1398 return b.bp.OtherModuleDependencyTag(m)
1399}
Ulya Trafimovichcc21bba2020-01-13 15:18:16 +00001400func (b *baseModuleContext) OtherModuleExists(name string) bool { return b.bp.OtherModuleExists(name) }
1401func (b *baseModuleContext) OtherModuleType(m blueprint.Module) string {
1402 return b.bp.OtherModuleType(m)
1403}
Colin Cross1184b642019-12-30 18:43:07 -08001404
1405func (b *baseModuleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1406 return b.bp.GetDirectDepWithTag(name, tag)
1407}
1408
Colin Cross25de6c32019-06-06 14:29:25 -07001409type moduleContext struct {
Colin Crossdc35e212019-06-06 16:13:11 -07001410 bp blueprint.ModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -07001411 baseModuleContext
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001412 installDeps Paths
1413 installFiles Paths
1414 checkbuildFiles Paths
Colin Cross8d8f8e22016-08-03 11:57:50 -07001415 module Module
Colin Cross98552072020-06-04 13:25:17 -07001416 phonies map[string]Paths
Colin Crosscec81712017-07-13 14:43:27 -07001417
1418 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001419 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001420 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001421 variables map[string]string
Colin Cross6ff51382015-12-17 16:39:19 -08001422}
1423
Colin Crossb88b3c52019-06-10 15:15:17 -07001424func (m *moduleContext) ninjaError(params BuildParams, err error) (PackageContext, BuildParams) {
1425 return pctx, BuildParams{
Colin Cross4b69c492019-06-07 13:06:06 -07001426 Rule: ErrorRule,
1427 Description: params.Description,
1428 Output: params.Output,
1429 Outputs: params.Outputs,
1430 ImplicitOutput: params.ImplicitOutput,
1431 ImplicitOutputs: params.ImplicitOutputs,
Colin Cross6ff51382015-12-17 16:39:19 -08001432 Args: map[string]string{
1433 "error": err.Error(),
1434 },
Colin Crossb88b3c52019-06-10 15:15:17 -07001435 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001436}
1437
Colin Cross25de6c32019-06-06 14:29:25 -07001438func (m *moduleContext) ModuleBuild(pctx PackageContext, params ModuleBuildParams) {
1439 m.Build(pctx, BuildParams(params))
Colin Cross3f40fa42015-01-30 17:27:36 -08001440}
1441
Colin Cross0875c522017-11-28 17:34:01 -08001442func convertBuildParams(params BuildParams) blueprint.BuildParams {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001443 bparams := blueprint.BuildParams{
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001444 Rule: params.Rule,
Colin Cross0875c522017-11-28 17:34:01 -08001445 Description: params.Description,
Colin Cross33bfb0a2016-11-21 17:23:08 -08001446 Deps: params.Deps,
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001447 Outputs: params.Outputs.Strings(),
1448 ImplicitOutputs: params.ImplicitOutputs.Strings(),
1449 Inputs: params.Inputs.Strings(),
1450 Implicits: params.Implicits.Strings(),
1451 OrderOnly: params.OrderOnly.Strings(),
1452 Args: params.Args,
1453 Optional: !params.Default,
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001454 }
1455
Colin Cross33bfb0a2016-11-21 17:23:08 -08001456 if params.Depfile != nil {
1457 bparams.Depfile = params.Depfile.String()
1458 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001459 if params.Output != nil {
1460 bparams.Outputs = append(bparams.Outputs, params.Output.String())
1461 }
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001462 if params.ImplicitOutput != nil {
1463 bparams.ImplicitOutputs = append(bparams.ImplicitOutputs, params.ImplicitOutput.String())
1464 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001465 if params.Input != nil {
1466 bparams.Inputs = append(bparams.Inputs, params.Input.String())
1467 }
1468 if params.Implicit != nil {
1469 bparams.Implicits = append(bparams.Implicits, params.Implicit.String())
1470 }
1471
Colin Cross0b9f31f2019-02-28 11:00:01 -08001472 bparams.Outputs = proptools.NinjaEscapeList(bparams.Outputs)
1473 bparams.ImplicitOutputs = proptools.NinjaEscapeList(bparams.ImplicitOutputs)
1474 bparams.Inputs = proptools.NinjaEscapeList(bparams.Inputs)
1475 bparams.Implicits = proptools.NinjaEscapeList(bparams.Implicits)
1476 bparams.OrderOnly = proptools.NinjaEscapeList(bparams.OrderOnly)
1477 bparams.Depfile = proptools.NinjaEscapeList([]string{bparams.Depfile})[0]
Colin Crossfe4bc362018-09-12 10:02:13 -07001478
Colin Cross0875c522017-11-28 17:34:01 -08001479 return bparams
1480}
1481
Colin Cross25de6c32019-06-06 14:29:25 -07001482func (m *moduleContext) Variable(pctx PackageContext, name, value string) {
1483 if m.config.captureBuild {
1484 m.variables[name] = value
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001485 }
1486
Colin Crossdc35e212019-06-06 16:13:11 -07001487 m.bp.Variable(pctx.PackageContext, name, value)
Colin Cross0875c522017-11-28 17:34:01 -08001488}
1489
Colin Cross25de6c32019-06-06 14:29:25 -07001490func (m *moduleContext) Rule(pctx PackageContext, name string, params blueprint.RuleParams,
Colin Cross0875c522017-11-28 17:34:01 -08001491 argNames ...string) blueprint.Rule {
1492
Ramy Medhat79c4fcc2020-03-31 22:14:52 -04001493 if m.config.UseRemoteBuild() {
1494 if params.Pool == nil {
1495 // When USE_GOMA=true or USE_RBE=true are set and the rule is not supported by goma/RBE, restrict
1496 // jobs to the local parallelism value
1497 params.Pool = localPool
1498 } else if params.Pool == remotePool {
1499 // remotePool is a fake pool used to identify rule that are supported for remoting. If the rule's
1500 // pool is the remotePool, replace with nil so that ninja runs it at NINJA_REMOTE_NUM_JOBS
1501 // parallelism.
1502 params.Pool = nil
1503 }
Colin Cross2e2dbc22019-09-25 13:31:46 -07001504 }
1505
Colin Crossdc35e212019-06-06 16:13:11 -07001506 rule := m.bp.Rule(pctx.PackageContext, name, params, argNames...)
Colin Cross4c83e5c2019-02-25 14:54:28 -08001507
Colin Cross25de6c32019-06-06 14:29:25 -07001508 if m.config.captureBuild {
1509 m.ruleParams[rule] = params
Colin Cross4c83e5c2019-02-25 14:54:28 -08001510 }
1511
1512 return rule
Colin Cross0875c522017-11-28 17:34:01 -08001513}
1514
Colin Cross25de6c32019-06-06 14:29:25 -07001515func (m *moduleContext) Build(pctx PackageContext, params BuildParams) {
Colin Crossb88b3c52019-06-10 15:15:17 -07001516 if params.Description != "" {
1517 params.Description = "${moduleDesc}" + params.Description + "${moduleDescSuffix}"
1518 }
1519
1520 if missingDeps := m.GetMissingDependencies(); len(missingDeps) > 0 {
1521 pctx, params = m.ninjaError(params, fmt.Errorf("module %s missing dependencies: %s\n",
1522 m.ModuleName(), strings.Join(missingDeps, ", ")))
1523 }
1524
Colin Cross25de6c32019-06-06 14:29:25 -07001525 if m.config.captureBuild {
1526 m.buildParams = append(m.buildParams, params)
Colin Cross0875c522017-11-28 17:34:01 -08001527 }
1528
Colin Crossdc35e212019-06-06 16:13:11 -07001529 m.bp.Build(pctx.PackageContext, convertBuildParams(params))
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001530}
Colin Cross98552072020-06-04 13:25:17 -07001531
1532func (m *moduleContext) Phony(name string, deps ...Path) {
1533 addPhony(m.config, name, deps...)
1534}
1535
Colin Cross25de6c32019-06-06 14:29:25 -07001536func (m *moduleContext) GetMissingDependencies() []string {
Colin Cross6c4f21f2019-06-06 15:41:36 -07001537 var missingDeps []string
1538 missingDeps = append(missingDeps, m.Module().base().commonProperties.MissingDeps...)
Colin Crossdc35e212019-06-06 16:13:11 -07001539 missingDeps = append(missingDeps, m.bp.GetMissingDependencies()...)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001540 missingDeps = FirstUniqueStrings(missingDeps)
1541 return missingDeps
Colin Cross6ff51382015-12-17 16:39:19 -08001542}
1543
Colin Crossdc35e212019-06-06 16:13:11 -07001544func (b *baseModuleContext) AddMissingDependencies(deps []string) {
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001545 if deps != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001546 missingDeps := &b.Module().base().commonProperties.MissingDeps
Colin Cross6c4f21f2019-06-06 15:41:36 -07001547 *missingDeps = append(*missingDeps, deps...)
1548 *missingDeps = FirstUniqueStrings(*missingDeps)
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001549 }
1550}
1551
Colin Crossdc35e212019-06-06 16:13:11 -07001552func (b *baseModuleContext) validateAndroidModule(module blueprint.Module, strict bool) Module {
Colin Crossd11fcda2017-10-23 17:59:01 -07001553 aModule, _ := module.(Module)
Colin Crossdc35e212019-06-06 16:13:11 -07001554
1555 if !strict {
1556 return aModule
1557 }
1558
Colin Cross380c69a2019-06-10 17:49:58 +00001559 if aModule == nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001560 b.ModuleErrorf("module %q not an android module", b.OtherModuleName(module))
Colin Cross380c69a2019-06-10 17:49:58 +00001561 return nil
1562 }
1563
1564 if !aModule.Enabled() {
Colin Crossdc35e212019-06-06 16:13:11 -07001565 if b.Config().AllowMissingDependencies() {
1566 b.AddMissingDependencies([]string{b.OtherModuleName(aModule)})
Colin Cross380c69a2019-06-10 17:49:58 +00001567 } else {
Colin Crossdc35e212019-06-06 16:13:11 -07001568 b.ModuleErrorf("depends on disabled module %q", b.OtherModuleName(aModule))
Colin Cross380c69a2019-06-10 17:49:58 +00001569 }
1570 return nil
1571 }
Colin Crossd11fcda2017-10-23 17:59:01 -07001572 return aModule
1573}
1574
Colin Crossdc35e212019-06-06 16:13:11 -07001575func (b *baseModuleContext) getDirectDepInternal(name string, tag blueprint.DependencyTag) (blueprint.Module, blueprint.DependencyTag) {
Jiyong Parkf2976302019-04-17 21:47:37 +09001576 type dep struct {
1577 mod blueprint.Module
1578 tag blueprint.DependencyTag
1579 }
1580 var deps []dep
Colin Crossdc35e212019-06-06 16:13:11 -07001581 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001582 if aModule, _ := module.(Module); aModule != nil && aModule.base().BaseModuleName() == name {
Colin Cross1184b642019-12-30 18:43:07 -08001583 returnedTag := b.bp.OtherModuleDependencyTag(aModule)
Jiyong Parkf2976302019-04-17 21:47:37 +09001584 if tag == nil || returnedTag == tag {
1585 deps = append(deps, dep{aModule, returnedTag})
1586 }
1587 }
1588 })
1589 if len(deps) == 1 {
1590 return deps[0].mod, deps[0].tag
1591 } else if len(deps) >= 2 {
1592 panic(fmt.Errorf("Multiple dependencies having same BaseModuleName() %q found from %q",
Colin Crossdc35e212019-06-06 16:13:11 -07001593 name, b.ModuleName()))
Jiyong Parkf2976302019-04-17 21:47:37 +09001594 } else {
1595 return nil, nil
1596 }
1597}
1598
Colin Crossdc35e212019-06-06 16:13:11 -07001599func (b *baseModuleContext) GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module {
Colin Cross0ef08162019-05-01 15:50:51 -07001600 var deps []Module
Colin Crossdc35e212019-06-06 16:13:11 -07001601 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001602 if aModule, _ := module.(Module); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001603 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Cross0ef08162019-05-01 15:50:51 -07001604 deps = append(deps, aModule)
1605 }
1606 }
1607 })
1608 return deps
1609}
1610
Colin Cross25de6c32019-06-06 14:29:25 -07001611func (m *moduleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1612 module, _ := m.getDirectDepInternal(name, tag)
1613 return module
Jiyong Parkf2976302019-04-17 21:47:37 +09001614}
1615
Colin Crossdc35e212019-06-06 16:13:11 -07001616func (b *baseModuleContext) GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag) {
1617 return b.getDirectDepInternal(name, nil)
Jiyong Parkf2976302019-04-17 21:47:37 +09001618}
1619
Colin Crossdc35e212019-06-06 16:13:11 -07001620func (b *baseModuleContext) VisitDirectDepsBlueprint(visit func(blueprint.Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001621 b.bp.VisitDirectDeps(visit)
Colin Cross35143d02017-11-16 00:11:20 -08001622}
1623
Colin Crossdc35e212019-06-06 16:13:11 -07001624func (b *baseModuleContext) VisitDirectDeps(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001625 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001626 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001627 visit(aModule)
1628 }
1629 })
1630}
1631
Colin Crossdc35e212019-06-06 16:13:11 -07001632func (b *baseModuleContext) VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001633 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001634 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001635 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Crossee6143c2017-12-30 17:54:27 -08001636 visit(aModule)
1637 }
1638 }
1639 })
1640}
1641
Colin Crossdc35e212019-06-06 16:13:11 -07001642func (b *baseModuleContext) VisitDirectDepsIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001643 b.bp.VisitDirectDepsIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001644 // pred
1645 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001646 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001647 return pred(aModule)
1648 } else {
1649 return false
1650 }
1651 },
1652 // visit
1653 func(module blueprint.Module) {
1654 visit(module.(Module))
1655 })
1656}
1657
Colin Crossdc35e212019-06-06 16:13:11 -07001658func (b *baseModuleContext) VisitDepsDepthFirst(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001659 b.bp.VisitDepsDepthFirst(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001660 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001661 visit(aModule)
1662 }
1663 })
1664}
1665
Colin Crossdc35e212019-06-06 16:13:11 -07001666func (b *baseModuleContext) VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001667 b.bp.VisitDepsDepthFirstIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001668 // pred
1669 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001670 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001671 return pred(aModule)
1672 } else {
1673 return false
1674 }
1675 },
1676 // visit
1677 func(module blueprint.Module) {
1678 visit(module.(Module))
1679 })
1680}
1681
Colin Crossdc35e212019-06-06 16:13:11 -07001682func (b *baseModuleContext) WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool) {
Colin Cross1184b642019-12-30 18:43:07 -08001683 b.bp.WalkDeps(visit)
Alex Light778127a2019-02-27 14:19:50 -08001684}
1685
Colin Crossdc35e212019-06-06 16:13:11 -07001686func (b *baseModuleContext) WalkDeps(visit func(Module, Module) bool) {
1687 b.walkPath = []Module{b.Module()}
Paul Duffinf0207962020-03-31 11:31:36 +01001688 b.tagPath = []blueprint.DependencyTag{}
Colin Cross1184b642019-12-30 18:43:07 -08001689 b.bp.WalkDeps(func(child, parent blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001690 childAndroidModule, _ := child.(Module)
1691 parentAndroidModule, _ := parent.(Module)
Colin Crossd11fcda2017-10-23 17:59:01 -07001692 if childAndroidModule != nil && parentAndroidModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001693 // record walkPath before visit
1694 for b.walkPath[len(b.walkPath)-1] != parentAndroidModule {
1695 b.walkPath = b.walkPath[0 : len(b.walkPath)-1]
Paul Duffinf0207962020-03-31 11:31:36 +01001696 b.tagPath = b.tagPath[0 : len(b.tagPath)-1]
Colin Crossdc35e212019-06-06 16:13:11 -07001697 }
1698 b.walkPath = append(b.walkPath, childAndroidModule)
Paul Duffinf0207962020-03-31 11:31:36 +01001699 b.tagPath = append(b.tagPath, b.OtherModuleDependencyTag(childAndroidModule))
Colin Crossd11fcda2017-10-23 17:59:01 -07001700 return visit(childAndroidModule, parentAndroidModule)
1701 } else {
1702 return false
1703 }
1704 })
1705}
1706
Colin Crossdc35e212019-06-06 16:13:11 -07001707func (b *baseModuleContext) GetWalkPath() []Module {
1708 return b.walkPath
1709}
1710
Paul Duffinf0207962020-03-31 11:31:36 +01001711func (b *baseModuleContext) GetTagPath() []blueprint.DependencyTag {
1712 return b.tagPath
1713}
1714
Colin Cross25de6c32019-06-06 14:29:25 -07001715func (m *moduleContext) VisitAllModuleVariants(visit func(Module)) {
Colin Crossdc35e212019-06-06 16:13:11 -07001716 m.bp.VisitAllModuleVariants(func(module blueprint.Module) {
Colin Cross0875c522017-11-28 17:34:01 -08001717 visit(module.(Module))
1718 })
1719}
1720
Colin Cross25de6c32019-06-06 14:29:25 -07001721func (m *moduleContext) PrimaryModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001722 return m.bp.PrimaryModule().(Module)
Colin Cross0875c522017-11-28 17:34:01 -08001723}
1724
Colin Cross25de6c32019-06-06 14:29:25 -07001725func (m *moduleContext) FinalModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001726 return m.bp.FinalModule().(Module)
1727}
1728
1729func (m *moduleContext) ModuleSubDir() string {
1730 return m.bp.ModuleSubDir()
Colin Cross0875c522017-11-28 17:34:01 -08001731}
1732
Colin Cross0ea8ba82019-06-06 14:33:29 -07001733func (b *baseModuleContext) Target() Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001734 return b.target
Colin Crossa1ad8d12016-06-01 17:09:44 -07001735}
1736
Colin Cross0ea8ba82019-06-06 14:33:29 -07001737func (b *baseModuleContext) TargetPrimary() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001738 return b.targetPrimary
Colin Cross8b74d172016-09-13 09:59:14 -07001739}
1740
Colin Cross0ea8ba82019-06-06 14:33:29 -07001741func (b *baseModuleContext) MultiTargets() []Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001742 return b.multiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07001743}
1744
Colin Cross0ea8ba82019-06-06 14:33:29 -07001745func (b *baseModuleContext) Arch() Arch {
Colin Cross25de6c32019-06-06 14:29:25 -07001746 return b.target.Arch
Colin Cross3f40fa42015-01-30 17:27:36 -08001747}
1748
Colin Cross0ea8ba82019-06-06 14:33:29 -07001749func (b *baseModuleContext) Os() OsType {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001750 return b.os
Dan Willemsen490fd492015-11-24 17:53:15 -08001751}
1752
Colin Cross0ea8ba82019-06-06 14:33:29 -07001753func (b *baseModuleContext) Host() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001754 return b.os.Class == Host || b.os.Class == HostCross
Colin Crossf6566ed2015-03-24 11:13:38 -07001755}
1756
Colin Cross0ea8ba82019-06-06 14:33:29 -07001757func (b *baseModuleContext) Device() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001758 return b.os.Class == Device
Colin Crossf6566ed2015-03-24 11:13:38 -07001759}
1760
Colin Cross0ea8ba82019-06-06 14:33:29 -07001761func (b *baseModuleContext) Darwin() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001762 return b.os == Darwin
Colin Cross0af4b842015-04-30 16:36:18 -07001763}
1764
Colin Cross0ea8ba82019-06-06 14:33:29 -07001765func (b *baseModuleContext) Fuchsia() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001766 return b.os == Fuchsia
Doug Horn21b94272019-01-16 12:06:11 -08001767}
1768
Colin Cross0ea8ba82019-06-06 14:33:29 -07001769func (b *baseModuleContext) Windows() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001770 return b.os == Windows
Colin Cross3edeee12017-04-04 12:59:48 -07001771}
1772
Colin Cross0ea8ba82019-06-06 14:33:29 -07001773func (b *baseModuleContext) Debug() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001774 return b.debug
Colin Crossf6566ed2015-03-24 11:13:38 -07001775}
1776
Colin Cross0ea8ba82019-06-06 14:33:29 -07001777func (b *baseModuleContext) PrimaryArch() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001778 if len(b.config.Targets[b.target.Os]) <= 1 {
Colin Cross67a5c132017-05-09 13:45:28 -07001779 return true
1780 }
Colin Cross25de6c32019-06-06 14:29:25 -07001781 return b.target.Arch.ArchType == b.config.Targets[b.target.Os][0].Arch.ArchType
Colin Cross1e7d3702016-08-24 15:25:47 -07001782}
1783
Jiyong Park5baac542018-08-28 09:55:37 +09001784// Makes this module a platform module, i.e. not specific to soc, device,
Justin Yund5f6c822019-06-25 16:47:17 +09001785// product, or system_ext.
Colin Cross4157e882019-06-06 16:57:04 -07001786func (m *ModuleBase) MakeAsPlatform() {
1787 m.commonProperties.Vendor = boolPtr(false)
1788 m.commonProperties.Proprietary = boolPtr(false)
1789 m.commonProperties.Soc_specific = boolPtr(false)
1790 m.commonProperties.Product_specific = boolPtr(false)
Justin Yund5f6c822019-06-25 16:47:17 +09001791 m.commonProperties.System_ext_specific = boolPtr(false)
Jiyong Park5baac542018-08-28 09:55:37 +09001792}
1793
Colin Cross4157e882019-06-06 16:57:04 -07001794func (m *ModuleBase) EnableNativeBridgeSupportByDefault() {
1795 m.commonProperties.Native_bridge_supported = boolPtr(true)
dimitry03dc3f62019-05-09 14:07:34 +02001796}
1797
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001798func (m *ModuleBase) MakeAsSystemExt() {
Jooyung Han91df2082019-11-20 01:49:42 +09001799 m.commonProperties.Vendor = boolPtr(false)
1800 m.commonProperties.Proprietary = boolPtr(false)
1801 m.commonProperties.Soc_specific = boolPtr(false)
1802 m.commonProperties.Product_specific = boolPtr(false)
1803 m.commonProperties.System_ext_specific = boolPtr(true)
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001804}
1805
Jooyung Han344d5432019-08-23 11:17:39 +09001806// IsNativeBridgeSupported returns true if "native_bridge_supported" is explicitly set as "true"
1807func (m *ModuleBase) IsNativeBridgeSupported() bool {
1808 return proptools.Bool(m.commonProperties.Native_bridge_supported)
1809}
1810
Colin Cross25de6c32019-06-06 14:29:25 -07001811func (m *moduleContext) InstallInData() bool {
1812 return m.module.InstallInData()
Dan Willemsen782a2d12015-12-21 14:55:28 -08001813}
1814
Jaewoong Jung0949f312019-09-11 10:25:18 -07001815func (m *moduleContext) InstallInTestcases() bool {
1816 return m.module.InstallInTestcases()
1817}
1818
Colin Cross25de6c32019-06-06 14:29:25 -07001819func (m *moduleContext) InstallInSanitizerDir() bool {
1820 return m.module.InstallInSanitizerDir()
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001821}
1822
Yifan Hong1b3348d2020-01-21 15:53:22 -08001823func (m *moduleContext) InstallInRamdisk() bool {
1824 return m.module.InstallInRamdisk()
1825}
1826
Colin Cross25de6c32019-06-06 14:29:25 -07001827func (m *moduleContext) InstallInRecovery() bool {
1828 return m.module.InstallInRecovery()
Jiyong Parkf9332f12018-02-01 00:54:12 +09001829}
1830
Colin Cross90ba5f42019-10-02 11:10:58 -07001831func (m *moduleContext) InstallInRoot() bool {
1832 return m.module.InstallInRoot()
1833}
1834
Colin Cross607d8582019-07-29 16:44:46 -07001835func (m *moduleContext) InstallBypassMake() bool {
1836 return m.module.InstallBypassMake()
1837}
1838
Colin Cross70dda7e2019-10-01 22:05:35 -07001839func (m *moduleContext) skipInstall(fullInstallPath InstallPath) bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001840 if m.module.base().commonProperties.SkipInstall {
Colin Cross893d8162017-04-26 17:34:03 -07001841 return true
1842 }
1843
Colin Cross3607f212018-05-07 15:28:05 -07001844 // We'll need a solution for choosing which of modules with the same name in different
1845 // namespaces to install. For now, reuse the list of namespaces exported to Make as the
1846 // list of namespaces to install in a Soong-only build.
Colin Cross25de6c32019-06-06 14:29:25 -07001847 if !m.module.base().commonProperties.NamespaceExportedToMake {
Colin Cross3607f212018-05-07 15:28:05 -07001848 return true
1849 }
1850
Colin Cross25de6c32019-06-06 14:29:25 -07001851 if m.Device() {
Colin Cross607d8582019-07-29 16:44:46 -07001852 if m.Config().EmbeddedInMake() && !m.InstallBypassMake() {
Colin Cross893d8162017-04-26 17:34:03 -07001853 return true
1854 }
1855
Colin Cross25de6c32019-06-06 14:29:25 -07001856 if m.Config().SkipMegaDeviceInstall(fullInstallPath.String()) {
Colin Cross893d8162017-04-26 17:34:03 -07001857 return true
1858 }
1859 }
1860
1861 return false
1862}
1863
Colin Cross70dda7e2019-10-01 22:05:35 -07001864func (m *moduleContext) InstallFile(installPath InstallPath, name string, srcPath Path,
1865 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001866 return m.installFile(installPath, name, srcPath, Cp, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001867}
1868
Colin Cross70dda7e2019-10-01 22:05:35 -07001869func (m *moduleContext) InstallExecutable(installPath InstallPath, name string, srcPath Path,
1870 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001871 return m.installFile(installPath, name, srcPath, CpExecutable, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001872}
1873
Colin Cross70dda7e2019-10-01 22:05:35 -07001874func (m *moduleContext) installFile(installPath InstallPath, name string, srcPath Path,
1875 rule blueprint.Rule, deps []Path) InstallPath {
Colin Cross35cec122015-04-02 14:37:16 -07001876
Colin Cross25de6c32019-06-06 14:29:25 -07001877 fullInstallPath := installPath.Join(m, name)
1878 m.module.base().hooks.runInstallHooks(m, fullInstallPath, false)
Colin Cross3f40fa42015-01-30 17:27:36 -08001879
Colin Cross25de6c32019-06-06 14:29:25 -07001880 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001881
Colin Cross25de6c32019-06-06 14:29:25 -07001882 deps = append(deps, m.installDeps...)
Colin Cross35cec122015-04-02 14:37:16 -07001883
Colin Cross89562dc2016-10-03 17:47:19 -07001884 var implicitDeps, orderOnlyDeps Paths
1885
Colin Cross25de6c32019-06-06 14:29:25 -07001886 if m.Host() {
Colin Cross89562dc2016-10-03 17:47:19 -07001887 // Installed host modules might be used during the build, depend directly on their
1888 // dependencies so their timestamp is updated whenever their dependency is updated
1889 implicitDeps = deps
1890 } else {
1891 orderOnlyDeps = deps
1892 }
1893
Colin Cross25de6c32019-06-06 14:29:25 -07001894 m.Build(pctx, BuildParams{
Colin Cross5c517922017-08-31 12:29:17 -07001895 Rule: rule,
Colin Cross67a5c132017-05-09 13:45:28 -07001896 Description: "install " + fullInstallPath.Base(),
1897 Output: fullInstallPath,
1898 Input: srcPath,
1899 Implicits: implicitDeps,
1900 OrderOnly: orderOnlyDeps,
Colin Cross25de6c32019-06-06 14:29:25 -07001901 Default: !m.Config().EmbeddedInMake(),
Dan Willemsen322acaf2016-01-12 23:07:05 -08001902 })
Colin Cross3f40fa42015-01-30 17:27:36 -08001903
Colin Cross25de6c32019-06-06 14:29:25 -07001904 m.installFiles = append(m.installFiles, fullInstallPath)
Dan Willemsen322acaf2016-01-12 23:07:05 -08001905 }
Colin Cross25de6c32019-06-06 14:29:25 -07001906 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross35cec122015-04-02 14:37:16 -07001907 return fullInstallPath
1908}
1909
Colin Cross70dda7e2019-10-01 22:05:35 -07001910func (m *moduleContext) InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001911 fullInstallPath := installPath.Join(m, name)
1912 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Colin Cross3854a602016-01-11 12:49:11 -08001913
Colin Cross25de6c32019-06-06 14:29:25 -07001914 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001915
Alex Lightfb4353d2019-01-17 13:57:45 -08001916 relPath, err := filepath.Rel(path.Dir(fullInstallPath.String()), srcPath.String())
1917 if err != nil {
1918 panic(fmt.Sprintf("Unable to generate symlink between %q and %q: %s", fullInstallPath.Base(), srcPath.Base(), err))
1919 }
Colin Cross25de6c32019-06-06 14:29:25 -07001920 m.Build(pctx, BuildParams{
Colin Cross67a5c132017-05-09 13:45:28 -07001921 Rule: Symlink,
1922 Description: "install symlink " + fullInstallPath.Base(),
1923 Output: fullInstallPath,
Dan Willemsen40efa1c2020-01-14 15:19:52 -08001924 Input: srcPath,
Colin Cross25de6c32019-06-06 14:29:25 -07001925 Default: !m.Config().EmbeddedInMake(),
Colin Cross12fc4972016-01-11 12:49:11 -08001926 Args: map[string]string{
Alex Lightfb4353d2019-01-17 13:57:45 -08001927 "fromPath": relPath,
Colin Cross12fc4972016-01-11 12:49:11 -08001928 },
1929 })
Colin Cross3854a602016-01-11 12:49:11 -08001930
Colin Cross25de6c32019-06-06 14:29:25 -07001931 m.installFiles = append(m.installFiles, fullInstallPath)
1932 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross12fc4972016-01-11 12:49:11 -08001933 }
Colin Cross3854a602016-01-11 12:49:11 -08001934 return fullInstallPath
1935}
1936
Jiyong Parkf1194352019-02-25 11:05:47 +09001937// installPath/name -> absPath where absPath might be a path that is available only at runtime
1938// (e.g. /apex/...)
Colin Cross70dda7e2019-10-01 22:05:35 -07001939func (m *moduleContext) InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001940 fullInstallPath := installPath.Join(m, name)
1941 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Jiyong Parkf1194352019-02-25 11:05:47 +09001942
Colin Cross25de6c32019-06-06 14:29:25 -07001943 if !m.skipInstall(fullInstallPath) {
1944 m.Build(pctx, BuildParams{
Jiyong Parkf1194352019-02-25 11:05:47 +09001945 Rule: Symlink,
1946 Description: "install symlink " + fullInstallPath.Base() + " -> " + absPath,
1947 Output: fullInstallPath,
Colin Cross25de6c32019-06-06 14:29:25 -07001948 Default: !m.Config().EmbeddedInMake(),
Jiyong Parkf1194352019-02-25 11:05:47 +09001949 Args: map[string]string{
1950 "fromPath": absPath,
1951 },
1952 })
1953
Colin Cross25de6c32019-06-06 14:29:25 -07001954 m.installFiles = append(m.installFiles, fullInstallPath)
Jiyong Parkf1194352019-02-25 11:05:47 +09001955 }
1956 return fullInstallPath
1957}
1958
Colin Cross25de6c32019-06-06 14:29:25 -07001959func (m *moduleContext) CheckbuildFile(srcPath Path) {
1960 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross3f40fa42015-01-30 17:27:36 -08001961}
1962
Colin Cross3f40fa42015-01-30 17:27:36 -08001963type fileInstaller interface {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001964 filesToInstall() Paths
Colin Cross3f40fa42015-01-30 17:27:36 -08001965}
1966
1967func isFileInstaller(m blueprint.Module) bool {
1968 _, ok := m.(fileInstaller)
1969 return ok
1970}
1971
1972func isAndroidModule(m blueprint.Module) bool {
Colin Cross635c3b02016-05-18 15:37:25 -07001973 _, ok := m.(Module)
Colin Cross3f40fa42015-01-30 17:27:36 -08001974 return ok
1975}
Colin Crossfce53272015-04-08 11:21:40 -07001976
Dan Willemsen2ef08f42015-06-30 18:15:24 -07001977func findStringInSlice(str string, slice []string) int {
1978 for i, s := range slice {
1979 if s == str {
1980 return i
Colin Crossfce53272015-04-08 11:21:40 -07001981 }
1982 }
Dan Willemsen2ef08f42015-06-30 18:15:24 -07001983 return -1
1984}
1985
Colin Cross41955e82019-05-29 14:40:35 -07001986// SrcIsModule decodes module references in the format ":name" into the module name, or empty string if the input
1987// was not a module reference.
1988func SrcIsModule(s string) (module string) {
Colin Cross068e0fe2016-12-13 15:23:47 -08001989 if len(s) > 1 && s[0] == ':' {
1990 return s[1:]
1991 }
1992 return ""
1993}
1994
Colin Cross41955e82019-05-29 14:40:35 -07001995// SrcIsModule decodes module references in the format ":name{.tag}" into the module name and tag, ":name" into the
1996// module name and an empty string for the tag, or empty strings if the input was not a module reference.
1997func SrcIsModuleWithTag(s string) (module, tag string) {
1998 if len(s) > 1 && s[0] == ':' {
1999 module = s[1:]
2000 if tagStart := strings.IndexByte(module, '{'); tagStart > 0 {
2001 if module[len(module)-1] == '}' {
2002 tag = module[tagStart+1 : len(module)-1]
2003 module = module[:tagStart]
2004 return module, tag
2005 }
2006 }
2007 return module, ""
2008 }
2009 return "", ""
Colin Cross068e0fe2016-12-13 15:23:47 -08002010}
2011
Colin Cross41955e82019-05-29 14:40:35 -07002012type sourceOrOutputDependencyTag struct {
2013 blueprint.BaseDependencyTag
2014 tag string
2015}
2016
2017func sourceOrOutputDepTag(tag string) blueprint.DependencyTag {
2018 return sourceOrOutputDependencyTag{tag: tag}
2019}
2020
2021var SourceDepTag = sourceOrOutputDepTag("")
Colin Cross068e0fe2016-12-13 15:23:47 -08002022
Colin Cross366938f2017-12-11 16:29:02 -08002023// Adds necessary dependencies to satisfy filegroup or generated sources modules listed in srcFiles
2024// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002025//
2026// Deprecated: tag the property with `android:"path"` instead.
Colin Cross068e0fe2016-12-13 15:23:47 -08002027func ExtractSourcesDeps(ctx BottomUpMutatorContext, srcFiles []string) {
Nan Zhang2439eb72017-04-10 11:27:50 -07002028 set := make(map[string]bool)
2029
Colin Cross068e0fe2016-12-13 15:23:47 -08002030 for _, s := range srcFiles {
Colin Cross41955e82019-05-29 14:40:35 -07002031 if m, t := SrcIsModuleWithTag(s); m != "" {
2032 if _, found := set[s]; found {
2033 ctx.ModuleErrorf("found source dependency duplicate: %q!", s)
Nan Zhang2439eb72017-04-10 11:27:50 -07002034 } else {
Colin Cross41955e82019-05-29 14:40:35 -07002035 set[s] = true
2036 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Nan Zhang2439eb72017-04-10 11:27:50 -07002037 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002038 }
2039 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002040}
2041
Colin Cross366938f2017-12-11 16:29:02 -08002042// Adds necessary dependencies to satisfy filegroup or generated sources modules specified in s
2043// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002044//
2045// Deprecated: tag the property with `android:"path"` instead.
Colin Cross366938f2017-12-11 16:29:02 -08002046func ExtractSourceDeps(ctx BottomUpMutatorContext, s *string) {
2047 if s != nil {
Colin Cross41955e82019-05-29 14:40:35 -07002048 if m, t := SrcIsModuleWithTag(*s); m != "" {
2049 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Colin Cross366938f2017-12-11 16:29:02 -08002050 }
2051 }
2052}
2053
Colin Cross41955e82019-05-29 14:40:35 -07002054// A module that implements SourceFileProducer can be referenced from any property that is tagged with `android:"path"`
2055// 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 -08002056type SourceFileProducer interface {
2057 Srcs() Paths
2058}
2059
Colin Cross41955e82019-05-29 14:40:35 -07002060// A module that implements OutputFileProducer can be referenced from any property that is tagged with `android:"path"`
Roland Levillain97c1f342019-11-22 14:20:54 +00002061// 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 -07002062// listed in the property.
2063type OutputFileProducer interface {
2064 OutputFiles(tag string) (Paths, error)
2065}
2066
Colin Cross5e708052019-08-06 13:59:50 -07002067// OutputFilesForModule returns the paths from an OutputFileProducer with the given tag. On error, including if the
2068// module produced zero paths, it reports errors to the ctx and returns nil.
2069func OutputFilesForModule(ctx PathContext, module blueprint.Module, tag string) Paths {
2070 paths, err := outputFilesForModule(ctx, module, tag)
2071 if err != nil {
2072 reportPathError(ctx, err)
2073 return nil
2074 }
2075 return paths
2076}
2077
2078// OutputFileForModule returns the path from an OutputFileProducer with the given tag. On error, including if the
2079// module produced zero or multiple paths, it reports errors to the ctx and returns nil.
2080func OutputFileForModule(ctx PathContext, module blueprint.Module, tag string) Path {
2081 paths, err := outputFilesForModule(ctx, module, tag)
2082 if err != nil {
2083 reportPathError(ctx, err)
2084 return nil
2085 }
2086 if len(paths) > 1 {
2087 reportPathErrorf(ctx, "got multiple output files from module %q, expected exactly one",
2088 pathContextName(ctx, module))
2089 return nil
2090 }
2091 return paths[0]
2092}
2093
2094func outputFilesForModule(ctx PathContext, module blueprint.Module, tag string) (Paths, error) {
2095 if outputFileProducer, ok := module.(OutputFileProducer); ok {
2096 paths, err := outputFileProducer.OutputFiles(tag)
2097 if err != nil {
2098 return nil, fmt.Errorf("failed to get output file from module %q: %s",
2099 pathContextName(ctx, module), err.Error())
2100 }
2101 if len(paths) == 0 {
2102 return nil, fmt.Errorf("failed to get output files from module %q", pathContextName(ctx, module))
2103 }
2104 return paths, nil
2105 } else {
2106 return nil, fmt.Errorf("module %q is not an OutputFileProducer", pathContextName(ctx, module))
2107 }
2108}
2109
Colin Crossfe17f6f2019-03-28 19:30:56 -07002110type HostToolProvider interface {
2111 HostToolPath() OptionalPath
2112}
2113
Colin Cross27b922f2019-03-04 22:35:41 -08002114// Returns a list of paths expanded from globs and modules referenced using ":module" syntax. The property must
2115// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002116//
2117// Deprecated: use PathsForModuleSrc or PathsForModuleSrcExcludes instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002118func (m *moduleContext) ExpandSources(srcFiles, excludes []string) Paths {
2119 return PathsForModuleSrcExcludes(m, srcFiles, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07002120}
2121
Colin Cross2fafa3e2019-03-05 12:39:51 -08002122// Returns a single path expanded from globs and modules referenced using ":module" syntax. The property must
2123// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002124//
2125// Deprecated: use PathForModuleSrc instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002126func (m *moduleContext) ExpandSource(srcFile, prop string) Path {
2127 return PathForModuleSrc(m, srcFile)
Colin Cross2fafa3e2019-03-05 12:39:51 -08002128}
2129
2130// Returns an optional single path expanded from globs and modules referenced using ":module" syntax if
2131// the srcFile is non-nil. The property must be tagged with `android:"path" to support automatic source module
2132// dependency resolution.
Colin Cross25de6c32019-06-06 14:29:25 -07002133func (m *moduleContext) ExpandOptionalSource(srcFile *string, prop string) OptionalPath {
Colin Cross2fafa3e2019-03-05 12:39:51 -08002134 if srcFile != nil {
Colin Cross25de6c32019-06-06 14:29:25 -07002135 return OptionalPathForPath(PathForModuleSrc(m, *srcFile))
Colin Cross2fafa3e2019-03-05 12:39:51 -08002136 }
2137 return OptionalPath{}
2138}
2139
Colin Cross25de6c32019-06-06 14:29:25 -07002140func (m *moduleContext) RequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002141 return m.module.RequiredModuleNames()
Nan Zhang6d34b302017-02-04 17:47:46 -08002142}
2143
Colin Cross25de6c32019-06-06 14:29:25 -07002144func (m *moduleContext) HostRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002145 return m.module.HostRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002146}
2147
Colin Cross25de6c32019-06-06 14:29:25 -07002148func (m *moduleContext) TargetRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002149 return m.module.TargetRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002150}
2151
Colin Cross463a90e2015-06-17 14:20:06 -07002152func init() {
Colin Cross798bfce2016-10-12 14:28:16 -07002153 RegisterSingletonType("buildtarget", BuildTargetSingleton)
Colin Cross463a90e2015-06-17 14:20:06 -07002154}
2155
Colin Cross0875c522017-11-28 17:34:01 -08002156func BuildTargetSingleton() Singleton {
Colin Cross1f8c52b2015-06-16 16:38:17 -07002157 return &buildTargetSingleton{}
2158}
2159
Colin Cross87d8b562017-04-25 10:01:55 -07002160func parentDir(dir string) string {
2161 dir, _ = filepath.Split(dir)
2162 return filepath.Clean(dir)
2163}
2164
Colin Cross1f8c52b2015-06-16 16:38:17 -07002165type buildTargetSingleton struct{}
2166
Colin Cross0875c522017-11-28 17:34:01 -08002167func (c *buildTargetSingleton) GenerateBuildActions(ctx SingletonContext) {
2168 var checkbuildDeps Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07002169
Colin Cross98552072020-06-04 13:25:17 -07002170 mmTarget := func(dir string) string {
2171 return "MODULES-IN-" + strings.Replace(filepath.Clean(dir), "/", "-", -1)
Colin Cross87d8b562017-04-25 10:01:55 -07002172 }
2173
Colin Cross0875c522017-11-28 17:34:01 -08002174 modulesInDir := make(map[string]Paths)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002175
Colin Cross0875c522017-11-28 17:34:01 -08002176 ctx.VisitAllModules(func(module Module) {
2177 blueprintDir := module.base().blueprintDir
2178 installTarget := module.base().installTarget
2179 checkbuildTarget := module.base().checkbuildTarget
Colin Cross1f8c52b2015-06-16 16:38:17 -07002180
Colin Cross0875c522017-11-28 17:34:01 -08002181 if checkbuildTarget != nil {
2182 checkbuildDeps = append(checkbuildDeps, checkbuildTarget)
2183 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], checkbuildTarget)
2184 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002185
Colin Cross0875c522017-11-28 17:34:01 -08002186 if installTarget != nil {
2187 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], installTarget)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002188 }
2189 })
2190
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002191 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08002192 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002193 suffix = "-soong"
2194 }
2195
Colin Cross1f8c52b2015-06-16 16:38:17 -07002196 // Create a top-level checkbuild target that depends on all modules
Colin Cross98552072020-06-04 13:25:17 -07002197 ctx.Phony("checkbuild"+suffix, checkbuildDeps...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002198
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002199 // Make will generate the MODULES-IN-* targets
Colin Crossaabf6792017-11-29 00:27:14 -08002200 if ctx.Config().EmbeddedInMake() {
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002201 return
2202 }
2203
Colin Cross87d8b562017-04-25 10:01:55 -07002204 // Ensure ancestor directories are in modulesInDir
Inseob Kim1a365c62019-06-08 15:47:51 +09002205 dirs := SortedStringKeys(modulesInDir)
Colin Cross87d8b562017-04-25 10:01:55 -07002206 for _, dir := range dirs {
2207 dir := parentDir(dir)
2208 for dir != "." && dir != "/" {
2209 if _, exists := modulesInDir[dir]; exists {
2210 break
2211 }
2212 modulesInDir[dir] = nil
2213 dir = parentDir(dir)
2214 }
2215 }
2216
2217 // Make directories build their direct subdirectories
Colin Cross87d8b562017-04-25 10:01:55 -07002218 for _, dir := range dirs {
2219 p := parentDir(dir)
2220 if p != "." && p != "/" {
Colin Cross98552072020-06-04 13:25:17 -07002221 modulesInDir[p] = append(modulesInDir[p], PathForPhony(ctx, mmTarget(dir)))
Colin Cross87d8b562017-04-25 10:01:55 -07002222 }
2223 }
2224
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002225 // Create a MODULES-IN-<directory> target that depends on all modules in a directory, and
2226 // depends on the MODULES-IN-* targets of all of its subdirectories that contain Android.bp
2227 // files.
Colin Cross1f8c52b2015-06-16 16:38:17 -07002228 for _, dir := range dirs {
Colin Cross98552072020-06-04 13:25:17 -07002229 ctx.Phony(mmTarget(dir), modulesInDir[dir]...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002230 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002231
2232 // Create (host|host-cross|target)-<OS> phony rules to build a reduced checkbuild.
2233 osDeps := map[OsType]Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08002234 ctx.VisitAllModules(func(module Module) {
2235 if module.Enabled() {
2236 os := module.Target().Os
2237 osDeps[os] = append(osDeps[os], module.base().checkbuildFiles...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002238 }
2239 })
2240
Colin Cross0875c522017-11-28 17:34:01 -08002241 osClass := make(map[string]Paths)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002242 for os, deps := range osDeps {
2243 var className string
2244
2245 switch os.Class {
2246 case Host:
2247 className = "host"
2248 case HostCross:
2249 className = "host-cross"
2250 case Device:
2251 className = "target"
2252 default:
2253 continue
2254 }
2255
Colin Cross98552072020-06-04 13:25:17 -07002256 name := className + "-" + os.Name
2257 osClass[className] = append(osClass[className], PathForPhony(ctx, name))
Dan Willemsen61d88b82017-09-20 17:29:08 -07002258
Colin Cross98552072020-06-04 13:25:17 -07002259 ctx.Phony(name, deps...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002260 }
2261
2262 // Wrap those into host|host-cross|target phony rules
Inseob Kim1a365c62019-06-08 15:47:51 +09002263 for _, class := range SortedStringKeys(osClass) {
Colin Cross98552072020-06-04 13:25:17 -07002264 ctx.Phony(class, osClass[class]...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002265 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002266}
Colin Crossd779da42015-12-17 18:00:23 -08002267
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002268// Collect information for opening IDE project files in java/jdeps.go.
2269type IDEInfo interface {
2270 IDEInfo(ideInfo *IdeInfo)
2271 BaseModuleName() string
2272}
2273
2274// Extract the base module name from the Import name.
2275// Often the Import name has a prefix "prebuilt_".
2276// Remove the prefix explicitly if needed
2277// until we find a better solution to get the Import name.
2278type IDECustomizedModuleName interface {
2279 IDECustomizedModuleName() string
2280}
2281
2282type IdeInfo struct {
2283 Deps []string `json:"dependencies,omitempty"`
2284 Srcs []string `json:"srcs,omitempty"`
2285 Aidl_include_dirs []string `json:"aidl_include_dirs,omitempty"`
2286 Jarjar_rules []string `json:"jarjar_rules,omitempty"`
2287 Jars []string `json:"jars,omitempty"`
2288 Classes []string `json:"class,omitempty"`
2289 Installed_paths []string `json:"installed,omitempty"`
patricktu18c82ff2019-05-10 15:48:50 +08002290 SrcJars []string `json:"srcjars,omitempty"`
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002291}