blob: 5192a6a72f80cef38fe2ca7720cc06b57fd062fa [file] [log] [blame]
Colin Cross3f40fa42015-01-30 17:27:36 -08001// Copyright 2015 Google Inc. All rights reserved.
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
Colin Cross635c3b02016-05-18 15:37:25 -070015package android
Colin Cross3f40fa42015-01-30 17:27:36 -080016
17import (
Colin Cross6ff51382015-12-17 16:39:19 -080018 "fmt"
Colin Cross988414c2020-01-11 01:11:46 +000019 "os"
Alex Lightfb4353d2019-01-17 13:57:45 -080020 "path"
Colin Cross3f40fa42015-01-30 17:27:36 -080021 "path/filepath"
Jiyong Park1c7e9622020-05-07 16:12:13 +090022 "regexp"
Colin Cross6ff51382015-12-17 16:39:19 -080023 "strings"
Colin Crossaabf6792017-11-29 00:27:14 -080024 "text/scanner"
Colin Crossf6566ed2015-03-24 11:13:38 -070025
26 "github.com/google/blueprint"
Colin Crossfe4bc362018-09-12 10:02:13 -070027 "github.com/google/blueprint/proptools"
Colin Cross3f40fa42015-01-30 17:27:36 -080028)
29
30var (
31 DeviceSharedLibrary = "shared_library"
32 DeviceStaticLibrary = "static_library"
33 DeviceExecutable = "executable"
34 HostSharedLibrary = "host_shared_library"
35 HostStaticLibrary = "host_static_library"
36 HostExecutable = "host_executable"
37)
38
Colin Crossae887032017-10-23 17:16:14 -070039type BuildParams struct {
Dan Willemsen9f3c5742016-11-03 14:28:31 -070040 Rule blueprint.Rule
Colin Cross33bfb0a2016-11-21 17:23:08 -080041 Deps blueprint.Deps
42 Depfile WritablePath
Colin Cross67a5c132017-05-09 13:45:28 -070043 Description string
Dan Willemsen9f3c5742016-11-03 14:28:31 -070044 Output WritablePath
45 Outputs WritablePaths
46 ImplicitOutput WritablePath
47 ImplicitOutputs WritablePaths
48 Input Path
49 Inputs Paths
50 Implicit Path
51 Implicits Paths
52 OrderOnly Paths
Colin Cross824f1162020-07-16 13:07:51 -070053 Validation Path
54 Validations Paths
Dan Willemsen9f3c5742016-11-03 14:28:31 -070055 Default bool
56 Args map[string]string
Dan Willemsen34cc69e2015-09-23 15:26:20 -070057}
58
Colin Crossae887032017-10-23 17:16:14 -070059type ModuleBuildParams BuildParams
60
Colin Cross1184b642019-12-30 18:43:07 -080061// EarlyModuleContext provides methods that can be called early, as soon as the properties have
62// been parsed into the module and before any mutators have run.
63type EarlyModuleContext interface {
64 Module() Module
65 ModuleName() string
66 ModuleDir() string
67 ModuleType() string
Colin Cross9d34f352019-11-22 16:03:51 -080068 BlueprintsFile() string
Colin Cross1184b642019-12-30 18:43:07 -080069
70 ContainsProperty(name string) bool
71 Errorf(pos scanner.Position, fmt string, args ...interface{})
72 ModuleErrorf(fmt string, args ...interface{})
73 PropertyErrorf(property, fmt string, args ...interface{})
74 Failed() bool
75
76 AddNinjaFileDeps(deps ...string)
77
78 DeviceSpecific() bool
79 SocSpecific() bool
80 ProductSpecific() bool
81 SystemExtSpecific() bool
82 Platform() bool
83
84 Config() Config
85 DeviceConfig() DeviceConfig
86
87 // Deprecated: use Config()
88 AConfig() Config
89
90 // GlobWithDeps returns a list of files that match the specified pattern but do not match any
91 // of the patterns in excludes. It also adds efficient dependencies to rerun the primary
92 // builder whenever a file matching the pattern as added or removed, without rerunning if a
93 // file that does not match the pattern is added to a searched directory.
94 GlobWithDeps(pattern string, excludes []string) ([]string, error)
95
96 Glob(globPattern string, excludes []string) Paths
97 GlobFiles(globPattern string, excludes []string) Paths
Colin Cross988414c2020-01-11 01:11:46 +000098 IsSymlink(path Path) bool
99 Readlink(path Path) string
Colin Cross133ebef2020-08-14 17:38:45 -0700100
101 Namespace() *Namespace
Colin Cross1184b642019-12-30 18:43:07 -0800102}
103
Colin Cross0ea8ba82019-06-06 14:33:29 -0700104// BaseModuleContext is the same as blueprint.BaseModuleContext except that Config() returns
Colin Crossdc35e212019-06-06 16:13:11 -0700105// a Config instead of an interface{}, and some methods have been wrapped to use an android.Module
106// instead of a blueprint.Module, plus some extra methods that return Android-specific information
Colin Cross0ea8ba82019-06-06 14:33:29 -0700107// about the current module.
108type BaseModuleContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800109 EarlyModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -0700110
Paul Duffinf88d8e02020-05-07 20:21:34 +0100111 blueprintBaseModuleContext() blueprint.BaseModuleContext
112
Colin Crossdc35e212019-06-06 16:13:11 -0700113 OtherModuleName(m blueprint.Module) string
114 OtherModuleDir(m blueprint.Module) string
115 OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{})
116 OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag
117 OtherModuleExists(name string) bool
Martin Stjernholm009a9dc2020-03-05 17:34:13 +0000118 OtherModuleDependencyVariantExists(variations []blueprint.Variation, name string) bool
119 OtherModuleReverseDependencyVariantExists(name string) bool
Jiyong Park9e6c2422019-08-09 20:39:45 +0900120 OtherModuleType(m blueprint.Module) string
Colin Crossdc35e212019-06-06 16:13:11 -0700121
122 GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module
123 GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module
124 GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag)
125
126 VisitDirectDepsBlueprint(visit func(blueprint.Module))
127 VisitDirectDeps(visit func(Module))
128 VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module))
129 VisitDirectDepsIf(pred func(Module) bool, visit func(Module))
130 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
131 VisitDepsDepthFirst(visit func(Module))
132 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
133 VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module))
134 WalkDeps(visit func(Module, Module) bool)
135 WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool)
136 // GetWalkPath is supposed to be called in visit function passed in WalkDeps()
137 // and returns a top-down dependency path from a start module to current child module.
138 GetWalkPath() []Module
139
Paul Duffinc5192442020-03-31 11:31:36 +0100140 // GetTagPath is supposed to be called in visit function passed in WalkDeps()
141 // and returns a top-down dependency tags path from a start module to current child module.
142 // It has one less entry than GetWalkPath() as it contains the dependency tags that
143 // exist between each adjacent pair of modules in the GetWalkPath().
144 // GetTagPath()[i] is the tag between GetWalkPath()[i] and GetWalkPath()[i+1]
145 GetTagPath() []blueprint.DependencyTag
146
Jiyong Park1c7e9622020-05-07 16:12:13 +0900147 // GetPathString is supposed to be called in visit function passed in WalkDeps()
148 // and returns a multi-line string showing the modules and dependency tags
149 // among them along the top-down dependency path from a start module to current child module.
150 // skipFirst when set to true, the output doesn't include the start module,
151 // which is already printed when this function is used along with ModuleErrorf().
152 GetPathString(skipFirst bool) string
153
Colin Crossdc35e212019-06-06 16:13:11 -0700154 AddMissingDependencies(missingDeps []string)
155
Colin Crossa1ad8d12016-06-01 17:09:44 -0700156 Target() Target
Colin Cross8b74d172016-09-13 09:59:14 -0700157 TargetPrimary() bool
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000158
159 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
160 // responsible for creating.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700161 MultiTargets() []Target
Colin Crossf6566ed2015-03-24 11:13:38 -0700162 Arch() Arch
Colin Crossa1ad8d12016-06-01 17:09:44 -0700163 Os() OsType
Colin Crossf6566ed2015-03-24 11:13:38 -0700164 Host() bool
165 Device() bool
Colin Cross0af4b842015-04-30 16:36:18 -0700166 Darwin() bool
Doug Horn21b94272019-01-16 12:06:11 -0800167 Fuchsia() bool
Colin Cross3edeee12017-04-04 12:59:48 -0700168 Windows() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700169 Debug() bool
Colin Cross1e7d3702016-08-24 15:25:47 -0700170 PrimaryArch() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700171}
172
Colin Cross1184b642019-12-30 18:43:07 -0800173// Deprecated: use EarlyModuleContext instead
Colin Cross635c3b02016-05-18 15:37:25 -0700174type BaseContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800175 EarlyModuleContext
Colin Crossaabf6792017-11-29 00:27:14 -0800176}
177
Colin Cross635c3b02016-05-18 15:37:25 -0700178type ModuleContext interface {
Colin Crossaabf6792017-11-29 00:27:14 -0800179 BaseModuleContext
Colin Cross3f40fa42015-01-30 17:27:36 -0800180
Colin Crossae887032017-10-23 17:16:14 -0700181 // Deprecated: use ModuleContext.Build instead.
Colin Cross0875c522017-11-28 17:34:01 -0800182 ModuleBuild(pctx PackageContext, params ModuleBuildParams)
Colin Cross8f101b42015-06-17 15:09:06 -0700183
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700184 ExpandSources(srcFiles, excludes []string) Paths
Colin Cross366938f2017-12-11 16:29:02 -0800185 ExpandSource(srcFile, prop string) Path
Colin Cross2383f3b2018-02-06 14:40:13 -0800186 ExpandOptionalSource(srcFile *string, prop string) OptionalPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700187
Colin Cross70dda7e2019-10-01 22:05:35 -0700188 InstallExecutable(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
189 InstallFile(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
190 InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath
191 InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700192 CheckbuildFile(srcPath Path)
Dan Willemsen6553f5e2016-03-10 18:14:25 -0800193
Colin Cross8d8f8e22016-08-03 11:57:50 -0700194 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700195 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700196 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800197 InstallInRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900198 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700199 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700200 InstallBypassMake() bool
Jiyong Park87788b52020-09-01 12:37:45 +0900201 InstallForceOS() (*OsType, *ArchType)
Nan Zhang6d34b302017-02-04 17:47:46 -0800202
203 RequiredModuleNames() []string
Sasha Smundakb6d23052019-04-01 18:37:36 -0700204 HostRequiredModuleNames() []string
205 TargetRequiredModuleNames() []string
Colin Cross3f68a132017-10-23 17:10:29 -0700206
Colin Cross3f68a132017-10-23 17:10:29 -0700207 ModuleSubDir() string
208
Colin Cross0875c522017-11-28 17:34:01 -0800209 Variable(pctx PackageContext, name, value string)
210 Rule(pctx PackageContext, name string, params blueprint.RuleParams, argNames ...string) blueprint.Rule
Colin Crossae887032017-10-23 17:16:14 -0700211 // Similar to blueprint.ModuleContext.Build, but takes Paths instead of []string,
212 // and performs more verification.
Colin Cross0875c522017-11-28 17:34:01 -0800213 Build(pctx PackageContext, params BuildParams)
Colin Crossc3d87d32020-06-04 13:25:17 -0700214 // Phony creates a Make-style phony rule, a rule with no commands that can depend on other
215 // phony rules or real files. Phony can be called on the same name multiple times to add
216 // additional dependencies.
217 Phony(phony string, deps ...Path)
Colin Cross3f68a132017-10-23 17:10:29 -0700218
Colin Cross0875c522017-11-28 17:34:01 -0800219 PrimaryModule() Module
220 FinalModule() Module
221 VisitAllModuleVariants(visit func(Module))
Colin Cross3f68a132017-10-23 17:10:29 -0700222
223 GetMissingDependencies() []string
Colin Cross3f40fa42015-01-30 17:27:36 -0800224}
225
Colin Cross635c3b02016-05-18 15:37:25 -0700226type Module interface {
Colin Cross3f40fa42015-01-30 17:27:36 -0800227 blueprint.Module
228
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700229 // GenerateAndroidBuildActions is analogous to Blueprints' GenerateBuildActions,
230 // but GenerateAndroidBuildActions also has access to Android-specific information.
231 // For more information, see Module.GenerateBuildActions within Blueprint's module_ctx.go
Colin Cross635c3b02016-05-18 15:37:25 -0700232 GenerateAndroidBuildActions(ModuleContext)
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700233
Paul Duffin44f1d842020-06-26 20:17:02 +0100234 // Add dependencies to the components of a module, i.e. modules that are created
235 // by the module and which are considered to be part of the creating module.
236 //
237 // This is called before prebuilts are renamed so as to allow a dependency to be
238 // added directly to a prebuilt child module instead of depending on a source module
239 // and relying on prebuilt processing to switch to the prebuilt module if preferred.
240 //
241 // A dependency on a prebuilt must include the "prebuilt_" prefix.
242 ComponentDepsMutator(ctx BottomUpMutatorContext)
243
Colin Cross1e676be2016-10-12 14:38:15 -0700244 DepsMutator(BottomUpMutatorContext)
Colin Cross3f40fa42015-01-30 17:27:36 -0800245
Colin Cross635c3b02016-05-18 15:37:25 -0700246 base() *ModuleBase
Inseob Kimeec88e12020-01-22 11:11:29 +0900247 Disable()
Dan Willemsen0effe062015-11-30 16:06:01 -0800248 Enabled() bool
Colin Crossa1ad8d12016-06-01 17:09:44 -0700249 Target() Target
Dan Willemsen782a2d12015-12-21 14:55:28 -0800250 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700251 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700252 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800253 InstallInRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900254 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700255 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700256 InstallBypassMake() bool
Jiyong Park87788b52020-09-01 12:37:45 +0900257 InstallForceOS() (*OsType, *ArchType)
Colin Crossa2f296f2016-11-29 15:16:18 -0800258 SkipInstall()
Ulya Trafimovichb28cc372020-01-13 15:18:16 +0000259 IsSkipInstall() bool
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +0100260 MakeUninstallable()
Liz Kammer5ca3a622020-08-05 15:40:41 -0700261 ReplacedByPrebuilt()
262 IsReplacedByPrebuilt() bool
Jiyong Park374510b2018-03-19 18:23:01 +0900263 ExportedToMake() bool
Inseob Kim8471cda2019-11-15 09:59:12 +0900264 InitRc() Paths
265 VintfFragments() Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800266 NoticeFiles() Paths
Colin Cross36242852017-06-23 15:06:31 -0700267
268 AddProperties(props ...interface{})
269 GetProperties() []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700270
Colin Crossae887032017-10-23 17:16:14 -0700271 BuildParamsForTests() []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800272 RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800273 VariablesForTests() map[string]string
Paul Duffine2453c72019-05-31 14:00:04 +0100274
Colin Cross9a362232019-07-01 15:32:45 -0700275 // String returns a string that includes the module name and variants for printing during debugging.
276 String() string
277
Paul Duffine2453c72019-05-31 14:00:04 +0100278 // Get the qualified module id for this module.
279 qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName
280
281 // Get information about the properties that can contain visibility rules.
282 visibilityProperties() []visibilityProperty
Paul Duffin63c6e182019-07-24 14:24:38 +0100283
Jiyong Park6a8cf5f2019-12-30 16:31:09 +0900284 RequiredModuleNames() []string
285 HostRequiredModuleNames() []string
286 TargetRequiredModuleNames() []string
Colin Cross897266e2020-02-13 13:22:08 -0800287
288 filesToInstall() InstallPaths
Paul Duffine2453c72019-05-31 14:00:04 +0100289}
290
291// Qualified id for a module
292type qualifiedModuleName struct {
293 // The package (i.e. directory) in which the module is defined, without trailing /
294 pkg string
295
296 // The name of the module, empty string if package.
297 name string
298}
299
300func (q qualifiedModuleName) String() string {
301 if q.name == "" {
302 return "//" + q.pkg
303 }
304 return "//" + q.pkg + ":" + q.name
305}
306
Paul Duffine484f472019-06-20 16:38:08 +0100307func (q qualifiedModuleName) isRootPackage() bool {
308 return q.pkg == "" && q.name == ""
309}
310
Paul Duffine2453c72019-05-31 14:00:04 +0100311// Get the id for the package containing this module.
312func (q qualifiedModuleName) getContainingPackageId() qualifiedModuleName {
313 pkg := q.pkg
314 if q.name == "" {
Paul Duffine484f472019-06-20 16:38:08 +0100315 if pkg == "" {
316 panic(fmt.Errorf("Cannot get containing package id of root package"))
317 }
318
319 index := strings.LastIndex(pkg, "/")
320 if index == -1 {
321 pkg = ""
322 } else {
323 pkg = pkg[:index]
324 }
Paul Duffine2453c72019-05-31 14:00:04 +0100325 }
326 return newPackageId(pkg)
327}
328
329func newPackageId(pkg string) qualifiedModuleName {
330 // A qualified id for a package module has no name.
331 return qualifiedModuleName{pkg: pkg, name: ""}
Colin Cross3f40fa42015-01-30 17:27:36 -0800332}
333
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000334type Dist struct {
335 // Copy the output of this module to the $DIST_DIR when `dist` is specified on the
336 // command line and any of these targets are also on the command line, or otherwise
337 // built
338 Targets []string `android:"arch_variant"`
339
340 // The name of the output artifact. This defaults to the basename of the output of
341 // the module.
342 Dest *string `android:"arch_variant"`
343
344 // The directory within the dist directory to store the artifact. Defaults to the
345 // top level directory ("").
346 Dir *string `android:"arch_variant"`
347
348 // A suffix to add to the artifact file name (before any extension).
349 Suffix *string `android:"arch_variant"`
350
351 // A string tag to select the OutputFiles associated with the tag. Defaults to the
352 // the empty "" string.
353 Tag *string `android:"arch_variant"`
354}
355
Colin Crossfc754582016-05-17 16:34:16 -0700356type nameProperties struct {
357 // The name of the module. Must be unique across all modules.
Nan Zhang0007d812017-11-07 10:57:05 -0800358 Name *string
Colin Crossfc754582016-05-17 16:34:16 -0700359}
360
361type commonProperties struct {
Dan Willemsen0effe062015-11-30 16:06:01 -0800362 // emit build rules for this module
Paul Duffin54d9bb72020-02-12 10:20:56 +0000363 //
364 // Disabling a module should only be done for those modules that cannot be built
365 // in the current environment. Modules that can build in the current environment
366 // but are not usually required (e.g. superceded by a prebuilt) should not be
367 // disabled as that will prevent them from being built by the checkbuild target
368 // and so prevent early detection of changes that have broken those modules.
Dan Willemsen0effe062015-11-30 16:06:01 -0800369 Enabled *bool `android:"arch_variant"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800370
Paul Duffin2e61fa62019-03-28 14:10:57 +0000371 // Controls the visibility of this module to other modules. Allowable values are one or more of
372 // these formats:
373 //
374 // ["//visibility:public"]: Anyone can use this module.
375 // ["//visibility:private"]: Only rules in the module's package (not its subpackages) can use
376 // this module.
Paul Duffin51084ff2020-05-05 19:19:22 +0100377 // ["//visibility:override"]: Discards any rules inherited from defaults or a creating module.
378 // Can only be used at the beginning of a list of visibility rules.
Paul Duffin2e61fa62019-03-28 14:10:57 +0000379 // ["//some/package:__pkg__", "//other/package:__pkg__"]: Only modules in some/package and
380 // other/package (defined in some/package/*.bp and other/package/*.bp) have access to
381 // this module. Note that sub-packages do not have access to the rule; for example,
382 // //some/package/foo:bar or //other/package/testing:bla wouldn't have access. __pkg__
383 // is a special module and must be used verbatim. It represents all of the modules in the
384 // package.
385 // ["//project:__subpackages__", "//other:__subpackages__"]: Only modules in packages project
386 // or other or in one of their sub-packages have access to this module. For example,
387 // //project:rule, //project/library:lib or //other/testing/internal:munge are allowed
388 // to depend on this rule (but not //independent:evil)
389 // ["//project"]: This is shorthand for ["//project:__pkg__"]
390 // [":__subpackages__"]: This is shorthand for ["//project:__subpackages__"] where
391 // //project is the module's package. e.g. using [":__subpackages__"] in
392 // packages/apps/Settings/Android.bp is equivalent to
393 // //packages/apps/Settings:__subpackages__.
394 // ["//visibility:legacy_public"]: The default visibility, behaves as //visibility:public
395 // for now. It is an error if it is used in a module.
Paul Duffine2453c72019-05-31 14:00:04 +0100396 //
397 // If a module does not specify the `visibility` property then it uses the
398 // `default_visibility` property of the `package` module in the module's package.
399 //
400 // If the `default_visibility` property is not set for the module's package then
Paul Duffine484f472019-06-20 16:38:08 +0100401 // it will use the `default_visibility` of its closest ancestor package for which
402 // a `default_visibility` property is specified.
403 //
404 // If no `default_visibility` property can be found then the module uses the
405 // global default of `//visibility:legacy_public`.
Paul Duffine2453c72019-05-31 14:00:04 +0100406 //
Paul Duffin95d53b52019-07-24 13:45:05 +0100407 // The `visibility` property has no effect on a defaults module although it does
408 // apply to any non-defaults module that uses it. To set the visibility of a
409 // defaults module, use the `defaults_visibility` property on the defaults module;
410 // not to be confused with the `default_visibility` property on the package module.
411 //
Paul Duffin2e61fa62019-03-28 14:10:57 +0000412 // See https://android.googlesource.com/platform/build/soong/+/master/README.md#visibility for
413 // more details.
414 Visibility []string
415
Colin Cross7d5136f2015-05-11 13:39:40 -0700416 // control whether this module compiles for 32-bit, 64-bit, or both. Possible values
Colin Cross3f40fa42015-01-30 17:27:36 -0800417 // are "32" (compile for 32-bit only), "64" (compile for 64-bit only), "both" (compile for both
418 // architectures), or "first" (compile for 64-bit on a 64-bit platform, and 32-bit on a 32-bit
419 // platform
Colin Cross7d716ba2017-11-01 10:38:29 -0700420 Compile_multilib *string `android:"arch_variant"`
Colin Cross69617d32016-09-06 10:39:07 -0700421
422 Target struct {
423 Host struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700424 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700425 }
426 Android struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700427 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700428 }
429 }
430
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000431 // If set to true then the archMutator will create variants for each arch specific target
432 // (e.g. 32/64) that the module is required to produce. If set to false then it will only
433 // create a variant for the architecture and will list the additional arch specific targets
434 // that the variant needs to produce in the CompileMultiTargets property.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700435 UseTargetVariants bool `blueprint:"mutated"`
436 Default_multilib string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800437
Dan Willemsen782a2d12015-12-21 14:55:28 -0800438 // whether this is a proprietary vendor module, and should be installed into /vendor
Colin Cross7d716ba2017-11-01 10:38:29 -0700439 Proprietary *bool
Dan Willemsen782a2d12015-12-21 14:55:28 -0800440
Colin Cross55708f32017-03-20 13:23:34 -0700441 // vendor who owns this module
Dan Willemsenefac4a82017-07-18 19:42:09 -0700442 Owner *string
Colin Cross55708f32017-03-20 13:23:34 -0700443
Jiyong Park2db76922017-11-08 16:03:48 +0900444 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
445 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
446 // Use `soc_specific` instead for better meaning.
Colin Cross7d716ba2017-11-01 10:38:29 -0700447 Vendor *bool
Dan Willemsenaa118f92017-04-06 12:49:58 -0700448
Jiyong Park2db76922017-11-08 16:03:48 +0900449 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
450 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
451 Soc_specific *bool
452
453 // whether this module is specific to a device, not only for SoC, but also for off-chip
454 // peripherals. When set to true, it is installed into /odm (or /vendor/odm if odm partition
455 // does not exist, or /system/vendor/odm if both odm and vendor partitions do not exist).
456 // This implies `soc_specific:true`.
457 Device_specific *bool
458
459 // whether this module is specific to a software configuration of a product (e.g. country,
Jaekyun Seok5cfbfbb2018-01-10 19:00:15 +0900460 // network operator, etc). When set to true, it is installed into /product (or
461 // /system/product if product partition does not exist).
Jiyong Park2db76922017-11-08 16:03:48 +0900462 Product_specific *bool
463
Justin Yund5f6c822019-06-25 16:47:17 +0900464 // whether this module extends system. When set to true, it is installed into /system_ext
465 // (or /system/system_ext if system_ext partition does not exist).
466 System_ext_specific *bool
467
Jiyong Parkf9332f12018-02-01 00:54:12 +0900468 // Whether this module is installed to recovery partition
469 Recovery *bool
470
Yifan Hong1b3348d2020-01-21 15:53:22 -0800471 // Whether this module is installed to ramdisk
472 Ramdisk *bool
473
dimitry1f33e402019-03-26 12:39:31 +0100474 // Whether this module is built for non-native architecures (also known as native bridge binary)
475 Native_bridge_supported *bool `android:"arch_variant"`
476
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700477 // init.rc files to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800478 Init_rc []string `android:"path"`
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700479
Steven Moreland57a23d22018-04-04 15:42:19 -0700480 // VINTF manifest fragments to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800481 Vintf_fragments []string `android:"path"`
Steven Moreland57a23d22018-04-04 15:42:19 -0700482
Chris Wolfe998306e2016-08-15 14:47:23 -0400483 // names of other modules to install if this module is installed
Colin Crossc602b7d2017-05-05 13:36:36 -0700484 Required []string `android:"arch_variant"`
Chris Wolfe998306e2016-08-15 14:47:23 -0400485
Sasha Smundakb6d23052019-04-01 18:37:36 -0700486 // names of other modules to install on host if this module is installed
487 Host_required []string `android:"arch_variant"`
488
489 // names of other modules to install on target if this module is installed
490 Target_required []string `android:"arch_variant"`
491
Colin Cross5aac3622017-08-31 15:07:09 -0700492 // relative path to a file to include in the list of notices for the device
Colin Cross27b922f2019-03-04 22:35:41 -0800493 Notice *string `android:"path"`
Colin Cross5aac3622017-08-31 15:07:09 -0700494
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000495 // The OsType of artifacts that this module variant is responsible for creating.
496 //
497 // Set by osMutator
498 CompileOS OsType `blueprint:"mutated"`
499
500 // The Target of artifacts that this module variant is responsible for creating.
501 //
502 // Set by archMutator
503 CompileTarget Target `blueprint:"mutated"`
504
505 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
506 // responsible for creating.
507 //
508 // By default this is nil as, where necessary, separate variants are created for the
509 // different multilib types supported and that information is encapsulated in the
510 // CompileTarget so the module variant simply needs to create artifacts for that.
511 //
512 // However, if UseTargetVariants is set to false (e.g. by
513 // InitAndroidMultiTargetsArchModule) then no separate variants are created for the
514 // multilib targets. Instead a single variant is created for the architecture and
515 // this contains the multilib specific targets that this variant should create.
516 //
517 // Set by archMutator
Colin Crossee0bc3b2018-10-02 22:01:37 -0700518 CompileMultiTargets []Target `blueprint:"mutated"`
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000519
520 // True if the module variant's CompileTarget is the primary target
521 //
522 // Set by archMutator
523 CompilePrimary bool `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800524
525 // Set by InitAndroidModule
526 HostOrDeviceSupported HostOrDeviceSupported `blueprint:"mutated"`
Dan Willemsen0b24c742016-10-04 15:13:37 -0700527 ArchSpecific bool `blueprint:"mutated"`
Colin Crossce75d2c2016-10-06 16:12:58 -0700528
Paul Duffin1356d8c2020-02-25 19:26:33 +0000529 // If set to true then a CommonOS variant will be created which will have dependencies
530 // on all its OsType specific variants. Used by sdk/module_exports to create a snapshot
531 // that covers all os and architecture variants.
532 //
533 // The OsType specific variants can be retrieved by calling
534 // GetOsSpecificVariantsOfCommonOSVariant
535 //
536 // Set at module initialization time by calling InitCommonOSAndroidMultiTargetsArchModule
537 CreateCommonOSVariant bool `blueprint:"mutated"`
538
539 // If set to true then this variant is the CommonOS variant that has dependencies on its
540 // OsType specific variants.
541 //
542 // Set by osMutator.
543 CommonOSVariant bool `blueprint:"mutated"`
544
Colin Crossce75d2c2016-10-06 16:12:58 -0700545 SkipInstall bool `blueprint:"mutated"`
Jeff Gaston088e29e2017-11-29 16:47:17 -0800546
Liz Kammer5ca3a622020-08-05 15:40:41 -0700547 // Whether the module has been replaced by a prebuilt
548 ReplacedByPrebuilt bool `blueprint:"mutated"`
549
Justin Yun32f053b2020-07-31 23:07:17 +0900550 // Disabled by mutators. If set to true, it overrides Enabled property.
551 ForcedDisabled bool `blueprint:"mutated"`
552
Jeff Gaston088e29e2017-11-29 16:47:17 -0800553 NamespaceExportedToMake bool `blueprint:"mutated"`
Colin Cross6c4f21f2019-06-06 15:41:36 -0700554
555 MissingDeps []string `blueprint:"mutated"`
Colin Cross9a362232019-07-01 15:32:45 -0700556
557 // Name and variant strings stored by mutators to enable Module.String()
558 DebugName string `blueprint:"mutated"`
559 DebugMutators []string `blueprint:"mutated"`
560 DebugVariations []string `blueprint:"mutated"`
Colin Cross7228ecd2019-11-18 16:00:16 -0800561
562 // set by ImageMutator
563 ImageVariation string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800564}
565
Paul Duffined875132020-09-02 13:08:57 +0100566type distProperties struct {
567 // configuration to distribute output files from this module to the distribution
568 // directory (default: $OUT/dist, configurable with $DIST_DIR)
569 Dist Dist `android:"arch_variant"`
570
571 // a list of configurations to distribute output files from this module to the
572 // distribution directory (default: $OUT/dist, configurable with $DIST_DIR)
573 Dists []Dist `android:"arch_variant"`
574}
575
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000576// A map of OutputFile tag keys to Paths, for disting purposes.
577type TaggedDistFiles map[string]Paths
578
579func MakeDefaultDistFiles(paths ...Path) TaggedDistFiles {
Jingwen Chen7b27ca72020-07-24 09:13:49 +0000580 for _, path := range paths {
581 if path == nil {
582 panic("The path to a dist file cannot be nil.")
583 }
584 }
585
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000586 // The default OutputFile tag is the empty "" string.
587 return TaggedDistFiles{"": paths}
588}
589
Colin Cross3f40fa42015-01-30 17:27:36 -0800590type hostAndDeviceProperties struct {
Colin Cross4e81d702018-11-09 10:36:55 -0800591 // If set to true, build a variant of the module for the host. Defaults to false.
592 Host_supported *bool
593
594 // If set to true, build a variant of the module for the device. Defaults to true.
Colin Crossa4190c12016-07-12 13:11:25 -0700595 Device_supported *bool
Colin Cross3f40fa42015-01-30 17:27:36 -0800596}
597
Colin Crossc472d572015-03-17 15:06:21 -0700598type Multilib string
599
600const (
Colin Cross6b4a32d2017-12-05 13:42:45 -0800601 MultilibBoth Multilib = "both"
602 MultilibFirst Multilib = "first"
603 MultilibCommon Multilib = "common"
604 MultilibCommonFirst Multilib = "common_first"
605 MultilibDefault Multilib = ""
Colin Crossc472d572015-03-17 15:06:21 -0700606)
607
Colin Crossa1ad8d12016-06-01 17:09:44 -0700608type HostOrDeviceSupported int
609
610const (
611 _ HostOrDeviceSupported = iota
Dan Albert0981b5c2018-08-02 13:46:35 -0700612
613 // Host and HostCross are built by default. Device is not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700614 HostSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700615
616 // Host is built by default. HostCross and Device are not supported.
Dan Albertc6345fb2016-10-20 01:36:11 -0700617 HostSupportedNoCross
Dan Albert0981b5c2018-08-02 13:46:35 -0700618
619 // Device is built by default. Host and HostCross are not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700620 DeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700621
622 // Device is built by default. Host and HostCross are supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700623 HostAndDeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700624
625 // Host, HostCross, and Device are built by default.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700626 HostAndDeviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700627
628 // Nothing is supported. This is not exposed to the user, but used to mark a
629 // host only module as unsupported when the module type is not supported on
630 // the host OS. E.g. benchmarks are supported on Linux but not Darwin.
Dan Willemsen0b24c742016-10-04 15:13:37 -0700631 NeitherHostNorDeviceSupported
Colin Crossa1ad8d12016-06-01 17:09:44 -0700632)
633
Jiyong Park2db76922017-11-08 16:03:48 +0900634type moduleKind int
635
636const (
637 platformModule moduleKind = iota
638 deviceSpecificModule
639 socSpecificModule
640 productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900641 systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900642)
643
644func (k moduleKind) String() string {
645 switch k {
646 case platformModule:
647 return "platform"
648 case deviceSpecificModule:
649 return "device-specific"
650 case socSpecificModule:
651 return "soc-specific"
652 case productSpecificModule:
653 return "product-specific"
Justin Yund5f6c822019-06-25 16:47:17 +0900654 case systemExtSpecificModule:
655 return "systemext-specific"
Jiyong Park2db76922017-11-08 16:03:48 +0900656 default:
657 panic(fmt.Errorf("unknown module kind %d", k))
658 }
659}
660
Colin Cross9d34f352019-11-22 16:03:51 -0800661func initAndroidModuleBase(m Module) {
662 m.base().module = m
663}
664
Colin Cross36242852017-06-23 15:06:31 -0700665func InitAndroidModule(m Module) {
Colin Cross9d34f352019-11-22 16:03:51 -0800666 initAndroidModuleBase(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800667 base := m.base()
Colin Cross5049f022015-03-18 13:28:46 -0700668
Colin Cross36242852017-06-23 15:06:31 -0700669 m.AddProperties(
Colin Crossfc754582016-05-17 16:34:16 -0700670 &base.nameProperties,
Paul Duffined875132020-09-02 13:08:57 +0100671 &base.commonProperties,
672 &base.distProperties)
Colin Cross18c46802019-09-24 22:19:02 -0700673
Colin Crosseabaedd2020-02-06 17:01:55 -0800674 initProductVariableModule(m)
Colin Cross18c46802019-09-24 22:19:02 -0700675
Colin Crossa3a97412019-03-18 12:24:29 -0700676 base.generalProperties = m.GetProperties()
Pirama Arumuga Nainar955dc492018-04-17 14:58:42 -0700677 base.customizableProperties = m.GetProperties()
Paul Duffin63c6e182019-07-24 14:24:38 +0100678
679 // The default_visibility property needs to be checked and parsed by the visibility module during
Paul Duffin5ec73ec2020-05-01 17:52:01 +0100680 // its checking and parsing phases so make it the primary visibility property.
681 setPrimaryVisibilityProperty(m, "visibility", &base.commonProperties.Visibility)
Colin Cross5049f022015-03-18 13:28:46 -0700682}
683
Colin Cross36242852017-06-23 15:06:31 -0700684func InitAndroidArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
685 InitAndroidModule(m)
Colin Cross5049f022015-03-18 13:28:46 -0700686
687 base := m.base()
Colin Cross3f40fa42015-01-30 17:27:36 -0800688 base.commonProperties.HostOrDeviceSupported = hod
Colin Cross69617d32016-09-06 10:39:07 -0700689 base.commonProperties.Default_multilib = string(defaultMultilib)
Dan Willemsen0b24c742016-10-04 15:13:37 -0700690 base.commonProperties.ArchSpecific = true
Colin Crossee0bc3b2018-10-02 22:01:37 -0700691 base.commonProperties.UseTargetVariants = true
Colin Cross3f40fa42015-01-30 17:27:36 -0800692
Dan Willemsen218f6562015-07-08 18:13:11 -0700693 switch hod {
Nan Zhang1a0f09b2017-07-05 10:35:11 -0700694 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Cross36242852017-06-23 15:06:31 -0700695 m.AddProperties(&base.hostAndDeviceProperties)
Colin Cross3f40fa42015-01-30 17:27:36 -0800696 }
697
Colin Cross36242852017-06-23 15:06:31 -0700698 InitArchModule(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800699}
700
Colin Crossee0bc3b2018-10-02 22:01:37 -0700701func InitAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
702 InitAndroidArchModule(m, hod, defaultMultilib)
703 m.base().commonProperties.UseTargetVariants = false
704}
705
Paul Duffin1356d8c2020-02-25 19:26:33 +0000706// As InitAndroidMultiTargetsArchModule except it creates an additional CommonOS variant that
707// has dependencies on all the OsType specific variants.
708func InitCommonOSAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
709 InitAndroidArchModule(m, hod, defaultMultilib)
710 m.base().commonProperties.UseTargetVariants = false
711 m.base().commonProperties.CreateCommonOSVariant = true
712}
713
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800714// A ModuleBase object contains the properties that are common to all Android
Colin Cross3f40fa42015-01-30 17:27:36 -0800715// modules. It should be included as an anonymous field in every module
716// struct definition. InitAndroidModule should then be called from the module's
717// factory function, and the return values from InitAndroidModule should be
718// returned from the factory function.
719//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800720// The ModuleBase type is responsible for implementing the GenerateBuildActions
721// method to support the blueprint.Module interface. This method will then call
722// the module's GenerateAndroidBuildActions method once for each build variant
Colin Cross25de6c32019-06-06 14:29:25 -0700723// that is to be built. GenerateAndroidBuildActions is passed a ModuleContext
724// rather than the usual blueprint.ModuleContext.
725// ModuleContext exposes extra functionality specific to the Android build
Colin Cross3f40fa42015-01-30 17:27:36 -0800726// system including details about the particular build variant that is to be
727// generated.
728//
729// For example:
730//
731// import (
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800732// "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -0800733// )
734//
735// type myModule struct {
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800736// android.ModuleBase
Colin Cross3f40fa42015-01-30 17:27:36 -0800737// properties struct {
738// MyProperty string
739// }
740// }
741//
Colin Cross36242852017-06-23 15:06:31 -0700742// func NewMyModule() android.Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800743// m := &myModule{}
Colin Cross36242852017-06-23 15:06:31 -0700744// m.AddProperties(&m.properties)
745// android.InitAndroidModule(m)
746// return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800747// }
748//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800749// func (m *myModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800750// // Get the CPU architecture for the current build variant.
751// variantArch := ctx.Arch()
752//
753// // ...
754// }
Colin Cross635c3b02016-05-18 15:37:25 -0700755type ModuleBase struct {
Colin Cross3f40fa42015-01-30 17:27:36 -0800756 // Putting the curiously recurring thing pointing to the thing that contains
757 // the thing pattern to good use.
Colin Cross36242852017-06-23 15:06:31 -0700758 // TODO: remove this
Colin Cross635c3b02016-05-18 15:37:25 -0700759 module Module
Colin Cross3f40fa42015-01-30 17:27:36 -0800760
Colin Crossfc754582016-05-17 16:34:16 -0700761 nameProperties nameProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800762 commonProperties commonProperties
Paul Duffined875132020-09-02 13:08:57 +0100763 distProperties distProperties
Colin Cross18c46802019-09-24 22:19:02 -0700764 variableProperties interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800765 hostAndDeviceProperties hostAndDeviceProperties
766 generalProperties []interface{}
Colin Crossc17727d2018-10-24 12:42:09 -0700767 archProperties [][]interface{}
Colin Crossa120ec12016-08-19 16:07:38 -0700768 customizableProperties []interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800769
Paul Duffin63c6e182019-07-24 14:24:38 +0100770 // Information about all the properties on the module that contains visibility rules that need
771 // checking.
772 visibilityPropertyInfo []visibilityProperty
773
774 // The primary visibility property, may be nil, that controls access to the module.
775 primaryVisibilityProperty visibilityProperty
776
Colin Cross3f40fa42015-01-30 17:27:36 -0800777 noAddressSanitizer bool
Colin Cross897266e2020-02-13 13:22:08 -0800778 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700779 checkbuildFiles Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800780 noticeFiles Paths
Colin Crossc3d87d32020-06-04 13:25:17 -0700781 phonies map[string]Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -0700782
783 // Used by buildTargetSingleton to create checkbuild and per-directory build targets
784 // Only set on the final variant of each module
Colin Cross0875c522017-11-28 17:34:01 -0800785 installTarget WritablePath
786 checkbuildTarget WritablePath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700787 blueprintDir string
Colin Crossa120ec12016-08-19 16:07:38 -0700788
Colin Cross178a5092016-09-13 13:42:32 -0700789 hooks hooks
Colin Cross36242852017-06-23 15:06:31 -0700790
791 registerProps []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700792
793 // For tests
Colin Crossae887032017-10-23 17:16:14 -0700794 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800795 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800796 variables map[string]string
Colin Crossa9d8bee2018-10-02 13:59:46 -0700797
Inseob Kim8471cda2019-11-15 09:59:12 +0900798 initRcPaths Paths
799 vintfFragmentsPaths Paths
800
Colin Crossa9d8bee2018-10-02 13:59:46 -0700801 prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool
Colin Cross36242852017-06-23 15:06:31 -0700802}
803
Paul Duffin44f1d842020-06-26 20:17:02 +0100804func (m *ModuleBase) ComponentDepsMutator(BottomUpMutatorContext) {}
805
Colin Cross4157e882019-06-06 16:57:04 -0700806func (m *ModuleBase) DepsMutator(BottomUpMutatorContext) {}
Colin Cross5f692ec2019-02-01 16:53:07 -0800807
Colin Cross4157e882019-06-06 16:57:04 -0700808func (m *ModuleBase) AddProperties(props ...interface{}) {
809 m.registerProps = append(m.registerProps, props...)
Colin Cross36242852017-06-23 15:06:31 -0700810}
811
Colin Cross4157e882019-06-06 16:57:04 -0700812func (m *ModuleBase) GetProperties() []interface{} {
813 return m.registerProps
Colin Cross3f40fa42015-01-30 17:27:36 -0800814}
815
Colin Cross4157e882019-06-06 16:57:04 -0700816func (m *ModuleBase) BuildParamsForTests() []BuildParams {
817 return m.buildParams
Colin Crosscec81712017-07-13 14:43:27 -0700818}
819
Colin Cross4157e882019-06-06 16:57:04 -0700820func (m *ModuleBase) RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams {
821 return m.ruleParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800822}
823
Colin Cross4157e882019-06-06 16:57:04 -0700824func (m *ModuleBase) VariablesForTests() map[string]string {
825 return m.variables
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800826}
827
Colin Cross4157e882019-06-06 16:57:04 -0700828func (m *ModuleBase) Prefer32(prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool) {
829 m.prefer32 = prefer32
Colin Crossa9d8bee2018-10-02 13:59:46 -0700830}
831
Colin Crossce75d2c2016-10-06 16:12:58 -0700832// Name returns the name of the module. It may be overridden by individual module types, for
833// example prebuilts will prepend prebuilt_ to the name.
Colin Cross4157e882019-06-06 16:57:04 -0700834func (m *ModuleBase) Name() string {
835 return String(m.nameProperties.Name)
Colin Crossfc754582016-05-17 16:34:16 -0700836}
837
Colin Cross9a362232019-07-01 15:32:45 -0700838// String returns a string that includes the module name and variants for printing during debugging.
839func (m *ModuleBase) String() string {
840 sb := strings.Builder{}
841 sb.WriteString(m.commonProperties.DebugName)
842 sb.WriteString("{")
843 for i := range m.commonProperties.DebugMutators {
844 if i != 0 {
845 sb.WriteString(",")
846 }
847 sb.WriteString(m.commonProperties.DebugMutators[i])
848 sb.WriteString(":")
849 sb.WriteString(m.commonProperties.DebugVariations[i])
850 }
851 sb.WriteString("}")
852 return sb.String()
853}
854
Colin Crossce75d2c2016-10-06 16:12:58 -0700855// BaseModuleName returns the name of the module as specified in the blueprints file.
Colin Cross4157e882019-06-06 16:57:04 -0700856func (m *ModuleBase) BaseModuleName() string {
857 return String(m.nameProperties.Name)
Colin Crossce75d2c2016-10-06 16:12:58 -0700858}
859
Colin Cross4157e882019-06-06 16:57:04 -0700860func (m *ModuleBase) base() *ModuleBase {
861 return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800862}
863
Paul Duffine2453c72019-05-31 14:00:04 +0100864func (m *ModuleBase) qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName {
865 return qualifiedModuleName{pkg: ctx.ModuleDir(), name: ctx.ModuleName()}
866}
867
868func (m *ModuleBase) visibilityProperties() []visibilityProperty {
Paul Duffin63c6e182019-07-24 14:24:38 +0100869 return m.visibilityPropertyInfo
870}
871
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000872func (m *ModuleBase) Dists() []Dist {
Paul Duffined875132020-09-02 13:08:57 +0100873 if len(m.distProperties.Dist.Targets) > 0 {
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000874 // Make a copy of the underlying Dists slice to protect against
875 // backing array modifications with repeated calls to this method.
Paul Duffined875132020-09-02 13:08:57 +0100876 distsCopy := append([]Dist(nil), m.distProperties.Dists...)
877 return append(distsCopy, m.distProperties.Dist)
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000878 } else {
Paul Duffined875132020-09-02 13:08:57 +0100879 return m.distProperties.Dists
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000880 }
881}
882
883func (m *ModuleBase) GenerateTaggedDistFiles(ctx BaseModuleContext) TaggedDistFiles {
884 distFiles := make(TaggedDistFiles)
885 for _, dist := range m.Dists() {
886 var tag string
887 var distFilesForTag Paths
888 if dist.Tag == nil {
889 tag = ""
890 } else {
891 tag = *dist.Tag
892 }
893 distFilesForTag, err := m.base().module.(OutputFileProducer).OutputFiles(tag)
894 if err != nil {
895 ctx.PropertyErrorf("dist.tag", "%s", err.Error())
896 }
897 for _, distFile := range distFilesForTag {
898 if distFile != nil && !distFiles[tag].containsPath(distFile) {
899 distFiles[tag] = append(distFiles[tag], distFile)
900 }
901 }
902 }
903
904 return distFiles
905}
906
Colin Cross4157e882019-06-06 16:57:04 -0700907func (m *ModuleBase) Target() Target {
908 return m.commonProperties.CompileTarget
Dan Willemsen490fd492015-11-24 17:53:15 -0800909}
910
Colin Cross4157e882019-06-06 16:57:04 -0700911func (m *ModuleBase) TargetPrimary() bool {
912 return m.commonProperties.CompilePrimary
Colin Cross8b74d172016-09-13 09:59:14 -0700913}
914
Colin Cross4157e882019-06-06 16:57:04 -0700915func (m *ModuleBase) MultiTargets() []Target {
916 return m.commonProperties.CompileMultiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -0700917}
918
Colin Cross4157e882019-06-06 16:57:04 -0700919func (m *ModuleBase) Os() OsType {
920 return m.Target().Os
Dan Willemsen490fd492015-11-24 17:53:15 -0800921}
922
Colin Cross4157e882019-06-06 16:57:04 -0700923func (m *ModuleBase) Host() bool {
924 return m.Os().Class == Host || m.Os().Class == HostCross
Dan Willemsen97750522016-02-09 17:43:51 -0800925}
926
Yo Chiangbba545e2020-06-09 16:15:37 +0800927func (m *ModuleBase) Device() bool {
928 return m.Os().Class == Device
929}
930
Colin Cross4157e882019-06-06 16:57:04 -0700931func (m *ModuleBase) Arch() Arch {
932 return m.Target().Arch
Dan Willemsen97750522016-02-09 17:43:51 -0800933}
934
Colin Cross4157e882019-06-06 16:57:04 -0700935func (m *ModuleBase) ArchSpecific() bool {
936 return m.commonProperties.ArchSpecific
Dan Willemsen0b24c742016-10-04 15:13:37 -0700937}
938
Paul Duffin1356d8c2020-02-25 19:26:33 +0000939// True if the current variant is a CommonOS variant, false otherwise.
940func (m *ModuleBase) IsCommonOSVariant() bool {
941 return m.commonProperties.CommonOSVariant
942}
943
Colin Cross4157e882019-06-06 16:57:04 -0700944func (m *ModuleBase) OsClassSupported() []OsClass {
945 switch m.commonProperties.HostOrDeviceSupported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700946 case HostSupported:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700947 return []OsClass{Host, HostCross}
Dan Albertc6345fb2016-10-20 01:36:11 -0700948 case HostSupportedNoCross:
949 return []OsClass{Host}
Colin Crossa1ad8d12016-06-01 17:09:44 -0700950 case DeviceSupported:
951 return []OsClass{Device}
Dan Albert0981b5c2018-08-02 13:46:35 -0700952 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700953 var supported []OsClass
Colin Cross4157e882019-06-06 16:57:04 -0700954 if Bool(m.hostAndDeviceProperties.Host_supported) ||
955 (m.commonProperties.HostOrDeviceSupported == HostAndDeviceDefault &&
956 m.hostAndDeviceProperties.Host_supported == nil) {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700957 supported = append(supported, Host, HostCross)
958 }
Colin Cross4157e882019-06-06 16:57:04 -0700959 if m.hostAndDeviceProperties.Device_supported == nil ||
960 *m.hostAndDeviceProperties.Device_supported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700961 supported = append(supported, Device)
962 }
963 return supported
964 default:
965 return nil
966 }
Colin Cross3f40fa42015-01-30 17:27:36 -0800967}
968
Colin Cross4157e882019-06-06 16:57:04 -0700969func (m *ModuleBase) DeviceSupported() bool {
970 return m.commonProperties.HostOrDeviceSupported == DeviceSupported ||
971 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
972 (m.hostAndDeviceProperties.Device_supported == nil ||
973 *m.hostAndDeviceProperties.Device_supported)
Colin Cross3f40fa42015-01-30 17:27:36 -0800974}
975
Paul Duffine44358f2019-11-26 18:04:12 +0000976func (m *ModuleBase) HostSupported() bool {
977 return m.commonProperties.HostOrDeviceSupported == HostSupported ||
978 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
979 (m.hostAndDeviceProperties.Host_supported != nil &&
980 *m.hostAndDeviceProperties.Host_supported)
981}
982
Colin Cross4157e882019-06-06 16:57:04 -0700983func (m *ModuleBase) Platform() bool {
Justin Yund5f6c822019-06-25 16:47:17 +0900984 return !m.DeviceSpecific() && !m.SocSpecific() && !m.ProductSpecific() && !m.SystemExtSpecific()
Jiyong Parkc678ad32018-04-10 13:07:10 +0900985}
986
Colin Cross4157e882019-06-06 16:57:04 -0700987func (m *ModuleBase) DeviceSpecific() bool {
988 return Bool(m.commonProperties.Device_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900989}
990
Colin Cross4157e882019-06-06 16:57:04 -0700991func (m *ModuleBase) SocSpecific() bool {
992 return Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900993}
994
Colin Cross4157e882019-06-06 16:57:04 -0700995func (m *ModuleBase) ProductSpecific() bool {
996 return Bool(m.commonProperties.Product_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900997}
998
Justin Yund5f6c822019-06-25 16:47:17 +0900999func (m *ModuleBase) SystemExtSpecific() bool {
1000 return Bool(m.commonProperties.System_ext_specific)
Dario Frenifd05a742018-05-29 13:28:54 +01001001}
1002
Colin Crossc2d24052020-05-13 11:05:02 -07001003// RequiresStableAPIs returns true if the module will be installed to a partition that may
1004// be updated separately from the system image.
1005func (m *ModuleBase) RequiresStableAPIs(ctx BaseModuleContext) bool {
1006 return m.SocSpecific() || m.DeviceSpecific() ||
1007 (m.ProductSpecific() && ctx.Config().EnforceProductPartitionInterface())
1008}
1009
Bill Peckhamfff3f8a2020-03-20 18:33:20 -07001010func (m *ModuleBase) PartitionTag(config DeviceConfig) string {
1011 partition := "system"
1012 if m.SocSpecific() {
1013 // A SoC-specific module could be on the vendor partition at
1014 // "vendor" or the system partition at "system/vendor".
1015 if config.VendorPath() == "vendor" {
1016 partition = "vendor"
1017 }
1018 } else if m.DeviceSpecific() {
1019 // A device-specific module could be on the odm partition at
1020 // "odm", the vendor partition at "vendor/odm", or the system
1021 // partition at "system/vendor/odm".
1022 if config.OdmPath() == "odm" {
1023 partition = "odm"
Ramy Medhat944839a2020-03-31 22:14:52 -04001024 } else if strings.HasPrefix(config.OdmPath(), "vendor/") {
Bill Peckhamfff3f8a2020-03-20 18:33:20 -07001025 partition = "vendor"
1026 }
1027 } else if m.ProductSpecific() {
1028 // A product-specific module could be on the product partition
1029 // at "product" or the system partition at "system/product".
1030 if config.ProductPath() == "product" {
1031 partition = "product"
1032 }
1033 } else if m.SystemExtSpecific() {
1034 // A system_ext-specific module could be on the system_ext
1035 // partition at "system_ext" or the system partition at
1036 // "system/system_ext".
1037 if config.SystemExtPath() == "system_ext" {
1038 partition = "system_ext"
1039 }
1040 }
1041 return partition
1042}
1043
Colin Cross4157e882019-06-06 16:57:04 -07001044func (m *ModuleBase) Enabled() bool {
Justin Yun32f053b2020-07-31 23:07:17 +09001045 if m.commonProperties.ForcedDisabled {
1046 return false
1047 }
Colin Cross4157e882019-06-06 16:57:04 -07001048 if m.commonProperties.Enabled == nil {
1049 return !m.Os().DefaultDisabled
Dan Willemsen490fd492015-11-24 17:53:15 -08001050 }
Colin Cross4157e882019-06-06 16:57:04 -07001051 return *m.commonProperties.Enabled
Colin Cross3f40fa42015-01-30 17:27:36 -08001052}
1053
Inseob Kimeec88e12020-01-22 11:11:29 +09001054func (m *ModuleBase) Disable() {
Justin Yun32f053b2020-07-31 23:07:17 +09001055 m.commonProperties.ForcedDisabled = true
Inseob Kimeec88e12020-01-22 11:11:29 +09001056}
1057
Colin Cross4157e882019-06-06 16:57:04 -07001058func (m *ModuleBase) SkipInstall() {
1059 m.commonProperties.SkipInstall = true
Colin Crossce75d2c2016-10-06 16:12:58 -07001060}
1061
Ulya Trafimovichb28cc372020-01-13 15:18:16 +00001062func (m *ModuleBase) IsSkipInstall() bool {
1063 return m.commonProperties.SkipInstall == true
1064}
1065
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001066// Similar to SkipInstall, but if the AndroidMk entry would set
1067// LOCAL_UNINSTALLABLE_MODULE then this variant may still output that entry
1068// rather than leaving it out altogether. That happens in cases where it would
1069// have other side effects, in particular when it adds a NOTICE file target,
1070// which other install targets might depend on.
1071func (m *ModuleBase) MakeUninstallable() {
1072 m.SkipInstall()
1073}
1074
Liz Kammer5ca3a622020-08-05 15:40:41 -07001075func (m *ModuleBase) ReplacedByPrebuilt() {
1076 m.commonProperties.ReplacedByPrebuilt = true
1077 m.SkipInstall()
1078}
1079
1080func (m *ModuleBase) IsReplacedByPrebuilt() bool {
1081 return m.commonProperties.ReplacedByPrebuilt
1082}
1083
Colin Cross4157e882019-06-06 16:57:04 -07001084func (m *ModuleBase) ExportedToMake() bool {
1085 return m.commonProperties.NamespaceExportedToMake
Jiyong Park374510b2018-03-19 18:23:01 +09001086}
1087
Colin Cross897266e2020-02-13 13:22:08 -08001088func (m *ModuleBase) computeInstallDeps(ctx blueprint.ModuleContext) InstallPaths {
Colin Cross3f40fa42015-01-30 17:27:36 -08001089
Colin Cross897266e2020-02-13 13:22:08 -08001090 var result InstallPaths
Colin Cross6b753602018-06-21 13:03:07 -07001091 // TODO(ccross): we need to use WalkDeps and have some way to know which dependencies require installation
Colin Cross897266e2020-02-13 13:22:08 -08001092 ctx.VisitDepsDepthFirst(func(m blueprint.Module) {
1093 if a, ok := m.(Module); ok {
1094 result = append(result, a.filesToInstall()...)
1095 }
1096 })
Colin Cross3f40fa42015-01-30 17:27:36 -08001097
1098 return result
1099}
1100
Colin Cross897266e2020-02-13 13:22:08 -08001101func (m *ModuleBase) filesToInstall() InstallPaths {
Colin Cross4157e882019-06-06 16:57:04 -07001102 return m.installFiles
Colin Cross3f40fa42015-01-30 17:27:36 -08001103}
1104
Colin Cross4157e882019-06-06 16:57:04 -07001105func (m *ModuleBase) NoAddressSanitizer() bool {
1106 return m.noAddressSanitizer
Colin Cross3f40fa42015-01-30 17:27:36 -08001107}
1108
Colin Cross4157e882019-06-06 16:57:04 -07001109func (m *ModuleBase) InstallInData() bool {
Dan Willemsen782a2d12015-12-21 14:55:28 -08001110 return false
1111}
1112
Jaewoong Jung0949f312019-09-11 10:25:18 -07001113func (m *ModuleBase) InstallInTestcases() bool {
1114 return false
1115}
1116
Colin Cross4157e882019-06-06 16:57:04 -07001117func (m *ModuleBase) InstallInSanitizerDir() bool {
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001118 return false
1119}
1120
Yifan Hong1b3348d2020-01-21 15:53:22 -08001121func (m *ModuleBase) InstallInRamdisk() bool {
1122 return Bool(m.commonProperties.Ramdisk)
1123}
1124
Colin Cross4157e882019-06-06 16:57:04 -07001125func (m *ModuleBase) InstallInRecovery() bool {
1126 return Bool(m.commonProperties.Recovery)
Jiyong Parkf9332f12018-02-01 00:54:12 +09001127}
1128
Colin Cross90ba5f42019-10-02 11:10:58 -07001129func (m *ModuleBase) InstallInRoot() bool {
1130 return false
1131}
1132
Colin Cross607d8582019-07-29 16:44:46 -07001133func (m *ModuleBase) InstallBypassMake() bool {
1134 return false
1135}
1136
Jiyong Park87788b52020-09-01 12:37:45 +09001137func (m *ModuleBase) InstallForceOS() (*OsType, *ArchType) {
1138 return nil, nil
Colin Cross6e359402020-02-10 15:29:54 -08001139}
1140
Colin Cross4157e882019-06-06 16:57:04 -07001141func (m *ModuleBase) Owner() string {
1142 return String(m.commonProperties.Owner)
Sundong Ahn4fd04bb2018-08-31 18:01:37 +09001143}
1144
Bob Badoura75b0572020-02-18 20:21:55 -08001145func (m *ModuleBase) NoticeFiles() Paths {
1146 return m.noticeFiles
Jiyong Park52818fc2019-03-18 12:01:38 +09001147}
1148
Colin Cross7228ecd2019-11-18 16:00:16 -08001149func (m *ModuleBase) setImageVariation(variant string) {
1150 m.commonProperties.ImageVariation = variant
1151}
1152
1153func (m *ModuleBase) ImageVariation() blueprint.Variation {
1154 return blueprint.Variation{
1155 Mutator: "image",
1156 Variation: m.base().commonProperties.ImageVariation,
1157 }
1158}
1159
Paul Duffin9b76c0b2020-03-12 10:24:35 +00001160func (m *ModuleBase) getVariationByMutatorName(mutator string) string {
1161 for i, v := range m.commonProperties.DebugMutators {
1162 if v == mutator {
1163 return m.commonProperties.DebugVariations[i]
1164 }
1165 }
1166
1167 return ""
1168}
1169
Yifan Hong1b3348d2020-01-21 15:53:22 -08001170func (m *ModuleBase) InRamdisk() bool {
1171 return m.base().commonProperties.ImageVariation == RamdiskVariation
1172}
1173
Colin Cross7228ecd2019-11-18 16:00:16 -08001174func (m *ModuleBase) InRecovery() bool {
1175 return m.base().commonProperties.ImageVariation == RecoveryVariation
1176}
1177
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09001178func (m *ModuleBase) RequiredModuleNames() []string {
1179 return m.base().commonProperties.Required
1180}
1181
1182func (m *ModuleBase) HostRequiredModuleNames() []string {
1183 return m.base().commonProperties.Host_required
1184}
1185
1186func (m *ModuleBase) TargetRequiredModuleNames() []string {
1187 return m.base().commonProperties.Target_required
1188}
1189
Inseob Kim8471cda2019-11-15 09:59:12 +09001190func (m *ModuleBase) InitRc() Paths {
1191 return append(Paths{}, m.initRcPaths...)
1192}
1193
1194func (m *ModuleBase) VintfFragments() Paths {
1195 return append(Paths{}, m.vintfFragmentsPaths...)
1196}
1197
Colin Cross4157e882019-06-06 16:57:04 -07001198func (m *ModuleBase) generateModuleTarget(ctx ModuleContext) {
Colin Cross897266e2020-02-13 13:22:08 -08001199 var allInstalledFiles InstallPaths
1200 var allCheckbuildFiles Paths
Colin Cross0875c522017-11-28 17:34:01 -08001201 ctx.VisitAllModuleVariants(func(module Module) {
1202 a := module.base()
Colin Crossc9404352015-03-26 16:10:12 -07001203 allInstalledFiles = append(allInstalledFiles, a.installFiles...)
1204 allCheckbuildFiles = append(allCheckbuildFiles, a.checkbuildFiles...)
Colin Cross3f40fa42015-01-30 17:27:36 -08001205 })
1206
Colin Cross0875c522017-11-28 17:34:01 -08001207 var deps Paths
Colin Cross9454bfa2015-03-17 13:24:18 -07001208
Colin Cross133ebef2020-08-14 17:38:45 -07001209 namespacePrefix := ctx.Namespace().id
Jeff Gaston088e29e2017-11-29 16:47:17 -08001210 if namespacePrefix != "" {
1211 namespacePrefix = namespacePrefix + "-"
1212 }
1213
Colin Cross3f40fa42015-01-30 17:27:36 -08001214 if len(allInstalledFiles) > 0 {
Colin Crossc3d87d32020-06-04 13:25:17 -07001215 name := namespacePrefix + ctx.ModuleName() + "-install"
1216 ctx.Phony(name, allInstalledFiles.Paths()...)
1217 m.installTarget = PathForPhony(ctx, name)
1218 deps = append(deps, m.installTarget)
Colin Cross9454bfa2015-03-17 13:24:18 -07001219 }
1220
1221 if len(allCheckbuildFiles) > 0 {
Colin Crossc3d87d32020-06-04 13:25:17 -07001222 name := namespacePrefix + ctx.ModuleName() + "-checkbuild"
1223 ctx.Phony(name, allCheckbuildFiles...)
1224 m.checkbuildTarget = PathForPhony(ctx, name)
1225 deps = append(deps, m.checkbuildTarget)
Colin Cross9454bfa2015-03-17 13:24:18 -07001226 }
1227
1228 if len(deps) > 0 {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001229 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08001230 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001231 suffix = "-soong"
1232 }
1233
Colin Crossc3d87d32020-06-04 13:25:17 -07001234 ctx.Phony(namespacePrefix+ctx.ModuleName()+suffix, deps...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07001235
Colin Cross4157e882019-06-06 16:57:04 -07001236 m.blueprintDir = ctx.ModuleDir()
Colin Cross3f40fa42015-01-30 17:27:36 -08001237 }
1238}
1239
Colin Crossc34d2322020-01-03 15:23:27 -08001240func determineModuleKind(m *ModuleBase, ctx blueprint.EarlyModuleContext) moduleKind {
Colin Cross4157e882019-06-06 16:57:04 -07001241 var socSpecific = Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
1242 var deviceSpecific = Bool(m.commonProperties.Device_specific)
1243 var productSpecific = Bool(m.commonProperties.Product_specific)
Justin Yund5f6c822019-06-25 16:47:17 +09001244 var systemExtSpecific = Bool(m.commonProperties.System_ext_specific)
Jiyong Park2db76922017-11-08 16:03:48 +09001245
Dario Frenifd05a742018-05-29 13:28:54 +01001246 msg := "conflicting value set here"
1247 if socSpecific && deviceSpecific {
1248 ctx.PropertyErrorf("device_specific", "a module cannot be specific to SoC and device at the same time.")
Colin Cross4157e882019-06-06 16:57:04 -07001249 if Bool(m.commonProperties.Vendor) {
Jiyong Park2db76922017-11-08 16:03:48 +09001250 ctx.PropertyErrorf("vendor", msg)
1251 }
Colin Cross4157e882019-06-06 16:57:04 -07001252 if Bool(m.commonProperties.Proprietary) {
Jiyong Park2db76922017-11-08 16:03:48 +09001253 ctx.PropertyErrorf("proprietary", msg)
1254 }
Colin Cross4157e882019-06-06 16:57:04 -07001255 if Bool(m.commonProperties.Soc_specific) {
Jiyong Park2db76922017-11-08 16:03:48 +09001256 ctx.PropertyErrorf("soc_specific", msg)
1257 }
1258 }
1259
Justin Yund5f6c822019-06-25 16:47:17 +09001260 if productSpecific && systemExtSpecific {
1261 ctx.PropertyErrorf("product_specific", "a module cannot be specific to product and system_ext at the same time.")
1262 ctx.PropertyErrorf("system_ext_specific", msg)
Dario Frenifd05a742018-05-29 13:28:54 +01001263 }
1264
Justin Yund5f6c822019-06-25 16:47:17 +09001265 if (socSpecific || deviceSpecific) && (productSpecific || systemExtSpecific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001266 if productSpecific {
1267 ctx.PropertyErrorf("product_specific", "a module cannot be specific to SoC or device and product at the same time.")
1268 } else {
Justin Yund5f6c822019-06-25 16:47:17 +09001269 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 +01001270 }
1271 if deviceSpecific {
1272 ctx.PropertyErrorf("device_specific", msg)
1273 } else {
Colin Cross4157e882019-06-06 16:57:04 -07001274 if Bool(m.commonProperties.Vendor) {
Dario Frenifd05a742018-05-29 13:28:54 +01001275 ctx.PropertyErrorf("vendor", msg)
1276 }
Colin Cross4157e882019-06-06 16:57:04 -07001277 if Bool(m.commonProperties.Proprietary) {
Dario Frenifd05a742018-05-29 13:28:54 +01001278 ctx.PropertyErrorf("proprietary", msg)
1279 }
Colin Cross4157e882019-06-06 16:57:04 -07001280 if Bool(m.commonProperties.Soc_specific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001281 ctx.PropertyErrorf("soc_specific", msg)
1282 }
1283 }
1284 }
1285
Jiyong Park2db76922017-11-08 16:03:48 +09001286 if productSpecific {
1287 return productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +09001288 } else if systemExtSpecific {
1289 return systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001290 } else if deviceSpecific {
1291 return deviceSpecificModule
1292 } else if socSpecific {
1293 return socSpecificModule
1294 } else {
1295 return platformModule
1296 }
1297}
1298
Colin Crossc34d2322020-01-03 15:23:27 -08001299func (m *ModuleBase) earlyModuleContextFactory(ctx blueprint.EarlyModuleContext) earlyModuleContext {
Colin Cross1184b642019-12-30 18:43:07 -08001300 return earlyModuleContext{
Colin Crossc34d2322020-01-03 15:23:27 -08001301 EarlyModuleContext: ctx,
1302 kind: determineModuleKind(m, ctx),
1303 config: ctx.Config().(Config),
Colin Cross3f40fa42015-01-30 17:27:36 -08001304 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001305}
1306
Colin Cross1184b642019-12-30 18:43:07 -08001307func (m *ModuleBase) baseModuleContextFactory(ctx blueprint.BaseModuleContext) baseModuleContext {
1308 return baseModuleContext{
1309 bp: ctx,
1310 earlyModuleContext: m.earlyModuleContextFactory(ctx),
1311 os: m.commonProperties.CompileOS,
1312 target: m.commonProperties.CompileTarget,
1313 targetPrimary: m.commonProperties.CompilePrimary,
1314 multiTargets: m.commonProperties.CompileMultiTargets,
1315 }
1316}
1317
Colin Cross4157e882019-06-06 16:57:04 -07001318func (m *ModuleBase) GenerateBuildActions(blueprintCtx blueprint.ModuleContext) {
Colin Cross25de6c32019-06-06 14:29:25 -07001319 ctx := &moduleContext{
Colin Cross0ea8ba82019-06-06 14:33:29 -07001320 module: m.module,
Colin Crossdc35e212019-06-06 16:13:11 -07001321 bp: blueprintCtx,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001322 baseModuleContext: m.baseModuleContextFactory(blueprintCtx),
1323 installDeps: m.computeInstallDeps(blueprintCtx),
1324 installFiles: m.installFiles,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001325 variables: make(map[string]string),
Colin Cross3f40fa42015-01-30 17:27:36 -08001326 }
1327
Colin Cross6c4f21f2019-06-06 15:41:36 -07001328 // Temporarily continue to call blueprintCtx.GetMissingDependencies() to maintain the previous behavior of never
1329 // reporting missing dependency errors in Blueprint when AllowMissingDependencies == true.
1330 // TODO: This will be removed once defaults modules handle missing dependency errors
1331 blueprintCtx.GetMissingDependencies()
1332
Colin Crossdc35e212019-06-06 16:13:11 -07001333 // For the final GenerateAndroidBuildActions pass, require that all visited dependencies Soong modules and
Paul Duffin1356d8c2020-02-25 19:26:33 +00001334 // are enabled. Unless the module is a CommonOS variant which may have dependencies on disabled variants
1335 // (because the dependencies are added before the modules are disabled). The
1336 // GetOsSpecificVariantsOfCommonOSVariant(...) method will ensure that the disabled variants are
1337 // ignored.
1338 ctx.baseModuleContext.strictVisitDeps = !m.IsCommonOSVariant()
Colin Crossdc35e212019-06-06 16:13:11 -07001339
Colin Cross4c83e5c2019-02-25 14:54:28 -08001340 if ctx.config.captureBuild {
1341 ctx.ruleParams = make(map[blueprint.Rule]blueprint.RuleParams)
1342 }
1343
Colin Cross67a5c132017-05-09 13:45:28 -07001344 desc := "//" + ctx.ModuleDir() + ":" + ctx.ModuleName() + " "
1345 var suffix []string
Colin Cross0875c522017-11-28 17:34:01 -08001346 if ctx.Os().Class != Device && ctx.Os().Class != Generic {
1347 suffix = append(suffix, ctx.Os().String())
Colin Cross67a5c132017-05-09 13:45:28 -07001348 }
Colin Cross0875c522017-11-28 17:34:01 -08001349 if !ctx.PrimaryArch() {
1350 suffix = append(suffix, ctx.Arch().ArchType.String())
Colin Cross67a5c132017-05-09 13:45:28 -07001351 }
Dan Willemsenb13a9482020-02-14 11:25:54 -08001352 if apex, ok := m.module.(ApexModule); ok && !apex.IsForPlatform() {
Colin Crosse07f2312020-08-13 11:24:56 -07001353 suffix = append(suffix, apex.ApexVariationName())
Dan Willemsenb13a9482020-02-14 11:25:54 -08001354 }
Colin Cross67a5c132017-05-09 13:45:28 -07001355
1356 ctx.Variable(pctx, "moduleDesc", desc)
1357
1358 s := ""
1359 if len(suffix) > 0 {
1360 s = " [" + strings.Join(suffix, " ") + "]"
1361 }
1362 ctx.Variable(pctx, "moduleDescSuffix", s)
1363
Dan Willemsen569edc52018-11-19 09:33:29 -08001364 // Some common property checks for properties that will be used later in androidmk.go
Paul Duffined875132020-09-02 13:08:57 +01001365 if m.distProperties.Dist.Dest != nil {
1366 _, err := validateSafePath(*m.distProperties.Dist.Dest)
Dan Willemsen569edc52018-11-19 09:33:29 -08001367 if err != nil {
1368 ctx.PropertyErrorf("dist.dest", "%s", err.Error())
1369 }
1370 }
Paul Duffined875132020-09-02 13:08:57 +01001371 if m.distProperties.Dist.Dir != nil {
1372 _, err := validateSafePath(*m.distProperties.Dist.Dir)
Dan Willemsen569edc52018-11-19 09:33:29 -08001373 if err != nil {
1374 ctx.PropertyErrorf("dist.dir", "%s", err.Error())
1375 }
1376 }
Paul Duffined875132020-09-02 13:08:57 +01001377 if m.distProperties.Dist.Suffix != nil {
1378 if strings.Contains(*m.distProperties.Dist.Suffix, "/") {
Dan Willemsen569edc52018-11-19 09:33:29 -08001379 ctx.PropertyErrorf("dist.suffix", "Suffix may not contain a '/' character.")
1380 }
1381 }
1382
Colin Cross4157e882019-06-06 16:57:04 -07001383 if m.Enabled() {
Jooyung Hand48f3c32019-08-23 11:18:57 +09001384 // ensure all direct android.Module deps are enabled
1385 ctx.VisitDirectDepsBlueprint(func(bm blueprint.Module) {
1386 if _, ok := bm.(Module); ok {
1387 ctx.validateAndroidModule(bm, ctx.baseModuleContext.strictVisitDeps)
1388 }
1389 })
1390
Bob Badoura75b0572020-02-18 20:21:55 -08001391 m.noticeFiles = make([]Path, 0)
1392 optPath := OptionalPath{}
1393 notice := proptools.StringDefault(m.commonProperties.Notice, "")
Colin Cross4157e882019-06-06 16:57:04 -07001394 if module := SrcIsModule(notice); module != "" {
Bob Badoura75b0572020-02-18 20:21:55 -08001395 optPath = ctx.ExpandOptionalSource(&notice, "notice")
1396 } else if notice != "" {
Jiyong Park52818fc2019-03-18 12:01:38 +09001397 noticePath := filepath.Join(ctx.ModuleDir(), notice)
Bob Badoura75b0572020-02-18 20:21:55 -08001398 optPath = ExistentPathForSource(ctx, noticePath)
1399 }
1400 if optPath.Valid() {
1401 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1402 } else {
1403 for _, notice = range []string{"LICENSE", "LICENCE", "NOTICE"} {
1404 noticePath := filepath.Join(ctx.ModuleDir(), notice)
1405 optPath = ExistentPathForSource(ctx, noticePath)
1406 if optPath.Valid() {
1407 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1408 }
1409 }
Jaewoong Jung62707f72018-11-16 13:26:43 -08001410 }
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001411
1412 m.module.GenerateAndroidBuildActions(ctx)
1413 if ctx.Failed() {
1414 return
1415 }
1416
1417 m.installFiles = append(m.installFiles, ctx.installFiles...)
1418 m.checkbuildFiles = append(m.checkbuildFiles, ctx.checkbuildFiles...)
Inseob Kim8471cda2019-11-15 09:59:12 +09001419 m.initRcPaths = PathsForModuleSrc(ctx, m.commonProperties.Init_rc)
1420 m.vintfFragmentsPaths = PathsForModuleSrc(ctx, m.commonProperties.Vintf_fragments)
Colin Crossc3d87d32020-06-04 13:25:17 -07001421 for k, v := range ctx.phonies {
1422 m.phonies[k] = append(m.phonies[k], v...)
1423 }
Colin Crossdc35e212019-06-06 16:13:11 -07001424 } else if ctx.Config().AllowMissingDependencies() {
1425 // If the module is not enabled it will not create any build rules, nothing will call
1426 // ctx.GetMissingDependencies(), and blueprint will consider the missing dependencies to be unhandled
1427 // and report them as an error even when AllowMissingDependencies = true. Call
1428 // ctx.GetMissingDependencies() here to tell blueprint not to handle them.
1429 ctx.GetMissingDependencies()
Colin Cross3f40fa42015-01-30 17:27:36 -08001430 }
1431
Colin Cross4157e882019-06-06 16:57:04 -07001432 if m == ctx.FinalModule().(Module).base() {
1433 m.generateModuleTarget(ctx)
Colin Cross9b1d13d2016-09-19 15:18:11 -07001434 if ctx.Failed() {
1435 return
1436 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001437 }
Colin Crosscec81712017-07-13 14:43:27 -07001438
Colin Cross4157e882019-06-06 16:57:04 -07001439 m.buildParams = ctx.buildParams
1440 m.ruleParams = ctx.ruleParams
1441 m.variables = ctx.variables
Colin Cross3f40fa42015-01-30 17:27:36 -08001442}
1443
Colin Cross1184b642019-12-30 18:43:07 -08001444type earlyModuleContext struct {
Colin Crossc34d2322020-01-03 15:23:27 -08001445 blueprint.EarlyModuleContext
Colin Cross1184b642019-12-30 18:43:07 -08001446
1447 kind moduleKind
1448 config Config
1449}
1450
1451func (e *earlyModuleContext) Glob(globPattern string, excludes []string) Paths {
1452 ret, err := e.GlobWithDeps(globPattern, excludes)
1453 if err != nil {
1454 e.ModuleErrorf("glob: %s", err.Error())
1455 }
1456 return pathsForModuleSrcFromFullPath(e, ret, true)
1457}
1458
1459func (e *earlyModuleContext) GlobFiles(globPattern string, excludes []string) Paths {
1460 ret, err := e.GlobWithDeps(globPattern, excludes)
1461 if err != nil {
1462 e.ModuleErrorf("glob: %s", err.Error())
1463 }
1464 return pathsForModuleSrcFromFullPath(e, ret, false)
1465}
1466
Colin Cross988414c2020-01-11 01:11:46 +00001467func (b *earlyModuleContext) IsSymlink(path Path) bool {
1468 fileInfo, err := b.config.fs.Lstat(path.String())
1469 if err != nil {
1470 b.ModuleErrorf("os.Lstat(%q) failed: %s", path.String(), err)
1471 }
1472 return fileInfo.Mode()&os.ModeSymlink == os.ModeSymlink
1473}
1474
1475func (b *earlyModuleContext) Readlink(path Path) string {
1476 dest, err := b.config.fs.Readlink(path.String())
1477 if err != nil {
1478 b.ModuleErrorf("os.Readlink(%q) failed: %s", path.String(), err)
1479 }
1480 return dest
1481}
1482
Colin Cross1184b642019-12-30 18:43:07 -08001483func (e *earlyModuleContext) Module() Module {
Colin Crossc34d2322020-01-03 15:23:27 -08001484 module, _ := e.EarlyModuleContext.Module().(Module)
Colin Cross1184b642019-12-30 18:43:07 -08001485 return module
1486}
1487
1488func (e *earlyModuleContext) Config() Config {
Colin Crossc34d2322020-01-03 15:23:27 -08001489 return e.EarlyModuleContext.Config().(Config)
Colin Cross1184b642019-12-30 18:43:07 -08001490}
1491
1492func (e *earlyModuleContext) AConfig() Config {
1493 return e.config
1494}
1495
1496func (e *earlyModuleContext) DeviceConfig() DeviceConfig {
1497 return DeviceConfig{e.config.deviceConfig}
1498}
1499
1500func (e *earlyModuleContext) Platform() bool {
1501 return e.kind == platformModule
1502}
1503
1504func (e *earlyModuleContext) DeviceSpecific() bool {
1505 return e.kind == deviceSpecificModule
1506}
1507
1508func (e *earlyModuleContext) SocSpecific() bool {
1509 return e.kind == socSpecificModule
1510}
1511
1512func (e *earlyModuleContext) ProductSpecific() bool {
1513 return e.kind == productSpecificModule
1514}
1515
1516func (e *earlyModuleContext) SystemExtSpecific() bool {
1517 return e.kind == systemExtSpecificModule
1518}
1519
Colin Cross133ebef2020-08-14 17:38:45 -07001520func (e *earlyModuleContext) Namespace() *Namespace {
1521 return e.EarlyModuleContext.Namespace().(*Namespace)
1522}
1523
Colin Cross1184b642019-12-30 18:43:07 -08001524type baseModuleContext struct {
1525 bp blueprint.BaseModuleContext
1526 earlyModuleContext
Colin Crossfb0c16e2019-11-20 17:12:35 -08001527 os OsType
Colin Cross8b74d172016-09-13 09:59:14 -07001528 target Target
Colin Crossee0bc3b2018-10-02 22:01:37 -07001529 multiTargets []Target
Colin Cross8b74d172016-09-13 09:59:14 -07001530 targetPrimary bool
1531 debug bool
Colin Crossdc35e212019-06-06 16:13:11 -07001532
1533 walkPath []Module
Paul Duffinc5192442020-03-31 11:31:36 +01001534 tagPath []blueprint.DependencyTag
Colin Crossdc35e212019-06-06 16:13:11 -07001535
1536 strictVisitDeps bool // If true, enforce that all dependencies are enabled
Colin Crossf6566ed2015-03-24 11:13:38 -07001537}
1538
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001539func (b *baseModuleContext) OtherModuleName(m blueprint.Module) string {
1540 return b.bp.OtherModuleName(m)
1541}
1542func (b *baseModuleContext) OtherModuleDir(m blueprint.Module) string { return b.bp.OtherModuleDir(m) }
Colin Cross1184b642019-12-30 18:43:07 -08001543func (b *baseModuleContext) OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{}) {
Jooyung Hancd87c692020-02-26 02:05:18 +09001544 b.bp.OtherModuleErrorf(m, fmt, args...)
Colin Cross1184b642019-12-30 18:43:07 -08001545}
1546func (b *baseModuleContext) OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag {
1547 return b.bp.OtherModuleDependencyTag(m)
1548}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001549func (b *baseModuleContext) OtherModuleExists(name string) bool { return b.bp.OtherModuleExists(name) }
Martin Stjernholm009a9dc2020-03-05 17:34:13 +00001550func (b *baseModuleContext) OtherModuleDependencyVariantExists(variations []blueprint.Variation, name string) bool {
1551 return b.bp.OtherModuleDependencyVariantExists(variations, name)
1552}
1553func (b *baseModuleContext) OtherModuleReverseDependencyVariantExists(name string) bool {
1554 return b.bp.OtherModuleReverseDependencyVariantExists(name)
1555}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001556func (b *baseModuleContext) OtherModuleType(m blueprint.Module) string {
1557 return b.bp.OtherModuleType(m)
1558}
Colin Cross1184b642019-12-30 18:43:07 -08001559
1560func (b *baseModuleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1561 return b.bp.GetDirectDepWithTag(name, tag)
1562}
1563
Paul Duffinf88d8e02020-05-07 20:21:34 +01001564func (b *baseModuleContext) blueprintBaseModuleContext() blueprint.BaseModuleContext {
1565 return b.bp
1566}
1567
Colin Cross25de6c32019-06-06 14:29:25 -07001568type moduleContext struct {
Colin Crossdc35e212019-06-06 16:13:11 -07001569 bp blueprint.ModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -07001570 baseModuleContext
Colin Cross897266e2020-02-13 13:22:08 -08001571 installDeps InstallPaths
1572 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001573 checkbuildFiles Paths
Colin Cross8d8f8e22016-08-03 11:57:50 -07001574 module Module
Colin Crossc3d87d32020-06-04 13:25:17 -07001575 phonies map[string]Paths
Colin Crosscec81712017-07-13 14:43:27 -07001576
1577 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001578 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001579 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001580 variables map[string]string
Colin Cross6ff51382015-12-17 16:39:19 -08001581}
1582
Colin Crossb88b3c52019-06-10 15:15:17 -07001583func (m *moduleContext) ninjaError(params BuildParams, err error) (PackageContext, BuildParams) {
1584 return pctx, BuildParams{
Colin Cross4b69c492019-06-07 13:06:06 -07001585 Rule: ErrorRule,
1586 Description: params.Description,
1587 Output: params.Output,
1588 Outputs: params.Outputs,
1589 ImplicitOutput: params.ImplicitOutput,
1590 ImplicitOutputs: params.ImplicitOutputs,
Colin Cross6ff51382015-12-17 16:39:19 -08001591 Args: map[string]string{
1592 "error": err.Error(),
1593 },
Colin Crossb88b3c52019-06-10 15:15:17 -07001594 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001595}
1596
Colin Cross25de6c32019-06-06 14:29:25 -07001597func (m *moduleContext) ModuleBuild(pctx PackageContext, params ModuleBuildParams) {
1598 m.Build(pctx, BuildParams(params))
Colin Cross3f40fa42015-01-30 17:27:36 -08001599}
1600
Colin Cross0875c522017-11-28 17:34:01 -08001601func convertBuildParams(params BuildParams) blueprint.BuildParams {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001602 bparams := blueprint.BuildParams{
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001603 Rule: params.Rule,
Colin Cross0875c522017-11-28 17:34:01 -08001604 Description: params.Description,
Colin Cross33bfb0a2016-11-21 17:23:08 -08001605 Deps: params.Deps,
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001606 Outputs: params.Outputs.Strings(),
1607 ImplicitOutputs: params.ImplicitOutputs.Strings(),
1608 Inputs: params.Inputs.Strings(),
1609 Implicits: params.Implicits.Strings(),
1610 OrderOnly: params.OrderOnly.Strings(),
Colin Cross824f1162020-07-16 13:07:51 -07001611 Validations: params.Validations.Strings(),
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001612 Args: params.Args,
1613 Optional: !params.Default,
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001614 }
1615
Colin Cross33bfb0a2016-11-21 17:23:08 -08001616 if params.Depfile != nil {
1617 bparams.Depfile = params.Depfile.String()
1618 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001619 if params.Output != nil {
1620 bparams.Outputs = append(bparams.Outputs, params.Output.String())
1621 }
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001622 if params.ImplicitOutput != nil {
1623 bparams.ImplicitOutputs = append(bparams.ImplicitOutputs, params.ImplicitOutput.String())
1624 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001625 if params.Input != nil {
1626 bparams.Inputs = append(bparams.Inputs, params.Input.String())
1627 }
1628 if params.Implicit != nil {
1629 bparams.Implicits = append(bparams.Implicits, params.Implicit.String())
1630 }
Colin Cross824f1162020-07-16 13:07:51 -07001631 if params.Validation != nil {
1632 bparams.Validations = append(bparams.Validations, params.Validation.String())
1633 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001634
Colin Cross0b9f31f2019-02-28 11:00:01 -08001635 bparams.Outputs = proptools.NinjaEscapeList(bparams.Outputs)
1636 bparams.ImplicitOutputs = proptools.NinjaEscapeList(bparams.ImplicitOutputs)
1637 bparams.Inputs = proptools.NinjaEscapeList(bparams.Inputs)
1638 bparams.Implicits = proptools.NinjaEscapeList(bparams.Implicits)
1639 bparams.OrderOnly = proptools.NinjaEscapeList(bparams.OrderOnly)
Colin Cross824f1162020-07-16 13:07:51 -07001640 bparams.Validations = proptools.NinjaEscapeList(bparams.Validations)
1641 bparams.Depfile = proptools.NinjaEscape(bparams.Depfile)
Colin Crossfe4bc362018-09-12 10:02:13 -07001642
Colin Cross0875c522017-11-28 17:34:01 -08001643 return bparams
1644}
1645
Colin Cross25de6c32019-06-06 14:29:25 -07001646func (m *moduleContext) Variable(pctx PackageContext, name, value string) {
1647 if m.config.captureBuild {
1648 m.variables[name] = value
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001649 }
1650
Colin Crossdc35e212019-06-06 16:13:11 -07001651 m.bp.Variable(pctx.PackageContext, name, value)
Colin Cross0875c522017-11-28 17:34:01 -08001652}
1653
Colin Cross25de6c32019-06-06 14:29:25 -07001654func (m *moduleContext) Rule(pctx PackageContext, name string, params blueprint.RuleParams,
Colin Cross0875c522017-11-28 17:34:01 -08001655 argNames ...string) blueprint.Rule {
1656
Ramy Medhat944839a2020-03-31 22:14:52 -04001657 if m.config.UseRemoteBuild() {
1658 if params.Pool == nil {
1659 // When USE_GOMA=true or USE_RBE=true are set and the rule is not supported by goma/RBE, restrict
1660 // jobs to the local parallelism value
1661 params.Pool = localPool
1662 } else if params.Pool == remotePool {
1663 // remotePool is a fake pool used to identify rule that are supported for remoting. If the rule's
1664 // pool is the remotePool, replace with nil so that ninja runs it at NINJA_REMOTE_NUM_JOBS
1665 // parallelism.
1666 params.Pool = nil
1667 }
Colin Cross2e2dbc22019-09-25 13:31:46 -07001668 }
1669
Colin Crossdc35e212019-06-06 16:13:11 -07001670 rule := m.bp.Rule(pctx.PackageContext, name, params, argNames...)
Colin Cross4c83e5c2019-02-25 14:54:28 -08001671
Colin Cross25de6c32019-06-06 14:29:25 -07001672 if m.config.captureBuild {
1673 m.ruleParams[rule] = params
Colin Cross4c83e5c2019-02-25 14:54:28 -08001674 }
1675
1676 return rule
Colin Cross0875c522017-11-28 17:34:01 -08001677}
1678
Colin Cross25de6c32019-06-06 14:29:25 -07001679func (m *moduleContext) Build(pctx PackageContext, params BuildParams) {
Colin Crossb88b3c52019-06-10 15:15:17 -07001680 if params.Description != "" {
1681 params.Description = "${moduleDesc}" + params.Description + "${moduleDescSuffix}"
1682 }
1683
1684 if missingDeps := m.GetMissingDependencies(); len(missingDeps) > 0 {
1685 pctx, params = m.ninjaError(params, fmt.Errorf("module %s missing dependencies: %s\n",
1686 m.ModuleName(), strings.Join(missingDeps, ", ")))
1687 }
1688
Colin Cross25de6c32019-06-06 14:29:25 -07001689 if m.config.captureBuild {
1690 m.buildParams = append(m.buildParams, params)
Colin Cross0875c522017-11-28 17:34:01 -08001691 }
1692
Colin Crossdc35e212019-06-06 16:13:11 -07001693 m.bp.Build(pctx.PackageContext, convertBuildParams(params))
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001694}
Colin Crossc3d87d32020-06-04 13:25:17 -07001695
1696func (m *moduleContext) Phony(name string, deps ...Path) {
1697 addPhony(m.config, name, deps...)
1698}
1699
Colin Cross25de6c32019-06-06 14:29:25 -07001700func (m *moduleContext) GetMissingDependencies() []string {
Colin Cross6c4f21f2019-06-06 15:41:36 -07001701 var missingDeps []string
1702 missingDeps = append(missingDeps, m.Module().base().commonProperties.MissingDeps...)
Colin Crossdc35e212019-06-06 16:13:11 -07001703 missingDeps = append(missingDeps, m.bp.GetMissingDependencies()...)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001704 missingDeps = FirstUniqueStrings(missingDeps)
1705 return missingDeps
Colin Cross6ff51382015-12-17 16:39:19 -08001706}
1707
Colin Crossdc35e212019-06-06 16:13:11 -07001708func (b *baseModuleContext) AddMissingDependencies(deps []string) {
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001709 if deps != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001710 missingDeps := &b.Module().base().commonProperties.MissingDeps
Colin Cross6c4f21f2019-06-06 15:41:36 -07001711 *missingDeps = append(*missingDeps, deps...)
1712 *missingDeps = FirstUniqueStrings(*missingDeps)
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001713 }
1714}
1715
Colin Crossdc35e212019-06-06 16:13:11 -07001716func (b *baseModuleContext) validateAndroidModule(module blueprint.Module, strict bool) Module {
Colin Crossd11fcda2017-10-23 17:59:01 -07001717 aModule, _ := module.(Module)
Colin Crossdc35e212019-06-06 16:13:11 -07001718
1719 if !strict {
1720 return aModule
1721 }
1722
Colin Cross380c69a2019-06-10 17:49:58 +00001723 if aModule == nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001724 b.ModuleErrorf("module %q not an android module", b.OtherModuleName(module))
Colin Cross380c69a2019-06-10 17:49:58 +00001725 return nil
1726 }
1727
1728 if !aModule.Enabled() {
Colin Crossdc35e212019-06-06 16:13:11 -07001729 if b.Config().AllowMissingDependencies() {
1730 b.AddMissingDependencies([]string{b.OtherModuleName(aModule)})
Colin Cross380c69a2019-06-10 17:49:58 +00001731 } else {
Colin Crossdc35e212019-06-06 16:13:11 -07001732 b.ModuleErrorf("depends on disabled module %q", b.OtherModuleName(aModule))
Colin Cross380c69a2019-06-10 17:49:58 +00001733 }
1734 return nil
1735 }
Colin Crossd11fcda2017-10-23 17:59:01 -07001736 return aModule
1737}
1738
Colin Crossdc35e212019-06-06 16:13:11 -07001739func (b *baseModuleContext) getDirectDepInternal(name string, tag blueprint.DependencyTag) (blueprint.Module, blueprint.DependencyTag) {
Jiyong Parkf2976302019-04-17 21:47:37 +09001740 type dep struct {
1741 mod blueprint.Module
1742 tag blueprint.DependencyTag
1743 }
1744 var deps []dep
Colin Crossdc35e212019-06-06 16:13:11 -07001745 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001746 if aModule, _ := module.(Module); aModule != nil && aModule.base().BaseModuleName() == name {
Colin Cross1184b642019-12-30 18:43:07 -08001747 returnedTag := b.bp.OtherModuleDependencyTag(aModule)
Jiyong Parkf2976302019-04-17 21:47:37 +09001748 if tag == nil || returnedTag == tag {
1749 deps = append(deps, dep{aModule, returnedTag})
1750 }
1751 }
1752 })
1753 if len(deps) == 1 {
1754 return deps[0].mod, deps[0].tag
1755 } else if len(deps) >= 2 {
1756 panic(fmt.Errorf("Multiple dependencies having same BaseModuleName() %q found from %q",
Colin Crossdc35e212019-06-06 16:13:11 -07001757 name, b.ModuleName()))
Jiyong Parkf2976302019-04-17 21:47:37 +09001758 } else {
1759 return nil, nil
1760 }
1761}
1762
Colin Crossdc35e212019-06-06 16:13:11 -07001763func (b *baseModuleContext) GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module {
Colin Cross0ef08162019-05-01 15:50:51 -07001764 var deps []Module
Colin Crossdc35e212019-06-06 16:13:11 -07001765 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001766 if aModule, _ := module.(Module); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001767 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Cross0ef08162019-05-01 15:50:51 -07001768 deps = append(deps, aModule)
1769 }
1770 }
1771 })
1772 return deps
1773}
1774
Colin Cross25de6c32019-06-06 14:29:25 -07001775func (m *moduleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1776 module, _ := m.getDirectDepInternal(name, tag)
1777 return module
Jiyong Parkf2976302019-04-17 21:47:37 +09001778}
1779
Colin Crossdc35e212019-06-06 16:13:11 -07001780func (b *baseModuleContext) GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag) {
1781 return b.getDirectDepInternal(name, nil)
Jiyong Parkf2976302019-04-17 21:47:37 +09001782}
1783
Colin Crossdc35e212019-06-06 16:13:11 -07001784func (b *baseModuleContext) VisitDirectDepsBlueprint(visit func(blueprint.Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001785 b.bp.VisitDirectDeps(visit)
Colin Cross35143d02017-11-16 00:11:20 -08001786}
1787
Colin Crossdc35e212019-06-06 16:13:11 -07001788func (b *baseModuleContext) VisitDirectDeps(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001789 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001790 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001791 visit(aModule)
1792 }
1793 })
1794}
1795
Colin Crossdc35e212019-06-06 16:13:11 -07001796func (b *baseModuleContext) VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001797 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001798 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001799 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Crossee6143c2017-12-30 17:54:27 -08001800 visit(aModule)
1801 }
1802 }
1803 })
1804}
1805
Colin Crossdc35e212019-06-06 16:13:11 -07001806func (b *baseModuleContext) VisitDirectDepsIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001807 b.bp.VisitDirectDepsIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001808 // pred
1809 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001810 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001811 return pred(aModule)
1812 } else {
1813 return false
1814 }
1815 },
1816 // visit
1817 func(module blueprint.Module) {
1818 visit(module.(Module))
1819 })
1820}
1821
Colin Crossdc35e212019-06-06 16:13:11 -07001822func (b *baseModuleContext) VisitDepsDepthFirst(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001823 b.bp.VisitDepsDepthFirst(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001824 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001825 visit(aModule)
1826 }
1827 })
1828}
1829
Colin Crossdc35e212019-06-06 16:13:11 -07001830func (b *baseModuleContext) VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001831 b.bp.VisitDepsDepthFirstIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001832 // pred
1833 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001834 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001835 return pred(aModule)
1836 } else {
1837 return false
1838 }
1839 },
1840 // visit
1841 func(module blueprint.Module) {
1842 visit(module.(Module))
1843 })
1844}
1845
Colin Crossdc35e212019-06-06 16:13:11 -07001846func (b *baseModuleContext) WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool) {
Colin Cross1184b642019-12-30 18:43:07 -08001847 b.bp.WalkDeps(visit)
Alex Light778127a2019-02-27 14:19:50 -08001848}
1849
Colin Crossdc35e212019-06-06 16:13:11 -07001850func (b *baseModuleContext) WalkDeps(visit func(Module, Module) bool) {
1851 b.walkPath = []Module{b.Module()}
Paul Duffinc5192442020-03-31 11:31:36 +01001852 b.tagPath = []blueprint.DependencyTag{}
Colin Cross1184b642019-12-30 18:43:07 -08001853 b.bp.WalkDeps(func(child, parent blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001854 childAndroidModule, _ := child.(Module)
1855 parentAndroidModule, _ := parent.(Module)
Colin Crossd11fcda2017-10-23 17:59:01 -07001856 if childAndroidModule != nil && parentAndroidModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001857 // record walkPath before visit
1858 for b.walkPath[len(b.walkPath)-1] != parentAndroidModule {
1859 b.walkPath = b.walkPath[0 : len(b.walkPath)-1]
Paul Duffinc5192442020-03-31 11:31:36 +01001860 b.tagPath = b.tagPath[0 : len(b.tagPath)-1]
Colin Crossdc35e212019-06-06 16:13:11 -07001861 }
1862 b.walkPath = append(b.walkPath, childAndroidModule)
Paul Duffinc5192442020-03-31 11:31:36 +01001863 b.tagPath = append(b.tagPath, b.OtherModuleDependencyTag(childAndroidModule))
Colin Crossd11fcda2017-10-23 17:59:01 -07001864 return visit(childAndroidModule, parentAndroidModule)
1865 } else {
1866 return false
1867 }
1868 })
1869}
1870
Colin Crossdc35e212019-06-06 16:13:11 -07001871func (b *baseModuleContext) GetWalkPath() []Module {
1872 return b.walkPath
1873}
1874
Paul Duffinc5192442020-03-31 11:31:36 +01001875func (b *baseModuleContext) GetTagPath() []blueprint.DependencyTag {
1876 return b.tagPath
1877}
1878
Jiyong Park1c7e9622020-05-07 16:12:13 +09001879// A regexp for removing boilerplate from BaseDependencyTag from the string representation of
1880// a dependency tag.
Colin Cross6e511a92020-07-27 21:26:48 -07001881var tagCleaner = regexp.MustCompile(`\QBaseDependencyTag:{}\E(, )?`)
Jiyong Park1c7e9622020-05-07 16:12:13 +09001882
1883// PrettyPrintTag returns string representation of the tag, but prefers
1884// custom String() method if available.
1885func PrettyPrintTag(tag blueprint.DependencyTag) string {
1886 // Use tag's custom String() method if available.
1887 if stringer, ok := tag.(fmt.Stringer); ok {
1888 return stringer.String()
1889 }
1890
1891 // Otherwise, get a default string representation of the tag's struct.
Colin Cross6e511a92020-07-27 21:26:48 -07001892 tagString := fmt.Sprintf("%T: %+v", tag, tag)
Jiyong Park1c7e9622020-05-07 16:12:13 +09001893
1894 // Remove the boilerplate from BaseDependencyTag as it adds no value.
1895 tagString = tagCleaner.ReplaceAllString(tagString, "")
1896 return tagString
1897}
1898
1899func (b *baseModuleContext) GetPathString(skipFirst bool) string {
1900 sb := strings.Builder{}
1901 tagPath := b.GetTagPath()
1902 walkPath := b.GetWalkPath()
1903 if !skipFirst {
1904 sb.WriteString(walkPath[0].String())
1905 }
1906 for i, m := range walkPath[1:] {
1907 sb.WriteString("\n")
1908 sb.WriteString(fmt.Sprintf(" via tag %s\n", PrettyPrintTag(tagPath[i])))
1909 sb.WriteString(fmt.Sprintf(" -> %s", m.String()))
1910 }
1911 return sb.String()
1912}
1913
Colin Cross25de6c32019-06-06 14:29:25 -07001914func (m *moduleContext) VisitAllModuleVariants(visit func(Module)) {
Colin Crossdc35e212019-06-06 16:13:11 -07001915 m.bp.VisitAllModuleVariants(func(module blueprint.Module) {
Colin Cross0875c522017-11-28 17:34:01 -08001916 visit(module.(Module))
1917 })
1918}
1919
Colin Cross25de6c32019-06-06 14:29:25 -07001920func (m *moduleContext) PrimaryModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001921 return m.bp.PrimaryModule().(Module)
Colin Cross0875c522017-11-28 17:34:01 -08001922}
1923
Colin Cross25de6c32019-06-06 14:29:25 -07001924func (m *moduleContext) FinalModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001925 return m.bp.FinalModule().(Module)
1926}
1927
1928func (m *moduleContext) ModuleSubDir() string {
1929 return m.bp.ModuleSubDir()
Colin Cross0875c522017-11-28 17:34:01 -08001930}
1931
Colin Cross0ea8ba82019-06-06 14:33:29 -07001932func (b *baseModuleContext) Target() Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001933 return b.target
Colin Crossa1ad8d12016-06-01 17:09:44 -07001934}
1935
Colin Cross0ea8ba82019-06-06 14:33:29 -07001936func (b *baseModuleContext) TargetPrimary() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001937 return b.targetPrimary
Colin Cross8b74d172016-09-13 09:59:14 -07001938}
1939
Colin Cross0ea8ba82019-06-06 14:33:29 -07001940func (b *baseModuleContext) MultiTargets() []Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001941 return b.multiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07001942}
1943
Colin Cross0ea8ba82019-06-06 14:33:29 -07001944func (b *baseModuleContext) Arch() Arch {
Colin Cross25de6c32019-06-06 14:29:25 -07001945 return b.target.Arch
Colin Cross3f40fa42015-01-30 17:27:36 -08001946}
1947
Colin Cross0ea8ba82019-06-06 14:33:29 -07001948func (b *baseModuleContext) Os() OsType {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001949 return b.os
Dan Willemsen490fd492015-11-24 17:53:15 -08001950}
1951
Colin Cross0ea8ba82019-06-06 14:33:29 -07001952func (b *baseModuleContext) Host() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001953 return b.os.Class == Host || b.os.Class == HostCross
Colin Crossf6566ed2015-03-24 11:13:38 -07001954}
1955
Colin Cross0ea8ba82019-06-06 14:33:29 -07001956func (b *baseModuleContext) Device() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001957 return b.os.Class == Device
Colin Crossf6566ed2015-03-24 11:13:38 -07001958}
1959
Colin Cross0ea8ba82019-06-06 14:33:29 -07001960func (b *baseModuleContext) Darwin() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001961 return b.os == Darwin
Colin Cross0af4b842015-04-30 16:36:18 -07001962}
1963
Colin Cross0ea8ba82019-06-06 14:33:29 -07001964func (b *baseModuleContext) Fuchsia() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001965 return b.os == Fuchsia
Doug Horn21b94272019-01-16 12:06:11 -08001966}
1967
Colin Cross0ea8ba82019-06-06 14:33:29 -07001968func (b *baseModuleContext) Windows() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08001969 return b.os == Windows
Colin Cross3edeee12017-04-04 12:59:48 -07001970}
1971
Colin Cross0ea8ba82019-06-06 14:33:29 -07001972func (b *baseModuleContext) Debug() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001973 return b.debug
Colin Crossf6566ed2015-03-24 11:13:38 -07001974}
1975
Colin Cross0ea8ba82019-06-06 14:33:29 -07001976func (b *baseModuleContext) PrimaryArch() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001977 if len(b.config.Targets[b.target.Os]) <= 1 {
Colin Cross67a5c132017-05-09 13:45:28 -07001978 return true
1979 }
Colin Cross25de6c32019-06-06 14:29:25 -07001980 return b.target.Arch.ArchType == b.config.Targets[b.target.Os][0].Arch.ArchType
Colin Cross1e7d3702016-08-24 15:25:47 -07001981}
1982
Jiyong Park5baac542018-08-28 09:55:37 +09001983// Makes this module a platform module, i.e. not specific to soc, device,
Justin Yund5f6c822019-06-25 16:47:17 +09001984// product, or system_ext.
Colin Cross4157e882019-06-06 16:57:04 -07001985func (m *ModuleBase) MakeAsPlatform() {
1986 m.commonProperties.Vendor = boolPtr(false)
1987 m.commonProperties.Proprietary = boolPtr(false)
1988 m.commonProperties.Soc_specific = boolPtr(false)
1989 m.commonProperties.Product_specific = boolPtr(false)
Justin Yund5f6c822019-06-25 16:47:17 +09001990 m.commonProperties.System_ext_specific = boolPtr(false)
Jiyong Park5baac542018-08-28 09:55:37 +09001991}
1992
Colin Cross4157e882019-06-06 16:57:04 -07001993func (m *ModuleBase) EnableNativeBridgeSupportByDefault() {
1994 m.commonProperties.Native_bridge_supported = boolPtr(true)
dimitry03dc3f62019-05-09 14:07:34 +02001995}
1996
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09001997func (m *ModuleBase) MakeAsSystemExt() {
Jooyung Han91df2082019-11-20 01:49:42 +09001998 m.commonProperties.Vendor = boolPtr(false)
1999 m.commonProperties.Proprietary = boolPtr(false)
2000 m.commonProperties.Soc_specific = boolPtr(false)
2001 m.commonProperties.Product_specific = boolPtr(false)
2002 m.commonProperties.System_ext_specific = boolPtr(true)
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09002003}
2004
Jooyung Han344d5432019-08-23 11:17:39 +09002005// IsNativeBridgeSupported returns true if "native_bridge_supported" is explicitly set as "true"
2006func (m *ModuleBase) IsNativeBridgeSupported() bool {
2007 return proptools.Bool(m.commonProperties.Native_bridge_supported)
2008}
2009
Colin Cross25de6c32019-06-06 14:29:25 -07002010func (m *moduleContext) InstallInData() bool {
2011 return m.module.InstallInData()
Dan Willemsen782a2d12015-12-21 14:55:28 -08002012}
2013
Jaewoong Jung0949f312019-09-11 10:25:18 -07002014func (m *moduleContext) InstallInTestcases() bool {
2015 return m.module.InstallInTestcases()
2016}
2017
Colin Cross25de6c32019-06-06 14:29:25 -07002018func (m *moduleContext) InstallInSanitizerDir() bool {
2019 return m.module.InstallInSanitizerDir()
Vishwath Mohan1dd88392017-03-29 22:00:18 -07002020}
2021
Yifan Hong1b3348d2020-01-21 15:53:22 -08002022func (m *moduleContext) InstallInRamdisk() bool {
2023 return m.module.InstallInRamdisk()
2024}
2025
Colin Cross25de6c32019-06-06 14:29:25 -07002026func (m *moduleContext) InstallInRecovery() bool {
2027 return m.module.InstallInRecovery()
Jiyong Parkf9332f12018-02-01 00:54:12 +09002028}
2029
Colin Cross90ba5f42019-10-02 11:10:58 -07002030func (m *moduleContext) InstallInRoot() bool {
2031 return m.module.InstallInRoot()
2032}
2033
Colin Cross607d8582019-07-29 16:44:46 -07002034func (m *moduleContext) InstallBypassMake() bool {
2035 return m.module.InstallBypassMake()
2036}
2037
Jiyong Park87788b52020-09-01 12:37:45 +09002038func (m *moduleContext) InstallForceOS() (*OsType, *ArchType) {
Colin Cross6e359402020-02-10 15:29:54 -08002039 return m.module.InstallForceOS()
2040}
2041
Colin Cross70dda7e2019-10-01 22:05:35 -07002042func (m *moduleContext) skipInstall(fullInstallPath InstallPath) bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002043 if m.module.base().commonProperties.SkipInstall {
Colin Cross893d8162017-04-26 17:34:03 -07002044 return true
2045 }
2046
Colin Cross3607f212018-05-07 15:28:05 -07002047 // We'll need a solution for choosing which of modules with the same name in different
2048 // namespaces to install. For now, reuse the list of namespaces exported to Make as the
2049 // list of namespaces to install in a Soong-only build.
Colin Cross25de6c32019-06-06 14:29:25 -07002050 if !m.module.base().commonProperties.NamespaceExportedToMake {
Colin Cross3607f212018-05-07 15:28:05 -07002051 return true
2052 }
2053
Colin Cross25de6c32019-06-06 14:29:25 -07002054 if m.Device() {
Colin Cross607d8582019-07-29 16:44:46 -07002055 if m.Config().EmbeddedInMake() && !m.InstallBypassMake() {
Colin Cross893d8162017-04-26 17:34:03 -07002056 return true
2057 }
2058
Colin Cross25de6c32019-06-06 14:29:25 -07002059 if m.Config().SkipMegaDeviceInstall(fullInstallPath.String()) {
Colin Cross893d8162017-04-26 17:34:03 -07002060 return true
2061 }
2062 }
2063
2064 return false
2065}
2066
Colin Cross70dda7e2019-10-01 22:05:35 -07002067func (m *moduleContext) InstallFile(installPath InstallPath, name string, srcPath Path,
2068 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002069 return m.installFile(installPath, name, srcPath, Cp, deps)
Colin Cross5c517922017-08-31 12:29:17 -07002070}
2071
Colin Cross70dda7e2019-10-01 22:05:35 -07002072func (m *moduleContext) InstallExecutable(installPath InstallPath, name string, srcPath Path,
2073 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002074 return m.installFile(installPath, name, srcPath, CpExecutable, deps)
Colin Cross5c517922017-08-31 12:29:17 -07002075}
2076
Colin Cross70dda7e2019-10-01 22:05:35 -07002077func (m *moduleContext) installFile(installPath InstallPath, name string, srcPath Path,
2078 rule blueprint.Rule, deps []Path) InstallPath {
Colin Cross35cec122015-04-02 14:37:16 -07002079
Colin Cross25de6c32019-06-06 14:29:25 -07002080 fullInstallPath := installPath.Join(m, name)
David Srbecky07656412020-06-04 01:26:16 +01002081 m.module.base().hooks.runInstallHooks(m, srcPath, fullInstallPath, false)
Colin Cross3f40fa42015-01-30 17:27:36 -08002082
Colin Cross25de6c32019-06-06 14:29:25 -07002083 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07002084
Colin Cross897266e2020-02-13 13:22:08 -08002085 deps = append(deps, m.installDeps.Paths()...)
Colin Cross35cec122015-04-02 14:37:16 -07002086
Colin Cross89562dc2016-10-03 17:47:19 -07002087 var implicitDeps, orderOnlyDeps Paths
2088
Colin Cross25de6c32019-06-06 14:29:25 -07002089 if m.Host() {
Colin Cross89562dc2016-10-03 17:47:19 -07002090 // Installed host modules might be used during the build, depend directly on their
2091 // dependencies so their timestamp is updated whenever their dependency is updated
2092 implicitDeps = deps
2093 } else {
2094 orderOnlyDeps = deps
2095 }
2096
Colin Cross25de6c32019-06-06 14:29:25 -07002097 m.Build(pctx, BuildParams{
Colin Cross5c517922017-08-31 12:29:17 -07002098 Rule: rule,
Colin Cross67a5c132017-05-09 13:45:28 -07002099 Description: "install " + fullInstallPath.Base(),
2100 Output: fullInstallPath,
2101 Input: srcPath,
2102 Implicits: implicitDeps,
2103 OrderOnly: orderOnlyDeps,
Colin Cross25de6c32019-06-06 14:29:25 -07002104 Default: !m.Config().EmbeddedInMake(),
Dan Willemsen322acaf2016-01-12 23:07:05 -08002105 })
Colin Cross3f40fa42015-01-30 17:27:36 -08002106
Colin Cross25de6c32019-06-06 14:29:25 -07002107 m.installFiles = append(m.installFiles, fullInstallPath)
Dan Willemsen322acaf2016-01-12 23:07:05 -08002108 }
Colin Cross25de6c32019-06-06 14:29:25 -07002109 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross35cec122015-04-02 14:37:16 -07002110 return fullInstallPath
2111}
2112
Colin Cross70dda7e2019-10-01 22:05:35 -07002113func (m *moduleContext) InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002114 fullInstallPath := installPath.Join(m, name)
David Srbecky07656412020-06-04 01:26:16 +01002115 m.module.base().hooks.runInstallHooks(m, srcPath, fullInstallPath, true)
Colin Cross3854a602016-01-11 12:49:11 -08002116
Colin Cross25de6c32019-06-06 14:29:25 -07002117 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07002118
Alex Lightfb4353d2019-01-17 13:57:45 -08002119 relPath, err := filepath.Rel(path.Dir(fullInstallPath.String()), srcPath.String())
2120 if err != nil {
2121 panic(fmt.Sprintf("Unable to generate symlink between %q and %q: %s", fullInstallPath.Base(), srcPath.Base(), err))
2122 }
Colin Cross25de6c32019-06-06 14:29:25 -07002123 m.Build(pctx, BuildParams{
Colin Cross67a5c132017-05-09 13:45:28 -07002124 Rule: Symlink,
2125 Description: "install symlink " + fullInstallPath.Base(),
2126 Output: fullInstallPath,
Dan Willemsen40efa1c2020-01-14 15:19:52 -08002127 Input: srcPath,
Colin Cross25de6c32019-06-06 14:29:25 -07002128 Default: !m.Config().EmbeddedInMake(),
Colin Cross12fc4972016-01-11 12:49:11 -08002129 Args: map[string]string{
Alex Lightfb4353d2019-01-17 13:57:45 -08002130 "fromPath": relPath,
Colin Cross12fc4972016-01-11 12:49:11 -08002131 },
2132 })
Colin Cross3854a602016-01-11 12:49:11 -08002133
Colin Cross25de6c32019-06-06 14:29:25 -07002134 m.installFiles = append(m.installFiles, fullInstallPath)
2135 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross12fc4972016-01-11 12:49:11 -08002136 }
Colin Cross3854a602016-01-11 12:49:11 -08002137 return fullInstallPath
2138}
2139
Jiyong Parkf1194352019-02-25 11:05:47 +09002140// installPath/name -> absPath where absPath might be a path that is available only at runtime
2141// (e.g. /apex/...)
Colin Cross70dda7e2019-10-01 22:05:35 -07002142func (m *moduleContext) InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002143 fullInstallPath := installPath.Join(m, name)
David Srbecky07656412020-06-04 01:26:16 +01002144 m.module.base().hooks.runInstallHooks(m, nil, fullInstallPath, true)
Jiyong Parkf1194352019-02-25 11:05:47 +09002145
Colin Cross25de6c32019-06-06 14:29:25 -07002146 if !m.skipInstall(fullInstallPath) {
2147 m.Build(pctx, BuildParams{
Jiyong Parkf1194352019-02-25 11:05:47 +09002148 Rule: Symlink,
2149 Description: "install symlink " + fullInstallPath.Base() + " -> " + absPath,
2150 Output: fullInstallPath,
Colin Cross25de6c32019-06-06 14:29:25 -07002151 Default: !m.Config().EmbeddedInMake(),
Jiyong Parkf1194352019-02-25 11:05:47 +09002152 Args: map[string]string{
2153 "fromPath": absPath,
2154 },
2155 })
2156
Colin Cross25de6c32019-06-06 14:29:25 -07002157 m.installFiles = append(m.installFiles, fullInstallPath)
Jiyong Parkf1194352019-02-25 11:05:47 +09002158 }
2159 return fullInstallPath
2160}
2161
Colin Cross25de6c32019-06-06 14:29:25 -07002162func (m *moduleContext) CheckbuildFile(srcPath Path) {
2163 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross3f40fa42015-01-30 17:27:36 -08002164}
2165
Colin Cross41955e82019-05-29 14:40:35 -07002166// SrcIsModule decodes module references in the format ":name" into the module name, or empty string if the input
2167// was not a module reference.
2168func SrcIsModule(s string) (module string) {
Colin Cross068e0fe2016-12-13 15:23:47 -08002169 if len(s) > 1 && s[0] == ':' {
2170 return s[1:]
2171 }
2172 return ""
2173}
2174
Colin Cross41955e82019-05-29 14:40:35 -07002175// SrcIsModule decodes module references in the format ":name{.tag}" into the module name and tag, ":name" into the
2176// module name and an empty string for the tag, or empty strings if the input was not a module reference.
2177func SrcIsModuleWithTag(s string) (module, tag string) {
2178 if len(s) > 1 && s[0] == ':' {
2179 module = s[1:]
2180 if tagStart := strings.IndexByte(module, '{'); tagStart > 0 {
2181 if module[len(module)-1] == '}' {
2182 tag = module[tagStart+1 : len(module)-1]
2183 module = module[:tagStart]
2184 return module, tag
2185 }
2186 }
2187 return module, ""
2188 }
2189 return "", ""
Colin Cross068e0fe2016-12-13 15:23:47 -08002190}
2191
Colin Cross41955e82019-05-29 14:40:35 -07002192type sourceOrOutputDependencyTag struct {
2193 blueprint.BaseDependencyTag
2194 tag string
2195}
2196
2197func sourceOrOutputDepTag(tag string) blueprint.DependencyTag {
2198 return sourceOrOutputDependencyTag{tag: tag}
2199}
2200
2201var SourceDepTag = sourceOrOutputDepTag("")
Colin Cross068e0fe2016-12-13 15:23:47 -08002202
Colin Cross366938f2017-12-11 16:29:02 -08002203// Adds necessary dependencies to satisfy filegroup or generated sources modules listed in srcFiles
2204// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002205//
2206// Deprecated: tag the property with `android:"path"` instead.
Colin Cross068e0fe2016-12-13 15:23:47 -08002207func ExtractSourcesDeps(ctx BottomUpMutatorContext, srcFiles []string) {
Nan Zhang2439eb72017-04-10 11:27:50 -07002208 set := make(map[string]bool)
2209
Colin Cross068e0fe2016-12-13 15:23:47 -08002210 for _, s := range srcFiles {
Colin Cross41955e82019-05-29 14:40:35 -07002211 if m, t := SrcIsModuleWithTag(s); m != "" {
2212 if _, found := set[s]; found {
2213 ctx.ModuleErrorf("found source dependency duplicate: %q!", s)
Nan Zhang2439eb72017-04-10 11:27:50 -07002214 } else {
Colin Cross41955e82019-05-29 14:40:35 -07002215 set[s] = true
2216 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Nan Zhang2439eb72017-04-10 11:27:50 -07002217 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002218 }
2219 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002220}
2221
Colin Cross366938f2017-12-11 16:29:02 -08002222// Adds necessary dependencies to satisfy filegroup or generated sources modules specified in s
2223// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002224//
2225// Deprecated: tag the property with `android:"path"` instead.
Colin Cross366938f2017-12-11 16:29:02 -08002226func ExtractSourceDeps(ctx BottomUpMutatorContext, s *string) {
2227 if s != nil {
Colin Cross41955e82019-05-29 14:40:35 -07002228 if m, t := SrcIsModuleWithTag(*s); m != "" {
2229 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Colin Cross366938f2017-12-11 16:29:02 -08002230 }
2231 }
2232}
2233
Colin Cross41955e82019-05-29 14:40:35 -07002234// A module that implements SourceFileProducer can be referenced from any property that is tagged with `android:"path"`
2235// 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 -08002236type SourceFileProducer interface {
2237 Srcs() Paths
2238}
2239
Colin Cross41955e82019-05-29 14:40:35 -07002240// A module that implements OutputFileProducer can be referenced from any property that is tagged with `android:"path"`
Roland Levillain97c1f342019-11-22 14:20:54 +00002241// 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 -07002242// listed in the property.
2243type OutputFileProducer interface {
2244 OutputFiles(tag string) (Paths, error)
2245}
2246
Colin Cross5e708052019-08-06 13:59:50 -07002247// OutputFilesForModule returns the paths from an OutputFileProducer with the given tag. On error, including if the
2248// module produced zero paths, it reports errors to the ctx and returns nil.
2249func OutputFilesForModule(ctx PathContext, module blueprint.Module, tag string) Paths {
2250 paths, err := outputFilesForModule(ctx, module, tag)
2251 if err != nil {
2252 reportPathError(ctx, err)
2253 return nil
2254 }
2255 return paths
2256}
2257
2258// OutputFileForModule returns the path from an OutputFileProducer with the given tag. On error, including if the
2259// module produced zero or multiple paths, it reports errors to the ctx and returns nil.
2260func OutputFileForModule(ctx PathContext, module blueprint.Module, tag string) Path {
2261 paths, err := outputFilesForModule(ctx, module, tag)
2262 if err != nil {
2263 reportPathError(ctx, err)
2264 return nil
2265 }
2266 if len(paths) > 1 {
Ulya Trafimovich5ab276a2020-08-25 12:45:15 +01002267 ReportPathErrorf(ctx, "got multiple output files from module %q, expected exactly one",
Colin Cross5e708052019-08-06 13:59:50 -07002268 pathContextName(ctx, module))
2269 return nil
2270 }
2271 return paths[0]
2272}
2273
2274func outputFilesForModule(ctx PathContext, module blueprint.Module, tag string) (Paths, error) {
2275 if outputFileProducer, ok := module.(OutputFileProducer); ok {
2276 paths, err := outputFileProducer.OutputFiles(tag)
2277 if err != nil {
2278 return nil, fmt.Errorf("failed to get output file from module %q: %s",
2279 pathContextName(ctx, module), err.Error())
2280 }
2281 if len(paths) == 0 {
2282 return nil, fmt.Errorf("failed to get output files from module %q", pathContextName(ctx, module))
2283 }
2284 return paths, nil
2285 } else {
2286 return nil, fmt.Errorf("module %q is not an OutputFileProducer", pathContextName(ctx, module))
2287 }
2288}
2289
Colin Crossfe17f6f2019-03-28 19:30:56 -07002290type HostToolProvider interface {
2291 HostToolPath() OptionalPath
2292}
2293
Colin Cross27b922f2019-03-04 22:35:41 -08002294// Returns a list of paths expanded from globs and modules referenced using ":module" syntax. The property must
2295// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002296//
2297// Deprecated: use PathsForModuleSrc or PathsForModuleSrcExcludes instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002298func (m *moduleContext) ExpandSources(srcFiles, excludes []string) Paths {
2299 return PathsForModuleSrcExcludes(m, srcFiles, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07002300}
2301
Colin Cross2fafa3e2019-03-05 12:39:51 -08002302// Returns a single path expanded from globs and modules referenced using ":module" syntax. The property must
2303// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002304//
2305// Deprecated: use PathForModuleSrc instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002306func (m *moduleContext) ExpandSource(srcFile, prop string) Path {
2307 return PathForModuleSrc(m, srcFile)
Colin Cross2fafa3e2019-03-05 12:39:51 -08002308}
2309
2310// Returns an optional single path expanded from globs and modules referenced using ":module" syntax if
2311// the srcFile is non-nil. The property must be tagged with `android:"path" to support automatic source module
2312// dependency resolution.
Colin Cross25de6c32019-06-06 14:29:25 -07002313func (m *moduleContext) ExpandOptionalSource(srcFile *string, prop string) OptionalPath {
Colin Cross2fafa3e2019-03-05 12:39:51 -08002314 if srcFile != nil {
Colin Cross25de6c32019-06-06 14:29:25 -07002315 return OptionalPathForPath(PathForModuleSrc(m, *srcFile))
Colin Cross2fafa3e2019-03-05 12:39:51 -08002316 }
2317 return OptionalPath{}
2318}
2319
Colin Cross25de6c32019-06-06 14:29:25 -07002320func (m *moduleContext) RequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002321 return m.module.RequiredModuleNames()
Nan Zhang6d34b302017-02-04 17:47:46 -08002322}
2323
Colin Cross25de6c32019-06-06 14:29:25 -07002324func (m *moduleContext) HostRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002325 return m.module.HostRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002326}
2327
Colin Cross25de6c32019-06-06 14:29:25 -07002328func (m *moduleContext) TargetRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002329 return m.module.TargetRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002330}
2331
Colin Cross463a90e2015-06-17 14:20:06 -07002332func init() {
Colin Cross798bfce2016-10-12 14:28:16 -07002333 RegisterSingletonType("buildtarget", BuildTargetSingleton)
Colin Cross463a90e2015-06-17 14:20:06 -07002334}
2335
Colin Cross0875c522017-11-28 17:34:01 -08002336func BuildTargetSingleton() Singleton {
Colin Cross1f8c52b2015-06-16 16:38:17 -07002337 return &buildTargetSingleton{}
2338}
2339
Colin Cross87d8b562017-04-25 10:01:55 -07002340func parentDir(dir string) string {
2341 dir, _ = filepath.Split(dir)
2342 return filepath.Clean(dir)
2343}
2344
Colin Cross1f8c52b2015-06-16 16:38:17 -07002345type buildTargetSingleton struct{}
2346
Colin Cross0875c522017-11-28 17:34:01 -08002347func (c *buildTargetSingleton) GenerateBuildActions(ctx SingletonContext) {
2348 var checkbuildDeps Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07002349
Colin Crossc3d87d32020-06-04 13:25:17 -07002350 mmTarget := func(dir string) string {
2351 return "MODULES-IN-" + strings.Replace(filepath.Clean(dir), "/", "-", -1)
Colin Cross87d8b562017-04-25 10:01:55 -07002352 }
2353
Colin Cross0875c522017-11-28 17:34:01 -08002354 modulesInDir := make(map[string]Paths)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002355
Colin Cross0875c522017-11-28 17:34:01 -08002356 ctx.VisitAllModules(func(module Module) {
2357 blueprintDir := module.base().blueprintDir
2358 installTarget := module.base().installTarget
2359 checkbuildTarget := module.base().checkbuildTarget
Colin Cross1f8c52b2015-06-16 16:38:17 -07002360
Colin Cross0875c522017-11-28 17:34:01 -08002361 if checkbuildTarget != nil {
2362 checkbuildDeps = append(checkbuildDeps, checkbuildTarget)
2363 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], checkbuildTarget)
2364 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002365
Colin Cross0875c522017-11-28 17:34:01 -08002366 if installTarget != nil {
2367 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], installTarget)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002368 }
2369 })
2370
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002371 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08002372 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002373 suffix = "-soong"
2374 }
2375
Colin Cross1f8c52b2015-06-16 16:38:17 -07002376 // Create a top-level checkbuild target that depends on all modules
Colin Crossc3d87d32020-06-04 13:25:17 -07002377 ctx.Phony("checkbuild"+suffix, checkbuildDeps...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002378
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002379 // Make will generate the MODULES-IN-* targets
Colin Crossaabf6792017-11-29 00:27:14 -08002380 if ctx.Config().EmbeddedInMake() {
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002381 return
2382 }
2383
Colin Cross87d8b562017-04-25 10:01:55 -07002384 // Ensure ancestor directories are in modulesInDir
Inseob Kim1a365c62019-06-08 15:47:51 +09002385 dirs := SortedStringKeys(modulesInDir)
Colin Cross87d8b562017-04-25 10:01:55 -07002386 for _, dir := range dirs {
2387 dir := parentDir(dir)
2388 for dir != "." && dir != "/" {
2389 if _, exists := modulesInDir[dir]; exists {
2390 break
2391 }
2392 modulesInDir[dir] = nil
2393 dir = parentDir(dir)
2394 }
2395 }
2396
2397 // Make directories build their direct subdirectories
Colin Cross87d8b562017-04-25 10:01:55 -07002398 for _, dir := range dirs {
2399 p := parentDir(dir)
2400 if p != "." && p != "/" {
Colin Crossc3d87d32020-06-04 13:25:17 -07002401 modulesInDir[p] = append(modulesInDir[p], PathForPhony(ctx, mmTarget(dir)))
Colin Cross87d8b562017-04-25 10:01:55 -07002402 }
2403 }
2404
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002405 // Create a MODULES-IN-<directory> target that depends on all modules in a directory, and
2406 // depends on the MODULES-IN-* targets of all of its subdirectories that contain Android.bp
2407 // files.
Colin Cross1f8c52b2015-06-16 16:38:17 -07002408 for _, dir := range dirs {
Colin Crossc3d87d32020-06-04 13:25:17 -07002409 ctx.Phony(mmTarget(dir), modulesInDir[dir]...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002410 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002411
2412 // Create (host|host-cross|target)-<OS> phony rules to build a reduced checkbuild.
2413 osDeps := map[OsType]Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08002414 ctx.VisitAllModules(func(module Module) {
2415 if module.Enabled() {
2416 os := module.Target().Os
2417 osDeps[os] = append(osDeps[os], module.base().checkbuildFiles...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002418 }
2419 })
2420
Colin Cross0875c522017-11-28 17:34:01 -08002421 osClass := make(map[string]Paths)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002422 for os, deps := range osDeps {
2423 var className string
2424
2425 switch os.Class {
2426 case Host:
2427 className = "host"
2428 case HostCross:
2429 className = "host-cross"
2430 case Device:
2431 className = "target"
2432 default:
2433 continue
2434 }
2435
Colin Crossc3d87d32020-06-04 13:25:17 -07002436 name := className + "-" + os.Name
2437 osClass[className] = append(osClass[className], PathForPhony(ctx, name))
Dan Willemsen61d88b82017-09-20 17:29:08 -07002438
Colin Crossc3d87d32020-06-04 13:25:17 -07002439 ctx.Phony(name, deps...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002440 }
2441
2442 // Wrap those into host|host-cross|target phony rules
Inseob Kim1a365c62019-06-08 15:47:51 +09002443 for _, class := range SortedStringKeys(osClass) {
Colin Crossc3d87d32020-06-04 13:25:17 -07002444 ctx.Phony(class, osClass[class]...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002445 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002446}
Colin Crossd779da42015-12-17 18:00:23 -08002447
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002448// Collect information for opening IDE project files in java/jdeps.go.
2449type IDEInfo interface {
2450 IDEInfo(ideInfo *IdeInfo)
2451 BaseModuleName() string
2452}
2453
2454// Extract the base module name from the Import name.
2455// Often the Import name has a prefix "prebuilt_".
2456// Remove the prefix explicitly if needed
2457// until we find a better solution to get the Import name.
2458type IDECustomizedModuleName interface {
2459 IDECustomizedModuleName() string
2460}
2461
2462type IdeInfo struct {
2463 Deps []string `json:"dependencies,omitempty"`
2464 Srcs []string `json:"srcs,omitempty"`
2465 Aidl_include_dirs []string `json:"aidl_include_dirs,omitempty"`
2466 Jarjar_rules []string `json:"jarjar_rules,omitempty"`
2467 Jars []string `json:"jars,omitempty"`
2468 Classes []string `json:"class,omitempty"`
2469 Installed_paths []string `json:"installed,omitempty"`
patricktu18c82ff2019-05-10 15:48:50 +08002470 SrcJars []string `json:"srcjars,omitempty"`
bralee1fbf4402020-05-21 10:11:59 +08002471 Paths []string `json:"path,omitempty"`
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002472}
Paul Duffinf88d8e02020-05-07 20:21:34 +01002473
2474func CheckBlueprintSyntax(ctx BaseModuleContext, filename string, contents string) []error {
2475 bpctx := ctx.blueprintBaseModuleContext()
2476 return blueprint.CheckBlueprintSyntax(bpctx.ModuleFactories(), filename, contents)
2477}