blob: 80f477b043b8608377c7b6c9ade11a86ee374fa9 [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
Colin Crossdc35e212019-06-06 16:13:11 -0700131 AddMissingDependencies(missingDeps []string)
132
Colin Crossa1ad8d12016-06-01 17:09:44 -0700133 Target() Target
Colin Cross8b74d172016-09-13 09:59:14 -0700134 TargetPrimary() bool
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000135
136 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
137 // responsible for creating.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700138 MultiTargets() []Target
Colin Crossf6566ed2015-03-24 11:13:38 -0700139 Arch() Arch
Colin Crossa1ad8d12016-06-01 17:09:44 -0700140 Os() OsType
Colin Crossf6566ed2015-03-24 11:13:38 -0700141 Host() bool
142 Device() bool
Colin Cross0af4b842015-04-30 16:36:18 -0700143 Darwin() bool
Doug Horn21b94272019-01-16 12:06:11 -0800144 Fuchsia() bool
Colin Cross3edeee12017-04-04 12:59:48 -0700145 Windows() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700146 Debug() bool
Colin Cross1e7d3702016-08-24 15:25:47 -0700147 PrimaryArch() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700148}
149
Colin Cross1184b642019-12-30 18:43:07 -0800150// Deprecated: use EarlyModuleContext instead
Colin Cross635c3b02016-05-18 15:37:25 -0700151type BaseContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800152 EarlyModuleContext
Colin Crossaabf6792017-11-29 00:27:14 -0800153}
154
Colin Cross635c3b02016-05-18 15:37:25 -0700155type ModuleContext interface {
Colin Crossaabf6792017-11-29 00:27:14 -0800156 BaseModuleContext
Colin Cross3f40fa42015-01-30 17:27:36 -0800157
Colin Crossae887032017-10-23 17:16:14 -0700158 // Deprecated: use ModuleContext.Build instead.
Colin Cross0875c522017-11-28 17:34:01 -0800159 ModuleBuild(pctx PackageContext, params ModuleBuildParams)
Colin Cross8f101b42015-06-17 15:09:06 -0700160
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700161 ExpandSources(srcFiles, excludes []string) Paths
Colin Cross366938f2017-12-11 16:29:02 -0800162 ExpandSource(srcFile, prop string) Path
Colin Cross2383f3b2018-02-06 14:40:13 -0800163 ExpandOptionalSource(srcFile *string, prop string) OptionalPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700164
Colin Cross70dda7e2019-10-01 22:05:35 -0700165 InstallExecutable(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
166 InstallFile(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
167 InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath
168 InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700169 CheckbuildFile(srcPath Path)
Dan Willemsen6553f5e2016-03-10 18:14:25 -0800170
Colin Cross8d8f8e22016-08-03 11:57:50 -0700171 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700172 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700173 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800174 InstallInRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900175 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700176 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700177 InstallBypassMake() bool
Colin Cross6e359402020-02-10 15:29:54 -0800178 InstallForceOS() *OsType
Nan Zhang6d34b302017-02-04 17:47:46 -0800179
180 RequiredModuleNames() []string
Sasha Smundakb6d23052019-04-01 18:37:36 -0700181 HostRequiredModuleNames() []string
182 TargetRequiredModuleNames() []string
Colin Cross3f68a132017-10-23 17:10:29 -0700183
Colin Cross3f68a132017-10-23 17:10:29 -0700184 ModuleSubDir() string
185
Colin Cross0875c522017-11-28 17:34:01 -0800186 Variable(pctx PackageContext, name, value string)
187 Rule(pctx PackageContext, name string, params blueprint.RuleParams, argNames ...string) blueprint.Rule
Colin Crossae887032017-10-23 17:16:14 -0700188 // Similar to blueprint.ModuleContext.Build, but takes Paths instead of []string,
189 // and performs more verification.
Colin Cross0875c522017-11-28 17:34:01 -0800190 Build(pctx PackageContext, params BuildParams)
Colin Cross3f68a132017-10-23 17:10:29 -0700191
Colin Cross0875c522017-11-28 17:34:01 -0800192 PrimaryModule() Module
193 FinalModule() Module
194 VisitAllModuleVariants(visit func(Module))
Colin Cross3f68a132017-10-23 17:10:29 -0700195
196 GetMissingDependencies() []string
Jeff Gaston088e29e2017-11-29 16:47:17 -0800197 Namespace() blueprint.Namespace
Colin Cross3f40fa42015-01-30 17:27:36 -0800198}
199
Colin Cross635c3b02016-05-18 15:37:25 -0700200type Module interface {
Colin Cross3f40fa42015-01-30 17:27:36 -0800201 blueprint.Module
202
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700203 // GenerateAndroidBuildActions is analogous to Blueprints' GenerateBuildActions,
204 // but GenerateAndroidBuildActions also has access to Android-specific information.
205 // For more information, see Module.GenerateBuildActions within Blueprint's module_ctx.go
Colin Cross635c3b02016-05-18 15:37:25 -0700206 GenerateAndroidBuildActions(ModuleContext)
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700207
Colin Cross1e676be2016-10-12 14:38:15 -0700208 DepsMutator(BottomUpMutatorContext)
Colin Cross3f40fa42015-01-30 17:27:36 -0800209
Colin Cross635c3b02016-05-18 15:37:25 -0700210 base() *ModuleBase
Inseob Kimeec88e12020-01-22 11:11:29 +0900211 Disable()
Dan Willemsen0effe062015-11-30 16:06:01 -0800212 Enabled() bool
Colin Crossa1ad8d12016-06-01 17:09:44 -0700213 Target() Target
Dan Willemsen782a2d12015-12-21 14:55:28 -0800214 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700215 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700216 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800217 InstallInRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900218 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700219 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700220 InstallBypassMake() bool
Colin Cross6e359402020-02-10 15:29:54 -0800221 InstallForceOS() *OsType
Colin Crossa2f296f2016-11-29 15:16:18 -0800222 SkipInstall()
Jiyong Park374510b2018-03-19 18:23:01 +0900223 ExportedToMake() bool
Inseob Kim8471cda2019-11-15 09:59:12 +0900224 InitRc() Paths
225 VintfFragments() Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800226 NoticeFiles() Paths
Colin Cross36242852017-06-23 15:06:31 -0700227
228 AddProperties(props ...interface{})
229 GetProperties() []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700230
Colin Crossae887032017-10-23 17:16:14 -0700231 BuildParamsForTests() []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800232 RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800233 VariablesForTests() map[string]string
Paul Duffine2453c72019-05-31 14:00:04 +0100234
Colin Cross9a362232019-07-01 15:32:45 -0700235 // String returns a string that includes the module name and variants for printing during debugging.
236 String() string
237
Paul Duffine2453c72019-05-31 14:00:04 +0100238 // Get the qualified module id for this module.
239 qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName
240
241 // Get information about the properties that can contain visibility rules.
242 visibilityProperties() []visibilityProperty
Paul Duffin63c6e182019-07-24 14:24:38 +0100243
244 // Get the visibility rules that control the visibility of this module.
245 visibility() []string
Jiyong Park6a8cf5f2019-12-30 16:31:09 +0900246
247 RequiredModuleNames() []string
248 HostRequiredModuleNames() []string
249 TargetRequiredModuleNames() []string
Colin Cross897266e2020-02-13 13:22:08 -0800250
251 filesToInstall() InstallPaths
Paul Duffine2453c72019-05-31 14:00:04 +0100252}
253
254// Qualified id for a module
255type qualifiedModuleName struct {
256 // The package (i.e. directory) in which the module is defined, without trailing /
257 pkg string
258
259 // The name of the module, empty string if package.
260 name string
261}
262
263func (q qualifiedModuleName) String() string {
264 if q.name == "" {
265 return "//" + q.pkg
266 }
267 return "//" + q.pkg + ":" + q.name
268}
269
Paul Duffine484f472019-06-20 16:38:08 +0100270func (q qualifiedModuleName) isRootPackage() bool {
271 return q.pkg == "" && q.name == ""
272}
273
Paul Duffine2453c72019-05-31 14:00:04 +0100274// Get the id for the package containing this module.
275func (q qualifiedModuleName) getContainingPackageId() qualifiedModuleName {
276 pkg := q.pkg
277 if q.name == "" {
Paul Duffine484f472019-06-20 16:38:08 +0100278 if pkg == "" {
279 panic(fmt.Errorf("Cannot get containing package id of root package"))
280 }
281
282 index := strings.LastIndex(pkg, "/")
283 if index == -1 {
284 pkg = ""
285 } else {
286 pkg = pkg[:index]
287 }
Paul Duffine2453c72019-05-31 14:00:04 +0100288 }
289 return newPackageId(pkg)
290}
291
292func newPackageId(pkg string) qualifiedModuleName {
293 // A qualified id for a package module has no name.
294 return qualifiedModuleName{pkg: pkg, name: ""}
Colin Cross3f40fa42015-01-30 17:27:36 -0800295}
296
Colin Crossfc754582016-05-17 16:34:16 -0700297type nameProperties struct {
298 // The name of the module. Must be unique across all modules.
Nan Zhang0007d812017-11-07 10:57:05 -0800299 Name *string
Colin Crossfc754582016-05-17 16:34:16 -0700300}
301
302type commonProperties struct {
Dan Willemsen0effe062015-11-30 16:06:01 -0800303 // emit build rules for this module
Paul Duffin54d9bb72020-02-12 10:20:56 +0000304 //
305 // Disabling a module should only be done for those modules that cannot be built
306 // in the current environment. Modules that can build in the current environment
307 // but are not usually required (e.g. superceded by a prebuilt) should not be
308 // disabled as that will prevent them from being built by the checkbuild target
309 // and so prevent early detection of changes that have broken those modules.
Dan Willemsen0effe062015-11-30 16:06:01 -0800310 Enabled *bool `android:"arch_variant"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800311
Paul Duffin2e61fa62019-03-28 14:10:57 +0000312 // Controls the visibility of this module to other modules. Allowable values are one or more of
313 // these formats:
314 //
315 // ["//visibility:public"]: Anyone can use this module.
316 // ["//visibility:private"]: Only rules in the module's package (not its subpackages) can use
317 // this module.
318 // ["//some/package:__pkg__", "//other/package:__pkg__"]: Only modules in some/package and
319 // other/package (defined in some/package/*.bp and other/package/*.bp) have access to
320 // this module. Note that sub-packages do not have access to the rule; for example,
321 // //some/package/foo:bar or //other/package/testing:bla wouldn't have access. __pkg__
322 // is a special module and must be used verbatim. It represents all of the modules in the
323 // package.
324 // ["//project:__subpackages__", "//other:__subpackages__"]: Only modules in packages project
325 // or other or in one of their sub-packages have access to this module. For example,
326 // //project:rule, //project/library:lib or //other/testing/internal:munge are allowed
327 // to depend on this rule (but not //independent:evil)
328 // ["//project"]: This is shorthand for ["//project:__pkg__"]
329 // [":__subpackages__"]: This is shorthand for ["//project:__subpackages__"] where
330 // //project is the module's package. e.g. using [":__subpackages__"] in
331 // packages/apps/Settings/Android.bp is equivalent to
332 // //packages/apps/Settings:__subpackages__.
333 // ["//visibility:legacy_public"]: The default visibility, behaves as //visibility:public
334 // for now. It is an error if it is used in a module.
Paul Duffine2453c72019-05-31 14:00:04 +0100335 //
336 // If a module does not specify the `visibility` property then it uses the
337 // `default_visibility` property of the `package` module in the module's package.
338 //
339 // If the `default_visibility` property is not set for the module's package then
Paul Duffine484f472019-06-20 16:38:08 +0100340 // it will use the `default_visibility` of its closest ancestor package for which
341 // a `default_visibility` property is specified.
342 //
343 // If no `default_visibility` property can be found then the module uses the
344 // global default of `//visibility:legacy_public`.
Paul Duffine2453c72019-05-31 14:00:04 +0100345 //
Paul Duffin95d53b52019-07-24 13:45:05 +0100346 // The `visibility` property has no effect on a defaults module although it does
347 // apply to any non-defaults module that uses it. To set the visibility of a
348 // defaults module, use the `defaults_visibility` property on the defaults module;
349 // not to be confused with the `default_visibility` property on the package module.
350 //
Paul Duffin2e61fa62019-03-28 14:10:57 +0000351 // See https://android.googlesource.com/platform/build/soong/+/master/README.md#visibility for
352 // more details.
353 Visibility []string
354
Colin Cross7d5136f2015-05-11 13:39:40 -0700355 // control whether this module compiles for 32-bit, 64-bit, or both. Possible values
Colin Cross3f40fa42015-01-30 17:27:36 -0800356 // are "32" (compile for 32-bit only), "64" (compile for 64-bit only), "both" (compile for both
357 // architectures), or "first" (compile for 64-bit on a 64-bit platform, and 32-bit on a 32-bit
358 // platform
Colin Cross7d716ba2017-11-01 10:38:29 -0700359 Compile_multilib *string `android:"arch_variant"`
Colin Cross69617d32016-09-06 10:39:07 -0700360
361 Target struct {
362 Host struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700363 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700364 }
365 Android struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700366 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700367 }
368 }
369
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000370 // If set to true then the archMutator will create variants for each arch specific target
371 // (e.g. 32/64) that the module is required to produce. If set to false then it will only
372 // create a variant for the architecture and will list the additional arch specific targets
373 // that the variant needs to produce in the CompileMultiTargets property.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700374 UseTargetVariants bool `blueprint:"mutated"`
375 Default_multilib string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800376
Dan Willemsen782a2d12015-12-21 14:55:28 -0800377 // whether this is a proprietary vendor module, and should be installed into /vendor
Colin Cross7d716ba2017-11-01 10:38:29 -0700378 Proprietary *bool
Dan Willemsen782a2d12015-12-21 14:55:28 -0800379
Colin Cross55708f32017-03-20 13:23:34 -0700380 // vendor who owns this module
Dan Willemsenefac4a82017-07-18 19:42:09 -0700381 Owner *string
Colin Cross55708f32017-03-20 13:23:34 -0700382
Jiyong Park2db76922017-11-08 16:03:48 +0900383 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
384 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
385 // Use `soc_specific` instead for better meaning.
Colin Cross7d716ba2017-11-01 10:38:29 -0700386 Vendor *bool
Dan Willemsenaa118f92017-04-06 12:49:58 -0700387
Jiyong Park2db76922017-11-08 16:03:48 +0900388 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
389 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
390 Soc_specific *bool
391
392 // whether this module is specific to a device, not only for SoC, but also for off-chip
393 // peripherals. When set to true, it is installed into /odm (or /vendor/odm if odm partition
394 // does not exist, or /system/vendor/odm if both odm and vendor partitions do not exist).
395 // This implies `soc_specific:true`.
396 Device_specific *bool
397
398 // whether this module is specific to a software configuration of a product (e.g. country,
Jaekyun Seok5cfbfbb2018-01-10 19:00:15 +0900399 // network operator, etc). When set to true, it is installed into /product (or
400 // /system/product if product partition does not exist).
Jiyong Park2db76922017-11-08 16:03:48 +0900401 Product_specific *bool
402
Justin Yund5f6c822019-06-25 16:47:17 +0900403 // whether this module extends system. When set to true, it is installed into /system_ext
404 // (or /system/system_ext if system_ext partition does not exist).
405 System_ext_specific *bool
406
Jiyong Parkf9332f12018-02-01 00:54:12 +0900407 // Whether this module is installed to recovery partition
408 Recovery *bool
409
Yifan Hong1b3348d2020-01-21 15:53:22 -0800410 // Whether this module is installed to ramdisk
411 Ramdisk *bool
412
dimitry1f33e402019-03-26 12:39:31 +0100413 // Whether this module is built for non-native architecures (also known as native bridge binary)
414 Native_bridge_supported *bool `android:"arch_variant"`
415
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700416 // init.rc files to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800417 Init_rc []string `android:"path"`
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700418
Steven Moreland57a23d22018-04-04 15:42:19 -0700419 // VINTF manifest fragments to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800420 Vintf_fragments []string `android:"path"`
Steven Moreland57a23d22018-04-04 15:42:19 -0700421
Chris Wolfe998306e2016-08-15 14:47:23 -0400422 // names of other modules to install if this module is installed
Colin Crossc602b7d2017-05-05 13:36:36 -0700423 Required []string `android:"arch_variant"`
Chris Wolfe998306e2016-08-15 14:47:23 -0400424
Sasha Smundakb6d23052019-04-01 18:37:36 -0700425 // names of other modules to install on host if this module is installed
426 Host_required []string `android:"arch_variant"`
427
428 // names of other modules to install on target if this module is installed
429 Target_required []string `android:"arch_variant"`
430
Colin Cross5aac3622017-08-31 15:07:09 -0700431 // relative path to a file to include in the list of notices for the device
Colin Cross27b922f2019-03-04 22:35:41 -0800432 Notice *string `android:"path"`
Colin Cross5aac3622017-08-31 15:07:09 -0700433
Dan Willemsen569edc52018-11-19 09:33:29 -0800434 Dist struct {
435 // copy the output of this module to the $DIST_DIR when `dist` is specified on the
436 // command line and any of these targets are also on the command line, or otherwise
437 // built
438 Targets []string `android:"arch_variant"`
439
440 // The name of the output artifact. This defaults to the basename of the output of
441 // the module.
442 Dest *string `android:"arch_variant"`
443
444 // The directory within the dist directory to store the artifact. Defaults to the
445 // top level directory ("").
446 Dir *string `android:"arch_variant"`
447
448 // A suffix to add to the artifact file name (before any extension).
449 Suffix *string `android:"arch_variant"`
450 } `android:"arch_variant"`
451
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000452 // The OsType of artifacts that this module variant is responsible for creating.
453 //
454 // Set by osMutator
455 CompileOS OsType `blueprint:"mutated"`
456
457 // The Target of artifacts that this module variant is responsible for creating.
458 //
459 // Set by archMutator
460 CompileTarget Target `blueprint:"mutated"`
461
462 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
463 // responsible for creating.
464 //
465 // By default this is nil as, where necessary, separate variants are created for the
466 // different multilib types supported and that information is encapsulated in the
467 // CompileTarget so the module variant simply needs to create artifacts for that.
468 //
469 // However, if UseTargetVariants is set to false (e.g. by
470 // InitAndroidMultiTargetsArchModule) then no separate variants are created for the
471 // multilib targets. Instead a single variant is created for the architecture and
472 // this contains the multilib specific targets that this variant should create.
473 //
474 // Set by archMutator
Colin Crossee0bc3b2018-10-02 22:01:37 -0700475 CompileMultiTargets []Target `blueprint:"mutated"`
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000476
477 // True if the module variant's CompileTarget is the primary target
478 //
479 // Set by archMutator
480 CompilePrimary bool `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800481
482 // Set by InitAndroidModule
483 HostOrDeviceSupported HostOrDeviceSupported `blueprint:"mutated"`
Dan Willemsen0b24c742016-10-04 15:13:37 -0700484 ArchSpecific bool `blueprint:"mutated"`
Colin Crossce75d2c2016-10-06 16:12:58 -0700485
Paul Duffin1356d8c2020-02-25 19:26:33 +0000486 // If set to true then a CommonOS variant will be created which will have dependencies
487 // on all its OsType specific variants. Used by sdk/module_exports to create a snapshot
488 // that covers all os and architecture variants.
489 //
490 // The OsType specific variants can be retrieved by calling
491 // GetOsSpecificVariantsOfCommonOSVariant
492 //
493 // Set at module initialization time by calling InitCommonOSAndroidMultiTargetsArchModule
494 CreateCommonOSVariant bool `blueprint:"mutated"`
495
496 // If set to true then this variant is the CommonOS variant that has dependencies on its
497 // OsType specific variants.
498 //
499 // Set by osMutator.
500 CommonOSVariant bool `blueprint:"mutated"`
501
Colin Crossce75d2c2016-10-06 16:12:58 -0700502 SkipInstall bool `blueprint:"mutated"`
Jeff Gaston088e29e2017-11-29 16:47:17 -0800503
504 NamespaceExportedToMake bool `blueprint:"mutated"`
Colin Cross6c4f21f2019-06-06 15:41:36 -0700505
506 MissingDeps []string `blueprint:"mutated"`
Colin Cross9a362232019-07-01 15:32:45 -0700507
508 // Name and variant strings stored by mutators to enable Module.String()
509 DebugName string `blueprint:"mutated"`
510 DebugMutators []string `blueprint:"mutated"`
511 DebugVariations []string `blueprint:"mutated"`
Colin Cross7228ecd2019-11-18 16:00:16 -0800512
513 // set by ImageMutator
514 ImageVariation string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800515}
516
517type hostAndDeviceProperties struct {
Colin Cross4e81d702018-11-09 10:36:55 -0800518 // If set to true, build a variant of the module for the host. Defaults to false.
519 Host_supported *bool
520
521 // If set to true, build a variant of the module for the device. Defaults to true.
Colin Crossa4190c12016-07-12 13:11:25 -0700522 Device_supported *bool
Colin Cross3f40fa42015-01-30 17:27:36 -0800523}
524
Colin Crossc472d572015-03-17 15:06:21 -0700525type Multilib string
526
527const (
Colin Cross6b4a32d2017-12-05 13:42:45 -0800528 MultilibBoth Multilib = "both"
529 MultilibFirst Multilib = "first"
530 MultilibCommon Multilib = "common"
531 MultilibCommonFirst Multilib = "common_first"
532 MultilibDefault Multilib = ""
Colin Crossc472d572015-03-17 15:06:21 -0700533)
534
Colin Crossa1ad8d12016-06-01 17:09:44 -0700535type HostOrDeviceSupported int
536
537const (
538 _ HostOrDeviceSupported = iota
Dan Albert0981b5c2018-08-02 13:46:35 -0700539
540 // Host and HostCross are built by default. Device is not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700541 HostSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700542
543 // Host is built by default. HostCross and Device are not supported.
Dan Albertc6345fb2016-10-20 01:36:11 -0700544 HostSupportedNoCross
Dan Albert0981b5c2018-08-02 13:46:35 -0700545
546 // Device is built by default. Host and HostCross are not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700547 DeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700548
549 // Device is built by default. Host and HostCross are supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700550 HostAndDeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700551
552 // Host, HostCross, and Device are built by default.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700553 HostAndDeviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700554
555 // Nothing is supported. This is not exposed to the user, but used to mark a
556 // host only module as unsupported when the module type is not supported on
557 // the host OS. E.g. benchmarks are supported on Linux but not Darwin.
Dan Willemsen0b24c742016-10-04 15:13:37 -0700558 NeitherHostNorDeviceSupported
Colin Crossa1ad8d12016-06-01 17:09:44 -0700559)
560
Jiyong Park2db76922017-11-08 16:03:48 +0900561type moduleKind int
562
563const (
564 platformModule moduleKind = iota
565 deviceSpecificModule
566 socSpecificModule
567 productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900568 systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900569)
570
571func (k moduleKind) String() string {
572 switch k {
573 case platformModule:
574 return "platform"
575 case deviceSpecificModule:
576 return "device-specific"
577 case socSpecificModule:
578 return "soc-specific"
579 case productSpecificModule:
580 return "product-specific"
Justin Yund5f6c822019-06-25 16:47:17 +0900581 case systemExtSpecificModule:
582 return "systemext-specific"
Jiyong Park2db76922017-11-08 16:03:48 +0900583 default:
584 panic(fmt.Errorf("unknown module kind %d", k))
585 }
586}
587
Colin Cross9d34f352019-11-22 16:03:51 -0800588func initAndroidModuleBase(m Module) {
589 m.base().module = m
590}
591
Colin Cross36242852017-06-23 15:06:31 -0700592func InitAndroidModule(m Module) {
Colin Cross9d34f352019-11-22 16:03:51 -0800593 initAndroidModuleBase(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800594 base := m.base()
Colin Cross5049f022015-03-18 13:28:46 -0700595
Colin Cross36242852017-06-23 15:06:31 -0700596 m.AddProperties(
Colin Crossfc754582016-05-17 16:34:16 -0700597 &base.nameProperties,
Colin Cross18c46802019-09-24 22:19:02 -0700598 &base.commonProperties)
599
Colin Crosseabaedd2020-02-06 17:01:55 -0800600 initProductVariableModule(m)
Colin Cross18c46802019-09-24 22:19:02 -0700601
Colin Crossa3a97412019-03-18 12:24:29 -0700602 base.generalProperties = m.GetProperties()
Pirama Arumuga Nainar955dc492018-04-17 14:58:42 -0700603 base.customizableProperties = m.GetProperties()
Paul Duffin63c6e182019-07-24 14:24:38 +0100604
605 // The default_visibility property needs to be checked and parsed by the visibility module during
606 // its checking and parsing phases.
607 base.primaryVisibilityProperty =
608 newVisibilityProperty("visibility", &base.commonProperties.Visibility)
609 base.visibilityPropertyInfo = []visibilityProperty{base.primaryVisibilityProperty}
Colin Cross5049f022015-03-18 13:28:46 -0700610}
611
Colin Cross36242852017-06-23 15:06:31 -0700612func InitAndroidArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
613 InitAndroidModule(m)
Colin Cross5049f022015-03-18 13:28:46 -0700614
615 base := m.base()
Colin Cross3f40fa42015-01-30 17:27:36 -0800616 base.commonProperties.HostOrDeviceSupported = hod
Colin Cross69617d32016-09-06 10:39:07 -0700617 base.commonProperties.Default_multilib = string(defaultMultilib)
Dan Willemsen0b24c742016-10-04 15:13:37 -0700618 base.commonProperties.ArchSpecific = true
Colin Crossee0bc3b2018-10-02 22:01:37 -0700619 base.commonProperties.UseTargetVariants = true
Colin Cross3f40fa42015-01-30 17:27:36 -0800620
Dan Willemsen218f6562015-07-08 18:13:11 -0700621 switch hod {
Nan Zhang1a0f09b2017-07-05 10:35:11 -0700622 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Cross36242852017-06-23 15:06:31 -0700623 m.AddProperties(&base.hostAndDeviceProperties)
Colin Cross3f40fa42015-01-30 17:27:36 -0800624 }
625
Colin Cross36242852017-06-23 15:06:31 -0700626 InitArchModule(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800627}
628
Colin Crossee0bc3b2018-10-02 22:01:37 -0700629func InitAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
630 InitAndroidArchModule(m, hod, defaultMultilib)
631 m.base().commonProperties.UseTargetVariants = false
632}
633
Paul Duffin1356d8c2020-02-25 19:26:33 +0000634// As InitAndroidMultiTargetsArchModule except it creates an additional CommonOS variant that
635// has dependencies on all the OsType specific variants.
636func InitCommonOSAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
637 InitAndroidArchModule(m, hod, defaultMultilib)
638 m.base().commonProperties.UseTargetVariants = false
639 m.base().commonProperties.CreateCommonOSVariant = true
640}
641
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800642// A ModuleBase object contains the properties that are common to all Android
Colin Cross3f40fa42015-01-30 17:27:36 -0800643// modules. It should be included as an anonymous field in every module
644// struct definition. InitAndroidModule should then be called from the module's
645// factory function, and the return values from InitAndroidModule should be
646// returned from the factory function.
647//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800648// The ModuleBase type is responsible for implementing the GenerateBuildActions
649// method to support the blueprint.Module interface. This method will then call
650// the module's GenerateAndroidBuildActions method once for each build variant
Colin Cross25de6c32019-06-06 14:29:25 -0700651// that is to be built. GenerateAndroidBuildActions is passed a ModuleContext
652// rather than the usual blueprint.ModuleContext.
653// ModuleContext exposes extra functionality specific to the Android build
Colin Cross3f40fa42015-01-30 17:27:36 -0800654// system including details about the particular build variant that is to be
655// generated.
656//
657// For example:
658//
659// import (
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800660// "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -0800661// )
662//
663// type myModule struct {
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800664// android.ModuleBase
Colin Cross3f40fa42015-01-30 17:27:36 -0800665// properties struct {
666// MyProperty string
667// }
668// }
669//
Colin Cross36242852017-06-23 15:06:31 -0700670// func NewMyModule() android.Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800671// m := &myModule{}
Colin Cross36242852017-06-23 15:06:31 -0700672// m.AddProperties(&m.properties)
673// android.InitAndroidModule(m)
674// return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800675// }
676//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800677// func (m *myModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800678// // Get the CPU architecture for the current build variant.
679// variantArch := ctx.Arch()
680//
681// // ...
682// }
Colin Cross635c3b02016-05-18 15:37:25 -0700683type ModuleBase struct {
Colin Cross3f40fa42015-01-30 17:27:36 -0800684 // Putting the curiously recurring thing pointing to the thing that contains
685 // the thing pattern to good use.
Colin Cross36242852017-06-23 15:06:31 -0700686 // TODO: remove this
Colin Cross635c3b02016-05-18 15:37:25 -0700687 module Module
Colin Cross3f40fa42015-01-30 17:27:36 -0800688
Colin Crossfc754582016-05-17 16:34:16 -0700689 nameProperties nameProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800690 commonProperties commonProperties
Colin Cross18c46802019-09-24 22:19:02 -0700691 variableProperties interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800692 hostAndDeviceProperties hostAndDeviceProperties
693 generalProperties []interface{}
Colin Crossc17727d2018-10-24 12:42:09 -0700694 archProperties [][]interface{}
Colin Crossa120ec12016-08-19 16:07:38 -0700695 customizableProperties []interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800696
Paul Duffin63c6e182019-07-24 14:24:38 +0100697 // Information about all the properties on the module that contains visibility rules that need
698 // checking.
699 visibilityPropertyInfo []visibilityProperty
700
701 // The primary visibility property, may be nil, that controls access to the module.
702 primaryVisibilityProperty visibilityProperty
703
Colin Cross3f40fa42015-01-30 17:27:36 -0800704 noAddressSanitizer bool
Colin Cross897266e2020-02-13 13:22:08 -0800705 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700706 checkbuildFiles Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800707 noticeFiles Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -0700708
709 // Used by buildTargetSingleton to create checkbuild and per-directory build targets
710 // Only set on the final variant of each module
Colin Cross0875c522017-11-28 17:34:01 -0800711 installTarget WritablePath
712 checkbuildTarget WritablePath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700713 blueprintDir string
Colin Crossa120ec12016-08-19 16:07:38 -0700714
Colin Cross178a5092016-09-13 13:42:32 -0700715 hooks hooks
Colin Cross36242852017-06-23 15:06:31 -0700716
717 registerProps []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700718
719 // For tests
Colin Crossae887032017-10-23 17:16:14 -0700720 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800721 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800722 variables map[string]string
Colin Crossa9d8bee2018-10-02 13:59:46 -0700723
Inseob Kim8471cda2019-11-15 09:59:12 +0900724 initRcPaths Paths
725 vintfFragmentsPaths Paths
726
Colin Crossa9d8bee2018-10-02 13:59:46 -0700727 prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool
Colin Cross36242852017-06-23 15:06:31 -0700728}
729
Colin Cross4157e882019-06-06 16:57:04 -0700730func (m *ModuleBase) DepsMutator(BottomUpMutatorContext) {}
Colin Cross5f692ec2019-02-01 16:53:07 -0800731
Colin Cross4157e882019-06-06 16:57:04 -0700732func (m *ModuleBase) AddProperties(props ...interface{}) {
733 m.registerProps = append(m.registerProps, props...)
Colin Cross36242852017-06-23 15:06:31 -0700734}
735
Colin Cross4157e882019-06-06 16:57:04 -0700736func (m *ModuleBase) GetProperties() []interface{} {
737 return m.registerProps
Colin Cross3f40fa42015-01-30 17:27:36 -0800738}
739
Colin Cross4157e882019-06-06 16:57:04 -0700740func (m *ModuleBase) BuildParamsForTests() []BuildParams {
741 return m.buildParams
Colin Crosscec81712017-07-13 14:43:27 -0700742}
743
Colin Cross4157e882019-06-06 16:57:04 -0700744func (m *ModuleBase) RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams {
745 return m.ruleParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800746}
747
Colin Cross4157e882019-06-06 16:57:04 -0700748func (m *ModuleBase) VariablesForTests() map[string]string {
749 return m.variables
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800750}
751
Colin Cross4157e882019-06-06 16:57:04 -0700752func (m *ModuleBase) Prefer32(prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool) {
753 m.prefer32 = prefer32
Colin Crossa9d8bee2018-10-02 13:59:46 -0700754}
755
Colin Crossce75d2c2016-10-06 16:12:58 -0700756// Name returns the name of the module. It may be overridden by individual module types, for
757// example prebuilts will prepend prebuilt_ to the name.
Colin Cross4157e882019-06-06 16:57:04 -0700758func (m *ModuleBase) Name() string {
759 return String(m.nameProperties.Name)
Colin Crossfc754582016-05-17 16:34:16 -0700760}
761
Colin Cross9a362232019-07-01 15:32:45 -0700762// String returns a string that includes the module name and variants for printing during debugging.
763func (m *ModuleBase) String() string {
764 sb := strings.Builder{}
765 sb.WriteString(m.commonProperties.DebugName)
766 sb.WriteString("{")
767 for i := range m.commonProperties.DebugMutators {
768 if i != 0 {
769 sb.WriteString(",")
770 }
771 sb.WriteString(m.commonProperties.DebugMutators[i])
772 sb.WriteString(":")
773 sb.WriteString(m.commonProperties.DebugVariations[i])
774 }
775 sb.WriteString("}")
776 return sb.String()
777}
778
Colin Crossce75d2c2016-10-06 16:12:58 -0700779// BaseModuleName returns the name of the module as specified in the blueprints file.
Colin Cross4157e882019-06-06 16:57:04 -0700780func (m *ModuleBase) BaseModuleName() string {
781 return String(m.nameProperties.Name)
Colin Crossce75d2c2016-10-06 16:12:58 -0700782}
783
Colin Cross4157e882019-06-06 16:57:04 -0700784func (m *ModuleBase) base() *ModuleBase {
785 return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800786}
787
Paul Duffine2453c72019-05-31 14:00:04 +0100788func (m *ModuleBase) qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName {
789 return qualifiedModuleName{pkg: ctx.ModuleDir(), name: ctx.ModuleName()}
790}
791
792func (m *ModuleBase) visibilityProperties() []visibilityProperty {
Paul Duffin63c6e182019-07-24 14:24:38 +0100793 return m.visibilityPropertyInfo
794}
795
796func (m *ModuleBase) visibility() []string {
797 // The soong_namespace module does not initialize the primaryVisibilityProperty.
798 if m.primaryVisibilityProperty != nil {
799 return m.primaryVisibilityProperty.getStrings()
800 } else {
801 return nil
Paul Duffine2453c72019-05-31 14:00:04 +0100802 }
803}
804
Colin Cross4157e882019-06-06 16:57:04 -0700805func (m *ModuleBase) Target() Target {
806 return m.commonProperties.CompileTarget
Dan Willemsen490fd492015-11-24 17:53:15 -0800807}
808
Colin Cross4157e882019-06-06 16:57:04 -0700809func (m *ModuleBase) TargetPrimary() bool {
810 return m.commonProperties.CompilePrimary
Colin Cross8b74d172016-09-13 09:59:14 -0700811}
812
Colin Cross4157e882019-06-06 16:57:04 -0700813func (m *ModuleBase) MultiTargets() []Target {
814 return m.commonProperties.CompileMultiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -0700815}
816
Colin Cross4157e882019-06-06 16:57:04 -0700817func (m *ModuleBase) Os() OsType {
818 return m.Target().Os
Dan Willemsen490fd492015-11-24 17:53:15 -0800819}
820
Colin Cross4157e882019-06-06 16:57:04 -0700821func (m *ModuleBase) Host() bool {
822 return m.Os().Class == Host || m.Os().Class == HostCross
Dan Willemsen97750522016-02-09 17:43:51 -0800823}
824
Colin Cross4157e882019-06-06 16:57:04 -0700825func (m *ModuleBase) Arch() Arch {
826 return m.Target().Arch
Dan Willemsen97750522016-02-09 17:43:51 -0800827}
828
Colin Cross4157e882019-06-06 16:57:04 -0700829func (m *ModuleBase) ArchSpecific() bool {
830 return m.commonProperties.ArchSpecific
Dan Willemsen0b24c742016-10-04 15:13:37 -0700831}
832
Paul Duffin1356d8c2020-02-25 19:26:33 +0000833// True if the current variant is a CommonOS variant, false otherwise.
834func (m *ModuleBase) IsCommonOSVariant() bool {
835 return m.commonProperties.CommonOSVariant
836}
837
Colin Cross4157e882019-06-06 16:57:04 -0700838func (m *ModuleBase) OsClassSupported() []OsClass {
839 switch m.commonProperties.HostOrDeviceSupported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700840 case HostSupported:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700841 return []OsClass{Host, HostCross}
Dan Albertc6345fb2016-10-20 01:36:11 -0700842 case HostSupportedNoCross:
843 return []OsClass{Host}
Colin Crossa1ad8d12016-06-01 17:09:44 -0700844 case DeviceSupported:
845 return []OsClass{Device}
Dan Albert0981b5c2018-08-02 13:46:35 -0700846 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700847 var supported []OsClass
Colin Cross4157e882019-06-06 16:57:04 -0700848 if Bool(m.hostAndDeviceProperties.Host_supported) ||
849 (m.commonProperties.HostOrDeviceSupported == HostAndDeviceDefault &&
850 m.hostAndDeviceProperties.Host_supported == nil) {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700851 supported = append(supported, Host, HostCross)
852 }
Colin Cross4157e882019-06-06 16:57:04 -0700853 if m.hostAndDeviceProperties.Device_supported == nil ||
854 *m.hostAndDeviceProperties.Device_supported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700855 supported = append(supported, Device)
856 }
857 return supported
858 default:
859 return nil
860 }
Colin Cross3f40fa42015-01-30 17:27:36 -0800861}
862
Colin Cross4157e882019-06-06 16:57:04 -0700863func (m *ModuleBase) DeviceSupported() bool {
864 return m.commonProperties.HostOrDeviceSupported == DeviceSupported ||
865 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
866 (m.hostAndDeviceProperties.Device_supported == nil ||
867 *m.hostAndDeviceProperties.Device_supported)
Colin Cross3f40fa42015-01-30 17:27:36 -0800868}
869
Paul Duffine44358f2019-11-26 18:04:12 +0000870func (m *ModuleBase) HostSupported() bool {
871 return m.commonProperties.HostOrDeviceSupported == HostSupported ||
872 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
873 (m.hostAndDeviceProperties.Host_supported != nil &&
874 *m.hostAndDeviceProperties.Host_supported)
875}
876
Colin Cross4157e882019-06-06 16:57:04 -0700877func (m *ModuleBase) Platform() bool {
Justin Yund5f6c822019-06-25 16:47:17 +0900878 return !m.DeviceSpecific() && !m.SocSpecific() && !m.ProductSpecific() && !m.SystemExtSpecific()
Jiyong Parkc678ad32018-04-10 13:07:10 +0900879}
880
Colin Cross4157e882019-06-06 16:57:04 -0700881func (m *ModuleBase) DeviceSpecific() bool {
882 return Bool(m.commonProperties.Device_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900883}
884
Colin Cross4157e882019-06-06 16:57:04 -0700885func (m *ModuleBase) SocSpecific() bool {
886 return Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900887}
888
Colin Cross4157e882019-06-06 16:57:04 -0700889func (m *ModuleBase) ProductSpecific() bool {
890 return Bool(m.commonProperties.Product_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900891}
892
Justin Yund5f6c822019-06-25 16:47:17 +0900893func (m *ModuleBase) SystemExtSpecific() bool {
894 return Bool(m.commonProperties.System_ext_specific)
Dario Frenifd05a742018-05-29 13:28:54 +0100895}
896
Bill Peckhamfff3f8a2020-03-20 18:33:20 -0700897func (m *ModuleBase) PartitionTag(config DeviceConfig) string {
898 partition := "system"
899 if m.SocSpecific() {
900 // A SoC-specific module could be on the vendor partition at
901 // "vendor" or the system partition at "system/vendor".
902 if config.VendorPath() == "vendor" {
903 partition = "vendor"
904 }
905 } else if m.DeviceSpecific() {
906 // A device-specific module could be on the odm partition at
907 // "odm", the vendor partition at "vendor/odm", or the system
908 // partition at "system/vendor/odm".
909 if config.OdmPath() == "odm" {
910 partition = "odm"
Ramy Medhat944839a2020-03-31 22:14:52 -0400911 } else if strings.HasPrefix(config.OdmPath(), "vendor/") {
Bill Peckhamfff3f8a2020-03-20 18:33:20 -0700912 partition = "vendor"
913 }
914 } else if m.ProductSpecific() {
915 // A product-specific module could be on the product partition
916 // at "product" or the system partition at "system/product".
917 if config.ProductPath() == "product" {
918 partition = "product"
919 }
920 } else if m.SystemExtSpecific() {
921 // A system_ext-specific module could be on the system_ext
922 // partition at "system_ext" or the system partition at
923 // "system/system_ext".
924 if config.SystemExtPath() == "system_ext" {
925 partition = "system_ext"
926 }
927 }
928 return partition
929}
930
Colin Cross4157e882019-06-06 16:57:04 -0700931func (m *ModuleBase) Enabled() bool {
932 if m.commonProperties.Enabled == nil {
933 return !m.Os().DefaultDisabled
Dan Willemsen490fd492015-11-24 17:53:15 -0800934 }
Colin Cross4157e882019-06-06 16:57:04 -0700935 return *m.commonProperties.Enabled
Colin Cross3f40fa42015-01-30 17:27:36 -0800936}
937
Inseob Kimeec88e12020-01-22 11:11:29 +0900938func (m *ModuleBase) Disable() {
939 m.commonProperties.Enabled = proptools.BoolPtr(false)
940}
941
Colin Cross4157e882019-06-06 16:57:04 -0700942func (m *ModuleBase) SkipInstall() {
943 m.commonProperties.SkipInstall = true
Colin Crossce75d2c2016-10-06 16:12:58 -0700944}
945
Colin Cross4157e882019-06-06 16:57:04 -0700946func (m *ModuleBase) ExportedToMake() bool {
947 return m.commonProperties.NamespaceExportedToMake
Jiyong Park374510b2018-03-19 18:23:01 +0900948}
949
Colin Cross897266e2020-02-13 13:22:08 -0800950func (m *ModuleBase) computeInstallDeps(ctx blueprint.ModuleContext) InstallPaths {
Colin Cross3f40fa42015-01-30 17:27:36 -0800951
Colin Cross897266e2020-02-13 13:22:08 -0800952 var result InstallPaths
Colin Cross6b753602018-06-21 13:03:07 -0700953 // TODO(ccross): we need to use WalkDeps and have some way to know which dependencies require installation
Colin Cross897266e2020-02-13 13:22:08 -0800954 ctx.VisitDepsDepthFirst(func(m blueprint.Module) {
955 if a, ok := m.(Module); ok {
956 result = append(result, a.filesToInstall()...)
957 }
958 })
Colin Cross3f40fa42015-01-30 17:27:36 -0800959
960 return result
961}
962
Colin Cross897266e2020-02-13 13:22:08 -0800963func (m *ModuleBase) filesToInstall() InstallPaths {
Colin Cross4157e882019-06-06 16:57:04 -0700964 return m.installFiles
Colin Cross3f40fa42015-01-30 17:27:36 -0800965}
966
Colin Cross4157e882019-06-06 16:57:04 -0700967func (m *ModuleBase) NoAddressSanitizer() bool {
968 return m.noAddressSanitizer
Colin Cross3f40fa42015-01-30 17:27:36 -0800969}
970
Colin Cross4157e882019-06-06 16:57:04 -0700971func (m *ModuleBase) InstallInData() bool {
Dan Willemsen782a2d12015-12-21 14:55:28 -0800972 return false
973}
974
Jaewoong Jung0949f312019-09-11 10:25:18 -0700975func (m *ModuleBase) InstallInTestcases() bool {
976 return false
977}
978
Colin Cross4157e882019-06-06 16:57:04 -0700979func (m *ModuleBase) InstallInSanitizerDir() bool {
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700980 return false
981}
982
Yifan Hong1b3348d2020-01-21 15:53:22 -0800983func (m *ModuleBase) InstallInRamdisk() bool {
984 return Bool(m.commonProperties.Ramdisk)
985}
986
Colin Cross4157e882019-06-06 16:57:04 -0700987func (m *ModuleBase) InstallInRecovery() bool {
988 return Bool(m.commonProperties.Recovery)
Jiyong Parkf9332f12018-02-01 00:54:12 +0900989}
990
Colin Cross90ba5f42019-10-02 11:10:58 -0700991func (m *ModuleBase) InstallInRoot() bool {
992 return false
993}
994
Colin Cross607d8582019-07-29 16:44:46 -0700995func (m *ModuleBase) InstallBypassMake() bool {
996 return false
997}
998
Colin Cross6e359402020-02-10 15:29:54 -0800999func (m *ModuleBase) InstallForceOS() *OsType {
1000 return nil
1001}
1002
Colin Cross4157e882019-06-06 16:57:04 -07001003func (m *ModuleBase) Owner() string {
1004 return String(m.commonProperties.Owner)
Sundong Ahn4fd04bb2018-08-31 18:01:37 +09001005}
1006
Bob Badoura75b0572020-02-18 20:21:55 -08001007func (m *ModuleBase) NoticeFiles() Paths {
1008 return m.noticeFiles
Jiyong Park52818fc2019-03-18 12:01:38 +09001009}
1010
Colin Cross7228ecd2019-11-18 16:00:16 -08001011func (m *ModuleBase) setImageVariation(variant string) {
1012 m.commonProperties.ImageVariation = variant
1013}
1014
1015func (m *ModuleBase) ImageVariation() blueprint.Variation {
1016 return blueprint.Variation{
1017 Mutator: "image",
1018 Variation: m.base().commonProperties.ImageVariation,
1019 }
1020}
1021
Paul Duffin9b76c0b2020-03-12 10:24:35 +00001022func (m *ModuleBase) getVariationByMutatorName(mutator string) string {
1023 for i, v := range m.commonProperties.DebugMutators {
1024 if v == mutator {
1025 return m.commonProperties.DebugVariations[i]
1026 }
1027 }
1028
1029 return ""
1030}
1031
Yifan Hong1b3348d2020-01-21 15:53:22 -08001032func (m *ModuleBase) InRamdisk() bool {
1033 return m.base().commonProperties.ImageVariation == RamdiskVariation
1034}
1035
Colin Cross7228ecd2019-11-18 16:00:16 -08001036func (m *ModuleBase) InRecovery() bool {
1037 return m.base().commonProperties.ImageVariation == RecoveryVariation
1038}
1039
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09001040func (m *ModuleBase) RequiredModuleNames() []string {
1041 return m.base().commonProperties.Required
1042}
1043
1044func (m *ModuleBase) HostRequiredModuleNames() []string {
1045 return m.base().commonProperties.Host_required
1046}
1047
1048func (m *ModuleBase) TargetRequiredModuleNames() []string {
1049 return m.base().commonProperties.Target_required
1050}
1051
Inseob Kim8471cda2019-11-15 09:59:12 +09001052func (m *ModuleBase) InitRc() Paths {
1053 return append(Paths{}, m.initRcPaths...)
1054}
1055
1056func (m *ModuleBase) VintfFragments() Paths {
1057 return append(Paths{}, m.vintfFragmentsPaths...)
1058}
1059
Colin Cross4157e882019-06-06 16:57:04 -07001060func (m *ModuleBase) generateModuleTarget(ctx ModuleContext) {
Colin Cross897266e2020-02-13 13:22:08 -08001061 var allInstalledFiles InstallPaths
1062 var allCheckbuildFiles Paths
Colin Cross0875c522017-11-28 17:34:01 -08001063 ctx.VisitAllModuleVariants(func(module Module) {
1064 a := module.base()
Colin Crossc9404352015-03-26 16:10:12 -07001065 allInstalledFiles = append(allInstalledFiles, a.installFiles...)
1066 allCheckbuildFiles = append(allCheckbuildFiles, a.checkbuildFiles...)
Colin Cross3f40fa42015-01-30 17:27:36 -08001067 })
1068
Colin Cross0875c522017-11-28 17:34:01 -08001069 var deps Paths
Colin Cross9454bfa2015-03-17 13:24:18 -07001070
Jeff Gaston088e29e2017-11-29 16:47:17 -08001071 namespacePrefix := ctx.Namespace().(*Namespace).id
1072 if namespacePrefix != "" {
1073 namespacePrefix = namespacePrefix + "-"
1074 }
1075
Colin Cross3f40fa42015-01-30 17:27:36 -08001076 if len(allInstalledFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -08001077 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-install")
Colin Cross0875c522017-11-28 17:34:01 -08001078 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001079 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001080 Output: name,
Colin Cross897266e2020-02-13 13:22:08 -08001081 Implicits: allInstalledFiles.Paths(),
Colin Crossaabf6792017-11-29 00:27:14 -08001082 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross9454bfa2015-03-17 13:24:18 -07001083 })
1084 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -07001085 m.installTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -07001086 }
1087
1088 if len(allCheckbuildFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -08001089 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-checkbuild")
Colin Cross0875c522017-11-28 17:34:01 -08001090 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001091 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001092 Output: name,
1093 Implicits: allCheckbuildFiles,
Colin Cross9454bfa2015-03-17 13:24:18 -07001094 })
1095 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -07001096 m.checkbuildTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -07001097 }
1098
1099 if len(deps) > 0 {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001100 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08001101 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001102 suffix = "-soong"
1103 }
1104
Jeff Gaston088e29e2017-11-29 16:47:17 -08001105 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+suffix)
Colin Cross0875c522017-11-28 17:34:01 -08001106 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -07001107 Rule: blueprint.Phony,
Jeff Gaston088e29e2017-11-29 16:47:17 -08001108 Outputs: []WritablePath{name},
Colin Cross9454bfa2015-03-17 13:24:18 -07001109 Implicits: deps,
Colin Cross3f40fa42015-01-30 17:27:36 -08001110 })
Colin Cross1f8c52b2015-06-16 16:38:17 -07001111
Colin Cross4157e882019-06-06 16:57:04 -07001112 m.blueprintDir = ctx.ModuleDir()
Colin Cross3f40fa42015-01-30 17:27:36 -08001113 }
1114}
1115
Colin Crossc34d2322020-01-03 15:23:27 -08001116func determineModuleKind(m *ModuleBase, ctx blueprint.EarlyModuleContext) moduleKind {
Colin Cross4157e882019-06-06 16:57:04 -07001117 var socSpecific = Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
1118 var deviceSpecific = Bool(m.commonProperties.Device_specific)
1119 var productSpecific = Bool(m.commonProperties.Product_specific)
Justin Yund5f6c822019-06-25 16:47:17 +09001120 var systemExtSpecific = Bool(m.commonProperties.System_ext_specific)
Jiyong Park2db76922017-11-08 16:03:48 +09001121
Dario Frenifd05a742018-05-29 13:28:54 +01001122 msg := "conflicting value set here"
1123 if socSpecific && deviceSpecific {
1124 ctx.PropertyErrorf("device_specific", "a module cannot be specific to SoC and device at the same time.")
Colin Cross4157e882019-06-06 16:57:04 -07001125 if Bool(m.commonProperties.Vendor) {
Jiyong Park2db76922017-11-08 16:03:48 +09001126 ctx.PropertyErrorf("vendor", msg)
1127 }
Colin Cross4157e882019-06-06 16:57:04 -07001128 if Bool(m.commonProperties.Proprietary) {
Jiyong Park2db76922017-11-08 16:03:48 +09001129 ctx.PropertyErrorf("proprietary", msg)
1130 }
Colin Cross4157e882019-06-06 16:57:04 -07001131 if Bool(m.commonProperties.Soc_specific) {
Jiyong Park2db76922017-11-08 16:03:48 +09001132 ctx.PropertyErrorf("soc_specific", msg)
1133 }
1134 }
1135
Justin Yund5f6c822019-06-25 16:47:17 +09001136 if productSpecific && systemExtSpecific {
1137 ctx.PropertyErrorf("product_specific", "a module cannot be specific to product and system_ext at the same time.")
1138 ctx.PropertyErrorf("system_ext_specific", msg)
Dario Frenifd05a742018-05-29 13:28:54 +01001139 }
1140
Justin Yund5f6c822019-06-25 16:47:17 +09001141 if (socSpecific || deviceSpecific) && (productSpecific || systemExtSpecific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001142 if productSpecific {
1143 ctx.PropertyErrorf("product_specific", "a module cannot be specific to SoC or device and product at the same time.")
1144 } else {
Justin Yund5f6c822019-06-25 16:47:17 +09001145 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 +01001146 }
1147 if deviceSpecific {
1148 ctx.PropertyErrorf("device_specific", msg)
1149 } else {
Colin Cross4157e882019-06-06 16:57:04 -07001150 if Bool(m.commonProperties.Vendor) {
Dario Frenifd05a742018-05-29 13:28:54 +01001151 ctx.PropertyErrorf("vendor", msg)
1152 }
Colin Cross4157e882019-06-06 16:57:04 -07001153 if Bool(m.commonProperties.Proprietary) {
Dario Frenifd05a742018-05-29 13:28:54 +01001154 ctx.PropertyErrorf("proprietary", msg)
1155 }
Colin Cross4157e882019-06-06 16:57:04 -07001156 if Bool(m.commonProperties.Soc_specific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001157 ctx.PropertyErrorf("soc_specific", msg)
1158 }
1159 }
1160 }
1161
Jiyong Park2db76922017-11-08 16:03:48 +09001162 if productSpecific {
1163 return productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +09001164 } else if systemExtSpecific {
1165 return systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001166 } else if deviceSpecific {
1167 return deviceSpecificModule
1168 } else if socSpecific {
1169 return socSpecificModule
1170 } else {
1171 return platformModule
1172 }
1173}
1174
Colin Crossc34d2322020-01-03 15:23:27 -08001175func (m *ModuleBase) earlyModuleContextFactory(ctx blueprint.EarlyModuleContext) earlyModuleContext {
Colin Cross1184b642019-12-30 18:43:07 -08001176 return earlyModuleContext{
Colin Crossc34d2322020-01-03 15:23:27 -08001177 EarlyModuleContext: ctx,
1178 kind: determineModuleKind(m, ctx),
1179 config: ctx.Config().(Config),
Colin Cross3f40fa42015-01-30 17:27:36 -08001180 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001181}
1182
Colin Cross1184b642019-12-30 18:43:07 -08001183func (m *ModuleBase) baseModuleContextFactory(ctx blueprint.BaseModuleContext) baseModuleContext {
1184 return baseModuleContext{
1185 bp: ctx,
1186 earlyModuleContext: m.earlyModuleContextFactory(ctx),
1187 os: m.commonProperties.CompileOS,
1188 target: m.commonProperties.CompileTarget,
1189 targetPrimary: m.commonProperties.CompilePrimary,
1190 multiTargets: m.commonProperties.CompileMultiTargets,
1191 }
1192}
1193
Colin Cross4157e882019-06-06 16:57:04 -07001194func (m *ModuleBase) GenerateBuildActions(blueprintCtx blueprint.ModuleContext) {
Colin Cross25de6c32019-06-06 14:29:25 -07001195 ctx := &moduleContext{
Colin Cross0ea8ba82019-06-06 14:33:29 -07001196 module: m.module,
Colin Crossdc35e212019-06-06 16:13:11 -07001197 bp: blueprintCtx,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001198 baseModuleContext: m.baseModuleContextFactory(blueprintCtx),
1199 installDeps: m.computeInstallDeps(blueprintCtx),
1200 installFiles: m.installFiles,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001201 variables: make(map[string]string),
Colin Cross3f40fa42015-01-30 17:27:36 -08001202 }
1203
Colin Cross6c4f21f2019-06-06 15:41:36 -07001204 // Temporarily continue to call blueprintCtx.GetMissingDependencies() to maintain the previous behavior of never
1205 // reporting missing dependency errors in Blueprint when AllowMissingDependencies == true.
1206 // TODO: This will be removed once defaults modules handle missing dependency errors
1207 blueprintCtx.GetMissingDependencies()
1208
Colin Crossdc35e212019-06-06 16:13:11 -07001209 // For the final GenerateAndroidBuildActions pass, require that all visited dependencies Soong modules and
Paul Duffin1356d8c2020-02-25 19:26:33 +00001210 // are enabled. Unless the module is a CommonOS variant which may have dependencies on disabled variants
1211 // (because the dependencies are added before the modules are disabled). The
1212 // GetOsSpecificVariantsOfCommonOSVariant(...) method will ensure that the disabled variants are
1213 // ignored.
1214 ctx.baseModuleContext.strictVisitDeps = !m.IsCommonOSVariant()
Colin Crossdc35e212019-06-06 16:13:11 -07001215
Colin Cross4c83e5c2019-02-25 14:54:28 -08001216 if ctx.config.captureBuild {
1217 ctx.ruleParams = make(map[blueprint.Rule]blueprint.RuleParams)
1218 }
1219
Colin Cross67a5c132017-05-09 13:45:28 -07001220 desc := "//" + ctx.ModuleDir() + ":" + ctx.ModuleName() + " "
1221 var suffix []string
Colin Cross0875c522017-11-28 17:34:01 -08001222 if ctx.Os().Class != Device && ctx.Os().Class != Generic {
1223 suffix = append(suffix, ctx.Os().String())
Colin Cross67a5c132017-05-09 13:45:28 -07001224 }
Colin Cross0875c522017-11-28 17:34:01 -08001225 if !ctx.PrimaryArch() {
1226 suffix = append(suffix, ctx.Arch().ArchType.String())
Colin Cross67a5c132017-05-09 13:45:28 -07001227 }
Dan Willemsenb13a9482020-02-14 11:25:54 -08001228 if apex, ok := m.module.(ApexModule); ok && !apex.IsForPlatform() {
1229 suffix = append(suffix, apex.ApexName())
1230 }
Colin Cross67a5c132017-05-09 13:45:28 -07001231
1232 ctx.Variable(pctx, "moduleDesc", desc)
1233
1234 s := ""
1235 if len(suffix) > 0 {
1236 s = " [" + strings.Join(suffix, " ") + "]"
1237 }
1238 ctx.Variable(pctx, "moduleDescSuffix", s)
1239
Dan Willemsen569edc52018-11-19 09:33:29 -08001240 // Some common property checks for properties that will be used later in androidmk.go
Colin Cross4157e882019-06-06 16:57:04 -07001241 if m.commonProperties.Dist.Dest != nil {
1242 _, err := validateSafePath(*m.commonProperties.Dist.Dest)
Dan Willemsen569edc52018-11-19 09:33:29 -08001243 if err != nil {
1244 ctx.PropertyErrorf("dist.dest", "%s", err.Error())
1245 }
1246 }
Colin Cross4157e882019-06-06 16:57:04 -07001247 if m.commonProperties.Dist.Dir != nil {
1248 _, err := validateSafePath(*m.commonProperties.Dist.Dir)
Dan Willemsen569edc52018-11-19 09:33:29 -08001249 if err != nil {
1250 ctx.PropertyErrorf("dist.dir", "%s", err.Error())
1251 }
1252 }
Colin Cross4157e882019-06-06 16:57:04 -07001253 if m.commonProperties.Dist.Suffix != nil {
1254 if strings.Contains(*m.commonProperties.Dist.Suffix, "/") {
Dan Willemsen569edc52018-11-19 09:33:29 -08001255 ctx.PropertyErrorf("dist.suffix", "Suffix may not contain a '/' character.")
1256 }
1257 }
1258
Colin Cross4157e882019-06-06 16:57:04 -07001259 if m.Enabled() {
Jooyung Hand48f3c32019-08-23 11:18:57 +09001260 // ensure all direct android.Module deps are enabled
1261 ctx.VisitDirectDepsBlueprint(func(bm blueprint.Module) {
1262 if _, ok := bm.(Module); ok {
1263 ctx.validateAndroidModule(bm, ctx.baseModuleContext.strictVisitDeps)
1264 }
1265 })
1266
Bob Badoura75b0572020-02-18 20:21:55 -08001267 m.noticeFiles = make([]Path, 0)
1268 optPath := OptionalPath{}
1269 notice := proptools.StringDefault(m.commonProperties.Notice, "")
Colin Cross4157e882019-06-06 16:57:04 -07001270 if module := SrcIsModule(notice); module != "" {
Bob Badoura75b0572020-02-18 20:21:55 -08001271 optPath = ctx.ExpandOptionalSource(&notice, "notice")
1272 } else if notice != "" {
Jiyong Park52818fc2019-03-18 12:01:38 +09001273 noticePath := filepath.Join(ctx.ModuleDir(), notice)
Bob Badoura75b0572020-02-18 20:21:55 -08001274 optPath = ExistentPathForSource(ctx, noticePath)
1275 }
1276 if optPath.Valid() {
1277 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1278 } else {
1279 for _, notice = range []string{"LICENSE", "LICENCE", "NOTICE"} {
1280 noticePath := filepath.Join(ctx.ModuleDir(), notice)
1281 optPath = ExistentPathForSource(ctx, noticePath)
1282 if optPath.Valid() {
1283 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1284 }
1285 }
Jaewoong Jung62707f72018-11-16 13:26:43 -08001286 }
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001287
1288 m.module.GenerateAndroidBuildActions(ctx)
1289 if ctx.Failed() {
1290 return
1291 }
1292
1293 m.installFiles = append(m.installFiles, ctx.installFiles...)
1294 m.checkbuildFiles = append(m.checkbuildFiles, ctx.checkbuildFiles...)
Inseob Kim8471cda2019-11-15 09:59:12 +09001295 m.initRcPaths = PathsForModuleSrc(ctx, m.commonProperties.Init_rc)
1296 m.vintfFragmentsPaths = PathsForModuleSrc(ctx, m.commonProperties.Vintf_fragments)
Colin Crossdc35e212019-06-06 16:13:11 -07001297 } else if ctx.Config().AllowMissingDependencies() {
1298 // If the module is not enabled it will not create any build rules, nothing will call
1299 // ctx.GetMissingDependencies(), and blueprint will consider the missing dependencies to be unhandled
1300 // and report them as an error even when AllowMissingDependencies = true. Call
1301 // ctx.GetMissingDependencies() here to tell blueprint not to handle them.
1302 ctx.GetMissingDependencies()
Colin Cross3f40fa42015-01-30 17:27:36 -08001303 }
1304
Colin Cross4157e882019-06-06 16:57:04 -07001305 if m == ctx.FinalModule().(Module).base() {
1306 m.generateModuleTarget(ctx)
Colin Cross9b1d13d2016-09-19 15:18:11 -07001307 if ctx.Failed() {
1308 return
1309 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001310 }
Colin Crosscec81712017-07-13 14:43:27 -07001311
Colin Cross4157e882019-06-06 16:57:04 -07001312 m.buildParams = ctx.buildParams
1313 m.ruleParams = ctx.ruleParams
1314 m.variables = ctx.variables
Colin Cross3f40fa42015-01-30 17:27:36 -08001315}
1316
Colin Cross1184b642019-12-30 18:43:07 -08001317type earlyModuleContext struct {
Colin Crossc34d2322020-01-03 15:23:27 -08001318 blueprint.EarlyModuleContext
Colin Cross1184b642019-12-30 18:43:07 -08001319
1320 kind moduleKind
1321 config Config
1322}
1323
1324func (e *earlyModuleContext) Glob(globPattern string, excludes []string) Paths {
1325 ret, err := e.GlobWithDeps(globPattern, excludes)
1326 if err != nil {
1327 e.ModuleErrorf("glob: %s", err.Error())
1328 }
1329 return pathsForModuleSrcFromFullPath(e, ret, true)
1330}
1331
1332func (e *earlyModuleContext) GlobFiles(globPattern string, excludes []string) Paths {
1333 ret, err := e.GlobWithDeps(globPattern, excludes)
1334 if err != nil {
1335 e.ModuleErrorf("glob: %s", err.Error())
1336 }
1337 return pathsForModuleSrcFromFullPath(e, ret, false)
1338}
1339
Colin Cross988414c2020-01-11 01:11:46 +00001340func (b *earlyModuleContext) IsSymlink(path Path) bool {
1341 fileInfo, err := b.config.fs.Lstat(path.String())
1342 if err != nil {
1343 b.ModuleErrorf("os.Lstat(%q) failed: %s", path.String(), err)
1344 }
1345 return fileInfo.Mode()&os.ModeSymlink == os.ModeSymlink
1346}
1347
1348func (b *earlyModuleContext) Readlink(path Path) string {
1349 dest, err := b.config.fs.Readlink(path.String())
1350 if err != nil {
1351 b.ModuleErrorf("os.Readlink(%q) failed: %s", path.String(), err)
1352 }
1353 return dest
1354}
1355
Colin Cross1184b642019-12-30 18:43:07 -08001356func (e *earlyModuleContext) Module() Module {
Colin Crossc34d2322020-01-03 15:23:27 -08001357 module, _ := e.EarlyModuleContext.Module().(Module)
Colin Cross1184b642019-12-30 18:43:07 -08001358 return module
1359}
1360
1361func (e *earlyModuleContext) Config() Config {
Colin Crossc34d2322020-01-03 15:23:27 -08001362 return e.EarlyModuleContext.Config().(Config)
Colin Cross1184b642019-12-30 18:43:07 -08001363}
1364
1365func (e *earlyModuleContext) AConfig() Config {
1366 return e.config
1367}
1368
1369func (e *earlyModuleContext) DeviceConfig() DeviceConfig {
1370 return DeviceConfig{e.config.deviceConfig}
1371}
1372
1373func (e *earlyModuleContext) Platform() bool {
1374 return e.kind == platformModule
1375}
1376
1377func (e *earlyModuleContext) DeviceSpecific() bool {
1378 return e.kind == deviceSpecificModule
1379}
1380
1381func (e *earlyModuleContext) SocSpecific() bool {
1382 return e.kind == socSpecificModule
1383}
1384
1385func (e *earlyModuleContext) ProductSpecific() bool {
1386 return e.kind == productSpecificModule
1387}
1388
1389func (e *earlyModuleContext) SystemExtSpecific() bool {
1390 return e.kind == systemExtSpecificModule
1391}
1392
1393type baseModuleContext struct {
1394 bp blueprint.BaseModuleContext
1395 earlyModuleContext
Colin Crossfb0c16e2019-11-20 17:12:35 -08001396 os OsType
Colin Cross8b74d172016-09-13 09:59:14 -07001397 target Target
Colin Crossee0bc3b2018-10-02 22:01:37 -07001398 multiTargets []Target
Colin Cross8b74d172016-09-13 09:59:14 -07001399 targetPrimary bool
1400 debug bool
Colin Crossdc35e212019-06-06 16:13:11 -07001401
1402 walkPath []Module
1403
1404 strictVisitDeps bool // If true, enforce that all dependencies are enabled
Colin Crossf6566ed2015-03-24 11:13:38 -07001405}
1406
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001407func (b *baseModuleContext) OtherModuleName(m blueprint.Module) string {
1408 return b.bp.OtherModuleName(m)
1409}
1410func (b *baseModuleContext) OtherModuleDir(m blueprint.Module) string { return b.bp.OtherModuleDir(m) }
Colin Cross1184b642019-12-30 18:43:07 -08001411func (b *baseModuleContext) OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{}) {
Jooyung Hancd87c692020-02-26 02:05:18 +09001412 b.bp.OtherModuleErrorf(m, fmt, args...)
Colin Cross1184b642019-12-30 18:43:07 -08001413}
1414func (b *baseModuleContext) OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag {
1415 return b.bp.OtherModuleDependencyTag(m)
1416}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001417func (b *baseModuleContext) OtherModuleExists(name string) bool { return b.bp.OtherModuleExists(name) }
1418func (b *baseModuleContext) OtherModuleType(m blueprint.Module) string {
1419 return b.bp.OtherModuleType(m)
1420}
Colin Cross1184b642019-12-30 18:43:07 -08001421
1422func (b *baseModuleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1423 return b.bp.GetDirectDepWithTag(name, tag)
1424}
1425
Colin Cross25de6c32019-06-06 14:29:25 -07001426type moduleContext struct {
Colin Crossdc35e212019-06-06 16:13:11 -07001427 bp blueprint.ModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -07001428 baseModuleContext
Colin Cross897266e2020-02-13 13:22:08 -08001429 installDeps InstallPaths
1430 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001431 checkbuildFiles Paths
Colin Cross8d8f8e22016-08-03 11:57:50 -07001432 module Module
Colin Crosscec81712017-07-13 14:43:27 -07001433
1434 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001435 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001436 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001437 variables map[string]string
Colin Cross6ff51382015-12-17 16:39:19 -08001438}
1439
Colin Crossb88b3c52019-06-10 15:15:17 -07001440func (m *moduleContext) ninjaError(params BuildParams, err error) (PackageContext, BuildParams) {
1441 return pctx, BuildParams{
Colin Cross4b69c492019-06-07 13:06:06 -07001442 Rule: ErrorRule,
1443 Description: params.Description,
1444 Output: params.Output,
1445 Outputs: params.Outputs,
1446 ImplicitOutput: params.ImplicitOutput,
1447 ImplicitOutputs: params.ImplicitOutputs,
Colin Cross6ff51382015-12-17 16:39:19 -08001448 Args: map[string]string{
1449 "error": err.Error(),
1450 },
Colin Crossb88b3c52019-06-10 15:15:17 -07001451 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001452}
1453
Colin Cross25de6c32019-06-06 14:29:25 -07001454func (m *moduleContext) ModuleBuild(pctx PackageContext, params ModuleBuildParams) {
1455 m.Build(pctx, BuildParams(params))
Colin Cross3f40fa42015-01-30 17:27:36 -08001456}
1457
Colin Cross0875c522017-11-28 17:34:01 -08001458func convertBuildParams(params BuildParams) blueprint.BuildParams {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001459 bparams := blueprint.BuildParams{
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001460 Rule: params.Rule,
Colin Cross0875c522017-11-28 17:34:01 -08001461 Description: params.Description,
Colin Cross33bfb0a2016-11-21 17:23:08 -08001462 Deps: params.Deps,
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001463 Outputs: params.Outputs.Strings(),
1464 ImplicitOutputs: params.ImplicitOutputs.Strings(),
1465 Inputs: params.Inputs.Strings(),
1466 Implicits: params.Implicits.Strings(),
1467 OrderOnly: params.OrderOnly.Strings(),
1468 Args: params.Args,
1469 Optional: !params.Default,
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001470 }
1471
Colin Cross33bfb0a2016-11-21 17:23:08 -08001472 if params.Depfile != nil {
1473 bparams.Depfile = params.Depfile.String()
1474 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001475 if params.Output != nil {
1476 bparams.Outputs = append(bparams.Outputs, params.Output.String())
1477 }
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001478 if params.ImplicitOutput != nil {
1479 bparams.ImplicitOutputs = append(bparams.ImplicitOutputs, params.ImplicitOutput.String())
1480 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001481 if params.Input != nil {
1482 bparams.Inputs = append(bparams.Inputs, params.Input.String())
1483 }
1484 if params.Implicit != nil {
1485 bparams.Implicits = append(bparams.Implicits, params.Implicit.String())
1486 }
1487
Colin Cross0b9f31f2019-02-28 11:00:01 -08001488 bparams.Outputs = proptools.NinjaEscapeList(bparams.Outputs)
1489 bparams.ImplicitOutputs = proptools.NinjaEscapeList(bparams.ImplicitOutputs)
1490 bparams.Inputs = proptools.NinjaEscapeList(bparams.Inputs)
1491 bparams.Implicits = proptools.NinjaEscapeList(bparams.Implicits)
1492 bparams.OrderOnly = proptools.NinjaEscapeList(bparams.OrderOnly)
1493 bparams.Depfile = proptools.NinjaEscapeList([]string{bparams.Depfile})[0]
Colin Crossfe4bc362018-09-12 10:02:13 -07001494
Colin Cross0875c522017-11-28 17:34:01 -08001495 return bparams
1496}
1497
Colin Cross25de6c32019-06-06 14:29:25 -07001498func (m *moduleContext) Variable(pctx PackageContext, name, value string) {
1499 if m.config.captureBuild {
1500 m.variables[name] = value
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001501 }
1502
Colin Crossdc35e212019-06-06 16:13:11 -07001503 m.bp.Variable(pctx.PackageContext, name, value)
Colin Cross0875c522017-11-28 17:34:01 -08001504}
1505
Colin Cross25de6c32019-06-06 14:29:25 -07001506func (m *moduleContext) Rule(pctx PackageContext, name string, params blueprint.RuleParams,
Colin Cross0875c522017-11-28 17:34:01 -08001507 argNames ...string) blueprint.Rule {
1508
Ramy Medhat944839a2020-03-31 22:14:52 -04001509 if m.config.UseRemoteBuild() {
1510 if params.Pool == nil {
1511 // When USE_GOMA=true or USE_RBE=true are set and the rule is not supported by goma/RBE, restrict
1512 // jobs to the local parallelism value
1513 params.Pool = localPool
1514 } else if params.Pool == remotePool {
1515 // remotePool is a fake pool used to identify rule that are supported for remoting. If the rule's
1516 // pool is the remotePool, replace with nil so that ninja runs it at NINJA_REMOTE_NUM_JOBS
1517 // parallelism.
1518 params.Pool = nil
1519 }
Colin Cross2e2dbc22019-09-25 13:31:46 -07001520 }
1521
Colin Crossdc35e212019-06-06 16:13:11 -07001522 rule := m.bp.Rule(pctx.PackageContext, name, params, argNames...)
Colin Cross4c83e5c2019-02-25 14:54:28 -08001523
Colin Cross25de6c32019-06-06 14:29:25 -07001524 if m.config.captureBuild {
1525 m.ruleParams[rule] = params
Colin Cross4c83e5c2019-02-25 14:54:28 -08001526 }
1527
1528 return rule
Colin Cross0875c522017-11-28 17:34:01 -08001529}
1530
Colin Cross25de6c32019-06-06 14:29:25 -07001531func (m *moduleContext) Build(pctx PackageContext, params BuildParams) {
Colin Crossb88b3c52019-06-10 15:15:17 -07001532 if params.Description != "" {
1533 params.Description = "${moduleDesc}" + params.Description + "${moduleDescSuffix}"
1534 }
1535
1536 if missingDeps := m.GetMissingDependencies(); len(missingDeps) > 0 {
1537 pctx, params = m.ninjaError(params, fmt.Errorf("module %s missing dependencies: %s\n",
1538 m.ModuleName(), strings.Join(missingDeps, ", ")))
1539 }
1540
Colin Cross25de6c32019-06-06 14:29:25 -07001541 if m.config.captureBuild {
1542 m.buildParams = append(m.buildParams, params)
Colin Cross0875c522017-11-28 17:34:01 -08001543 }
1544
Colin Crossdc35e212019-06-06 16:13:11 -07001545 m.bp.Build(pctx.PackageContext, convertBuildParams(params))
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001546}
Colin Cross25de6c32019-06-06 14:29:25 -07001547func (m *moduleContext) GetMissingDependencies() []string {
Colin Cross6c4f21f2019-06-06 15:41:36 -07001548 var missingDeps []string
1549 missingDeps = append(missingDeps, m.Module().base().commonProperties.MissingDeps...)
Colin Crossdc35e212019-06-06 16:13:11 -07001550 missingDeps = append(missingDeps, m.bp.GetMissingDependencies()...)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001551 missingDeps = FirstUniqueStrings(missingDeps)
1552 return missingDeps
Colin Cross6ff51382015-12-17 16:39:19 -08001553}
1554
Colin Crossdc35e212019-06-06 16:13:11 -07001555func (b *baseModuleContext) AddMissingDependencies(deps []string) {
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001556 if deps != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001557 missingDeps := &b.Module().base().commonProperties.MissingDeps
Colin Cross6c4f21f2019-06-06 15:41:36 -07001558 *missingDeps = append(*missingDeps, deps...)
1559 *missingDeps = FirstUniqueStrings(*missingDeps)
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001560 }
1561}
1562
Colin Crossdc35e212019-06-06 16:13:11 -07001563func (b *baseModuleContext) validateAndroidModule(module blueprint.Module, strict bool) Module {
Colin Crossd11fcda2017-10-23 17:59:01 -07001564 aModule, _ := module.(Module)
Colin Crossdc35e212019-06-06 16:13:11 -07001565
1566 if !strict {
1567 return aModule
1568 }
1569
Colin Cross380c69a2019-06-10 17:49:58 +00001570 if aModule == nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001571 b.ModuleErrorf("module %q not an android module", b.OtherModuleName(module))
Colin Cross380c69a2019-06-10 17:49:58 +00001572 return nil
1573 }
1574
1575 if !aModule.Enabled() {
Colin Crossdc35e212019-06-06 16:13:11 -07001576 if b.Config().AllowMissingDependencies() {
1577 b.AddMissingDependencies([]string{b.OtherModuleName(aModule)})
Colin Cross380c69a2019-06-10 17:49:58 +00001578 } else {
Colin Crossdc35e212019-06-06 16:13:11 -07001579 b.ModuleErrorf("depends on disabled module %q", b.OtherModuleName(aModule))
Colin Cross380c69a2019-06-10 17:49:58 +00001580 }
1581 return nil
1582 }
Colin Crossd11fcda2017-10-23 17:59:01 -07001583 return aModule
1584}
1585
Colin Crossdc35e212019-06-06 16:13:11 -07001586func (b *baseModuleContext) getDirectDepInternal(name string, tag blueprint.DependencyTag) (blueprint.Module, blueprint.DependencyTag) {
Jiyong Parkf2976302019-04-17 21:47:37 +09001587 type dep struct {
1588 mod blueprint.Module
1589 tag blueprint.DependencyTag
1590 }
1591 var deps []dep
Colin Crossdc35e212019-06-06 16:13:11 -07001592 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001593 if aModule, _ := module.(Module); aModule != nil && aModule.base().BaseModuleName() == name {
Colin Cross1184b642019-12-30 18:43:07 -08001594 returnedTag := b.bp.OtherModuleDependencyTag(aModule)
Jiyong Parkf2976302019-04-17 21:47:37 +09001595 if tag == nil || returnedTag == tag {
1596 deps = append(deps, dep{aModule, returnedTag})
1597 }
1598 }
1599 })
1600 if len(deps) == 1 {
1601 return deps[0].mod, deps[0].tag
1602 } else if len(deps) >= 2 {
1603 panic(fmt.Errorf("Multiple dependencies having same BaseModuleName() %q found from %q",
Colin Crossdc35e212019-06-06 16:13:11 -07001604 name, b.ModuleName()))
Jiyong Parkf2976302019-04-17 21:47:37 +09001605 } else {
1606 return nil, nil
1607 }
1608}
1609
Colin Crossdc35e212019-06-06 16:13:11 -07001610func (b *baseModuleContext) GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module {
Colin Cross0ef08162019-05-01 15:50:51 -07001611 var deps []Module
Colin Crossdc35e212019-06-06 16:13:11 -07001612 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001613 if aModule, _ := module.(Module); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001614 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Cross0ef08162019-05-01 15:50:51 -07001615 deps = append(deps, aModule)
1616 }
1617 }
1618 })
1619 return deps
1620}
1621
Colin Cross25de6c32019-06-06 14:29:25 -07001622func (m *moduleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1623 module, _ := m.getDirectDepInternal(name, tag)
1624 return module
Jiyong Parkf2976302019-04-17 21:47:37 +09001625}
1626
Colin Crossdc35e212019-06-06 16:13:11 -07001627func (b *baseModuleContext) GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag) {
1628 return b.getDirectDepInternal(name, nil)
Jiyong Parkf2976302019-04-17 21:47:37 +09001629}
1630
Colin Crossdc35e212019-06-06 16:13:11 -07001631func (b *baseModuleContext) VisitDirectDepsBlueprint(visit func(blueprint.Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001632 b.bp.VisitDirectDeps(visit)
Colin Cross35143d02017-11-16 00:11:20 -08001633}
1634
Colin Crossdc35e212019-06-06 16:13:11 -07001635func (b *baseModuleContext) VisitDirectDeps(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001636 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001637 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001638 visit(aModule)
1639 }
1640 })
1641}
1642
Colin Crossdc35e212019-06-06 16:13:11 -07001643func (b *baseModuleContext) VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001644 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001645 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001646 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Crossee6143c2017-12-30 17:54:27 -08001647 visit(aModule)
1648 }
1649 }
1650 })
1651}
1652
Colin Crossdc35e212019-06-06 16:13:11 -07001653func (b *baseModuleContext) VisitDirectDepsIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001654 b.bp.VisitDirectDepsIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001655 // pred
1656 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001657 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001658 return pred(aModule)
1659 } else {
1660 return false
1661 }
1662 },
1663 // visit
1664 func(module blueprint.Module) {
1665 visit(module.(Module))
1666 })
1667}
1668
Colin Crossdc35e212019-06-06 16:13:11 -07001669func (b *baseModuleContext) VisitDepsDepthFirst(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001670 b.bp.VisitDepsDepthFirst(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001671 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001672 visit(aModule)
1673 }
1674 })
1675}
1676
Colin Crossdc35e212019-06-06 16:13:11 -07001677func (b *baseModuleContext) VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001678 b.bp.VisitDepsDepthFirstIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001679 // pred
1680 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001681 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001682 return pred(aModule)
1683 } else {
1684 return false
1685 }
1686 },
1687 // visit
1688 func(module blueprint.Module) {
1689 visit(module.(Module))
1690 })
1691}
1692
Colin Crossdc35e212019-06-06 16:13:11 -07001693func (b *baseModuleContext) WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool) {
Colin Cross1184b642019-12-30 18:43:07 -08001694 b.bp.WalkDeps(visit)
Alex Light778127a2019-02-27 14:19:50 -08001695}
1696
Colin Crossdc35e212019-06-06 16:13:11 -07001697func (b *baseModuleContext) WalkDeps(visit func(Module, Module) bool) {
1698 b.walkPath = []Module{b.Module()}
Colin Cross1184b642019-12-30 18:43:07 -08001699 b.bp.WalkDeps(func(child, parent blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001700 childAndroidModule, _ := child.(Module)
1701 parentAndroidModule, _ := parent.(Module)
Colin Crossd11fcda2017-10-23 17:59:01 -07001702 if childAndroidModule != nil && parentAndroidModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001703 // record walkPath before visit
1704 for b.walkPath[len(b.walkPath)-1] != parentAndroidModule {
1705 b.walkPath = b.walkPath[0 : len(b.walkPath)-1]
1706 }
1707 b.walkPath = append(b.walkPath, childAndroidModule)
Colin Crossd11fcda2017-10-23 17:59:01 -07001708 return visit(childAndroidModule, parentAndroidModule)
1709 } else {
1710 return false
1711 }
1712 })
1713}
1714
Colin Crossdc35e212019-06-06 16:13:11 -07001715func (b *baseModuleContext) GetWalkPath() []Module {
1716 return b.walkPath
1717}
1718
Colin Cross25de6c32019-06-06 14:29:25 -07001719func (m *moduleContext) VisitAllModuleVariants(visit func(Module)) {
Colin Crossdc35e212019-06-06 16:13:11 -07001720 m.bp.VisitAllModuleVariants(func(module blueprint.Module) {
Colin Cross0875c522017-11-28 17:34:01 -08001721 visit(module.(Module))
1722 })
1723}
1724
Colin Cross25de6c32019-06-06 14:29:25 -07001725func (m *moduleContext) PrimaryModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001726 return m.bp.PrimaryModule().(Module)
Colin Cross0875c522017-11-28 17:34:01 -08001727}
1728
Colin Cross25de6c32019-06-06 14:29:25 -07001729func (m *moduleContext) FinalModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001730 return m.bp.FinalModule().(Module)
1731}
1732
1733func (m *moduleContext) ModuleSubDir() string {
1734 return m.bp.ModuleSubDir()
Colin Cross0875c522017-11-28 17:34:01 -08001735}
1736
Colin Cross0ea8ba82019-06-06 14:33:29 -07001737func (b *baseModuleContext) Target() Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001738 return b.target
Colin Crossa1ad8d12016-06-01 17:09:44 -07001739}
1740
Colin Cross0ea8ba82019-06-06 14:33:29 -07001741func (b *baseModuleContext) TargetPrimary() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001742 return b.targetPrimary
Colin Cross8b74d172016-09-13 09:59:14 -07001743}
1744
Colin Cross0ea8ba82019-06-06 14:33:29 -07001745func (b *baseModuleContext) MultiTargets() []Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001746 return b.multiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07001747}
1748
Colin Cross0ea8ba82019-06-06 14:33:29 -07001749func (b *baseModuleContext) Arch() Arch {
Colin Cross25de6c32019-06-06 14:29:25 -07001750 return b.target.Arch
Colin Cross3f40fa42015-01-30 17:27:36 -08001751}
1752
Colin Cross0ea8ba82019-06-06 14:33:29 -07001753func (b *baseModuleContext) Os() OsType {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001754 return b.os
Dan Willemsen490fd492015-11-24 17:53:15 -08001755}
1756
Colin Cross0ea8ba82019-06-06 14:33:29 -07001757func (b *baseModuleContext) Host() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001758 return b.os.Class == Host || b.os.Class == HostCross
Colin Crossf6566ed2015-03-24 11:13:38 -07001759}
1760
Colin Cross0ea8ba82019-06-06 14:33:29 -07001761func (b *baseModuleContext) Device() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001762 return b.os.Class == Device
Colin Crossf6566ed2015-03-24 11:13:38 -07001763}
1764
Colin Cross0ea8ba82019-06-06 14:33:29 -07001765func (b *baseModuleContext) Darwin() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001766 return b.os == Darwin
Colin Cross0af4b842015-04-30 16:36:18 -07001767}
1768
Colin Cross0ea8ba82019-06-06 14:33:29 -07001769func (b *baseModuleContext) Fuchsia() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001770 return b.os == Fuchsia
Doug Horn21b94272019-01-16 12:06:11 -08001771}
1772
Colin Cross0ea8ba82019-06-06 14:33:29 -07001773func (b *baseModuleContext) Windows() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001774 return b.os == Windows
Colin Cross3edeee12017-04-04 12:59:48 -07001775}
1776
Colin Cross0ea8ba82019-06-06 14:33:29 -07001777func (b *baseModuleContext) Debug() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001778 return b.debug
Colin Crossf6566ed2015-03-24 11:13:38 -07001779}
1780
Colin Cross0ea8ba82019-06-06 14:33:29 -07001781func (b *baseModuleContext) PrimaryArch() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001782 if len(b.config.Targets[b.target.Os]) <= 1 {
Colin Cross67a5c132017-05-09 13:45:28 -07001783 return true
1784 }
Colin Cross25de6c32019-06-06 14:29:25 -07001785 return b.target.Arch.ArchType == b.config.Targets[b.target.Os][0].Arch.ArchType
Colin Cross1e7d3702016-08-24 15:25:47 -07001786}
1787
Jiyong Park5baac542018-08-28 09:55:37 +09001788// Makes this module a platform module, i.e. not specific to soc, device,
Justin Yund5f6c822019-06-25 16:47:17 +09001789// product, or system_ext.
Colin Cross4157e882019-06-06 16:57:04 -07001790func (m *ModuleBase) MakeAsPlatform() {
1791 m.commonProperties.Vendor = boolPtr(false)
1792 m.commonProperties.Proprietary = boolPtr(false)
1793 m.commonProperties.Soc_specific = boolPtr(false)
1794 m.commonProperties.Product_specific = boolPtr(false)
Justin Yund5f6c822019-06-25 16:47:17 +09001795 m.commonProperties.System_ext_specific = boolPtr(false)
Jiyong Park5baac542018-08-28 09:55:37 +09001796}
1797
Colin Cross4157e882019-06-06 16:57:04 -07001798func (m *ModuleBase) EnableNativeBridgeSupportByDefault() {
1799 m.commonProperties.Native_bridge_supported = boolPtr(true)
dimitry03dc3f62019-05-09 14:07:34 +02001800}
1801
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001802func (m *ModuleBase) MakeAsSystemExt() {
Jooyung Han91df2082019-11-20 01:49:42 +09001803 m.commonProperties.Vendor = boolPtr(false)
1804 m.commonProperties.Proprietary = boolPtr(false)
1805 m.commonProperties.Soc_specific = boolPtr(false)
1806 m.commonProperties.Product_specific = boolPtr(false)
1807 m.commonProperties.System_ext_specific = boolPtr(true)
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001808}
1809
Jooyung Han344d5432019-08-23 11:17:39 +09001810// IsNativeBridgeSupported returns true if "native_bridge_supported" is explicitly set as "true"
1811func (m *ModuleBase) IsNativeBridgeSupported() bool {
1812 return proptools.Bool(m.commonProperties.Native_bridge_supported)
1813}
1814
Colin Cross25de6c32019-06-06 14:29:25 -07001815func (m *moduleContext) InstallInData() bool {
1816 return m.module.InstallInData()
Dan Willemsen782a2d12015-12-21 14:55:28 -08001817}
1818
Jaewoong Jung0949f312019-09-11 10:25:18 -07001819func (m *moduleContext) InstallInTestcases() bool {
1820 return m.module.InstallInTestcases()
1821}
1822
Colin Cross25de6c32019-06-06 14:29:25 -07001823func (m *moduleContext) InstallInSanitizerDir() bool {
1824 return m.module.InstallInSanitizerDir()
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001825}
1826
Yifan Hong1b3348d2020-01-21 15:53:22 -08001827func (m *moduleContext) InstallInRamdisk() bool {
1828 return m.module.InstallInRamdisk()
1829}
1830
Colin Cross25de6c32019-06-06 14:29:25 -07001831func (m *moduleContext) InstallInRecovery() bool {
1832 return m.module.InstallInRecovery()
Jiyong Parkf9332f12018-02-01 00:54:12 +09001833}
1834
Colin Cross90ba5f42019-10-02 11:10:58 -07001835func (m *moduleContext) InstallInRoot() bool {
1836 return m.module.InstallInRoot()
1837}
1838
Colin Cross607d8582019-07-29 16:44:46 -07001839func (m *moduleContext) InstallBypassMake() bool {
1840 return m.module.InstallBypassMake()
1841}
1842
Colin Cross6e359402020-02-10 15:29:54 -08001843func (m *moduleContext) InstallForceOS() *OsType {
1844 return m.module.InstallForceOS()
1845}
1846
Colin Cross70dda7e2019-10-01 22:05:35 -07001847func (m *moduleContext) skipInstall(fullInstallPath InstallPath) bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001848 if m.module.base().commonProperties.SkipInstall {
Colin Cross893d8162017-04-26 17:34:03 -07001849 return true
1850 }
1851
Colin Cross3607f212018-05-07 15:28:05 -07001852 // We'll need a solution for choosing which of modules with the same name in different
1853 // namespaces to install. For now, reuse the list of namespaces exported to Make as the
1854 // list of namespaces to install in a Soong-only build.
Colin Cross25de6c32019-06-06 14:29:25 -07001855 if !m.module.base().commonProperties.NamespaceExportedToMake {
Colin Cross3607f212018-05-07 15:28:05 -07001856 return true
1857 }
1858
Colin Cross25de6c32019-06-06 14:29:25 -07001859 if m.Device() {
Colin Cross607d8582019-07-29 16:44:46 -07001860 if m.Config().EmbeddedInMake() && !m.InstallBypassMake() {
Colin Cross893d8162017-04-26 17:34:03 -07001861 return true
1862 }
1863
Colin Cross25de6c32019-06-06 14:29:25 -07001864 if m.Config().SkipMegaDeviceInstall(fullInstallPath.String()) {
Colin Cross893d8162017-04-26 17:34:03 -07001865 return true
1866 }
1867 }
1868
1869 return false
1870}
1871
Colin Cross70dda7e2019-10-01 22:05:35 -07001872func (m *moduleContext) InstallFile(installPath InstallPath, name string, srcPath Path,
1873 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001874 return m.installFile(installPath, name, srcPath, Cp, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001875}
1876
Colin Cross70dda7e2019-10-01 22:05:35 -07001877func (m *moduleContext) InstallExecutable(installPath InstallPath, name string, srcPath Path,
1878 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001879 return m.installFile(installPath, name, srcPath, CpExecutable, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001880}
1881
Colin Cross70dda7e2019-10-01 22:05:35 -07001882func (m *moduleContext) installFile(installPath InstallPath, name string, srcPath Path,
1883 rule blueprint.Rule, deps []Path) InstallPath {
Colin Cross35cec122015-04-02 14:37:16 -07001884
Colin Cross25de6c32019-06-06 14:29:25 -07001885 fullInstallPath := installPath.Join(m, name)
1886 m.module.base().hooks.runInstallHooks(m, fullInstallPath, false)
Colin Cross3f40fa42015-01-30 17:27:36 -08001887
Colin Cross25de6c32019-06-06 14:29:25 -07001888 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001889
Colin Cross897266e2020-02-13 13:22:08 -08001890 deps = append(deps, m.installDeps.Paths()...)
Colin Cross35cec122015-04-02 14:37:16 -07001891
Colin Cross89562dc2016-10-03 17:47:19 -07001892 var implicitDeps, orderOnlyDeps Paths
1893
Colin Cross25de6c32019-06-06 14:29:25 -07001894 if m.Host() {
Colin Cross89562dc2016-10-03 17:47:19 -07001895 // Installed host modules might be used during the build, depend directly on their
1896 // dependencies so their timestamp is updated whenever their dependency is updated
1897 implicitDeps = deps
1898 } else {
1899 orderOnlyDeps = deps
1900 }
1901
Colin Cross25de6c32019-06-06 14:29:25 -07001902 m.Build(pctx, BuildParams{
Colin Cross5c517922017-08-31 12:29:17 -07001903 Rule: rule,
Colin Cross67a5c132017-05-09 13:45:28 -07001904 Description: "install " + fullInstallPath.Base(),
1905 Output: fullInstallPath,
1906 Input: srcPath,
1907 Implicits: implicitDeps,
1908 OrderOnly: orderOnlyDeps,
Colin Cross25de6c32019-06-06 14:29:25 -07001909 Default: !m.Config().EmbeddedInMake(),
Dan Willemsen322acaf2016-01-12 23:07:05 -08001910 })
Colin Cross3f40fa42015-01-30 17:27:36 -08001911
Colin Cross25de6c32019-06-06 14:29:25 -07001912 m.installFiles = append(m.installFiles, fullInstallPath)
Dan Willemsen322acaf2016-01-12 23:07:05 -08001913 }
Colin Cross25de6c32019-06-06 14:29:25 -07001914 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross35cec122015-04-02 14:37:16 -07001915 return fullInstallPath
1916}
1917
Colin Cross70dda7e2019-10-01 22:05:35 -07001918func (m *moduleContext) InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001919 fullInstallPath := installPath.Join(m, name)
1920 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Colin Cross3854a602016-01-11 12:49:11 -08001921
Colin Cross25de6c32019-06-06 14:29:25 -07001922 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001923
Alex Lightfb4353d2019-01-17 13:57:45 -08001924 relPath, err := filepath.Rel(path.Dir(fullInstallPath.String()), srcPath.String())
1925 if err != nil {
1926 panic(fmt.Sprintf("Unable to generate symlink between %q and %q: %s", fullInstallPath.Base(), srcPath.Base(), err))
1927 }
Colin Cross25de6c32019-06-06 14:29:25 -07001928 m.Build(pctx, BuildParams{
Colin Cross67a5c132017-05-09 13:45:28 -07001929 Rule: Symlink,
1930 Description: "install symlink " + fullInstallPath.Base(),
1931 Output: fullInstallPath,
Dan Willemsen40efa1c2020-01-14 15:19:52 -08001932 Input: srcPath,
Colin Cross25de6c32019-06-06 14:29:25 -07001933 Default: !m.Config().EmbeddedInMake(),
Colin Cross12fc4972016-01-11 12:49:11 -08001934 Args: map[string]string{
Alex Lightfb4353d2019-01-17 13:57:45 -08001935 "fromPath": relPath,
Colin Cross12fc4972016-01-11 12:49:11 -08001936 },
1937 })
Colin Cross3854a602016-01-11 12:49:11 -08001938
Colin Cross25de6c32019-06-06 14:29:25 -07001939 m.installFiles = append(m.installFiles, fullInstallPath)
1940 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross12fc4972016-01-11 12:49:11 -08001941 }
Colin Cross3854a602016-01-11 12:49:11 -08001942 return fullInstallPath
1943}
1944
Jiyong Parkf1194352019-02-25 11:05:47 +09001945// installPath/name -> absPath where absPath might be a path that is available only at runtime
1946// (e.g. /apex/...)
Colin Cross70dda7e2019-10-01 22:05:35 -07001947func (m *moduleContext) InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001948 fullInstallPath := installPath.Join(m, name)
1949 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Jiyong Parkf1194352019-02-25 11:05:47 +09001950
Colin Cross25de6c32019-06-06 14:29:25 -07001951 if !m.skipInstall(fullInstallPath) {
1952 m.Build(pctx, BuildParams{
Jiyong Parkf1194352019-02-25 11:05:47 +09001953 Rule: Symlink,
1954 Description: "install symlink " + fullInstallPath.Base() + " -> " + absPath,
1955 Output: fullInstallPath,
Colin Cross25de6c32019-06-06 14:29:25 -07001956 Default: !m.Config().EmbeddedInMake(),
Jiyong Parkf1194352019-02-25 11:05:47 +09001957 Args: map[string]string{
1958 "fromPath": absPath,
1959 },
1960 })
1961
Colin Cross25de6c32019-06-06 14:29:25 -07001962 m.installFiles = append(m.installFiles, fullInstallPath)
Jiyong Parkf1194352019-02-25 11:05:47 +09001963 }
1964 return fullInstallPath
1965}
1966
Colin Cross25de6c32019-06-06 14:29:25 -07001967func (m *moduleContext) CheckbuildFile(srcPath Path) {
1968 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross3f40fa42015-01-30 17:27:36 -08001969}
1970
Dan Willemsen2ef08f42015-06-30 18:15:24 -07001971func findStringInSlice(str string, slice []string) int {
1972 for i, s := range slice {
1973 if s == str {
1974 return i
Colin Crossfce53272015-04-08 11:21:40 -07001975 }
1976 }
Dan Willemsen2ef08f42015-06-30 18:15:24 -07001977 return -1
1978}
1979
Colin Cross41955e82019-05-29 14:40:35 -07001980// SrcIsModule decodes module references in the format ":name" into the module name, or empty string if the input
1981// was not a module reference.
1982func SrcIsModule(s string) (module string) {
Colin Cross068e0fe2016-12-13 15:23:47 -08001983 if len(s) > 1 && s[0] == ':' {
1984 return s[1:]
1985 }
1986 return ""
1987}
1988
Colin Cross41955e82019-05-29 14:40:35 -07001989// SrcIsModule decodes module references in the format ":name{.tag}" into the module name and tag, ":name" into the
1990// module name and an empty string for the tag, or empty strings if the input was not a module reference.
1991func SrcIsModuleWithTag(s string) (module, tag string) {
1992 if len(s) > 1 && s[0] == ':' {
1993 module = s[1:]
1994 if tagStart := strings.IndexByte(module, '{'); tagStart > 0 {
1995 if module[len(module)-1] == '}' {
1996 tag = module[tagStart+1 : len(module)-1]
1997 module = module[:tagStart]
1998 return module, tag
1999 }
2000 }
2001 return module, ""
2002 }
2003 return "", ""
Colin Cross068e0fe2016-12-13 15:23:47 -08002004}
2005
Colin Cross41955e82019-05-29 14:40:35 -07002006type sourceOrOutputDependencyTag struct {
2007 blueprint.BaseDependencyTag
2008 tag string
2009}
2010
2011func sourceOrOutputDepTag(tag string) blueprint.DependencyTag {
2012 return sourceOrOutputDependencyTag{tag: tag}
2013}
2014
2015var SourceDepTag = sourceOrOutputDepTag("")
Colin Cross068e0fe2016-12-13 15:23:47 -08002016
Colin Cross366938f2017-12-11 16:29:02 -08002017// Adds necessary dependencies to satisfy filegroup or generated sources modules listed in srcFiles
2018// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002019//
2020// Deprecated: tag the property with `android:"path"` instead.
Colin Cross068e0fe2016-12-13 15:23:47 -08002021func ExtractSourcesDeps(ctx BottomUpMutatorContext, srcFiles []string) {
Nan Zhang2439eb72017-04-10 11:27:50 -07002022 set := make(map[string]bool)
2023
Colin Cross068e0fe2016-12-13 15:23:47 -08002024 for _, s := range srcFiles {
Colin Cross41955e82019-05-29 14:40:35 -07002025 if m, t := SrcIsModuleWithTag(s); m != "" {
2026 if _, found := set[s]; found {
2027 ctx.ModuleErrorf("found source dependency duplicate: %q!", s)
Nan Zhang2439eb72017-04-10 11:27:50 -07002028 } else {
Colin Cross41955e82019-05-29 14:40:35 -07002029 set[s] = true
2030 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Nan Zhang2439eb72017-04-10 11:27:50 -07002031 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002032 }
2033 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002034}
2035
Colin Cross366938f2017-12-11 16:29:02 -08002036// Adds necessary dependencies to satisfy filegroup or generated sources modules specified in s
2037// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002038//
2039// Deprecated: tag the property with `android:"path"` instead.
Colin Cross366938f2017-12-11 16:29:02 -08002040func ExtractSourceDeps(ctx BottomUpMutatorContext, s *string) {
2041 if s != nil {
Colin Cross41955e82019-05-29 14:40:35 -07002042 if m, t := SrcIsModuleWithTag(*s); m != "" {
2043 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Colin Cross366938f2017-12-11 16:29:02 -08002044 }
2045 }
2046}
2047
Colin Cross41955e82019-05-29 14:40:35 -07002048// A module that implements SourceFileProducer can be referenced from any property that is tagged with `android:"path"`
2049// 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 -08002050type SourceFileProducer interface {
2051 Srcs() Paths
2052}
2053
Colin Cross41955e82019-05-29 14:40:35 -07002054// A module that implements OutputFileProducer can be referenced from any property that is tagged with `android:"path"`
Roland Levillain97c1f342019-11-22 14:20:54 +00002055// 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 -07002056// listed in the property.
2057type OutputFileProducer interface {
2058 OutputFiles(tag string) (Paths, error)
2059}
2060
Colin Cross5e708052019-08-06 13:59:50 -07002061// OutputFilesForModule returns the paths from an OutputFileProducer with the given tag. On error, including if the
2062// module produced zero paths, it reports errors to the ctx and returns nil.
2063func OutputFilesForModule(ctx PathContext, module blueprint.Module, tag string) Paths {
2064 paths, err := outputFilesForModule(ctx, module, tag)
2065 if err != nil {
2066 reportPathError(ctx, err)
2067 return nil
2068 }
2069 return paths
2070}
2071
2072// OutputFileForModule returns the path from an OutputFileProducer with the given tag. On error, including if the
2073// module produced zero or multiple paths, it reports errors to the ctx and returns nil.
2074func OutputFileForModule(ctx PathContext, module blueprint.Module, tag string) Path {
2075 paths, err := outputFilesForModule(ctx, module, tag)
2076 if err != nil {
2077 reportPathError(ctx, err)
2078 return nil
2079 }
2080 if len(paths) > 1 {
2081 reportPathErrorf(ctx, "got multiple output files from module %q, expected exactly one",
2082 pathContextName(ctx, module))
2083 return nil
2084 }
2085 return paths[0]
2086}
2087
2088func outputFilesForModule(ctx PathContext, module blueprint.Module, tag string) (Paths, error) {
2089 if outputFileProducer, ok := module.(OutputFileProducer); ok {
2090 paths, err := outputFileProducer.OutputFiles(tag)
2091 if err != nil {
2092 return nil, fmt.Errorf("failed to get output file from module %q: %s",
2093 pathContextName(ctx, module), err.Error())
2094 }
2095 if len(paths) == 0 {
2096 return nil, fmt.Errorf("failed to get output files from module %q", pathContextName(ctx, module))
2097 }
2098 return paths, nil
2099 } else {
2100 return nil, fmt.Errorf("module %q is not an OutputFileProducer", pathContextName(ctx, module))
2101 }
2102}
2103
Colin Crossfe17f6f2019-03-28 19:30:56 -07002104type HostToolProvider interface {
2105 HostToolPath() OptionalPath
2106}
2107
Colin Cross27b922f2019-03-04 22:35:41 -08002108// Returns a list of paths expanded from globs and modules referenced using ":module" syntax. The property must
2109// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002110//
2111// Deprecated: use PathsForModuleSrc or PathsForModuleSrcExcludes instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002112func (m *moduleContext) ExpandSources(srcFiles, excludes []string) Paths {
2113 return PathsForModuleSrcExcludes(m, srcFiles, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07002114}
2115
Colin Cross2fafa3e2019-03-05 12:39:51 -08002116// Returns a single path expanded from globs and modules referenced using ":module" syntax. The property must
2117// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002118//
2119// Deprecated: use PathForModuleSrc instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002120func (m *moduleContext) ExpandSource(srcFile, prop string) Path {
2121 return PathForModuleSrc(m, srcFile)
Colin Cross2fafa3e2019-03-05 12:39:51 -08002122}
2123
2124// Returns an optional single path expanded from globs and modules referenced using ":module" syntax if
2125// the srcFile is non-nil. The property must be tagged with `android:"path" to support automatic source module
2126// dependency resolution.
Colin Cross25de6c32019-06-06 14:29:25 -07002127func (m *moduleContext) ExpandOptionalSource(srcFile *string, prop string) OptionalPath {
Colin Cross2fafa3e2019-03-05 12:39:51 -08002128 if srcFile != nil {
Colin Cross25de6c32019-06-06 14:29:25 -07002129 return OptionalPathForPath(PathForModuleSrc(m, *srcFile))
Colin Cross2fafa3e2019-03-05 12:39:51 -08002130 }
2131 return OptionalPath{}
2132}
2133
Colin Cross25de6c32019-06-06 14:29:25 -07002134func (m *moduleContext) RequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002135 return m.module.RequiredModuleNames()
Nan Zhang6d34b302017-02-04 17:47:46 -08002136}
2137
Colin Cross25de6c32019-06-06 14:29:25 -07002138func (m *moduleContext) HostRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002139 return m.module.HostRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002140}
2141
Colin Cross25de6c32019-06-06 14:29:25 -07002142func (m *moduleContext) TargetRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002143 return m.module.TargetRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002144}
2145
Colin Cross463a90e2015-06-17 14:20:06 -07002146func init() {
Colin Cross798bfce2016-10-12 14:28:16 -07002147 RegisterSingletonType("buildtarget", BuildTargetSingleton)
Colin Cross463a90e2015-06-17 14:20:06 -07002148}
2149
Colin Cross0875c522017-11-28 17:34:01 -08002150func BuildTargetSingleton() Singleton {
Colin Cross1f8c52b2015-06-16 16:38:17 -07002151 return &buildTargetSingleton{}
2152}
2153
Colin Cross87d8b562017-04-25 10:01:55 -07002154func parentDir(dir string) string {
2155 dir, _ = filepath.Split(dir)
2156 return filepath.Clean(dir)
2157}
2158
Colin Cross1f8c52b2015-06-16 16:38:17 -07002159type buildTargetSingleton struct{}
2160
Colin Cross0875c522017-11-28 17:34:01 -08002161func (c *buildTargetSingleton) GenerateBuildActions(ctx SingletonContext) {
2162 var checkbuildDeps Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07002163
Colin Cross0875c522017-11-28 17:34:01 -08002164 mmTarget := func(dir string) WritablePath {
2165 return PathForPhony(ctx,
2166 "MODULES-IN-"+strings.Replace(filepath.Clean(dir), "/", "-", -1))
Colin Cross87d8b562017-04-25 10:01:55 -07002167 }
2168
Colin Cross0875c522017-11-28 17:34:01 -08002169 modulesInDir := make(map[string]Paths)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002170
Colin Cross0875c522017-11-28 17:34:01 -08002171 ctx.VisitAllModules(func(module Module) {
2172 blueprintDir := module.base().blueprintDir
2173 installTarget := module.base().installTarget
2174 checkbuildTarget := module.base().checkbuildTarget
Colin Cross1f8c52b2015-06-16 16:38:17 -07002175
Colin Cross0875c522017-11-28 17:34:01 -08002176 if checkbuildTarget != nil {
2177 checkbuildDeps = append(checkbuildDeps, checkbuildTarget)
2178 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], checkbuildTarget)
2179 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002180
Colin Cross0875c522017-11-28 17:34:01 -08002181 if installTarget != nil {
2182 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], installTarget)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002183 }
2184 })
2185
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002186 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08002187 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002188 suffix = "-soong"
2189 }
2190
Colin Cross1f8c52b2015-06-16 16:38:17 -07002191 // Create a top-level checkbuild target that depends on all modules
Colin Cross0875c522017-11-28 17:34:01 -08002192 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07002193 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002194 Output: PathForPhony(ctx, "checkbuild"+suffix),
Colin Cross1f8c52b2015-06-16 16:38:17 -07002195 Implicits: checkbuildDeps,
Colin Cross1f8c52b2015-06-16 16:38:17 -07002196 })
2197
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002198 // Make will generate the MODULES-IN-* targets
Colin Crossaabf6792017-11-29 00:27:14 -08002199 if ctx.Config().EmbeddedInMake() {
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002200 return
2201 }
2202
Colin Cross87d8b562017-04-25 10:01:55 -07002203 // Ensure ancestor directories are in modulesInDir
Inseob Kim1a365c62019-06-08 15:47:51 +09002204 dirs := SortedStringKeys(modulesInDir)
Colin Cross87d8b562017-04-25 10:01:55 -07002205 for _, dir := range dirs {
2206 dir := parentDir(dir)
2207 for dir != "." && dir != "/" {
2208 if _, exists := modulesInDir[dir]; exists {
2209 break
2210 }
2211 modulesInDir[dir] = nil
2212 dir = parentDir(dir)
2213 }
2214 }
2215
2216 // Make directories build their direct subdirectories
Colin Cross87d8b562017-04-25 10:01:55 -07002217 for _, dir := range dirs {
2218 p := parentDir(dir)
2219 if p != "." && p != "/" {
2220 modulesInDir[p] = append(modulesInDir[p], mmTarget(dir))
2221 }
2222 }
2223
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002224 // Create a MODULES-IN-<directory> target that depends on all modules in a directory, and
2225 // depends on the MODULES-IN-* targets of all of its subdirectories that contain Android.bp
2226 // files.
Colin Cross1f8c52b2015-06-16 16:38:17 -07002227 for _, dir := range dirs {
Colin Cross0875c522017-11-28 17:34:01 -08002228 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07002229 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002230 Output: mmTarget(dir),
Colin Cross87d8b562017-04-25 10:01:55 -07002231 Implicits: modulesInDir[dir],
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002232 // HACK: checkbuild should be an optional build, but force it
2233 // enabled for now in standalone builds
Colin Crossaabf6792017-11-29 00:27:14 -08002234 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross1f8c52b2015-06-16 16:38:17 -07002235 })
2236 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002237
2238 // Create (host|host-cross|target)-<OS> phony rules to build a reduced checkbuild.
2239 osDeps := map[OsType]Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08002240 ctx.VisitAllModules(func(module Module) {
2241 if module.Enabled() {
2242 os := module.Target().Os
2243 osDeps[os] = append(osDeps[os], module.base().checkbuildFiles...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002244 }
2245 })
2246
Colin Cross0875c522017-11-28 17:34:01 -08002247 osClass := make(map[string]Paths)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002248 for os, deps := range osDeps {
2249 var className string
2250
2251 switch os.Class {
2252 case Host:
2253 className = "host"
2254 case HostCross:
2255 className = "host-cross"
2256 case Device:
2257 className = "target"
2258 default:
2259 continue
2260 }
2261
Colin Cross0875c522017-11-28 17:34:01 -08002262 name := PathForPhony(ctx, className+"-"+os.Name)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002263 osClass[className] = append(osClass[className], name)
2264
Colin Cross0875c522017-11-28 17:34:01 -08002265 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07002266 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002267 Output: name,
2268 Implicits: deps,
Dan Willemsen61d88b82017-09-20 17:29:08 -07002269 })
2270 }
2271
2272 // Wrap those into host|host-cross|target phony rules
Inseob Kim1a365c62019-06-08 15:47:51 +09002273 for _, class := range SortedStringKeys(osClass) {
Colin Cross0875c522017-11-28 17:34:01 -08002274 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07002275 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08002276 Output: PathForPhony(ctx, class),
Dan Willemsen61d88b82017-09-20 17:29:08 -07002277 Implicits: osClass[class],
Dan Willemsen61d88b82017-09-20 17:29:08 -07002278 })
2279 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002280}
Colin Crossd779da42015-12-17 18:00:23 -08002281
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002282// Collect information for opening IDE project files in java/jdeps.go.
2283type IDEInfo interface {
2284 IDEInfo(ideInfo *IdeInfo)
2285 BaseModuleName() string
2286}
2287
2288// Extract the base module name from the Import name.
2289// Often the Import name has a prefix "prebuilt_".
2290// Remove the prefix explicitly if needed
2291// until we find a better solution to get the Import name.
2292type IDECustomizedModuleName interface {
2293 IDECustomizedModuleName() string
2294}
2295
2296type IdeInfo struct {
2297 Deps []string `json:"dependencies,omitempty"`
2298 Srcs []string `json:"srcs,omitempty"`
2299 Aidl_include_dirs []string `json:"aidl_include_dirs,omitempty"`
2300 Jarjar_rules []string `json:"jarjar_rules,omitempty"`
2301 Jars []string `json:"jars,omitempty"`
2302 Classes []string `json:"class,omitempty"`
2303 Installed_paths []string `json:"installed,omitempty"`
patricktu18c82ff2019-05-10 15:48:50 +08002304 SrcJars []string `json:"srcjars,omitempty"`
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002305}