blob: d64b5163c9b8dfe5dc25236567f0a3e8dd6cf2e7 [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
Jingwen Chence679d22020-09-23 04:30:02 +000046 SymlinkOutput WritablePath
47 SymlinkOutputs WritablePaths
Dan Willemsen9f3c5742016-11-03 14:28:31 -070048 ImplicitOutput WritablePath
49 ImplicitOutputs WritablePaths
50 Input Path
51 Inputs Paths
52 Implicit Path
53 Implicits Paths
54 OrderOnly Paths
Colin Cross824f1162020-07-16 13:07:51 -070055 Validation Path
56 Validations Paths
Dan Willemsen9f3c5742016-11-03 14:28:31 -070057 Default bool
58 Args map[string]string
Dan Willemsen34cc69e2015-09-23 15:26:20 -070059}
60
Colin Crossae887032017-10-23 17:16:14 -070061type ModuleBuildParams BuildParams
62
Colin Cross1184b642019-12-30 18:43:07 -080063// EarlyModuleContext provides methods that can be called early, as soon as the properties have
64// been parsed into the module and before any mutators have run.
65type EarlyModuleContext interface {
Colin Cross9f35c3d2020-09-16 19:04:41 -070066 // Module returns the current module as a Module. It should rarely be necessary, as the module already has a
67 // reference to itself.
Colin Cross1184b642019-12-30 18:43:07 -080068 Module() Module
Colin Cross9f35c3d2020-09-16 19:04:41 -070069
70 // ModuleName returns the name of the module. This is generally the value that was returned by Module.Name() when
71 // the module was created, but may have been modified by calls to BaseMutatorContext.Rename.
Colin Cross1184b642019-12-30 18:43:07 -080072 ModuleName() string
Colin Cross9f35c3d2020-09-16 19:04:41 -070073
74 // ModuleDir returns the path to the directory that contains the definition of the module.
Colin Cross1184b642019-12-30 18:43:07 -080075 ModuleDir() string
Colin Cross9f35c3d2020-09-16 19:04:41 -070076
77 // ModuleType returns the name of the module type that was used to create the module, as specified in
78 // RegisterModuleType.
Colin Cross1184b642019-12-30 18:43:07 -080079 ModuleType() string
Colin Cross9f35c3d2020-09-16 19:04:41 -070080
81 // BlueprintFile returns the name of the blueprint file that contains the definition of this
82 // module.
Colin Cross9d34f352019-11-22 16:03:51 -080083 BlueprintsFile() string
Colin Cross1184b642019-12-30 18:43:07 -080084
Colin Cross9f35c3d2020-09-16 19:04:41 -070085 // ContainsProperty returns true if the specified property name was set in the module definition.
Colin Cross1184b642019-12-30 18:43:07 -080086 ContainsProperty(name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -070087
88 // Errorf reports an error at the specified position of the module definition file.
Colin Cross1184b642019-12-30 18:43:07 -080089 Errorf(pos scanner.Position, fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -070090
91 // ModuleErrorf reports an error at the line number of the module type in the module definition.
Colin Cross1184b642019-12-30 18:43:07 -080092 ModuleErrorf(fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -070093
94 // PropertyErrorf reports an error at the line number of a property in the module definition.
Colin Cross1184b642019-12-30 18:43:07 -080095 PropertyErrorf(property, fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -070096
97 // Failed returns true if any errors have been reported. In most cases the module can continue with generating
98 // build rules after an error, allowing it to report additional errors in a single run, but in cases where the error
99 // has prevented the module from creating necessary data it can return early when Failed returns true.
Colin Cross1184b642019-12-30 18:43:07 -0800100 Failed() bool
101
Colin Cross9f35c3d2020-09-16 19:04:41 -0700102 // AddNinjaFileDeps adds dependencies on the specified files to the rule that creates the ninja manifest. The
103 // primary builder will be rerun whenever the specified files are modified.
Colin Cross1184b642019-12-30 18:43:07 -0800104 AddNinjaFileDeps(deps ...string)
105
106 DeviceSpecific() bool
107 SocSpecific() bool
108 ProductSpecific() bool
109 SystemExtSpecific() bool
110 Platform() bool
111
112 Config() Config
113 DeviceConfig() DeviceConfig
114
115 // Deprecated: use Config()
116 AConfig() Config
117
118 // GlobWithDeps returns a list of files that match the specified pattern but do not match any
119 // of the patterns in excludes. It also adds efficient dependencies to rerun the primary
120 // builder whenever a file matching the pattern as added or removed, without rerunning if a
121 // file that does not match the pattern is added to a searched directory.
122 GlobWithDeps(pattern string, excludes []string) ([]string, error)
123
124 Glob(globPattern string, excludes []string) Paths
125 GlobFiles(globPattern string, excludes []string) Paths
Colin Cross988414c2020-01-11 01:11:46 +0000126 IsSymlink(path Path) bool
127 Readlink(path Path) string
Colin Cross133ebef2020-08-14 17:38:45 -0700128
Colin Cross9f35c3d2020-09-16 19:04:41 -0700129 // Namespace returns the Namespace object provided by the NameInterface set by Context.SetNameInterface, or the
130 // default SimpleNameInterface if Context.SetNameInterface was not called.
Colin Cross133ebef2020-08-14 17:38:45 -0700131 Namespace() *Namespace
Colin Cross1184b642019-12-30 18:43:07 -0800132}
133
Colin Cross0ea8ba82019-06-06 14:33:29 -0700134// BaseModuleContext is the same as blueprint.BaseModuleContext except that Config() returns
Colin Crossdc35e212019-06-06 16:13:11 -0700135// a Config instead of an interface{}, and some methods have been wrapped to use an android.Module
136// instead of a blueprint.Module, plus some extra methods that return Android-specific information
Colin Cross0ea8ba82019-06-06 14:33:29 -0700137// about the current module.
138type BaseModuleContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800139 EarlyModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -0700140
Paul Duffinf88d8e02020-05-07 20:21:34 +0100141 blueprintBaseModuleContext() blueprint.BaseModuleContext
142
Colin Cross9f35c3d2020-09-16 19:04:41 -0700143 // OtherModuleName returns the name of another Module. See BaseModuleContext.ModuleName for more information.
144 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Colin Crossdc35e212019-06-06 16:13:11 -0700145 OtherModuleName(m blueprint.Module) string
Colin Cross9f35c3d2020-09-16 19:04:41 -0700146
147 // OtherModuleDir returns the directory of another Module. See BaseModuleContext.ModuleDir for more information.
148 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Colin Crossdc35e212019-06-06 16:13:11 -0700149 OtherModuleDir(m blueprint.Module) string
Colin Cross9f35c3d2020-09-16 19:04:41 -0700150
151 // OtherModuleErrorf reports an error on another Module. See BaseModuleContext.ModuleErrorf for more information.
152 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Colin Crossdc35e212019-06-06 16:13:11 -0700153 OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -0700154
155 // OtherModuleDependencyTag returns the dependency tag used to depend on a module, or nil if there is no dependency
156 // on the module. When called inside a Visit* method with current module being visited, and there are multiple
157 // dependencies on the module being visited, it returns the dependency tag used for the current dependency.
Colin Crossdc35e212019-06-06 16:13:11 -0700158 OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag
Colin Cross9f35c3d2020-09-16 19:04:41 -0700159
160 // OtherModuleExists returns true if a module with the specified name exists, as determined by the NameInterface
161 // passed to Context.SetNameInterface, or SimpleNameInterface if it was not called.
Colin Crossdc35e212019-06-06 16:13:11 -0700162 OtherModuleExists(name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -0700163
164 // OtherModuleDependencyVariantExists returns true if a module with the
165 // specified name and variant exists. The variant must match the given
166 // variations. It must also match all the non-local variations of the current
167 // module. In other words, it checks for the module AddVariationDependencies
168 // would add a dependency on with the same arguments.
Martin Stjernholm009a9dc2020-03-05 17:34:13 +0000169 OtherModuleDependencyVariantExists(variations []blueprint.Variation, name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -0700170
171 // OtherModuleReverseDependencyVariantExists returns true if a module with the
172 // specified name exists with the same variations as the current module. In
173 // other words, it checks for the module AddReverseDependency would add a
174 // dependency on with the same argument.
Martin Stjernholm009a9dc2020-03-05 17:34:13 +0000175 OtherModuleReverseDependencyVariantExists(name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -0700176
177 // OtherModuleType returns the type of another Module. See BaseModuleContext.ModuleType for more information.
178 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Jiyong Park9e6c2422019-08-09 20:39:45 +0900179 OtherModuleType(m blueprint.Module) string
Colin Crossdc35e212019-06-06 16:13:11 -0700180
Colin Crossd27e7b82020-07-02 11:38:17 -0700181 // OtherModuleProvider returns the value for a provider for the given module. If the value is
182 // not set it returns the zero value of the type of the provider, so the return value can always
183 // be type asserted to the type of the provider. The value returned may be a deep copy of the
184 // value originally passed to SetProvider.
185 OtherModuleProvider(m blueprint.Module, provider blueprint.ProviderKey) interface{}
186
187 // OtherModuleHasProvider returns true if the provider for the given module has been set.
188 OtherModuleHasProvider(m blueprint.Module, provider blueprint.ProviderKey) bool
189
190 // Provider returns the value for a provider for the current module. If the value is
191 // not set it returns the zero value of the type of the provider, so the return value can always
192 // be type asserted to the type of the provider. It panics if called before the appropriate
193 // mutator or GenerateBuildActions pass for the provider. The value returned may be a deep
194 // copy of the value originally passed to SetProvider.
195 Provider(provider blueprint.ProviderKey) interface{}
196
197 // HasProvider returns true if the provider for the current module has been set.
198 HasProvider(provider blueprint.ProviderKey) bool
199
200 // SetProvider sets the value for a provider for the current module. It panics if not called
201 // during the appropriate mutator or GenerateBuildActions pass for the provider, if the value
202 // is not of the appropriate type, or if the value has already been set. The value should not
203 // be modified after being passed to SetProvider.
204 SetProvider(provider blueprint.ProviderKey, value interface{})
205
Colin Crossdc35e212019-06-06 16:13:11 -0700206 GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module
Colin Cross9f35c3d2020-09-16 19:04:41 -0700207
208 // GetDirectDepWithTag returns the Module the direct dependency with the specified name, or nil if
209 // none exists. It panics if the dependency does not have the specified tag. It skips any
210 // dependencies that are not an android.Module.
Colin Crossdc35e212019-06-06 16:13:11 -0700211 GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module
Colin Cross9f35c3d2020-09-16 19:04:41 -0700212
213 // GetDirectDep returns the Module and DependencyTag for the direct dependency with the specified
214 // name, or nil if none exists. If there are multiple dependencies on the same module it returns
215 // the first DependencyTag. It skips any dependencies that are not an android.Module.
Colin Crossdc35e212019-06-06 16:13:11 -0700216 GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag)
217
Colin Cross9f35c3d2020-09-16 19:04:41 -0700218 // VisitDirectDepsBlueprint calls visit for each direct dependency. If there are multiple
219 // direct dependencies on the same module visit will be called multiple times on that module
220 // and OtherModuleDependencyTag will return a different tag for each.
221 //
222 // The Module passed to the visit function should not be retained outside of the visit
223 // function, it may be invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700224 VisitDirectDepsBlueprint(visit func(blueprint.Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700225
226 // VisitDirectDeps calls visit for each direct dependency. If there are multiple
227 // direct dependencies on the same module visit will be called multiple times on that module
228 // and OtherModuleDependencyTag will return a different tag for each. It skips any
229 // dependencies that are not an android.Module.
230 //
231 // The Module passed to the visit function should not be retained outside of the visit
232 // function, it may be invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700233 VisitDirectDeps(visit func(Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700234
Colin Crossdc35e212019-06-06 16:13:11 -0700235 VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700236
237 // VisitDirectDepsIf calls pred for each direct dependency, and if pred returns true calls visit. If there are
238 // multiple direct dependencies on the same module pred and visit will be called multiple times on that module and
239 // OtherModuleDependencyTag will return a different tag for each. It skips any
240 // dependencies that are not an android.Module.
241 //
242 // The Module passed to the visit function should not be retained outside of the visit function, it may be
243 // invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700244 VisitDirectDepsIf(pred func(Module) bool, visit func(Module))
245 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
246 VisitDepsDepthFirst(visit func(Module))
247 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
248 VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700249
250 // WalkDeps calls visit for each transitive dependency, traversing the dependency tree in top down order. visit may
251 // be called multiple times for the same (child, parent) pair if there are multiple direct dependencies between the
252 // child and parent with different tags. OtherModuleDependencyTag will return the tag for the currently visited
253 // (child, parent) pair. If visit returns false WalkDeps will not continue recursing down to child. It skips
254 // any dependencies that are not an android.Module.
255 //
256 // The Modules passed to the visit function should not be retained outside of the visit function, they may be
257 // invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700258 WalkDeps(visit func(Module, Module) bool)
Colin Cross9f35c3d2020-09-16 19:04:41 -0700259
260 // WalkDepsBlueprint calls visit for each transitive dependency, traversing the dependency
261 // tree in top down order. visit may be called multiple times for the same (child, parent)
262 // pair if there are multiple direct dependencies between the child and parent with different
263 // tags. OtherModuleDependencyTag will return the tag for the currently visited
264 // (child, parent) pair. If visit returns false WalkDeps will not continue recursing down
265 // to child.
266 //
267 // The Modules passed to the visit function should not be retained outside of the visit function, they may be
268 // invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700269 WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool)
Colin Cross9f35c3d2020-09-16 19:04:41 -0700270
Colin Crossdc35e212019-06-06 16:13:11 -0700271 // GetWalkPath is supposed to be called in visit function passed in WalkDeps()
272 // and returns a top-down dependency path from a start module to current child module.
273 GetWalkPath() []Module
274
Colin Cross4dfacf92020-09-16 19:22:27 -0700275 // PrimaryModule returns the first variant of the current module. Variants of a module are always visited in
276 // order by mutators and GenerateBuildActions, so the data created by the current mutator can be read from the
277 // Module returned by PrimaryModule without data races. This can be used to perform singleton actions that are
278 // only done once for all variants of a module.
279 PrimaryModule() Module
280
281 // FinalModule returns the last variant of the current module. Variants of a module are always visited in
282 // order by mutators and GenerateBuildActions, so the data created by the current mutator can be read from all
283 // variants using VisitAllModuleVariants if the current module == FinalModule(). This can be used to perform
284 // singleton actions that are only done once for all variants of a module.
285 FinalModule() Module
286
287 // VisitAllModuleVariants calls visit for each variant of the current module. Variants of a module are always
288 // visited in order by mutators and GenerateBuildActions, so the data created by the current mutator can be read
289 // from all variants if the current module == FinalModule(). Otherwise, care must be taken to not access any
290 // data modified by the current mutator.
291 VisitAllModuleVariants(visit func(Module))
292
Paul Duffinc5192442020-03-31 11:31:36 +0100293 // GetTagPath is supposed to be called in visit function passed in WalkDeps()
294 // and returns a top-down dependency tags path from a start module to current child module.
295 // It has one less entry than GetWalkPath() as it contains the dependency tags that
296 // exist between each adjacent pair of modules in the GetWalkPath().
297 // GetTagPath()[i] is the tag between GetWalkPath()[i] and GetWalkPath()[i+1]
298 GetTagPath() []blueprint.DependencyTag
299
Jiyong Park1c7e9622020-05-07 16:12:13 +0900300 // GetPathString is supposed to be called in visit function passed in WalkDeps()
301 // and returns a multi-line string showing the modules and dependency tags
302 // among them along the top-down dependency path from a start module to current child module.
303 // skipFirst when set to true, the output doesn't include the start module,
304 // which is already printed when this function is used along with ModuleErrorf().
305 GetPathString(skipFirst bool) string
306
Colin Crossdc35e212019-06-06 16:13:11 -0700307 AddMissingDependencies(missingDeps []string)
308
Colin Crossa1ad8d12016-06-01 17:09:44 -0700309 Target() Target
Colin Cross8b74d172016-09-13 09:59:14 -0700310 TargetPrimary() bool
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000311
312 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
313 // responsible for creating.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700314 MultiTargets() []Target
Colin Crossf6566ed2015-03-24 11:13:38 -0700315 Arch() Arch
Colin Crossa1ad8d12016-06-01 17:09:44 -0700316 Os() OsType
Colin Crossf6566ed2015-03-24 11:13:38 -0700317 Host() bool
318 Device() bool
Colin Cross0af4b842015-04-30 16:36:18 -0700319 Darwin() bool
Doug Horn21b94272019-01-16 12:06:11 -0800320 Fuchsia() bool
Colin Cross3edeee12017-04-04 12:59:48 -0700321 Windows() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700322 Debug() bool
Colin Cross1e7d3702016-08-24 15:25:47 -0700323 PrimaryArch() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700324}
325
Colin Cross1184b642019-12-30 18:43:07 -0800326// Deprecated: use EarlyModuleContext instead
Colin Cross635c3b02016-05-18 15:37:25 -0700327type BaseContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800328 EarlyModuleContext
Colin Crossaabf6792017-11-29 00:27:14 -0800329}
330
Colin Cross635c3b02016-05-18 15:37:25 -0700331type ModuleContext interface {
Colin Crossaabf6792017-11-29 00:27:14 -0800332 BaseModuleContext
Colin Cross3f40fa42015-01-30 17:27:36 -0800333
Colin Crossae887032017-10-23 17:16:14 -0700334 // Deprecated: use ModuleContext.Build instead.
Colin Cross0875c522017-11-28 17:34:01 -0800335 ModuleBuild(pctx PackageContext, params ModuleBuildParams)
Colin Cross8f101b42015-06-17 15:09:06 -0700336
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700337 ExpandSources(srcFiles, excludes []string) Paths
Colin Cross366938f2017-12-11 16:29:02 -0800338 ExpandSource(srcFile, prop string) Path
Colin Cross2383f3b2018-02-06 14:40:13 -0800339 ExpandOptionalSource(srcFile *string, prop string) OptionalPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700340
Colin Cross70dda7e2019-10-01 22:05:35 -0700341 InstallExecutable(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
342 InstallFile(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
343 InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath
344 InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700345 CheckbuildFile(srcPath Path)
Dan Willemsen6553f5e2016-03-10 18:14:25 -0800346
Colin Cross8d8f8e22016-08-03 11:57:50 -0700347 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700348 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700349 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800350 InstallInRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -0700351 InstallInVendorRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900352 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700353 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700354 InstallBypassMake() bool
Jiyong Park87788b52020-09-01 12:37:45 +0900355 InstallForceOS() (*OsType, *ArchType)
Nan Zhang6d34b302017-02-04 17:47:46 -0800356
357 RequiredModuleNames() []string
Sasha Smundakb6d23052019-04-01 18:37:36 -0700358 HostRequiredModuleNames() []string
359 TargetRequiredModuleNames() []string
Colin Cross3f68a132017-10-23 17:10:29 -0700360
Colin Cross3f68a132017-10-23 17:10:29 -0700361 ModuleSubDir() string
362
Colin Cross0875c522017-11-28 17:34:01 -0800363 Variable(pctx PackageContext, name, value string)
364 Rule(pctx PackageContext, name string, params blueprint.RuleParams, argNames ...string) blueprint.Rule
Colin Crossae887032017-10-23 17:16:14 -0700365 // Similar to blueprint.ModuleContext.Build, but takes Paths instead of []string,
366 // and performs more verification.
Colin Cross0875c522017-11-28 17:34:01 -0800367 Build(pctx PackageContext, params BuildParams)
Colin Crossc3d87d32020-06-04 13:25:17 -0700368 // Phony creates a Make-style phony rule, a rule with no commands that can depend on other
369 // phony rules or real files. Phony can be called on the same name multiple times to add
370 // additional dependencies.
371 Phony(phony string, deps ...Path)
Colin Cross3f68a132017-10-23 17:10:29 -0700372
Colin Cross9f35c3d2020-09-16 19:04:41 -0700373 // GetMissingDependencies returns the list of dependencies that were passed to AddDependencies or related methods,
374 // but do not exist.
Colin Cross3f68a132017-10-23 17:10:29 -0700375 GetMissingDependencies() []string
Colin Cross3f40fa42015-01-30 17:27:36 -0800376}
377
Colin Cross635c3b02016-05-18 15:37:25 -0700378type Module interface {
Colin Cross3f40fa42015-01-30 17:27:36 -0800379 blueprint.Module
380
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700381 // GenerateAndroidBuildActions is analogous to Blueprints' GenerateBuildActions,
382 // but GenerateAndroidBuildActions also has access to Android-specific information.
383 // For more information, see Module.GenerateBuildActions within Blueprint's module_ctx.go
Colin Cross635c3b02016-05-18 15:37:25 -0700384 GenerateAndroidBuildActions(ModuleContext)
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700385
Paul Duffin44f1d842020-06-26 20:17:02 +0100386 // Add dependencies to the components of a module, i.e. modules that are created
387 // by the module and which are considered to be part of the creating module.
388 //
389 // This is called before prebuilts are renamed so as to allow a dependency to be
390 // added directly to a prebuilt child module instead of depending on a source module
391 // and relying on prebuilt processing to switch to the prebuilt module if preferred.
392 //
393 // A dependency on a prebuilt must include the "prebuilt_" prefix.
394 ComponentDepsMutator(ctx BottomUpMutatorContext)
395
Colin Cross1e676be2016-10-12 14:38:15 -0700396 DepsMutator(BottomUpMutatorContext)
Colin Cross3f40fa42015-01-30 17:27:36 -0800397
Colin Cross635c3b02016-05-18 15:37:25 -0700398 base() *ModuleBase
Inseob Kimeec88e12020-01-22 11:11:29 +0900399 Disable()
Dan Willemsen0effe062015-11-30 16:06:01 -0800400 Enabled() bool
Colin Crossa1ad8d12016-06-01 17:09:44 -0700401 Target() Target
Anton Hansson1ee62c02020-06-30 11:51:53 +0100402 Owner() string
Dan Willemsen782a2d12015-12-21 14:55:28 -0800403 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700404 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700405 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800406 InstallInRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -0700407 InstallInVendorRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900408 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700409 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700410 InstallBypassMake() bool
Jiyong Park87788b52020-09-01 12:37:45 +0900411 InstallForceOS() (*OsType, *ArchType)
Colin Crossa2f296f2016-11-29 15:16:18 -0800412 SkipInstall()
Ulya Trafimovichb28cc372020-01-13 15:18:16 +0000413 IsSkipInstall() bool
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +0100414 MakeUninstallable()
Liz Kammer5ca3a622020-08-05 15:40:41 -0700415 ReplacedByPrebuilt()
416 IsReplacedByPrebuilt() bool
Jiyong Park374510b2018-03-19 18:23:01 +0900417 ExportedToMake() bool
Inseob Kim8471cda2019-11-15 09:59:12 +0900418 InitRc() Paths
419 VintfFragments() Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800420 NoticeFiles() Paths
Colin Cross36242852017-06-23 15:06:31 -0700421
422 AddProperties(props ...interface{})
423 GetProperties() []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700424
Colin Crossae887032017-10-23 17:16:14 -0700425 BuildParamsForTests() []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800426 RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800427 VariablesForTests() map[string]string
Paul Duffine2453c72019-05-31 14:00:04 +0100428
Colin Cross9a362232019-07-01 15:32:45 -0700429 // String returns a string that includes the module name and variants for printing during debugging.
430 String() string
431
Paul Duffine2453c72019-05-31 14:00:04 +0100432 // Get the qualified module id for this module.
433 qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName
434
435 // Get information about the properties that can contain visibility rules.
436 visibilityProperties() []visibilityProperty
Paul Duffin63c6e182019-07-24 14:24:38 +0100437
Jiyong Park6a8cf5f2019-12-30 16:31:09 +0900438 RequiredModuleNames() []string
439 HostRequiredModuleNames() []string
440 TargetRequiredModuleNames() []string
Colin Cross897266e2020-02-13 13:22:08 -0800441
Jiyong Park4dc2a1a2020-09-28 17:46:22 +0900442 FilesToInstall() InstallPaths
Jiyong Park073ea552020-11-09 14:08:34 +0900443 PackagingSpecs() []PackagingSpec
Paul Duffine2453c72019-05-31 14:00:04 +0100444}
445
446// Qualified id for a module
447type qualifiedModuleName struct {
448 // The package (i.e. directory) in which the module is defined, without trailing /
449 pkg string
450
451 // The name of the module, empty string if package.
452 name string
453}
454
455func (q qualifiedModuleName) String() string {
456 if q.name == "" {
457 return "//" + q.pkg
458 }
459 return "//" + q.pkg + ":" + q.name
460}
461
Paul Duffine484f472019-06-20 16:38:08 +0100462func (q qualifiedModuleName) isRootPackage() bool {
463 return q.pkg == "" && q.name == ""
464}
465
Paul Duffine2453c72019-05-31 14:00:04 +0100466// Get the id for the package containing this module.
467func (q qualifiedModuleName) getContainingPackageId() qualifiedModuleName {
468 pkg := q.pkg
469 if q.name == "" {
Paul Duffine484f472019-06-20 16:38:08 +0100470 if pkg == "" {
471 panic(fmt.Errorf("Cannot get containing package id of root package"))
472 }
473
474 index := strings.LastIndex(pkg, "/")
475 if index == -1 {
476 pkg = ""
477 } else {
478 pkg = pkg[:index]
479 }
Paul Duffine2453c72019-05-31 14:00:04 +0100480 }
481 return newPackageId(pkg)
482}
483
484func newPackageId(pkg string) qualifiedModuleName {
485 // A qualified id for a package module has no name.
486 return qualifiedModuleName{pkg: pkg, name: ""}
Colin Cross3f40fa42015-01-30 17:27:36 -0800487}
488
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000489type Dist struct {
490 // Copy the output of this module to the $DIST_DIR when `dist` is specified on the
491 // command line and any of these targets are also on the command line, or otherwise
492 // built
493 Targets []string `android:"arch_variant"`
494
495 // The name of the output artifact. This defaults to the basename of the output of
496 // the module.
497 Dest *string `android:"arch_variant"`
498
499 // The directory within the dist directory to store the artifact. Defaults to the
500 // top level directory ("").
501 Dir *string `android:"arch_variant"`
502
503 // A suffix to add to the artifact file name (before any extension).
504 Suffix *string `android:"arch_variant"`
505
Paul Duffin74f05592020-11-25 16:37:46 +0000506 // A string tag to select the OutputFiles associated with the tag.
507 //
508 // If no tag is specified then it will select the default dist paths provided
509 // by the module type. If a tag of "" is specified then it will return the
510 // default output files provided by the modules, i.e. the result of calling
511 // OutputFiles("").
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000512 Tag *string `android:"arch_variant"`
513}
514
Colin Crossfc754582016-05-17 16:34:16 -0700515type nameProperties struct {
516 // The name of the module. Must be unique across all modules.
Nan Zhang0007d812017-11-07 10:57:05 -0800517 Name *string
Colin Crossfc754582016-05-17 16:34:16 -0700518}
519
Colin Cross08d6f8f2020-11-19 02:33:19 +0000520type commonProperties struct {
Dan Willemsen0effe062015-11-30 16:06:01 -0800521 // emit build rules for this module
Paul Duffin54d9bb72020-02-12 10:20:56 +0000522 //
523 // Disabling a module should only be done for those modules that cannot be built
524 // in the current environment. Modules that can build in the current environment
525 // but are not usually required (e.g. superceded by a prebuilt) should not be
526 // disabled as that will prevent them from being built by the checkbuild target
527 // and so prevent early detection of changes that have broken those modules.
Dan Willemsen0effe062015-11-30 16:06:01 -0800528 Enabled *bool `android:"arch_variant"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800529
Paul Duffin2e61fa62019-03-28 14:10:57 +0000530 // Controls the visibility of this module to other modules. Allowable values are one or more of
531 // these formats:
532 //
533 // ["//visibility:public"]: Anyone can use this module.
534 // ["//visibility:private"]: Only rules in the module's package (not its subpackages) can use
535 // this module.
Paul Duffin51084ff2020-05-05 19:19:22 +0100536 // ["//visibility:override"]: Discards any rules inherited from defaults or a creating module.
537 // Can only be used at the beginning of a list of visibility rules.
Paul Duffin2e61fa62019-03-28 14:10:57 +0000538 // ["//some/package:__pkg__", "//other/package:__pkg__"]: Only modules in some/package and
539 // other/package (defined in some/package/*.bp and other/package/*.bp) have access to
540 // this module. Note that sub-packages do not have access to the rule; for example,
541 // //some/package/foo:bar or //other/package/testing:bla wouldn't have access. __pkg__
542 // is a special module and must be used verbatim. It represents all of the modules in the
543 // package.
544 // ["//project:__subpackages__", "//other:__subpackages__"]: Only modules in packages project
545 // or other or in one of their sub-packages have access to this module. For example,
546 // //project:rule, //project/library:lib or //other/testing/internal:munge are allowed
547 // to depend on this rule (but not //independent:evil)
548 // ["//project"]: This is shorthand for ["//project:__pkg__"]
549 // [":__subpackages__"]: This is shorthand for ["//project:__subpackages__"] where
550 // //project is the module's package. e.g. using [":__subpackages__"] in
551 // packages/apps/Settings/Android.bp is equivalent to
552 // //packages/apps/Settings:__subpackages__.
553 // ["//visibility:legacy_public"]: The default visibility, behaves as //visibility:public
554 // for now. It is an error if it is used in a module.
Paul Duffine2453c72019-05-31 14:00:04 +0100555 //
556 // If a module does not specify the `visibility` property then it uses the
557 // `default_visibility` property of the `package` module in the module's package.
558 //
559 // If the `default_visibility` property is not set for the module's package then
Paul Duffine484f472019-06-20 16:38:08 +0100560 // it will use the `default_visibility` of its closest ancestor package for which
561 // a `default_visibility` property is specified.
562 //
563 // If no `default_visibility` property can be found then the module uses the
564 // global default of `//visibility:legacy_public`.
Paul Duffine2453c72019-05-31 14:00:04 +0100565 //
Paul Duffin95d53b52019-07-24 13:45:05 +0100566 // The `visibility` property has no effect on a defaults module although it does
567 // apply to any non-defaults module that uses it. To set the visibility of a
568 // defaults module, use the `defaults_visibility` property on the defaults module;
569 // not to be confused with the `default_visibility` property on the package module.
570 //
Paul Duffin2e61fa62019-03-28 14:10:57 +0000571 // See https://android.googlesource.com/platform/build/soong/+/master/README.md#visibility for
572 // more details.
573 Visibility []string
574
Colin Cross7d5136f2015-05-11 13:39:40 -0700575 // control whether this module compiles for 32-bit, 64-bit, or both. Possible values
Colin Cross3f40fa42015-01-30 17:27:36 -0800576 // are "32" (compile for 32-bit only), "64" (compile for 64-bit only), "both" (compile for both
577 // architectures), or "first" (compile for 64-bit on a 64-bit platform, and 32-bit on a 32-bit
Roland Levillain24bb2e62020-09-22 11:18:38 +0000578 // platform).
Colin Cross7d716ba2017-11-01 10:38:29 -0700579 Compile_multilib *string `android:"arch_variant"`
Colin Cross69617d32016-09-06 10:39:07 -0700580
581 Target struct {
582 Host struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700583 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700584 }
585 Android struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700586 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700587 }
588 }
589
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000590 // If set to true then the archMutator will create variants for each arch specific target
591 // (e.g. 32/64) that the module is required to produce. If set to false then it will only
592 // create a variant for the architecture and will list the additional arch specific targets
593 // that the variant needs to produce in the CompileMultiTargets property.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700594 UseTargetVariants bool `blueprint:"mutated"`
595 Default_multilib string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800596
Dan Willemsen782a2d12015-12-21 14:55:28 -0800597 // whether this is a proprietary vendor module, and should be installed into /vendor
Colin Cross7d716ba2017-11-01 10:38:29 -0700598 Proprietary *bool
Dan Willemsen782a2d12015-12-21 14:55:28 -0800599
Colin Cross55708f32017-03-20 13:23:34 -0700600 // vendor who owns this module
Dan Willemsenefac4a82017-07-18 19:42:09 -0700601 Owner *string
Colin Cross55708f32017-03-20 13:23:34 -0700602
Jiyong Park2db76922017-11-08 16:03:48 +0900603 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
604 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
605 // Use `soc_specific` instead for better meaning.
Colin Cross7d716ba2017-11-01 10:38:29 -0700606 Vendor *bool
Dan Willemsenaa118f92017-04-06 12:49:58 -0700607
Jiyong Park2db76922017-11-08 16:03:48 +0900608 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
609 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
610 Soc_specific *bool
611
612 // whether this module is specific to a device, not only for SoC, but also for off-chip
613 // peripherals. When set to true, it is installed into /odm (or /vendor/odm if odm partition
614 // does not exist, or /system/vendor/odm if both odm and vendor partitions do not exist).
615 // This implies `soc_specific:true`.
616 Device_specific *bool
617
618 // whether this module is specific to a software configuration of a product (e.g. country,
Jaekyun Seok5cfbfbb2018-01-10 19:00:15 +0900619 // network operator, etc). When set to true, it is installed into /product (or
620 // /system/product if product partition does not exist).
Jiyong Park2db76922017-11-08 16:03:48 +0900621 Product_specific *bool
622
Justin Yund5f6c822019-06-25 16:47:17 +0900623 // whether this module extends system. When set to true, it is installed into /system_ext
624 // (or /system/system_ext if system_ext partition does not exist).
625 System_ext_specific *bool
626
Jiyong Parkf9332f12018-02-01 00:54:12 +0900627 // Whether this module is installed to recovery partition
628 Recovery *bool
629
Yifan Hong1b3348d2020-01-21 15:53:22 -0800630 // Whether this module is installed to ramdisk
631 Ramdisk *bool
632
Yifan Hong60e0cfb2020-10-21 15:17:56 -0700633 // Whether this module is installed to vendor ramdisk
634 Vendor_ramdisk *bool
635
dimitry1f33e402019-03-26 12:39:31 +0100636 // Whether this module is built for non-native architecures (also known as native bridge binary)
637 Native_bridge_supported *bool `android:"arch_variant"`
638
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700639 // init.rc files to be installed if this module is installed
Colin Cross0bab8772020-09-25 14:01:21 -0700640 Init_rc []string `android:"arch_variant,path"`
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700641
Steven Moreland57a23d22018-04-04 15:42:19 -0700642 // VINTF manifest fragments to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800643 Vintf_fragments []string `android:"path"`
Steven Moreland57a23d22018-04-04 15:42:19 -0700644
Chris Wolfe998306e2016-08-15 14:47:23 -0400645 // names of other modules to install if this module is installed
Colin Crossc602b7d2017-05-05 13:36:36 -0700646 Required []string `android:"arch_variant"`
Chris Wolfe998306e2016-08-15 14:47:23 -0400647
Sasha Smundakb6d23052019-04-01 18:37:36 -0700648 // names of other modules to install on host if this module is installed
649 Host_required []string `android:"arch_variant"`
650
651 // names of other modules to install on target if this module is installed
652 Target_required []string `android:"arch_variant"`
653
Colin Cross5aac3622017-08-31 15:07:09 -0700654 // relative path to a file to include in the list of notices for the device
Colin Cross27b922f2019-03-04 22:35:41 -0800655 Notice *string `android:"path"`
Colin Cross5aac3622017-08-31 15:07:09 -0700656
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000657 // The OsType of artifacts that this module variant is responsible for creating.
658 //
659 // Set by osMutator
660 CompileOS OsType `blueprint:"mutated"`
661
662 // The Target of artifacts that this module variant is responsible for creating.
663 //
664 // Set by archMutator
665 CompileTarget Target `blueprint:"mutated"`
666
667 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
668 // responsible for creating.
669 //
670 // By default this is nil as, where necessary, separate variants are created for the
671 // different multilib types supported and that information is encapsulated in the
672 // CompileTarget so the module variant simply needs to create artifacts for that.
673 //
674 // However, if UseTargetVariants is set to false (e.g. by
675 // InitAndroidMultiTargetsArchModule) then no separate variants are created for the
676 // multilib targets. Instead a single variant is created for the architecture and
677 // this contains the multilib specific targets that this variant should create.
678 //
679 // Set by archMutator
Colin Crossee0bc3b2018-10-02 22:01:37 -0700680 CompileMultiTargets []Target `blueprint:"mutated"`
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000681
682 // True if the module variant's CompileTarget is the primary target
683 //
684 // Set by archMutator
685 CompilePrimary bool `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800686
687 // Set by InitAndroidModule
688 HostOrDeviceSupported HostOrDeviceSupported `blueprint:"mutated"`
Dan Willemsen0b24c742016-10-04 15:13:37 -0700689 ArchSpecific bool `blueprint:"mutated"`
Colin Crossce75d2c2016-10-06 16:12:58 -0700690
Paul Duffin1356d8c2020-02-25 19:26:33 +0000691 // If set to true then a CommonOS variant will be created which will have dependencies
692 // on all its OsType specific variants. Used by sdk/module_exports to create a snapshot
693 // that covers all os and architecture variants.
694 //
695 // The OsType specific variants can be retrieved by calling
696 // GetOsSpecificVariantsOfCommonOSVariant
697 //
698 // Set at module initialization time by calling InitCommonOSAndroidMultiTargetsArchModule
699 CreateCommonOSVariant bool `blueprint:"mutated"`
700
701 // If set to true then this variant is the CommonOS variant that has dependencies on its
702 // OsType specific variants.
703 //
704 // Set by osMutator.
705 CommonOSVariant bool `blueprint:"mutated"`
706
Colin Crossce75d2c2016-10-06 16:12:58 -0700707 SkipInstall bool `blueprint:"mutated"`
Jeff Gaston088e29e2017-11-29 16:47:17 -0800708
Liz Kammer5ca3a622020-08-05 15:40:41 -0700709 // Whether the module has been replaced by a prebuilt
710 ReplacedByPrebuilt bool `blueprint:"mutated"`
711
Justin Yun32f053b2020-07-31 23:07:17 +0900712 // Disabled by mutators. If set to true, it overrides Enabled property.
713 ForcedDisabled bool `blueprint:"mutated"`
714
Jeff Gaston088e29e2017-11-29 16:47:17 -0800715 NamespaceExportedToMake bool `blueprint:"mutated"`
Colin Cross6c4f21f2019-06-06 15:41:36 -0700716
717 MissingDeps []string `blueprint:"mutated"`
Colin Cross9a362232019-07-01 15:32:45 -0700718
719 // Name and variant strings stored by mutators to enable Module.String()
720 DebugName string `blueprint:"mutated"`
721 DebugMutators []string `blueprint:"mutated"`
722 DebugVariations []string `blueprint:"mutated"`
Colin Cross7228ecd2019-11-18 16:00:16 -0800723
Colin Crossa6845402020-11-16 15:08:19 -0800724 // ImageVariation is set by ImageMutator to specify which image this variation is for,
725 // for example "" for core or "recovery" for recovery. It will often be set to one of the
726 // constants in image.go, but can also be set to a custom value by individual module types.
Colin Cross7228ecd2019-11-18 16:00:16 -0800727 ImageVariation string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800728}
729
Paul Duffined875132020-09-02 13:08:57 +0100730type distProperties struct {
731 // configuration to distribute output files from this module to the distribution
732 // directory (default: $OUT/dist, configurable with $DIST_DIR)
733 Dist Dist `android:"arch_variant"`
734
735 // a list of configurations to distribute output files from this module to the
736 // distribution directory (default: $OUT/dist, configurable with $DIST_DIR)
737 Dists []Dist `android:"arch_variant"`
738}
739
Paul Duffin74f05592020-11-25 16:37:46 +0000740// The key to use in TaggedDistFiles when a Dist structure does not specify a
741// tag property. This intentionally does not use "" as the default because that
742// would mean that an empty tag would have a different meaning when used in a dist
743// structure that when used to reference a specific set of output paths using the
744// :module{tag} syntax, which passes tag to the OutputFiles(tag) method.
745const DefaultDistTag = "<default-dist-tag>"
746
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000747// A map of OutputFile tag keys to Paths, for disting purposes.
748type TaggedDistFiles map[string]Paths
749
Paul Duffin74f05592020-11-25 16:37:46 +0000750// addPathsForTag adds a mapping from the tag to the paths. If the map is nil
751// then it will create a map, update it and then return it. If a mapping already
752// exists for the tag then the paths are appended to the end of the current list
753// of paths, ignoring any duplicates.
754func (t TaggedDistFiles) addPathsForTag(tag string, paths ...Path) TaggedDistFiles {
755 if t == nil {
756 t = make(TaggedDistFiles)
757 }
758
759 for _, distFile := range paths {
760 if distFile != nil && !t[tag].containsPath(distFile) {
761 t[tag] = append(t[tag], distFile)
762 }
763 }
764
765 return t
766}
767
768// merge merges the entries from the other TaggedDistFiles object into this one.
769// If the TaggedDistFiles is nil then it will create a new instance, merge the
770// other into it, and then return it.
771func (t TaggedDistFiles) merge(other TaggedDistFiles) TaggedDistFiles {
772 for tag, paths := range other {
773 t = t.addPathsForTag(tag, paths...)
774 }
775
776 return t
777}
778
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000779func MakeDefaultDistFiles(paths ...Path) TaggedDistFiles {
Jingwen Chen7b27ca72020-07-24 09:13:49 +0000780 for _, path := range paths {
781 if path == nil {
782 panic("The path to a dist file cannot be nil.")
783 }
784 }
785
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000786 // The default OutputFile tag is the empty "" string.
Paul Duffin74f05592020-11-25 16:37:46 +0000787 return TaggedDistFiles{DefaultDistTag: paths}
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000788}
789
Colin Cross3f40fa42015-01-30 17:27:36 -0800790type hostAndDeviceProperties struct {
Colin Cross4e81d702018-11-09 10:36:55 -0800791 // If set to true, build a variant of the module for the host. Defaults to false.
792 Host_supported *bool
793
794 // If set to true, build a variant of the module for the device. Defaults to true.
Colin Crossa4190c12016-07-12 13:11:25 -0700795 Device_supported *bool
Colin Cross3f40fa42015-01-30 17:27:36 -0800796}
797
Colin Crossc472d572015-03-17 15:06:21 -0700798type Multilib string
799
800const (
Colin Cross6b4a32d2017-12-05 13:42:45 -0800801 MultilibBoth Multilib = "both"
802 MultilibFirst Multilib = "first"
803 MultilibCommon Multilib = "common"
804 MultilibCommonFirst Multilib = "common_first"
805 MultilibDefault Multilib = ""
Colin Crossc472d572015-03-17 15:06:21 -0700806)
807
Colin Crossa1ad8d12016-06-01 17:09:44 -0700808type HostOrDeviceSupported int
809
810const (
Colin Cross34037c62020-11-17 13:19:17 -0800811 hostSupported = 1 << iota
812 hostCrossSupported
813 deviceSupported
814 hostDefault
815 deviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700816
817 // Host and HostCross are built by default. Device is not supported.
Colin Cross34037c62020-11-17 13:19:17 -0800818 HostSupported = hostSupported | hostCrossSupported | hostDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700819
820 // Host is built by default. HostCross and Device are not supported.
Colin Cross34037c62020-11-17 13:19:17 -0800821 HostSupportedNoCross = hostSupported | hostDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700822
823 // Device is built by default. Host and HostCross are not supported.
Colin Cross34037c62020-11-17 13:19:17 -0800824 DeviceSupported = deviceSupported | deviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700825
826 // Device is built by default. Host and HostCross are supported.
Colin Cross34037c62020-11-17 13:19:17 -0800827 HostAndDeviceSupported = hostSupported | hostCrossSupported | deviceSupported | deviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700828
829 // Host, HostCross, and Device are built by default.
Colin Cross34037c62020-11-17 13:19:17 -0800830 HostAndDeviceDefault = hostSupported | hostCrossSupported | hostDefault |
831 deviceSupported | deviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700832
833 // Nothing is supported. This is not exposed to the user, but used to mark a
834 // host only module as unsupported when the module type is not supported on
835 // the host OS. E.g. benchmarks are supported on Linux but not Darwin.
Colin Cross34037c62020-11-17 13:19:17 -0800836 NeitherHostNorDeviceSupported = 0
Colin Crossa1ad8d12016-06-01 17:09:44 -0700837)
838
Jiyong Park2db76922017-11-08 16:03:48 +0900839type moduleKind int
840
841const (
842 platformModule moduleKind = iota
843 deviceSpecificModule
844 socSpecificModule
845 productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900846 systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900847)
848
849func (k moduleKind) String() string {
850 switch k {
851 case platformModule:
852 return "platform"
853 case deviceSpecificModule:
854 return "device-specific"
855 case socSpecificModule:
856 return "soc-specific"
857 case productSpecificModule:
858 return "product-specific"
Justin Yund5f6c822019-06-25 16:47:17 +0900859 case systemExtSpecificModule:
860 return "systemext-specific"
Jiyong Park2db76922017-11-08 16:03:48 +0900861 default:
862 panic(fmt.Errorf("unknown module kind %d", k))
863 }
864}
865
Colin Cross9d34f352019-11-22 16:03:51 -0800866func initAndroidModuleBase(m Module) {
867 m.base().module = m
868}
869
Colin Crossa6845402020-11-16 15:08:19 -0800870// InitAndroidModule initializes the Module as an Android module that is not architecture-specific.
871// It adds the common properties, for example "name" and "enabled".
Colin Cross36242852017-06-23 15:06:31 -0700872func InitAndroidModule(m Module) {
Colin Cross9d34f352019-11-22 16:03:51 -0800873 initAndroidModuleBase(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800874 base := m.base()
Colin Cross5049f022015-03-18 13:28:46 -0700875
Colin Cross36242852017-06-23 15:06:31 -0700876 m.AddProperties(
Colin Crossfc754582016-05-17 16:34:16 -0700877 &base.nameProperties,
Paul Duffined875132020-09-02 13:08:57 +0100878 &base.commonProperties,
879 &base.distProperties)
Colin Cross18c46802019-09-24 22:19:02 -0700880
Colin Crosseabaedd2020-02-06 17:01:55 -0800881 initProductVariableModule(m)
Colin Cross18c46802019-09-24 22:19:02 -0700882
Colin Crossa3a97412019-03-18 12:24:29 -0700883 base.generalProperties = m.GetProperties()
Pirama Arumuga Nainar955dc492018-04-17 14:58:42 -0700884 base.customizableProperties = m.GetProperties()
Paul Duffin63c6e182019-07-24 14:24:38 +0100885
886 // The default_visibility property needs to be checked and parsed by the visibility module during
Paul Duffin5ec73ec2020-05-01 17:52:01 +0100887 // its checking and parsing phases so make it the primary visibility property.
888 setPrimaryVisibilityProperty(m, "visibility", &base.commonProperties.Visibility)
Colin Cross5049f022015-03-18 13:28:46 -0700889}
890
Colin Crossa6845402020-11-16 15:08:19 -0800891// InitAndroidArchModule initializes the Module as an Android module that is architecture-specific.
892// It adds the common properties, for example "name" and "enabled", as well as runtime generated
893// property structs for architecture-specific versions of generic properties tagged with
894// `android:"arch_variant"`.
895//
896// InitAndroidModule should not be called if InitAndroidArchModule was called.
Colin Cross36242852017-06-23 15:06:31 -0700897func InitAndroidArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
898 InitAndroidModule(m)
Colin Cross5049f022015-03-18 13:28:46 -0700899
900 base := m.base()
Colin Cross3f40fa42015-01-30 17:27:36 -0800901 base.commonProperties.HostOrDeviceSupported = hod
Colin Cross69617d32016-09-06 10:39:07 -0700902 base.commonProperties.Default_multilib = string(defaultMultilib)
Dan Willemsen0b24c742016-10-04 15:13:37 -0700903 base.commonProperties.ArchSpecific = true
Colin Crossee0bc3b2018-10-02 22:01:37 -0700904 base.commonProperties.UseTargetVariants = true
Colin Cross3f40fa42015-01-30 17:27:36 -0800905
Colin Cross34037c62020-11-17 13:19:17 -0800906 if hod&hostSupported != 0 && hod&deviceSupported != 0 {
Colin Cross36242852017-06-23 15:06:31 -0700907 m.AddProperties(&base.hostAndDeviceProperties)
Colin Cross3f40fa42015-01-30 17:27:36 -0800908 }
909
Colin Crossa6845402020-11-16 15:08:19 -0800910 initArchModule(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800911}
912
Colin Crossa6845402020-11-16 15:08:19 -0800913// InitAndroidMultiTargetsArchModule initializes the Module as an Android module that is
914// architecture-specific, but will only have a single variant per OS that handles all the
915// architectures simultaneously. The list of Targets that it must handle will be available from
916// ModuleContext.MultiTargets. It adds the common properties, for example "name" and "enabled", as
917// well as runtime generated property structs for architecture-specific versions of generic
918// properties tagged with `android:"arch_variant"`.
919//
920// InitAndroidModule or InitAndroidArchModule should not be called if
921// InitAndroidMultiTargetsArchModule was called.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700922func InitAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
923 InitAndroidArchModule(m, hod, defaultMultilib)
924 m.base().commonProperties.UseTargetVariants = false
925}
926
Colin Crossa6845402020-11-16 15:08:19 -0800927// InitCommonOSAndroidMultiTargetsArchModule initializes the Module as an Android module that is
928// architecture-specific, but will only have a single variant per OS that handles all the
929// architectures simultaneously, and will also have an additional CommonOS variant that has
930// dependencies on all the OS-specific variants. The list of Targets that it must handle will be
931// available from ModuleContext.MultiTargets. It adds the common properties, for example "name" and
932// "enabled", as well as runtime generated property structs for architecture-specific versions of
933// generic properties tagged with `android:"arch_variant"`.
934//
935// InitAndroidModule, InitAndroidArchModule or InitAndroidMultiTargetsArchModule should not be
936// called if InitCommonOSAndroidMultiTargetsArchModule was called.
Paul Duffin1356d8c2020-02-25 19:26:33 +0000937func InitCommonOSAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
938 InitAndroidArchModule(m, hod, defaultMultilib)
939 m.base().commonProperties.UseTargetVariants = false
940 m.base().commonProperties.CreateCommonOSVariant = true
941}
942
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800943// A ModuleBase object contains the properties that are common to all Android
Colin Cross3f40fa42015-01-30 17:27:36 -0800944// modules. It should be included as an anonymous field in every module
945// struct definition. InitAndroidModule should then be called from the module's
946// factory function, and the return values from InitAndroidModule should be
947// returned from the factory function.
948//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800949// The ModuleBase type is responsible for implementing the GenerateBuildActions
950// method to support the blueprint.Module interface. This method will then call
951// the module's GenerateAndroidBuildActions method once for each build variant
Colin Cross25de6c32019-06-06 14:29:25 -0700952// that is to be built. GenerateAndroidBuildActions is passed a ModuleContext
953// rather than the usual blueprint.ModuleContext.
954// ModuleContext exposes extra functionality specific to the Android build
Colin Cross3f40fa42015-01-30 17:27:36 -0800955// system including details about the particular build variant that is to be
956// generated.
957//
958// For example:
959//
960// import (
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800961// "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -0800962// )
963//
964// type myModule struct {
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800965// android.ModuleBase
Colin Cross3f40fa42015-01-30 17:27:36 -0800966// properties struct {
967// MyProperty string
968// }
969// }
970//
Colin Cross36242852017-06-23 15:06:31 -0700971// func NewMyModule() android.Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800972// m := &myModule{}
Colin Cross36242852017-06-23 15:06:31 -0700973// m.AddProperties(&m.properties)
974// android.InitAndroidModule(m)
975// return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800976// }
977//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800978// func (m *myModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800979// // Get the CPU architecture for the current build variant.
980// variantArch := ctx.Arch()
981//
982// // ...
983// }
Colin Cross635c3b02016-05-18 15:37:25 -0700984type ModuleBase struct {
Colin Cross3f40fa42015-01-30 17:27:36 -0800985 // Putting the curiously recurring thing pointing to the thing that contains
986 // the thing pattern to good use.
Colin Cross36242852017-06-23 15:06:31 -0700987 // TODO: remove this
Colin Cross635c3b02016-05-18 15:37:25 -0700988 module Module
Colin Cross3f40fa42015-01-30 17:27:36 -0800989
Colin Crossfc754582016-05-17 16:34:16 -0700990 nameProperties nameProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800991 commonProperties commonProperties
Paul Duffined875132020-09-02 13:08:57 +0100992 distProperties distProperties
Colin Cross18c46802019-09-24 22:19:02 -0700993 variableProperties interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800994 hostAndDeviceProperties hostAndDeviceProperties
995 generalProperties []interface{}
Colin Crossc17727d2018-10-24 12:42:09 -0700996 archProperties [][]interface{}
Colin Crossa120ec12016-08-19 16:07:38 -0700997 customizableProperties []interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800998
Paul Duffin63c6e182019-07-24 14:24:38 +0100999 // Information about all the properties on the module that contains visibility rules that need
1000 // checking.
1001 visibilityPropertyInfo []visibilityProperty
1002
1003 // The primary visibility property, may be nil, that controls access to the module.
1004 primaryVisibilityProperty visibilityProperty
1005
Colin Cross3f40fa42015-01-30 17:27:36 -08001006 noAddressSanitizer bool
Colin Cross897266e2020-02-13 13:22:08 -08001007 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001008 checkbuildFiles Paths
Jiyong Park073ea552020-11-09 14:08:34 +09001009 packagingSpecs []PackagingSpec
Bob Badoura75b0572020-02-18 20:21:55 -08001010 noticeFiles Paths
Colin Crossc3d87d32020-06-04 13:25:17 -07001011 phonies map[string]Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07001012
1013 // Used by buildTargetSingleton to create checkbuild and per-directory build targets
1014 // Only set on the final variant of each module
Colin Cross0875c522017-11-28 17:34:01 -08001015 installTarget WritablePath
1016 checkbuildTarget WritablePath
Colin Cross1f8c52b2015-06-16 16:38:17 -07001017 blueprintDir string
Colin Crossa120ec12016-08-19 16:07:38 -07001018
Colin Cross178a5092016-09-13 13:42:32 -07001019 hooks hooks
Colin Cross36242852017-06-23 15:06:31 -07001020
1021 registerProps []interface{}
Colin Crosscec81712017-07-13 14:43:27 -07001022
1023 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001024 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001025 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001026 variables map[string]string
Colin Crossa9d8bee2018-10-02 13:59:46 -07001027
Inseob Kim8471cda2019-11-15 09:59:12 +09001028 initRcPaths Paths
1029 vintfFragmentsPaths Paths
1030
Jiyong Park1613e552020-09-14 19:43:17 +09001031 prefer32 func(ctx BaseModuleContext, base *ModuleBase, os OsType) bool
Colin Cross36242852017-06-23 15:06:31 -07001032}
1033
Paul Duffin44f1d842020-06-26 20:17:02 +01001034func (m *ModuleBase) ComponentDepsMutator(BottomUpMutatorContext) {}
1035
Colin Cross4157e882019-06-06 16:57:04 -07001036func (m *ModuleBase) DepsMutator(BottomUpMutatorContext) {}
Colin Cross5f692ec2019-02-01 16:53:07 -08001037
Colin Cross4157e882019-06-06 16:57:04 -07001038func (m *ModuleBase) AddProperties(props ...interface{}) {
1039 m.registerProps = append(m.registerProps, props...)
Colin Cross36242852017-06-23 15:06:31 -07001040}
1041
Colin Cross4157e882019-06-06 16:57:04 -07001042func (m *ModuleBase) GetProperties() []interface{} {
1043 return m.registerProps
Colin Cross3f40fa42015-01-30 17:27:36 -08001044}
1045
Colin Cross4157e882019-06-06 16:57:04 -07001046func (m *ModuleBase) BuildParamsForTests() []BuildParams {
1047 return m.buildParams
Colin Crosscec81712017-07-13 14:43:27 -07001048}
1049
Colin Cross4157e882019-06-06 16:57:04 -07001050func (m *ModuleBase) RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams {
1051 return m.ruleParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001052}
1053
Colin Cross4157e882019-06-06 16:57:04 -07001054func (m *ModuleBase) VariablesForTests() map[string]string {
1055 return m.variables
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001056}
1057
Jiyong Park1613e552020-09-14 19:43:17 +09001058func (m *ModuleBase) Prefer32(prefer32 func(ctx BaseModuleContext, base *ModuleBase, os OsType) bool) {
Colin Cross4157e882019-06-06 16:57:04 -07001059 m.prefer32 = prefer32
Colin Crossa9d8bee2018-10-02 13:59:46 -07001060}
1061
Colin Crossce75d2c2016-10-06 16:12:58 -07001062// Name returns the name of the module. It may be overridden by individual module types, for
1063// example prebuilts will prepend prebuilt_ to the name.
Colin Cross4157e882019-06-06 16:57:04 -07001064func (m *ModuleBase) Name() string {
1065 return String(m.nameProperties.Name)
Colin Crossfc754582016-05-17 16:34:16 -07001066}
1067
Colin Cross9a362232019-07-01 15:32:45 -07001068// String returns a string that includes the module name and variants for printing during debugging.
1069func (m *ModuleBase) String() string {
1070 sb := strings.Builder{}
1071 sb.WriteString(m.commonProperties.DebugName)
1072 sb.WriteString("{")
1073 for i := range m.commonProperties.DebugMutators {
1074 if i != 0 {
1075 sb.WriteString(",")
1076 }
1077 sb.WriteString(m.commonProperties.DebugMutators[i])
1078 sb.WriteString(":")
1079 sb.WriteString(m.commonProperties.DebugVariations[i])
1080 }
1081 sb.WriteString("}")
1082 return sb.String()
1083}
1084
Colin Crossce75d2c2016-10-06 16:12:58 -07001085// BaseModuleName returns the name of the module as specified in the blueprints file.
Colin Cross4157e882019-06-06 16:57:04 -07001086func (m *ModuleBase) BaseModuleName() string {
1087 return String(m.nameProperties.Name)
Colin Crossce75d2c2016-10-06 16:12:58 -07001088}
1089
Colin Cross4157e882019-06-06 16:57:04 -07001090func (m *ModuleBase) base() *ModuleBase {
1091 return m
Colin Cross3f40fa42015-01-30 17:27:36 -08001092}
1093
Paul Duffine2453c72019-05-31 14:00:04 +01001094func (m *ModuleBase) qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName {
1095 return qualifiedModuleName{pkg: ctx.ModuleDir(), name: ctx.ModuleName()}
1096}
1097
1098func (m *ModuleBase) visibilityProperties() []visibilityProperty {
Paul Duffin63c6e182019-07-24 14:24:38 +01001099 return m.visibilityPropertyInfo
1100}
1101
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001102func (m *ModuleBase) Dists() []Dist {
Paul Duffined875132020-09-02 13:08:57 +01001103 if len(m.distProperties.Dist.Targets) > 0 {
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001104 // Make a copy of the underlying Dists slice to protect against
1105 // backing array modifications with repeated calls to this method.
Paul Duffined875132020-09-02 13:08:57 +01001106 distsCopy := append([]Dist(nil), m.distProperties.Dists...)
1107 return append(distsCopy, m.distProperties.Dist)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001108 } else {
Paul Duffined875132020-09-02 13:08:57 +01001109 return m.distProperties.Dists
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001110 }
1111}
1112
1113func (m *ModuleBase) GenerateTaggedDistFiles(ctx BaseModuleContext) TaggedDistFiles {
Paul Duffin74f05592020-11-25 16:37:46 +00001114 var distFiles TaggedDistFiles
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001115 for _, dist := range m.Dists() {
Paul Duffin74f05592020-11-25 16:37:46 +00001116 // If no tag is specified then it means to use the default dist paths so use
1117 // the special tag name which represents that.
1118 tag := proptools.StringDefault(dist.Tag, DefaultDistTag)
1119
1120 // Call the OutputFiles(tag) method to get the paths associated with the tag.
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001121 distFilesForTag, err := m.base().module.(OutputFileProducer).OutputFiles(tag)
Paul Duffin74f05592020-11-25 16:37:46 +00001122
1123 // If the tag was not supported and is not DefaultDistTag then it is an error.
1124 // Failing to find paths for DefaultDistTag is not an error. It just means
1125 // that the module type requires the legacy behavior.
1126 if err != nil && tag != DefaultDistTag {
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001127 ctx.PropertyErrorf("dist.tag", "%s", err.Error())
Paul Duffin74f05592020-11-25 16:37:46 +00001128 continue
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001129 }
Paul Duffin74f05592020-11-25 16:37:46 +00001130
1131 distFiles = distFiles.addPathsForTag(tag, distFilesForTag...)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001132 }
1133
1134 return distFiles
1135}
1136
Colin Cross4157e882019-06-06 16:57:04 -07001137func (m *ModuleBase) Target() Target {
1138 return m.commonProperties.CompileTarget
Dan Willemsen490fd492015-11-24 17:53:15 -08001139}
1140
Colin Cross4157e882019-06-06 16:57:04 -07001141func (m *ModuleBase) TargetPrimary() bool {
1142 return m.commonProperties.CompilePrimary
Colin Cross8b74d172016-09-13 09:59:14 -07001143}
1144
Colin Cross4157e882019-06-06 16:57:04 -07001145func (m *ModuleBase) MultiTargets() []Target {
1146 return m.commonProperties.CompileMultiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07001147}
1148
Colin Cross4157e882019-06-06 16:57:04 -07001149func (m *ModuleBase) Os() OsType {
1150 return m.Target().Os
Dan Willemsen490fd492015-11-24 17:53:15 -08001151}
1152
Colin Cross4157e882019-06-06 16:57:04 -07001153func (m *ModuleBase) Host() bool {
Jiyong Park1613e552020-09-14 19:43:17 +09001154 return m.Os().Class == Host
Dan Willemsen97750522016-02-09 17:43:51 -08001155}
1156
Yo Chiangbba545e2020-06-09 16:15:37 +08001157func (m *ModuleBase) Device() bool {
1158 return m.Os().Class == Device
1159}
1160
Colin Cross4157e882019-06-06 16:57:04 -07001161func (m *ModuleBase) Arch() Arch {
1162 return m.Target().Arch
Dan Willemsen97750522016-02-09 17:43:51 -08001163}
1164
Colin Cross4157e882019-06-06 16:57:04 -07001165func (m *ModuleBase) ArchSpecific() bool {
1166 return m.commonProperties.ArchSpecific
Dan Willemsen0b24c742016-10-04 15:13:37 -07001167}
1168
Paul Duffin1356d8c2020-02-25 19:26:33 +00001169// True if the current variant is a CommonOS variant, false otherwise.
1170func (m *ModuleBase) IsCommonOSVariant() bool {
1171 return m.commonProperties.CommonOSVariant
1172}
1173
Colin Cross34037c62020-11-17 13:19:17 -08001174// supportsTarget returns true if the given Target is supported by the current module.
1175func (m *ModuleBase) supportsTarget(target Target) bool {
1176 switch target.Os.Class {
1177 case Host:
1178 if target.HostCross {
1179 return m.HostCrossSupported()
1180 } else {
1181 return m.HostSupported()
Colin Crossa1ad8d12016-06-01 17:09:44 -07001182 }
Colin Cross34037c62020-11-17 13:19:17 -08001183 case Device:
1184 return m.DeviceSupported()
Colin Crossa1ad8d12016-06-01 17:09:44 -07001185 default:
Jiyong Park1613e552020-09-14 19:43:17 +09001186 return false
Colin Crossa1ad8d12016-06-01 17:09:44 -07001187 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001188}
1189
Colin Cross34037c62020-11-17 13:19:17 -08001190// DeviceSupported returns true if the current module is supported and enabled for device targets,
1191// i.e. the factory method set the HostOrDeviceSupported value to include device support and
1192// the device support is enabled by default or enabled by the device_supported property.
Colin Cross4157e882019-06-06 16:57:04 -07001193func (m *ModuleBase) DeviceSupported() bool {
Colin Cross34037c62020-11-17 13:19:17 -08001194 hod := m.commonProperties.HostOrDeviceSupported
1195 // deviceEnabled is true if the device_supported property is true or the HostOrDeviceSupported
1196 // value has the deviceDefault bit set.
1197 deviceEnabled := proptools.BoolDefault(m.hostAndDeviceProperties.Device_supported, hod&deviceDefault != 0)
1198 return hod&deviceSupported != 0 && deviceEnabled
Colin Cross3f40fa42015-01-30 17:27:36 -08001199}
1200
Colin Cross34037c62020-11-17 13:19:17 -08001201// HostSupported returns true if the current module is supported and enabled for host targets,
1202// i.e. the factory method set the HostOrDeviceSupported value to include host support and
1203// the host support is enabled by default or enabled by the host_supported property.
Paul Duffine44358f2019-11-26 18:04:12 +00001204func (m *ModuleBase) HostSupported() bool {
Colin Cross34037c62020-11-17 13:19:17 -08001205 hod := m.commonProperties.HostOrDeviceSupported
1206 // hostEnabled is true if the host_supported property is true or the HostOrDeviceSupported
1207 // value has the hostDefault bit set.
1208 hostEnabled := proptools.BoolDefault(m.hostAndDeviceProperties.Host_supported, hod&hostDefault != 0)
1209 return hod&hostSupported != 0 && hostEnabled
1210}
1211
1212// HostCrossSupported returns true if the current module is supported and enabled for host cross
1213// targets, i.e. the factory method set the HostOrDeviceSupported value to include host cross
1214// support and the host cross support is enabled by default or enabled by the
1215// host_supported property.
1216func (m *ModuleBase) HostCrossSupported() bool {
1217 hod := m.commonProperties.HostOrDeviceSupported
1218 // hostEnabled is true if the host_supported property is true or the HostOrDeviceSupported
1219 // value has the hostDefault bit set.
1220 hostEnabled := proptools.BoolDefault(m.hostAndDeviceProperties.Host_supported, hod&hostDefault != 0)
1221 return hod&hostCrossSupported != 0 && hostEnabled
Paul Duffine44358f2019-11-26 18:04:12 +00001222}
1223
Colin Cross4157e882019-06-06 16:57:04 -07001224func (m *ModuleBase) Platform() bool {
Justin Yund5f6c822019-06-25 16:47:17 +09001225 return !m.DeviceSpecific() && !m.SocSpecific() && !m.ProductSpecific() && !m.SystemExtSpecific()
Jiyong Parkc678ad32018-04-10 13:07:10 +09001226}
1227
Colin Cross4157e882019-06-06 16:57:04 -07001228func (m *ModuleBase) DeviceSpecific() bool {
1229 return Bool(m.commonProperties.Device_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +09001230}
1231
Colin Cross4157e882019-06-06 16:57:04 -07001232func (m *ModuleBase) SocSpecific() bool {
1233 return Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +09001234}
1235
Colin Cross4157e882019-06-06 16:57:04 -07001236func (m *ModuleBase) ProductSpecific() bool {
1237 return Bool(m.commonProperties.Product_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +09001238}
1239
Justin Yund5f6c822019-06-25 16:47:17 +09001240func (m *ModuleBase) SystemExtSpecific() bool {
1241 return Bool(m.commonProperties.System_ext_specific)
Dario Frenifd05a742018-05-29 13:28:54 +01001242}
1243
Colin Crossc2d24052020-05-13 11:05:02 -07001244// RequiresStableAPIs returns true if the module will be installed to a partition that may
1245// be updated separately from the system image.
1246func (m *ModuleBase) RequiresStableAPIs(ctx BaseModuleContext) bool {
1247 return m.SocSpecific() || m.DeviceSpecific() ||
1248 (m.ProductSpecific() && ctx.Config().EnforceProductPartitionInterface())
1249}
1250
Bill Peckhamfff3f8a2020-03-20 18:33:20 -07001251func (m *ModuleBase) PartitionTag(config DeviceConfig) string {
1252 partition := "system"
1253 if m.SocSpecific() {
1254 // A SoC-specific module could be on the vendor partition at
1255 // "vendor" or the system partition at "system/vendor".
1256 if config.VendorPath() == "vendor" {
1257 partition = "vendor"
1258 }
1259 } else if m.DeviceSpecific() {
1260 // A device-specific module could be on the odm partition at
1261 // "odm", the vendor partition at "vendor/odm", or the system
1262 // partition at "system/vendor/odm".
1263 if config.OdmPath() == "odm" {
1264 partition = "odm"
Ramy Medhat944839a2020-03-31 22:14:52 -04001265 } else if strings.HasPrefix(config.OdmPath(), "vendor/") {
Bill Peckhamfff3f8a2020-03-20 18:33:20 -07001266 partition = "vendor"
1267 }
1268 } else if m.ProductSpecific() {
1269 // A product-specific module could be on the product partition
1270 // at "product" or the system partition at "system/product".
1271 if config.ProductPath() == "product" {
1272 partition = "product"
1273 }
1274 } else if m.SystemExtSpecific() {
1275 // A system_ext-specific module could be on the system_ext
1276 // partition at "system_ext" or the system partition at
1277 // "system/system_ext".
1278 if config.SystemExtPath() == "system_ext" {
1279 partition = "system_ext"
1280 }
1281 }
1282 return partition
1283}
1284
Colin Cross4157e882019-06-06 16:57:04 -07001285func (m *ModuleBase) Enabled() bool {
Justin Yun32f053b2020-07-31 23:07:17 +09001286 if m.commonProperties.ForcedDisabled {
1287 return false
1288 }
Colin Cross08d6f8f2020-11-19 02:33:19 +00001289 if m.commonProperties.Enabled == nil {
1290 return !m.Os().DefaultDisabled
1291 }
1292 return *m.commonProperties.Enabled
Colin Cross3f40fa42015-01-30 17:27:36 -08001293}
1294
Inseob Kimeec88e12020-01-22 11:11:29 +09001295func (m *ModuleBase) Disable() {
Justin Yun32f053b2020-07-31 23:07:17 +09001296 m.commonProperties.ForcedDisabled = true
Inseob Kimeec88e12020-01-22 11:11:29 +09001297}
1298
Colin Cross4157e882019-06-06 16:57:04 -07001299func (m *ModuleBase) SkipInstall() {
1300 m.commonProperties.SkipInstall = true
Colin Crossce75d2c2016-10-06 16:12:58 -07001301}
1302
Ulya Trafimovichb28cc372020-01-13 15:18:16 +00001303func (m *ModuleBase) IsSkipInstall() bool {
1304 return m.commonProperties.SkipInstall == true
1305}
1306
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001307// Similar to SkipInstall, but if the AndroidMk entry would set
1308// LOCAL_UNINSTALLABLE_MODULE then this variant may still output that entry
1309// rather than leaving it out altogether. That happens in cases where it would
1310// have other side effects, in particular when it adds a NOTICE file target,
1311// which other install targets might depend on.
1312func (m *ModuleBase) MakeUninstallable() {
1313 m.SkipInstall()
1314}
1315
Liz Kammer5ca3a622020-08-05 15:40:41 -07001316func (m *ModuleBase) ReplacedByPrebuilt() {
1317 m.commonProperties.ReplacedByPrebuilt = true
1318 m.SkipInstall()
1319}
1320
1321func (m *ModuleBase) IsReplacedByPrebuilt() bool {
1322 return m.commonProperties.ReplacedByPrebuilt
1323}
1324
Colin Cross4157e882019-06-06 16:57:04 -07001325func (m *ModuleBase) ExportedToMake() bool {
1326 return m.commonProperties.NamespaceExportedToMake
Jiyong Park374510b2018-03-19 18:23:01 +09001327}
1328
Colin Crosse9fe2942020-11-10 18:12:15 -08001329// computeInstallDeps finds the installed paths of all dependencies that have a dependency
1330// tag that is annotated as needing installation via the IsInstallDepNeeded method.
Colin Cross897266e2020-02-13 13:22:08 -08001331func (m *ModuleBase) computeInstallDeps(ctx blueprint.ModuleContext) InstallPaths {
Colin Cross897266e2020-02-13 13:22:08 -08001332 var result InstallPaths
Colin Crosse9fe2942020-11-10 18:12:15 -08001333 ctx.WalkDeps(func(child, parent blueprint.Module) bool {
1334 if a, ok := child.(Module); ok {
1335 if IsInstallDepNeeded(ctx.OtherModuleDependencyTag(child)) {
1336 result = append(result, a.FilesToInstall()...)
1337 return true
1338 }
Colin Cross897266e2020-02-13 13:22:08 -08001339 }
Colin Crosse9fe2942020-11-10 18:12:15 -08001340 return false
Colin Cross897266e2020-02-13 13:22:08 -08001341 })
Colin Cross3f40fa42015-01-30 17:27:36 -08001342
1343 return result
1344}
1345
Jiyong Park4dc2a1a2020-09-28 17:46:22 +09001346func (m *ModuleBase) FilesToInstall() InstallPaths {
Colin Cross4157e882019-06-06 16:57:04 -07001347 return m.installFiles
Colin Cross3f40fa42015-01-30 17:27:36 -08001348}
1349
Jiyong Park073ea552020-11-09 14:08:34 +09001350func (m *ModuleBase) PackagingSpecs() []PackagingSpec {
1351 return m.packagingSpecs
1352}
1353
Colin Cross4157e882019-06-06 16:57:04 -07001354func (m *ModuleBase) NoAddressSanitizer() bool {
1355 return m.noAddressSanitizer
Colin Cross3f40fa42015-01-30 17:27:36 -08001356}
1357
Colin Cross4157e882019-06-06 16:57:04 -07001358func (m *ModuleBase) InstallInData() bool {
Dan Willemsen782a2d12015-12-21 14:55:28 -08001359 return false
1360}
1361
Jaewoong Jung0949f312019-09-11 10:25:18 -07001362func (m *ModuleBase) InstallInTestcases() bool {
1363 return false
1364}
1365
Colin Cross4157e882019-06-06 16:57:04 -07001366func (m *ModuleBase) InstallInSanitizerDir() bool {
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001367 return false
1368}
1369
Yifan Hong1b3348d2020-01-21 15:53:22 -08001370func (m *ModuleBase) InstallInRamdisk() bool {
1371 return Bool(m.commonProperties.Ramdisk)
1372}
1373
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001374func (m *ModuleBase) InstallInVendorRamdisk() bool {
1375 return Bool(m.commonProperties.Vendor_ramdisk)
1376}
1377
Colin Cross4157e882019-06-06 16:57:04 -07001378func (m *ModuleBase) InstallInRecovery() bool {
1379 return Bool(m.commonProperties.Recovery)
Jiyong Parkf9332f12018-02-01 00:54:12 +09001380}
1381
Colin Cross90ba5f42019-10-02 11:10:58 -07001382func (m *ModuleBase) InstallInRoot() bool {
1383 return false
1384}
1385
Colin Cross607d8582019-07-29 16:44:46 -07001386func (m *ModuleBase) InstallBypassMake() bool {
1387 return false
1388}
1389
Jiyong Park87788b52020-09-01 12:37:45 +09001390func (m *ModuleBase) InstallForceOS() (*OsType, *ArchType) {
1391 return nil, nil
Colin Cross6e359402020-02-10 15:29:54 -08001392}
1393
Colin Cross4157e882019-06-06 16:57:04 -07001394func (m *ModuleBase) Owner() string {
1395 return String(m.commonProperties.Owner)
Sundong Ahn4fd04bb2018-08-31 18:01:37 +09001396}
1397
Bob Badoura75b0572020-02-18 20:21:55 -08001398func (m *ModuleBase) NoticeFiles() Paths {
1399 return m.noticeFiles
Jiyong Park52818fc2019-03-18 12:01:38 +09001400}
1401
Colin Cross7228ecd2019-11-18 16:00:16 -08001402func (m *ModuleBase) setImageVariation(variant string) {
1403 m.commonProperties.ImageVariation = variant
1404}
1405
1406func (m *ModuleBase) ImageVariation() blueprint.Variation {
1407 return blueprint.Variation{
1408 Mutator: "image",
1409 Variation: m.base().commonProperties.ImageVariation,
1410 }
1411}
1412
Paul Duffin9b76c0b2020-03-12 10:24:35 +00001413func (m *ModuleBase) getVariationByMutatorName(mutator string) string {
1414 for i, v := range m.commonProperties.DebugMutators {
1415 if v == mutator {
1416 return m.commonProperties.DebugVariations[i]
1417 }
1418 }
1419
1420 return ""
1421}
1422
Yifan Hong1b3348d2020-01-21 15:53:22 -08001423func (m *ModuleBase) InRamdisk() bool {
1424 return m.base().commonProperties.ImageVariation == RamdiskVariation
1425}
1426
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001427func (m *ModuleBase) InVendorRamdisk() bool {
1428 return m.base().commonProperties.ImageVariation == VendorRamdiskVariation
1429}
1430
Colin Cross7228ecd2019-11-18 16:00:16 -08001431func (m *ModuleBase) InRecovery() bool {
1432 return m.base().commonProperties.ImageVariation == RecoveryVariation
1433}
1434
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09001435func (m *ModuleBase) RequiredModuleNames() []string {
1436 return m.base().commonProperties.Required
1437}
1438
1439func (m *ModuleBase) HostRequiredModuleNames() []string {
1440 return m.base().commonProperties.Host_required
1441}
1442
1443func (m *ModuleBase) TargetRequiredModuleNames() []string {
1444 return m.base().commonProperties.Target_required
1445}
1446
Inseob Kim8471cda2019-11-15 09:59:12 +09001447func (m *ModuleBase) InitRc() Paths {
1448 return append(Paths{}, m.initRcPaths...)
1449}
1450
1451func (m *ModuleBase) VintfFragments() Paths {
1452 return append(Paths{}, m.vintfFragmentsPaths...)
1453}
1454
Colin Cross4157e882019-06-06 16:57:04 -07001455func (m *ModuleBase) generateModuleTarget(ctx ModuleContext) {
Colin Cross897266e2020-02-13 13:22:08 -08001456 var allInstalledFiles InstallPaths
1457 var allCheckbuildFiles Paths
Colin Cross0875c522017-11-28 17:34:01 -08001458 ctx.VisitAllModuleVariants(func(module Module) {
1459 a := module.base()
Colin Crossc9404352015-03-26 16:10:12 -07001460 allInstalledFiles = append(allInstalledFiles, a.installFiles...)
1461 allCheckbuildFiles = append(allCheckbuildFiles, a.checkbuildFiles...)
Colin Cross3f40fa42015-01-30 17:27:36 -08001462 })
1463
Colin Cross0875c522017-11-28 17:34:01 -08001464 var deps Paths
Colin Cross9454bfa2015-03-17 13:24:18 -07001465
Colin Cross133ebef2020-08-14 17:38:45 -07001466 namespacePrefix := ctx.Namespace().id
Jeff Gaston088e29e2017-11-29 16:47:17 -08001467 if namespacePrefix != "" {
1468 namespacePrefix = namespacePrefix + "-"
1469 }
1470
Colin Cross3f40fa42015-01-30 17:27:36 -08001471 if len(allInstalledFiles) > 0 {
Colin Crossc3d87d32020-06-04 13:25:17 -07001472 name := namespacePrefix + ctx.ModuleName() + "-install"
1473 ctx.Phony(name, allInstalledFiles.Paths()...)
1474 m.installTarget = PathForPhony(ctx, name)
1475 deps = append(deps, m.installTarget)
Colin Cross9454bfa2015-03-17 13:24:18 -07001476 }
1477
1478 if len(allCheckbuildFiles) > 0 {
Colin Crossc3d87d32020-06-04 13:25:17 -07001479 name := namespacePrefix + ctx.ModuleName() + "-checkbuild"
1480 ctx.Phony(name, allCheckbuildFiles...)
1481 m.checkbuildTarget = PathForPhony(ctx, name)
1482 deps = append(deps, m.checkbuildTarget)
Colin Cross9454bfa2015-03-17 13:24:18 -07001483 }
1484
1485 if len(deps) > 0 {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001486 suffix := ""
Jingwen Chencda22c92020-11-23 00:22:30 -05001487 if ctx.Config().KatiEnabled() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001488 suffix = "-soong"
1489 }
1490
Colin Crossc3d87d32020-06-04 13:25:17 -07001491 ctx.Phony(namespacePrefix+ctx.ModuleName()+suffix, deps...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07001492
Colin Cross4157e882019-06-06 16:57:04 -07001493 m.blueprintDir = ctx.ModuleDir()
Colin Cross3f40fa42015-01-30 17:27:36 -08001494 }
1495}
1496
Colin Crossc34d2322020-01-03 15:23:27 -08001497func determineModuleKind(m *ModuleBase, ctx blueprint.EarlyModuleContext) moduleKind {
Colin Cross4157e882019-06-06 16:57:04 -07001498 var socSpecific = Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
1499 var deviceSpecific = Bool(m.commonProperties.Device_specific)
1500 var productSpecific = Bool(m.commonProperties.Product_specific)
Justin Yund5f6c822019-06-25 16:47:17 +09001501 var systemExtSpecific = Bool(m.commonProperties.System_ext_specific)
Jiyong Park2db76922017-11-08 16:03:48 +09001502
Dario Frenifd05a742018-05-29 13:28:54 +01001503 msg := "conflicting value set here"
1504 if socSpecific && deviceSpecific {
1505 ctx.PropertyErrorf("device_specific", "a module cannot be specific to SoC and device at the same time.")
Colin Cross4157e882019-06-06 16:57:04 -07001506 if Bool(m.commonProperties.Vendor) {
Jiyong Park2db76922017-11-08 16:03:48 +09001507 ctx.PropertyErrorf("vendor", msg)
1508 }
Colin Cross4157e882019-06-06 16:57:04 -07001509 if Bool(m.commonProperties.Proprietary) {
Jiyong Park2db76922017-11-08 16:03:48 +09001510 ctx.PropertyErrorf("proprietary", msg)
1511 }
Colin Cross4157e882019-06-06 16:57:04 -07001512 if Bool(m.commonProperties.Soc_specific) {
Jiyong Park2db76922017-11-08 16:03:48 +09001513 ctx.PropertyErrorf("soc_specific", msg)
1514 }
1515 }
1516
Justin Yund5f6c822019-06-25 16:47:17 +09001517 if productSpecific && systemExtSpecific {
1518 ctx.PropertyErrorf("product_specific", "a module cannot be specific to product and system_ext at the same time.")
1519 ctx.PropertyErrorf("system_ext_specific", msg)
Dario Frenifd05a742018-05-29 13:28:54 +01001520 }
1521
Justin Yund5f6c822019-06-25 16:47:17 +09001522 if (socSpecific || deviceSpecific) && (productSpecific || systemExtSpecific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001523 if productSpecific {
1524 ctx.PropertyErrorf("product_specific", "a module cannot be specific to SoC or device and product at the same time.")
1525 } else {
Justin Yund5f6c822019-06-25 16:47:17 +09001526 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 +01001527 }
1528 if deviceSpecific {
1529 ctx.PropertyErrorf("device_specific", msg)
1530 } else {
Colin Cross4157e882019-06-06 16:57:04 -07001531 if Bool(m.commonProperties.Vendor) {
Dario Frenifd05a742018-05-29 13:28:54 +01001532 ctx.PropertyErrorf("vendor", msg)
1533 }
Colin Cross4157e882019-06-06 16:57:04 -07001534 if Bool(m.commonProperties.Proprietary) {
Dario Frenifd05a742018-05-29 13:28:54 +01001535 ctx.PropertyErrorf("proprietary", msg)
1536 }
Colin Cross4157e882019-06-06 16:57:04 -07001537 if Bool(m.commonProperties.Soc_specific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001538 ctx.PropertyErrorf("soc_specific", msg)
1539 }
1540 }
1541 }
1542
Jiyong Park2db76922017-11-08 16:03:48 +09001543 if productSpecific {
1544 return productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +09001545 } else if systemExtSpecific {
1546 return systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001547 } else if deviceSpecific {
1548 return deviceSpecificModule
1549 } else if socSpecific {
1550 return socSpecificModule
1551 } else {
1552 return platformModule
1553 }
1554}
1555
Colin Crossc34d2322020-01-03 15:23:27 -08001556func (m *ModuleBase) earlyModuleContextFactory(ctx blueprint.EarlyModuleContext) earlyModuleContext {
Colin Cross1184b642019-12-30 18:43:07 -08001557 return earlyModuleContext{
Colin Crossc34d2322020-01-03 15:23:27 -08001558 EarlyModuleContext: ctx,
1559 kind: determineModuleKind(m, ctx),
1560 config: ctx.Config().(Config),
Colin Cross3f40fa42015-01-30 17:27:36 -08001561 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001562}
1563
Colin Cross1184b642019-12-30 18:43:07 -08001564func (m *ModuleBase) baseModuleContextFactory(ctx blueprint.BaseModuleContext) baseModuleContext {
1565 return baseModuleContext{
1566 bp: ctx,
1567 earlyModuleContext: m.earlyModuleContextFactory(ctx),
1568 os: m.commonProperties.CompileOS,
1569 target: m.commonProperties.CompileTarget,
1570 targetPrimary: m.commonProperties.CompilePrimary,
1571 multiTargets: m.commonProperties.CompileMultiTargets,
1572 }
1573}
1574
Colin Cross4157e882019-06-06 16:57:04 -07001575func (m *ModuleBase) GenerateBuildActions(blueprintCtx blueprint.ModuleContext) {
Colin Cross25de6c32019-06-06 14:29:25 -07001576 ctx := &moduleContext{
Colin Cross0ea8ba82019-06-06 14:33:29 -07001577 module: m.module,
Colin Crossdc35e212019-06-06 16:13:11 -07001578 bp: blueprintCtx,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001579 baseModuleContext: m.baseModuleContextFactory(blueprintCtx),
1580 installDeps: m.computeInstallDeps(blueprintCtx),
1581 installFiles: m.installFiles,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001582 variables: make(map[string]string),
Colin Cross3f40fa42015-01-30 17:27:36 -08001583 }
1584
Colin Cross6c4f21f2019-06-06 15:41:36 -07001585 // Temporarily continue to call blueprintCtx.GetMissingDependencies() to maintain the previous behavior of never
1586 // reporting missing dependency errors in Blueprint when AllowMissingDependencies == true.
1587 // TODO: This will be removed once defaults modules handle missing dependency errors
1588 blueprintCtx.GetMissingDependencies()
1589
Colin Crossdc35e212019-06-06 16:13:11 -07001590 // For the final GenerateAndroidBuildActions pass, require that all visited dependencies Soong modules and
Paul Duffin1356d8c2020-02-25 19:26:33 +00001591 // are enabled. Unless the module is a CommonOS variant which may have dependencies on disabled variants
1592 // (because the dependencies are added before the modules are disabled). The
1593 // GetOsSpecificVariantsOfCommonOSVariant(...) method will ensure that the disabled variants are
1594 // ignored.
1595 ctx.baseModuleContext.strictVisitDeps = !m.IsCommonOSVariant()
Colin Crossdc35e212019-06-06 16:13:11 -07001596
Colin Cross4c83e5c2019-02-25 14:54:28 -08001597 if ctx.config.captureBuild {
1598 ctx.ruleParams = make(map[blueprint.Rule]blueprint.RuleParams)
1599 }
1600
Colin Cross67a5c132017-05-09 13:45:28 -07001601 desc := "//" + ctx.ModuleDir() + ":" + ctx.ModuleName() + " "
1602 var suffix []string
Colin Cross0875c522017-11-28 17:34:01 -08001603 if ctx.Os().Class != Device && ctx.Os().Class != Generic {
1604 suffix = append(suffix, ctx.Os().String())
Colin Cross67a5c132017-05-09 13:45:28 -07001605 }
Colin Cross0875c522017-11-28 17:34:01 -08001606 if !ctx.PrimaryArch() {
1607 suffix = append(suffix, ctx.Arch().ArchType.String())
Colin Cross67a5c132017-05-09 13:45:28 -07001608 }
Colin Cross56a83212020-09-15 18:30:11 -07001609 if apexInfo := ctx.Provider(ApexInfoProvider).(ApexInfo); !apexInfo.IsForPlatform() {
1610 suffix = append(suffix, apexInfo.ApexVariationName)
Dan Willemsenb13a9482020-02-14 11:25:54 -08001611 }
Colin Cross67a5c132017-05-09 13:45:28 -07001612
1613 ctx.Variable(pctx, "moduleDesc", desc)
1614
1615 s := ""
1616 if len(suffix) > 0 {
1617 s = " [" + strings.Join(suffix, " ") + "]"
1618 }
1619 ctx.Variable(pctx, "moduleDescSuffix", s)
1620
Dan Willemsen569edc52018-11-19 09:33:29 -08001621 // Some common property checks for properties that will be used later in androidmk.go
Paul Duffin89968e32020-11-23 18:17:03 +00001622 checkDistProperties(ctx, "dist", &m.distProperties.Dist)
1623 for i, _ := range m.distProperties.Dists {
1624 checkDistProperties(ctx, fmt.Sprintf("dists[%d]", i), &m.distProperties.Dists[i])
Dan Willemsen569edc52018-11-19 09:33:29 -08001625 }
1626
Colin Cross4157e882019-06-06 16:57:04 -07001627 if m.Enabled() {
Jooyung Hand48f3c32019-08-23 11:18:57 +09001628 // ensure all direct android.Module deps are enabled
1629 ctx.VisitDirectDepsBlueprint(func(bm blueprint.Module) {
1630 if _, ok := bm.(Module); ok {
1631 ctx.validateAndroidModule(bm, ctx.baseModuleContext.strictVisitDeps)
1632 }
1633 })
1634
Bob Badoura75b0572020-02-18 20:21:55 -08001635 m.noticeFiles = make([]Path, 0)
1636 optPath := OptionalPath{}
1637 notice := proptools.StringDefault(m.commonProperties.Notice, "")
Colin Cross4157e882019-06-06 16:57:04 -07001638 if module := SrcIsModule(notice); module != "" {
Bob Badoura75b0572020-02-18 20:21:55 -08001639 optPath = ctx.ExpandOptionalSource(&notice, "notice")
1640 } else if notice != "" {
Jiyong Park52818fc2019-03-18 12:01:38 +09001641 noticePath := filepath.Join(ctx.ModuleDir(), notice)
Bob Badoura75b0572020-02-18 20:21:55 -08001642 optPath = ExistentPathForSource(ctx, noticePath)
1643 }
1644 if optPath.Valid() {
1645 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1646 } else {
1647 for _, notice = range []string{"LICENSE", "LICENCE", "NOTICE"} {
1648 noticePath := filepath.Join(ctx.ModuleDir(), notice)
1649 optPath = ExistentPathForSource(ctx, noticePath)
1650 if optPath.Valid() {
1651 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1652 }
1653 }
Jaewoong Jung62707f72018-11-16 13:26:43 -08001654 }
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001655
1656 m.module.GenerateAndroidBuildActions(ctx)
1657 if ctx.Failed() {
1658 return
1659 }
1660
1661 m.installFiles = append(m.installFiles, ctx.installFiles...)
1662 m.checkbuildFiles = append(m.checkbuildFiles, ctx.checkbuildFiles...)
Jiyong Park073ea552020-11-09 14:08:34 +09001663 m.packagingSpecs = append(m.packagingSpecs, ctx.packagingSpecs...)
Inseob Kim8471cda2019-11-15 09:59:12 +09001664 m.initRcPaths = PathsForModuleSrc(ctx, m.commonProperties.Init_rc)
1665 m.vintfFragmentsPaths = PathsForModuleSrc(ctx, m.commonProperties.Vintf_fragments)
Colin Crossc3d87d32020-06-04 13:25:17 -07001666 for k, v := range ctx.phonies {
1667 m.phonies[k] = append(m.phonies[k], v...)
1668 }
Colin Crossdc35e212019-06-06 16:13:11 -07001669 } else if ctx.Config().AllowMissingDependencies() {
1670 // If the module is not enabled it will not create any build rules, nothing will call
1671 // ctx.GetMissingDependencies(), and blueprint will consider the missing dependencies to be unhandled
1672 // and report them as an error even when AllowMissingDependencies = true. Call
1673 // ctx.GetMissingDependencies() here to tell blueprint not to handle them.
1674 ctx.GetMissingDependencies()
Colin Cross3f40fa42015-01-30 17:27:36 -08001675 }
1676
Colin Cross4157e882019-06-06 16:57:04 -07001677 if m == ctx.FinalModule().(Module).base() {
1678 m.generateModuleTarget(ctx)
Colin Cross9b1d13d2016-09-19 15:18:11 -07001679 if ctx.Failed() {
1680 return
1681 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001682 }
Colin Crosscec81712017-07-13 14:43:27 -07001683
Colin Cross4157e882019-06-06 16:57:04 -07001684 m.buildParams = ctx.buildParams
1685 m.ruleParams = ctx.ruleParams
1686 m.variables = ctx.variables
Colin Cross3f40fa42015-01-30 17:27:36 -08001687}
1688
Paul Duffin89968e32020-11-23 18:17:03 +00001689// Check the supplied dist structure to make sure that it is valid.
1690//
1691// property - the base property, e.g. dist or dists[1], which is combined with the
1692// name of the nested property to produce the full property, e.g. dist.dest or
1693// dists[1].dir.
1694func checkDistProperties(ctx *moduleContext, property string, dist *Dist) {
1695 if dist.Dest != nil {
1696 _, err := validateSafePath(*dist.Dest)
1697 if err != nil {
1698 ctx.PropertyErrorf(property+".dest", "%s", err.Error())
1699 }
1700 }
1701 if dist.Dir != nil {
1702 _, err := validateSafePath(*dist.Dir)
1703 if err != nil {
1704 ctx.PropertyErrorf(property+".dir", "%s", err.Error())
1705 }
1706 }
1707 if dist.Suffix != nil {
1708 if strings.Contains(*dist.Suffix, "/") {
1709 ctx.PropertyErrorf(property+".suffix", "Suffix may not contain a '/' character.")
1710 }
1711 }
1712
1713}
1714
Colin Cross1184b642019-12-30 18:43:07 -08001715type earlyModuleContext struct {
Colin Crossc34d2322020-01-03 15:23:27 -08001716 blueprint.EarlyModuleContext
Colin Cross1184b642019-12-30 18:43:07 -08001717
1718 kind moduleKind
1719 config Config
1720}
1721
1722func (e *earlyModuleContext) Glob(globPattern string, excludes []string) Paths {
1723 ret, err := e.GlobWithDeps(globPattern, excludes)
1724 if err != nil {
1725 e.ModuleErrorf("glob: %s", err.Error())
1726 }
1727 return pathsForModuleSrcFromFullPath(e, ret, true)
1728}
1729
1730func (e *earlyModuleContext) GlobFiles(globPattern string, excludes []string) Paths {
1731 ret, err := e.GlobWithDeps(globPattern, excludes)
1732 if err != nil {
1733 e.ModuleErrorf("glob: %s", err.Error())
1734 }
1735 return pathsForModuleSrcFromFullPath(e, ret, false)
1736}
1737
Colin Cross988414c2020-01-11 01:11:46 +00001738func (b *earlyModuleContext) IsSymlink(path Path) bool {
1739 fileInfo, err := b.config.fs.Lstat(path.String())
1740 if err != nil {
1741 b.ModuleErrorf("os.Lstat(%q) failed: %s", path.String(), err)
1742 }
1743 return fileInfo.Mode()&os.ModeSymlink == os.ModeSymlink
1744}
1745
1746func (b *earlyModuleContext) Readlink(path Path) string {
1747 dest, err := b.config.fs.Readlink(path.String())
1748 if err != nil {
1749 b.ModuleErrorf("os.Readlink(%q) failed: %s", path.String(), err)
1750 }
1751 return dest
1752}
1753
Colin Cross1184b642019-12-30 18:43:07 -08001754func (e *earlyModuleContext) Module() Module {
Colin Crossc34d2322020-01-03 15:23:27 -08001755 module, _ := e.EarlyModuleContext.Module().(Module)
Colin Cross1184b642019-12-30 18:43:07 -08001756 return module
1757}
1758
1759func (e *earlyModuleContext) Config() Config {
Colin Crossc34d2322020-01-03 15:23:27 -08001760 return e.EarlyModuleContext.Config().(Config)
Colin Cross1184b642019-12-30 18:43:07 -08001761}
1762
1763func (e *earlyModuleContext) AConfig() Config {
1764 return e.config
1765}
1766
1767func (e *earlyModuleContext) DeviceConfig() DeviceConfig {
1768 return DeviceConfig{e.config.deviceConfig}
1769}
1770
1771func (e *earlyModuleContext) Platform() bool {
1772 return e.kind == platformModule
1773}
1774
1775func (e *earlyModuleContext) DeviceSpecific() bool {
1776 return e.kind == deviceSpecificModule
1777}
1778
1779func (e *earlyModuleContext) SocSpecific() bool {
1780 return e.kind == socSpecificModule
1781}
1782
1783func (e *earlyModuleContext) ProductSpecific() bool {
1784 return e.kind == productSpecificModule
1785}
1786
1787func (e *earlyModuleContext) SystemExtSpecific() bool {
1788 return e.kind == systemExtSpecificModule
1789}
1790
Colin Cross133ebef2020-08-14 17:38:45 -07001791func (e *earlyModuleContext) Namespace() *Namespace {
1792 return e.EarlyModuleContext.Namespace().(*Namespace)
1793}
1794
Colin Cross1184b642019-12-30 18:43:07 -08001795type baseModuleContext struct {
1796 bp blueprint.BaseModuleContext
1797 earlyModuleContext
Colin Crossfb0c16e2019-11-20 17:12:35 -08001798 os OsType
Colin Cross8b74d172016-09-13 09:59:14 -07001799 target Target
Colin Crossee0bc3b2018-10-02 22:01:37 -07001800 multiTargets []Target
Colin Cross8b74d172016-09-13 09:59:14 -07001801 targetPrimary bool
1802 debug bool
Colin Crossdc35e212019-06-06 16:13:11 -07001803
1804 walkPath []Module
Paul Duffinc5192442020-03-31 11:31:36 +01001805 tagPath []blueprint.DependencyTag
Colin Crossdc35e212019-06-06 16:13:11 -07001806
1807 strictVisitDeps bool // If true, enforce that all dependencies are enabled
Colin Crossf6566ed2015-03-24 11:13:38 -07001808}
1809
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001810func (b *baseModuleContext) OtherModuleName(m blueprint.Module) string {
1811 return b.bp.OtherModuleName(m)
1812}
1813func (b *baseModuleContext) OtherModuleDir(m blueprint.Module) string { return b.bp.OtherModuleDir(m) }
Colin Cross1184b642019-12-30 18:43:07 -08001814func (b *baseModuleContext) OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{}) {
Jooyung Hancd87c692020-02-26 02:05:18 +09001815 b.bp.OtherModuleErrorf(m, fmt, args...)
Colin Cross1184b642019-12-30 18:43:07 -08001816}
1817func (b *baseModuleContext) OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag {
1818 return b.bp.OtherModuleDependencyTag(m)
1819}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001820func (b *baseModuleContext) OtherModuleExists(name string) bool { return b.bp.OtherModuleExists(name) }
Martin Stjernholm009a9dc2020-03-05 17:34:13 +00001821func (b *baseModuleContext) OtherModuleDependencyVariantExists(variations []blueprint.Variation, name string) bool {
1822 return b.bp.OtherModuleDependencyVariantExists(variations, name)
1823}
1824func (b *baseModuleContext) OtherModuleReverseDependencyVariantExists(name string) bool {
1825 return b.bp.OtherModuleReverseDependencyVariantExists(name)
1826}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001827func (b *baseModuleContext) OtherModuleType(m blueprint.Module) string {
1828 return b.bp.OtherModuleType(m)
1829}
Colin Crossd27e7b82020-07-02 11:38:17 -07001830func (b *baseModuleContext) OtherModuleProvider(m blueprint.Module, provider blueprint.ProviderKey) interface{} {
1831 return b.bp.OtherModuleProvider(m, provider)
1832}
1833func (b *baseModuleContext) OtherModuleHasProvider(m blueprint.Module, provider blueprint.ProviderKey) bool {
1834 return b.bp.OtherModuleHasProvider(m, provider)
1835}
1836func (b *baseModuleContext) Provider(provider blueprint.ProviderKey) interface{} {
1837 return b.bp.Provider(provider)
1838}
1839func (b *baseModuleContext) HasProvider(provider blueprint.ProviderKey) bool {
1840 return b.bp.HasProvider(provider)
1841}
1842func (b *baseModuleContext) SetProvider(provider blueprint.ProviderKey, value interface{}) {
1843 b.bp.SetProvider(provider, value)
1844}
Colin Cross1184b642019-12-30 18:43:07 -08001845
1846func (b *baseModuleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1847 return b.bp.GetDirectDepWithTag(name, tag)
1848}
1849
Paul Duffinf88d8e02020-05-07 20:21:34 +01001850func (b *baseModuleContext) blueprintBaseModuleContext() blueprint.BaseModuleContext {
1851 return b.bp
1852}
1853
Colin Cross25de6c32019-06-06 14:29:25 -07001854type moduleContext struct {
Colin Crossdc35e212019-06-06 16:13:11 -07001855 bp blueprint.ModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -07001856 baseModuleContext
Jiyong Park073ea552020-11-09 14:08:34 +09001857 packagingSpecs []PackagingSpec
Colin Cross897266e2020-02-13 13:22:08 -08001858 installDeps InstallPaths
1859 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001860 checkbuildFiles Paths
Colin Cross8d8f8e22016-08-03 11:57:50 -07001861 module Module
Colin Crossc3d87d32020-06-04 13:25:17 -07001862 phonies map[string]Paths
Colin Crosscec81712017-07-13 14:43:27 -07001863
1864 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001865 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001866 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001867 variables map[string]string
Colin Cross6ff51382015-12-17 16:39:19 -08001868}
1869
Colin Crossb88b3c52019-06-10 15:15:17 -07001870func (m *moduleContext) ninjaError(params BuildParams, err error) (PackageContext, BuildParams) {
1871 return pctx, BuildParams{
Colin Cross4b69c492019-06-07 13:06:06 -07001872 Rule: ErrorRule,
1873 Description: params.Description,
1874 Output: params.Output,
1875 Outputs: params.Outputs,
1876 ImplicitOutput: params.ImplicitOutput,
1877 ImplicitOutputs: params.ImplicitOutputs,
Colin Cross6ff51382015-12-17 16:39:19 -08001878 Args: map[string]string{
1879 "error": err.Error(),
1880 },
Colin Crossb88b3c52019-06-10 15:15:17 -07001881 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001882}
1883
Colin Cross25de6c32019-06-06 14:29:25 -07001884func (m *moduleContext) ModuleBuild(pctx PackageContext, params ModuleBuildParams) {
1885 m.Build(pctx, BuildParams(params))
Colin Cross3f40fa42015-01-30 17:27:36 -08001886}
1887
Jingwen Chence679d22020-09-23 04:30:02 +00001888func validateBuildParams(params blueprint.BuildParams) error {
1889 // Validate that the symlink outputs are declared outputs or implicit outputs
1890 allOutputs := map[string]bool{}
1891 for _, output := range params.Outputs {
1892 allOutputs[output] = true
1893 }
1894 for _, output := range params.ImplicitOutputs {
1895 allOutputs[output] = true
1896 }
1897 for _, symlinkOutput := range params.SymlinkOutputs {
1898 if !allOutputs[symlinkOutput] {
1899 return fmt.Errorf(
1900 "Symlink output %s is not a declared output or implicit output",
1901 symlinkOutput)
1902 }
1903 }
1904 return nil
1905}
1906
1907// Convert build parameters from their concrete Android types into their string representations,
1908// and combine the singular and plural fields of the same type (e.g. Output and Outputs).
Colin Cross0875c522017-11-28 17:34:01 -08001909func convertBuildParams(params BuildParams) blueprint.BuildParams {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001910 bparams := blueprint.BuildParams{
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001911 Rule: params.Rule,
Colin Cross0875c522017-11-28 17:34:01 -08001912 Description: params.Description,
Colin Cross33bfb0a2016-11-21 17:23:08 -08001913 Deps: params.Deps,
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001914 Outputs: params.Outputs.Strings(),
1915 ImplicitOutputs: params.ImplicitOutputs.Strings(),
Jingwen Chence679d22020-09-23 04:30:02 +00001916 SymlinkOutputs: params.SymlinkOutputs.Strings(),
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001917 Inputs: params.Inputs.Strings(),
1918 Implicits: params.Implicits.Strings(),
1919 OrderOnly: params.OrderOnly.Strings(),
Colin Cross824f1162020-07-16 13:07:51 -07001920 Validations: params.Validations.Strings(),
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001921 Args: params.Args,
1922 Optional: !params.Default,
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001923 }
1924
Colin Cross33bfb0a2016-11-21 17:23:08 -08001925 if params.Depfile != nil {
1926 bparams.Depfile = params.Depfile.String()
1927 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001928 if params.Output != nil {
1929 bparams.Outputs = append(bparams.Outputs, params.Output.String())
1930 }
Jingwen Chence679d22020-09-23 04:30:02 +00001931 if params.SymlinkOutput != nil {
1932 bparams.SymlinkOutputs = append(bparams.SymlinkOutputs, params.SymlinkOutput.String())
1933 }
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001934 if params.ImplicitOutput != nil {
1935 bparams.ImplicitOutputs = append(bparams.ImplicitOutputs, params.ImplicitOutput.String())
1936 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001937 if params.Input != nil {
1938 bparams.Inputs = append(bparams.Inputs, params.Input.String())
1939 }
1940 if params.Implicit != nil {
1941 bparams.Implicits = append(bparams.Implicits, params.Implicit.String())
1942 }
Colin Cross824f1162020-07-16 13:07:51 -07001943 if params.Validation != nil {
1944 bparams.Validations = append(bparams.Validations, params.Validation.String())
1945 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001946
Colin Cross0b9f31f2019-02-28 11:00:01 -08001947 bparams.Outputs = proptools.NinjaEscapeList(bparams.Outputs)
1948 bparams.ImplicitOutputs = proptools.NinjaEscapeList(bparams.ImplicitOutputs)
Jingwen Chence679d22020-09-23 04:30:02 +00001949 bparams.SymlinkOutputs = proptools.NinjaEscapeList(bparams.SymlinkOutputs)
Colin Cross0b9f31f2019-02-28 11:00:01 -08001950 bparams.Inputs = proptools.NinjaEscapeList(bparams.Inputs)
1951 bparams.Implicits = proptools.NinjaEscapeList(bparams.Implicits)
1952 bparams.OrderOnly = proptools.NinjaEscapeList(bparams.OrderOnly)
Colin Cross824f1162020-07-16 13:07:51 -07001953 bparams.Validations = proptools.NinjaEscapeList(bparams.Validations)
1954 bparams.Depfile = proptools.NinjaEscape(bparams.Depfile)
Colin Crossfe4bc362018-09-12 10:02:13 -07001955
Colin Cross0875c522017-11-28 17:34:01 -08001956 return bparams
1957}
1958
Colin Cross25de6c32019-06-06 14:29:25 -07001959func (m *moduleContext) Variable(pctx PackageContext, name, value string) {
1960 if m.config.captureBuild {
1961 m.variables[name] = value
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001962 }
1963
Colin Crossdc35e212019-06-06 16:13:11 -07001964 m.bp.Variable(pctx.PackageContext, name, value)
Colin Cross0875c522017-11-28 17:34:01 -08001965}
1966
Colin Cross25de6c32019-06-06 14:29:25 -07001967func (m *moduleContext) Rule(pctx PackageContext, name string, params blueprint.RuleParams,
Colin Cross0875c522017-11-28 17:34:01 -08001968 argNames ...string) blueprint.Rule {
1969
Ramy Medhat944839a2020-03-31 22:14:52 -04001970 if m.config.UseRemoteBuild() {
1971 if params.Pool == nil {
1972 // When USE_GOMA=true or USE_RBE=true are set and the rule is not supported by goma/RBE, restrict
1973 // jobs to the local parallelism value
1974 params.Pool = localPool
1975 } else if params.Pool == remotePool {
1976 // remotePool is a fake pool used to identify rule that are supported for remoting. If the rule's
1977 // pool is the remotePool, replace with nil so that ninja runs it at NINJA_REMOTE_NUM_JOBS
1978 // parallelism.
1979 params.Pool = nil
1980 }
Colin Cross2e2dbc22019-09-25 13:31:46 -07001981 }
1982
Colin Crossdc35e212019-06-06 16:13:11 -07001983 rule := m.bp.Rule(pctx.PackageContext, name, params, argNames...)
Colin Cross4c83e5c2019-02-25 14:54:28 -08001984
Colin Cross25de6c32019-06-06 14:29:25 -07001985 if m.config.captureBuild {
1986 m.ruleParams[rule] = params
Colin Cross4c83e5c2019-02-25 14:54:28 -08001987 }
1988
1989 return rule
Colin Cross0875c522017-11-28 17:34:01 -08001990}
1991
Colin Cross25de6c32019-06-06 14:29:25 -07001992func (m *moduleContext) Build(pctx PackageContext, params BuildParams) {
Colin Crossb88b3c52019-06-10 15:15:17 -07001993 if params.Description != "" {
1994 params.Description = "${moduleDesc}" + params.Description + "${moduleDescSuffix}"
1995 }
1996
1997 if missingDeps := m.GetMissingDependencies(); len(missingDeps) > 0 {
1998 pctx, params = m.ninjaError(params, fmt.Errorf("module %s missing dependencies: %s\n",
1999 m.ModuleName(), strings.Join(missingDeps, ", ")))
2000 }
2001
Colin Cross25de6c32019-06-06 14:29:25 -07002002 if m.config.captureBuild {
2003 m.buildParams = append(m.buildParams, params)
Colin Cross0875c522017-11-28 17:34:01 -08002004 }
2005
Jingwen Chence679d22020-09-23 04:30:02 +00002006 bparams := convertBuildParams(params)
2007 err := validateBuildParams(bparams)
2008 if err != nil {
2009 m.ModuleErrorf(
2010 "%s: build parameter validation failed: %s",
2011 m.ModuleName(),
2012 err.Error())
2013 }
2014 m.bp.Build(pctx.PackageContext, bparams)
Dan Willemsen34cc69e2015-09-23 15:26:20 -07002015}
Colin Crossc3d87d32020-06-04 13:25:17 -07002016
2017func (m *moduleContext) Phony(name string, deps ...Path) {
2018 addPhony(m.config, name, deps...)
2019}
2020
Colin Cross25de6c32019-06-06 14:29:25 -07002021func (m *moduleContext) GetMissingDependencies() []string {
Colin Cross6c4f21f2019-06-06 15:41:36 -07002022 var missingDeps []string
2023 missingDeps = append(missingDeps, m.Module().base().commonProperties.MissingDeps...)
Colin Crossdc35e212019-06-06 16:13:11 -07002024 missingDeps = append(missingDeps, m.bp.GetMissingDependencies()...)
Colin Cross6c4f21f2019-06-06 15:41:36 -07002025 missingDeps = FirstUniqueStrings(missingDeps)
2026 return missingDeps
Colin Cross6ff51382015-12-17 16:39:19 -08002027}
2028
Colin Crossdc35e212019-06-06 16:13:11 -07002029func (b *baseModuleContext) AddMissingDependencies(deps []string) {
Dan Willemsen6553f5e2016-03-10 18:14:25 -08002030 if deps != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07002031 missingDeps := &b.Module().base().commonProperties.MissingDeps
Colin Cross6c4f21f2019-06-06 15:41:36 -07002032 *missingDeps = append(*missingDeps, deps...)
2033 *missingDeps = FirstUniqueStrings(*missingDeps)
Dan Willemsen6553f5e2016-03-10 18:14:25 -08002034 }
2035}
2036
Colin Crossdc35e212019-06-06 16:13:11 -07002037func (b *baseModuleContext) validateAndroidModule(module blueprint.Module, strict bool) Module {
Colin Crossd11fcda2017-10-23 17:59:01 -07002038 aModule, _ := module.(Module)
Colin Crossdc35e212019-06-06 16:13:11 -07002039
2040 if !strict {
2041 return aModule
2042 }
2043
Colin Cross380c69a2019-06-10 17:49:58 +00002044 if aModule == nil {
Colin Crossdc35e212019-06-06 16:13:11 -07002045 b.ModuleErrorf("module %q not an android module", b.OtherModuleName(module))
Colin Cross380c69a2019-06-10 17:49:58 +00002046 return nil
2047 }
2048
2049 if !aModule.Enabled() {
Colin Crossdc35e212019-06-06 16:13:11 -07002050 if b.Config().AllowMissingDependencies() {
2051 b.AddMissingDependencies([]string{b.OtherModuleName(aModule)})
Colin Cross380c69a2019-06-10 17:49:58 +00002052 } else {
Colin Crossdc35e212019-06-06 16:13:11 -07002053 b.ModuleErrorf("depends on disabled module %q", b.OtherModuleName(aModule))
Colin Cross380c69a2019-06-10 17:49:58 +00002054 }
2055 return nil
2056 }
Colin Crossd11fcda2017-10-23 17:59:01 -07002057 return aModule
2058}
2059
Colin Crossdc35e212019-06-06 16:13:11 -07002060func (b *baseModuleContext) getDirectDepInternal(name string, tag blueprint.DependencyTag) (blueprint.Module, blueprint.DependencyTag) {
Jiyong Parkf2976302019-04-17 21:47:37 +09002061 type dep struct {
2062 mod blueprint.Module
2063 tag blueprint.DependencyTag
2064 }
2065 var deps []dep
Colin Crossdc35e212019-06-06 16:13:11 -07002066 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07002067 if aModule, _ := module.(Module); aModule != nil && aModule.base().BaseModuleName() == name {
Colin Cross1184b642019-12-30 18:43:07 -08002068 returnedTag := b.bp.OtherModuleDependencyTag(aModule)
Jiyong Parkf2976302019-04-17 21:47:37 +09002069 if tag == nil || returnedTag == tag {
2070 deps = append(deps, dep{aModule, returnedTag})
2071 }
2072 }
2073 })
2074 if len(deps) == 1 {
2075 return deps[0].mod, deps[0].tag
2076 } else if len(deps) >= 2 {
2077 panic(fmt.Errorf("Multiple dependencies having same BaseModuleName() %q found from %q",
Colin Crossdc35e212019-06-06 16:13:11 -07002078 name, b.ModuleName()))
Jiyong Parkf2976302019-04-17 21:47:37 +09002079 } else {
2080 return nil, nil
2081 }
2082}
2083
Colin Crossdc35e212019-06-06 16:13:11 -07002084func (b *baseModuleContext) GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module {
Colin Cross0ef08162019-05-01 15:50:51 -07002085 var deps []Module
Colin Crossdc35e212019-06-06 16:13:11 -07002086 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07002087 if aModule, _ := module.(Module); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08002088 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Cross0ef08162019-05-01 15:50:51 -07002089 deps = append(deps, aModule)
2090 }
2091 }
2092 })
2093 return deps
2094}
2095
Colin Cross25de6c32019-06-06 14:29:25 -07002096func (m *moduleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
2097 module, _ := m.getDirectDepInternal(name, tag)
2098 return module
Jiyong Parkf2976302019-04-17 21:47:37 +09002099}
2100
Colin Crossdc35e212019-06-06 16:13:11 -07002101func (b *baseModuleContext) GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag) {
2102 return b.getDirectDepInternal(name, nil)
Jiyong Parkf2976302019-04-17 21:47:37 +09002103}
2104
Colin Crossdc35e212019-06-06 16:13:11 -07002105func (b *baseModuleContext) VisitDirectDepsBlueprint(visit func(blueprint.Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002106 b.bp.VisitDirectDeps(visit)
Colin Cross35143d02017-11-16 00:11:20 -08002107}
2108
Colin Crossdc35e212019-06-06 16:13:11 -07002109func (b *baseModuleContext) VisitDirectDeps(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002110 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07002111 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07002112 visit(aModule)
2113 }
2114 })
2115}
2116
Colin Crossdc35e212019-06-06 16:13:11 -07002117func (b *baseModuleContext) VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002118 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07002119 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08002120 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Crossee6143c2017-12-30 17:54:27 -08002121 visit(aModule)
2122 }
2123 }
2124 })
2125}
2126
Colin Crossdc35e212019-06-06 16:13:11 -07002127func (b *baseModuleContext) VisitDirectDepsIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002128 b.bp.VisitDirectDepsIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07002129 // pred
2130 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07002131 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07002132 return pred(aModule)
2133 } else {
2134 return false
2135 }
2136 },
2137 // visit
2138 func(module blueprint.Module) {
2139 visit(module.(Module))
2140 })
2141}
2142
Colin Crossdc35e212019-06-06 16:13:11 -07002143func (b *baseModuleContext) VisitDepsDepthFirst(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002144 b.bp.VisitDepsDepthFirst(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07002145 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07002146 visit(aModule)
2147 }
2148 })
2149}
2150
Colin Crossdc35e212019-06-06 16:13:11 -07002151func (b *baseModuleContext) VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002152 b.bp.VisitDepsDepthFirstIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07002153 // pred
2154 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07002155 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07002156 return pred(aModule)
2157 } else {
2158 return false
2159 }
2160 },
2161 // visit
2162 func(module blueprint.Module) {
2163 visit(module.(Module))
2164 })
2165}
2166
Colin Crossdc35e212019-06-06 16:13:11 -07002167func (b *baseModuleContext) WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool) {
Colin Cross1184b642019-12-30 18:43:07 -08002168 b.bp.WalkDeps(visit)
Alex Light778127a2019-02-27 14:19:50 -08002169}
2170
Colin Crossdc35e212019-06-06 16:13:11 -07002171func (b *baseModuleContext) WalkDeps(visit func(Module, Module) bool) {
2172 b.walkPath = []Module{b.Module()}
Paul Duffinc5192442020-03-31 11:31:36 +01002173 b.tagPath = []blueprint.DependencyTag{}
Colin Cross1184b642019-12-30 18:43:07 -08002174 b.bp.WalkDeps(func(child, parent blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07002175 childAndroidModule, _ := child.(Module)
2176 parentAndroidModule, _ := parent.(Module)
Colin Crossd11fcda2017-10-23 17:59:01 -07002177 if childAndroidModule != nil && parentAndroidModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07002178 // record walkPath before visit
2179 for b.walkPath[len(b.walkPath)-1] != parentAndroidModule {
2180 b.walkPath = b.walkPath[0 : len(b.walkPath)-1]
Paul Duffinc5192442020-03-31 11:31:36 +01002181 b.tagPath = b.tagPath[0 : len(b.tagPath)-1]
Colin Crossdc35e212019-06-06 16:13:11 -07002182 }
2183 b.walkPath = append(b.walkPath, childAndroidModule)
Paul Duffinc5192442020-03-31 11:31:36 +01002184 b.tagPath = append(b.tagPath, b.OtherModuleDependencyTag(childAndroidModule))
Colin Crossd11fcda2017-10-23 17:59:01 -07002185 return visit(childAndroidModule, parentAndroidModule)
2186 } else {
2187 return false
2188 }
2189 })
2190}
2191
Colin Crossdc35e212019-06-06 16:13:11 -07002192func (b *baseModuleContext) GetWalkPath() []Module {
2193 return b.walkPath
2194}
2195
Paul Duffinc5192442020-03-31 11:31:36 +01002196func (b *baseModuleContext) GetTagPath() []blueprint.DependencyTag {
2197 return b.tagPath
2198}
2199
Colin Cross4dfacf92020-09-16 19:22:27 -07002200func (b *baseModuleContext) VisitAllModuleVariants(visit func(Module)) {
2201 b.bp.VisitAllModuleVariants(func(module blueprint.Module) {
2202 visit(module.(Module))
2203 })
2204}
2205
2206func (b *baseModuleContext) PrimaryModule() Module {
2207 return b.bp.PrimaryModule().(Module)
2208}
2209
2210func (b *baseModuleContext) FinalModule() Module {
2211 return b.bp.FinalModule().(Module)
2212}
2213
Jiyong Park1c7e9622020-05-07 16:12:13 +09002214// A regexp for removing boilerplate from BaseDependencyTag from the string representation of
2215// a dependency tag.
Colin Cross6e511a92020-07-27 21:26:48 -07002216var tagCleaner = regexp.MustCompile(`\QBaseDependencyTag:{}\E(, )?`)
Jiyong Park1c7e9622020-05-07 16:12:13 +09002217
2218// PrettyPrintTag returns string representation of the tag, but prefers
2219// custom String() method if available.
2220func PrettyPrintTag(tag blueprint.DependencyTag) string {
2221 // Use tag's custom String() method if available.
2222 if stringer, ok := tag.(fmt.Stringer); ok {
2223 return stringer.String()
2224 }
2225
2226 // Otherwise, get a default string representation of the tag's struct.
Colin Cross6e511a92020-07-27 21:26:48 -07002227 tagString := fmt.Sprintf("%T: %+v", tag, tag)
Jiyong Park1c7e9622020-05-07 16:12:13 +09002228
2229 // Remove the boilerplate from BaseDependencyTag as it adds no value.
2230 tagString = tagCleaner.ReplaceAllString(tagString, "")
2231 return tagString
2232}
2233
2234func (b *baseModuleContext) GetPathString(skipFirst bool) string {
2235 sb := strings.Builder{}
2236 tagPath := b.GetTagPath()
2237 walkPath := b.GetWalkPath()
2238 if !skipFirst {
2239 sb.WriteString(walkPath[0].String())
2240 }
2241 for i, m := range walkPath[1:] {
2242 sb.WriteString("\n")
2243 sb.WriteString(fmt.Sprintf(" via tag %s\n", PrettyPrintTag(tagPath[i])))
2244 sb.WriteString(fmt.Sprintf(" -> %s", m.String()))
2245 }
2246 return sb.String()
2247}
2248
Colin Crossdc35e212019-06-06 16:13:11 -07002249func (m *moduleContext) ModuleSubDir() string {
2250 return m.bp.ModuleSubDir()
Colin Cross0875c522017-11-28 17:34:01 -08002251}
2252
Colin Cross0ea8ba82019-06-06 14:33:29 -07002253func (b *baseModuleContext) Target() Target {
Colin Cross25de6c32019-06-06 14:29:25 -07002254 return b.target
Colin Crossa1ad8d12016-06-01 17:09:44 -07002255}
2256
Colin Cross0ea8ba82019-06-06 14:33:29 -07002257func (b *baseModuleContext) TargetPrimary() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002258 return b.targetPrimary
Colin Cross8b74d172016-09-13 09:59:14 -07002259}
2260
Colin Cross0ea8ba82019-06-06 14:33:29 -07002261func (b *baseModuleContext) MultiTargets() []Target {
Colin Cross25de6c32019-06-06 14:29:25 -07002262 return b.multiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07002263}
2264
Colin Cross0ea8ba82019-06-06 14:33:29 -07002265func (b *baseModuleContext) Arch() Arch {
Colin Cross25de6c32019-06-06 14:29:25 -07002266 return b.target.Arch
Colin Cross3f40fa42015-01-30 17:27:36 -08002267}
2268
Colin Cross0ea8ba82019-06-06 14:33:29 -07002269func (b *baseModuleContext) Os() OsType {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002270 return b.os
Dan Willemsen490fd492015-11-24 17:53:15 -08002271}
2272
Colin Cross0ea8ba82019-06-06 14:33:29 -07002273func (b *baseModuleContext) Host() bool {
Jiyong Park1613e552020-09-14 19:43:17 +09002274 return b.os.Class == Host
Colin Crossf6566ed2015-03-24 11:13:38 -07002275}
2276
Colin Cross0ea8ba82019-06-06 14:33:29 -07002277func (b *baseModuleContext) Device() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002278 return b.os.Class == Device
Colin Crossf6566ed2015-03-24 11:13:38 -07002279}
2280
Colin Cross0ea8ba82019-06-06 14:33:29 -07002281func (b *baseModuleContext) Darwin() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002282 return b.os == Darwin
Colin Cross0af4b842015-04-30 16:36:18 -07002283}
2284
Colin Cross0ea8ba82019-06-06 14:33:29 -07002285func (b *baseModuleContext) Fuchsia() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002286 return b.os == Fuchsia
Doug Horn21b94272019-01-16 12:06:11 -08002287}
2288
Colin Cross0ea8ba82019-06-06 14:33:29 -07002289func (b *baseModuleContext) Windows() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002290 return b.os == Windows
Colin Cross3edeee12017-04-04 12:59:48 -07002291}
2292
Colin Cross0ea8ba82019-06-06 14:33:29 -07002293func (b *baseModuleContext) Debug() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002294 return b.debug
Colin Crossf6566ed2015-03-24 11:13:38 -07002295}
2296
Colin Cross0ea8ba82019-06-06 14:33:29 -07002297func (b *baseModuleContext) PrimaryArch() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002298 if len(b.config.Targets[b.target.Os]) <= 1 {
Colin Cross67a5c132017-05-09 13:45:28 -07002299 return true
2300 }
Colin Cross25de6c32019-06-06 14:29:25 -07002301 return b.target.Arch.ArchType == b.config.Targets[b.target.Os][0].Arch.ArchType
Colin Cross1e7d3702016-08-24 15:25:47 -07002302}
2303
Jiyong Park5baac542018-08-28 09:55:37 +09002304// Makes this module a platform module, i.e. not specific to soc, device,
Justin Yund5f6c822019-06-25 16:47:17 +09002305// product, or system_ext.
Colin Cross4157e882019-06-06 16:57:04 -07002306func (m *ModuleBase) MakeAsPlatform() {
2307 m.commonProperties.Vendor = boolPtr(false)
2308 m.commonProperties.Proprietary = boolPtr(false)
2309 m.commonProperties.Soc_specific = boolPtr(false)
2310 m.commonProperties.Product_specific = boolPtr(false)
Justin Yund5f6c822019-06-25 16:47:17 +09002311 m.commonProperties.System_ext_specific = boolPtr(false)
Jiyong Park5baac542018-08-28 09:55:37 +09002312}
2313
Colin Cross4157e882019-06-06 16:57:04 -07002314func (m *ModuleBase) EnableNativeBridgeSupportByDefault() {
2315 m.commonProperties.Native_bridge_supported = boolPtr(true)
dimitry03dc3f62019-05-09 14:07:34 +02002316}
2317
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09002318func (m *ModuleBase) MakeAsSystemExt() {
Jooyung Han91df2082019-11-20 01:49:42 +09002319 m.commonProperties.Vendor = boolPtr(false)
2320 m.commonProperties.Proprietary = boolPtr(false)
2321 m.commonProperties.Soc_specific = boolPtr(false)
2322 m.commonProperties.Product_specific = boolPtr(false)
2323 m.commonProperties.System_ext_specific = boolPtr(true)
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09002324}
2325
Jooyung Han344d5432019-08-23 11:17:39 +09002326// IsNativeBridgeSupported returns true if "native_bridge_supported" is explicitly set as "true"
2327func (m *ModuleBase) IsNativeBridgeSupported() bool {
2328 return proptools.Bool(m.commonProperties.Native_bridge_supported)
2329}
2330
Colin Cross25de6c32019-06-06 14:29:25 -07002331func (m *moduleContext) InstallInData() bool {
2332 return m.module.InstallInData()
Dan Willemsen782a2d12015-12-21 14:55:28 -08002333}
2334
Jaewoong Jung0949f312019-09-11 10:25:18 -07002335func (m *moduleContext) InstallInTestcases() bool {
2336 return m.module.InstallInTestcases()
2337}
2338
Colin Cross25de6c32019-06-06 14:29:25 -07002339func (m *moduleContext) InstallInSanitizerDir() bool {
2340 return m.module.InstallInSanitizerDir()
Vishwath Mohan1dd88392017-03-29 22:00:18 -07002341}
2342
Yifan Hong1b3348d2020-01-21 15:53:22 -08002343func (m *moduleContext) InstallInRamdisk() bool {
2344 return m.module.InstallInRamdisk()
2345}
2346
Yifan Hong60e0cfb2020-10-21 15:17:56 -07002347func (m *moduleContext) InstallInVendorRamdisk() bool {
2348 return m.module.InstallInVendorRamdisk()
2349}
2350
Colin Cross25de6c32019-06-06 14:29:25 -07002351func (m *moduleContext) InstallInRecovery() bool {
2352 return m.module.InstallInRecovery()
Jiyong Parkf9332f12018-02-01 00:54:12 +09002353}
2354
Colin Cross90ba5f42019-10-02 11:10:58 -07002355func (m *moduleContext) InstallInRoot() bool {
2356 return m.module.InstallInRoot()
2357}
2358
Colin Cross607d8582019-07-29 16:44:46 -07002359func (m *moduleContext) InstallBypassMake() bool {
2360 return m.module.InstallBypassMake()
2361}
2362
Jiyong Park87788b52020-09-01 12:37:45 +09002363func (m *moduleContext) InstallForceOS() (*OsType, *ArchType) {
Colin Cross6e359402020-02-10 15:29:54 -08002364 return m.module.InstallForceOS()
2365}
2366
Colin Cross70dda7e2019-10-01 22:05:35 -07002367func (m *moduleContext) skipInstall(fullInstallPath InstallPath) bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002368 if m.module.base().commonProperties.SkipInstall {
Colin Cross893d8162017-04-26 17:34:03 -07002369 return true
2370 }
2371
Colin Cross3607f212018-05-07 15:28:05 -07002372 // We'll need a solution for choosing which of modules with the same name in different
2373 // namespaces to install. For now, reuse the list of namespaces exported to Make as the
2374 // list of namespaces to install in a Soong-only build.
Colin Cross25de6c32019-06-06 14:29:25 -07002375 if !m.module.base().commonProperties.NamespaceExportedToMake {
Colin Cross3607f212018-05-07 15:28:05 -07002376 return true
2377 }
2378
Colin Cross25de6c32019-06-06 14:29:25 -07002379 if m.Device() {
Jingwen Chencda22c92020-11-23 00:22:30 -05002380 if m.Config().KatiEnabled() && !m.InstallBypassMake() {
Colin Cross893d8162017-04-26 17:34:03 -07002381 return true
2382 }
2383
Colin Cross25de6c32019-06-06 14:29:25 -07002384 if m.Config().SkipMegaDeviceInstall(fullInstallPath.String()) {
Colin Cross893d8162017-04-26 17:34:03 -07002385 return true
2386 }
2387 }
2388
2389 return false
2390}
2391
Colin Cross70dda7e2019-10-01 22:05:35 -07002392func (m *moduleContext) InstallFile(installPath InstallPath, name string, srcPath Path,
2393 deps ...Path) InstallPath {
Jiyong Park073ea552020-11-09 14:08:34 +09002394 return m.installFile(installPath, name, srcPath, deps, false)
Colin Cross5c517922017-08-31 12:29:17 -07002395}
2396
Colin Cross70dda7e2019-10-01 22:05:35 -07002397func (m *moduleContext) InstallExecutable(installPath InstallPath, name string, srcPath Path,
2398 deps ...Path) InstallPath {
Jiyong Park073ea552020-11-09 14:08:34 +09002399 return m.installFile(installPath, name, srcPath, deps, true)
Colin Cross5c517922017-08-31 12:29:17 -07002400}
2401
Jiyong Park073ea552020-11-09 14:08:34 +09002402func (m *moduleContext) installFile(installPath InstallPath, name string, srcPath Path, deps []Path, executable bool) InstallPath {
Colin Cross35cec122015-04-02 14:37:16 -07002403
Colin Cross25de6c32019-06-06 14:29:25 -07002404 fullInstallPath := installPath.Join(m, name)
David Srbecky07656412020-06-04 01:26:16 +01002405 m.module.base().hooks.runInstallHooks(m, srcPath, fullInstallPath, false)
Colin Cross3f40fa42015-01-30 17:27:36 -08002406
Colin Cross25de6c32019-06-06 14:29:25 -07002407 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07002408
Colin Cross897266e2020-02-13 13:22:08 -08002409 deps = append(deps, m.installDeps.Paths()...)
Colin Cross35cec122015-04-02 14:37:16 -07002410
Colin Cross89562dc2016-10-03 17:47:19 -07002411 var implicitDeps, orderOnlyDeps Paths
2412
Colin Cross25de6c32019-06-06 14:29:25 -07002413 if m.Host() {
Colin Cross89562dc2016-10-03 17:47:19 -07002414 // Installed host modules might be used during the build, depend directly on their
2415 // dependencies so their timestamp is updated whenever their dependency is updated
2416 implicitDeps = deps
2417 } else {
2418 orderOnlyDeps = deps
2419 }
2420
Jiyong Park073ea552020-11-09 14:08:34 +09002421 rule := Cp
2422 if executable {
2423 rule = CpExecutable
2424 }
2425
Colin Cross25de6c32019-06-06 14:29:25 -07002426 m.Build(pctx, BuildParams{
Colin Cross5c517922017-08-31 12:29:17 -07002427 Rule: rule,
Colin Cross67a5c132017-05-09 13:45:28 -07002428 Description: "install " + fullInstallPath.Base(),
2429 Output: fullInstallPath,
2430 Input: srcPath,
2431 Implicits: implicitDeps,
2432 OrderOnly: orderOnlyDeps,
Jingwen Chencda22c92020-11-23 00:22:30 -05002433 Default: !m.Config().KatiEnabled(),
Dan Willemsen322acaf2016-01-12 23:07:05 -08002434 })
Colin Cross3f40fa42015-01-30 17:27:36 -08002435
Colin Cross25de6c32019-06-06 14:29:25 -07002436 m.installFiles = append(m.installFiles, fullInstallPath)
Dan Willemsen322acaf2016-01-12 23:07:05 -08002437 }
Jiyong Park073ea552020-11-09 14:08:34 +09002438
2439 m.packagingSpecs = append(m.packagingSpecs, PackagingSpec{
2440 relPathInPackage: Rel(m, fullInstallPath.PartitionDir(), fullInstallPath.String()),
2441 srcPath: srcPath,
2442 symlinkTarget: "",
2443 executable: executable,
2444 })
2445
Colin Cross25de6c32019-06-06 14:29:25 -07002446 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross35cec122015-04-02 14:37:16 -07002447 return fullInstallPath
2448}
2449
Colin Cross70dda7e2019-10-01 22:05:35 -07002450func (m *moduleContext) InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002451 fullInstallPath := installPath.Join(m, name)
David Srbecky07656412020-06-04 01:26:16 +01002452 m.module.base().hooks.runInstallHooks(m, srcPath, fullInstallPath, true)
Colin Cross3854a602016-01-11 12:49:11 -08002453
Jiyong Park073ea552020-11-09 14:08:34 +09002454 relPath, err := filepath.Rel(path.Dir(fullInstallPath.String()), srcPath.String())
2455 if err != nil {
2456 panic(fmt.Sprintf("Unable to generate symlink between %q and %q: %s", fullInstallPath.Base(), srcPath.Base(), err))
2457 }
Colin Cross25de6c32019-06-06 14:29:25 -07002458 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07002459
Colin Cross25de6c32019-06-06 14:29:25 -07002460 m.Build(pctx, BuildParams{
Colin Cross67a5c132017-05-09 13:45:28 -07002461 Rule: Symlink,
2462 Description: "install symlink " + fullInstallPath.Base(),
2463 Output: fullInstallPath,
Dan Willemsen40efa1c2020-01-14 15:19:52 -08002464 Input: srcPath,
Jingwen Chencda22c92020-11-23 00:22:30 -05002465 Default: !m.Config().KatiEnabled(),
Colin Cross12fc4972016-01-11 12:49:11 -08002466 Args: map[string]string{
Alex Lightfb4353d2019-01-17 13:57:45 -08002467 "fromPath": relPath,
Colin Cross12fc4972016-01-11 12:49:11 -08002468 },
2469 })
Colin Cross3854a602016-01-11 12:49:11 -08002470
Colin Cross25de6c32019-06-06 14:29:25 -07002471 m.installFiles = append(m.installFiles, fullInstallPath)
2472 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross12fc4972016-01-11 12:49:11 -08002473 }
Jiyong Park073ea552020-11-09 14:08:34 +09002474
2475 m.packagingSpecs = append(m.packagingSpecs, PackagingSpec{
2476 relPathInPackage: Rel(m, fullInstallPath.PartitionDir(), fullInstallPath.String()),
2477 srcPath: nil,
2478 symlinkTarget: relPath,
2479 executable: false,
2480 })
2481
Colin Cross3854a602016-01-11 12:49:11 -08002482 return fullInstallPath
2483}
2484
Jiyong Parkf1194352019-02-25 11:05:47 +09002485// installPath/name -> absPath where absPath might be a path that is available only at runtime
2486// (e.g. /apex/...)
Colin Cross70dda7e2019-10-01 22:05:35 -07002487func (m *moduleContext) InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002488 fullInstallPath := installPath.Join(m, name)
David Srbecky07656412020-06-04 01:26:16 +01002489 m.module.base().hooks.runInstallHooks(m, nil, fullInstallPath, true)
Jiyong Parkf1194352019-02-25 11:05:47 +09002490
Colin Cross25de6c32019-06-06 14:29:25 -07002491 if !m.skipInstall(fullInstallPath) {
2492 m.Build(pctx, BuildParams{
Jiyong Parkf1194352019-02-25 11:05:47 +09002493 Rule: Symlink,
2494 Description: "install symlink " + fullInstallPath.Base() + " -> " + absPath,
2495 Output: fullInstallPath,
Jingwen Chencda22c92020-11-23 00:22:30 -05002496 Default: !m.Config().KatiEnabled(),
Jiyong Parkf1194352019-02-25 11:05:47 +09002497 Args: map[string]string{
2498 "fromPath": absPath,
2499 },
2500 })
2501
Colin Cross25de6c32019-06-06 14:29:25 -07002502 m.installFiles = append(m.installFiles, fullInstallPath)
Jiyong Parkf1194352019-02-25 11:05:47 +09002503 }
Jiyong Park073ea552020-11-09 14:08:34 +09002504
2505 m.packagingSpecs = append(m.packagingSpecs, PackagingSpec{
2506 relPathInPackage: Rel(m, fullInstallPath.PartitionDir(), fullInstallPath.String()),
2507 srcPath: nil,
2508 symlinkTarget: absPath,
2509 executable: false,
2510 })
2511
Jiyong Parkf1194352019-02-25 11:05:47 +09002512 return fullInstallPath
2513}
2514
Colin Cross25de6c32019-06-06 14:29:25 -07002515func (m *moduleContext) CheckbuildFile(srcPath Path) {
2516 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross3f40fa42015-01-30 17:27:36 -08002517}
2518
Colin Cross41955e82019-05-29 14:40:35 -07002519// SrcIsModule decodes module references in the format ":name" into the module name, or empty string if the input
2520// was not a module reference.
2521func SrcIsModule(s string) (module string) {
Colin Cross068e0fe2016-12-13 15:23:47 -08002522 if len(s) > 1 && s[0] == ':' {
2523 return s[1:]
2524 }
2525 return ""
2526}
2527
Colin Cross41955e82019-05-29 14:40:35 -07002528// SrcIsModule decodes module references in the format ":name{.tag}" into the module name and tag, ":name" into the
2529// module name and an empty string for the tag, or empty strings if the input was not a module reference.
2530func SrcIsModuleWithTag(s string) (module, tag string) {
2531 if len(s) > 1 && s[0] == ':' {
2532 module = s[1:]
2533 if tagStart := strings.IndexByte(module, '{'); tagStart > 0 {
2534 if module[len(module)-1] == '}' {
2535 tag = module[tagStart+1 : len(module)-1]
2536 module = module[:tagStart]
2537 return module, tag
2538 }
2539 }
2540 return module, ""
2541 }
2542 return "", ""
Colin Cross068e0fe2016-12-13 15:23:47 -08002543}
2544
Colin Cross41955e82019-05-29 14:40:35 -07002545type sourceOrOutputDependencyTag struct {
2546 blueprint.BaseDependencyTag
2547 tag string
2548}
2549
2550func sourceOrOutputDepTag(tag string) blueprint.DependencyTag {
2551 return sourceOrOutputDependencyTag{tag: tag}
2552}
2553
2554var SourceDepTag = sourceOrOutputDepTag("")
Colin Cross068e0fe2016-12-13 15:23:47 -08002555
Colin Cross366938f2017-12-11 16:29:02 -08002556// Adds necessary dependencies to satisfy filegroup or generated sources modules listed in srcFiles
2557// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002558//
2559// Deprecated: tag the property with `android:"path"` instead.
Colin Cross068e0fe2016-12-13 15:23:47 -08002560func ExtractSourcesDeps(ctx BottomUpMutatorContext, srcFiles []string) {
Nan Zhang2439eb72017-04-10 11:27:50 -07002561 set := make(map[string]bool)
2562
Colin Cross068e0fe2016-12-13 15:23:47 -08002563 for _, s := range srcFiles {
Colin Cross41955e82019-05-29 14:40:35 -07002564 if m, t := SrcIsModuleWithTag(s); m != "" {
2565 if _, found := set[s]; found {
2566 ctx.ModuleErrorf("found source dependency duplicate: %q!", s)
Nan Zhang2439eb72017-04-10 11:27:50 -07002567 } else {
Colin Cross41955e82019-05-29 14:40:35 -07002568 set[s] = true
2569 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Nan Zhang2439eb72017-04-10 11:27:50 -07002570 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002571 }
2572 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002573}
2574
Colin Cross366938f2017-12-11 16:29:02 -08002575// Adds necessary dependencies to satisfy filegroup or generated sources modules specified in s
2576// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002577//
2578// Deprecated: tag the property with `android:"path"` instead.
Colin Cross366938f2017-12-11 16:29:02 -08002579func ExtractSourceDeps(ctx BottomUpMutatorContext, s *string) {
2580 if s != nil {
Colin Cross41955e82019-05-29 14:40:35 -07002581 if m, t := SrcIsModuleWithTag(*s); m != "" {
2582 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Colin Cross366938f2017-12-11 16:29:02 -08002583 }
2584 }
2585}
2586
Colin Cross41955e82019-05-29 14:40:35 -07002587// A module that implements SourceFileProducer can be referenced from any property that is tagged with `android:"path"`
2588// 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 -08002589type SourceFileProducer interface {
2590 Srcs() Paths
2591}
2592
Colin Cross41955e82019-05-29 14:40:35 -07002593// A module that implements OutputFileProducer can be referenced from any property that is tagged with `android:"path"`
Roland Levillain97c1f342019-11-22 14:20:54 +00002594// 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 -07002595// listed in the property.
2596type OutputFileProducer interface {
2597 OutputFiles(tag string) (Paths, error)
2598}
2599
Colin Cross5e708052019-08-06 13:59:50 -07002600// OutputFilesForModule returns the paths from an OutputFileProducer with the given tag. On error, including if the
2601// module produced zero paths, it reports errors to the ctx and returns nil.
2602func OutputFilesForModule(ctx PathContext, module blueprint.Module, tag string) Paths {
2603 paths, err := outputFilesForModule(ctx, module, tag)
2604 if err != nil {
2605 reportPathError(ctx, err)
2606 return nil
2607 }
2608 return paths
2609}
2610
2611// OutputFileForModule returns the path from an OutputFileProducer with the given tag. On error, including if the
2612// module produced zero or multiple paths, it reports errors to the ctx and returns nil.
2613func OutputFileForModule(ctx PathContext, module blueprint.Module, tag string) Path {
2614 paths, err := outputFilesForModule(ctx, module, tag)
2615 if err != nil {
2616 reportPathError(ctx, err)
2617 return nil
2618 }
2619 if len(paths) > 1 {
Ulya Trafimovich5ab276a2020-08-25 12:45:15 +01002620 ReportPathErrorf(ctx, "got multiple output files from module %q, expected exactly one",
Colin Cross5e708052019-08-06 13:59:50 -07002621 pathContextName(ctx, module))
2622 return nil
2623 }
2624 return paths[0]
2625}
2626
2627func outputFilesForModule(ctx PathContext, module blueprint.Module, tag string) (Paths, error) {
2628 if outputFileProducer, ok := module.(OutputFileProducer); ok {
2629 paths, err := outputFileProducer.OutputFiles(tag)
2630 if err != nil {
2631 return nil, fmt.Errorf("failed to get output file from module %q: %s",
2632 pathContextName(ctx, module), err.Error())
2633 }
2634 if len(paths) == 0 {
2635 return nil, fmt.Errorf("failed to get output files from module %q", pathContextName(ctx, module))
2636 }
2637 return paths, nil
Colin Cross74b1e2b2020-11-22 20:23:02 -08002638 } else if sourceFileProducer, ok := module.(SourceFileProducer); ok {
2639 if tag != "" {
2640 return nil, fmt.Errorf("module %q is a SourceFileProducer, not an OutputFileProducer, and so does not support tag %q", pathContextName(ctx, module), tag)
2641 }
2642 paths := sourceFileProducer.Srcs()
2643 if len(paths) == 0 {
2644 return nil, fmt.Errorf("failed to get output files from module %q", pathContextName(ctx, module))
2645 }
2646 return paths, nil
Colin Cross5e708052019-08-06 13:59:50 -07002647 } else {
2648 return nil, fmt.Errorf("module %q is not an OutputFileProducer", pathContextName(ctx, module))
2649 }
2650}
2651
Colin Crossfe17f6f2019-03-28 19:30:56 -07002652type HostToolProvider interface {
2653 HostToolPath() OptionalPath
2654}
2655
Colin Cross27b922f2019-03-04 22:35:41 -08002656// Returns a list of paths expanded from globs and modules referenced using ":module" syntax. The property must
2657// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002658//
2659// Deprecated: use PathsForModuleSrc or PathsForModuleSrcExcludes instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002660func (m *moduleContext) ExpandSources(srcFiles, excludes []string) Paths {
2661 return PathsForModuleSrcExcludes(m, srcFiles, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07002662}
2663
Colin Cross2fafa3e2019-03-05 12:39:51 -08002664// Returns a single path expanded from globs and modules referenced using ":module" syntax. The property must
2665// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002666//
2667// Deprecated: use PathForModuleSrc instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002668func (m *moduleContext) ExpandSource(srcFile, prop string) Path {
2669 return PathForModuleSrc(m, srcFile)
Colin Cross2fafa3e2019-03-05 12:39:51 -08002670}
2671
2672// Returns an optional single path expanded from globs and modules referenced using ":module" syntax if
2673// the srcFile is non-nil. The property must be tagged with `android:"path" to support automatic source module
2674// dependency resolution.
Colin Cross25de6c32019-06-06 14:29:25 -07002675func (m *moduleContext) ExpandOptionalSource(srcFile *string, prop string) OptionalPath {
Colin Cross2fafa3e2019-03-05 12:39:51 -08002676 if srcFile != nil {
Colin Cross25de6c32019-06-06 14:29:25 -07002677 return OptionalPathForPath(PathForModuleSrc(m, *srcFile))
Colin Cross2fafa3e2019-03-05 12:39:51 -08002678 }
2679 return OptionalPath{}
2680}
2681
Colin Cross25de6c32019-06-06 14:29:25 -07002682func (m *moduleContext) RequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002683 return m.module.RequiredModuleNames()
Nan Zhang6d34b302017-02-04 17:47:46 -08002684}
2685
Colin Cross25de6c32019-06-06 14:29:25 -07002686func (m *moduleContext) HostRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002687 return m.module.HostRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002688}
2689
Colin Cross25de6c32019-06-06 14:29:25 -07002690func (m *moduleContext) TargetRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002691 return m.module.TargetRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002692}
2693
Colin Cross463a90e2015-06-17 14:20:06 -07002694func init() {
Colin Cross798bfce2016-10-12 14:28:16 -07002695 RegisterSingletonType("buildtarget", BuildTargetSingleton)
Colin Cross463a90e2015-06-17 14:20:06 -07002696}
2697
Colin Cross0875c522017-11-28 17:34:01 -08002698func BuildTargetSingleton() Singleton {
Colin Cross1f8c52b2015-06-16 16:38:17 -07002699 return &buildTargetSingleton{}
2700}
2701
Colin Cross87d8b562017-04-25 10:01:55 -07002702func parentDir(dir string) string {
2703 dir, _ = filepath.Split(dir)
2704 return filepath.Clean(dir)
2705}
2706
Colin Cross1f8c52b2015-06-16 16:38:17 -07002707type buildTargetSingleton struct{}
2708
Colin Cross0875c522017-11-28 17:34:01 -08002709func (c *buildTargetSingleton) GenerateBuildActions(ctx SingletonContext) {
2710 var checkbuildDeps Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07002711
Colin Crossc3d87d32020-06-04 13:25:17 -07002712 mmTarget := func(dir string) string {
2713 return "MODULES-IN-" + strings.Replace(filepath.Clean(dir), "/", "-", -1)
Colin Cross87d8b562017-04-25 10:01:55 -07002714 }
2715
Colin Cross0875c522017-11-28 17:34:01 -08002716 modulesInDir := make(map[string]Paths)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002717
Colin Cross0875c522017-11-28 17:34:01 -08002718 ctx.VisitAllModules(func(module Module) {
2719 blueprintDir := module.base().blueprintDir
2720 installTarget := module.base().installTarget
2721 checkbuildTarget := module.base().checkbuildTarget
Colin Cross1f8c52b2015-06-16 16:38:17 -07002722
Colin Cross0875c522017-11-28 17:34:01 -08002723 if checkbuildTarget != nil {
2724 checkbuildDeps = append(checkbuildDeps, checkbuildTarget)
2725 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], checkbuildTarget)
2726 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002727
Colin Cross0875c522017-11-28 17:34:01 -08002728 if installTarget != nil {
2729 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], installTarget)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002730 }
2731 })
2732
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002733 suffix := ""
Jingwen Chencda22c92020-11-23 00:22:30 -05002734 if ctx.Config().KatiEnabled() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002735 suffix = "-soong"
2736 }
2737
Colin Cross1f8c52b2015-06-16 16:38:17 -07002738 // Create a top-level checkbuild target that depends on all modules
Colin Crossc3d87d32020-06-04 13:25:17 -07002739 ctx.Phony("checkbuild"+suffix, checkbuildDeps...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002740
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002741 // Make will generate the MODULES-IN-* targets
Jingwen Chencda22c92020-11-23 00:22:30 -05002742 if ctx.Config().KatiEnabled() {
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002743 return
2744 }
2745
Colin Cross87d8b562017-04-25 10:01:55 -07002746 // Ensure ancestor directories are in modulesInDir
Inseob Kim1a365c62019-06-08 15:47:51 +09002747 dirs := SortedStringKeys(modulesInDir)
Colin Cross87d8b562017-04-25 10:01:55 -07002748 for _, dir := range dirs {
2749 dir := parentDir(dir)
2750 for dir != "." && dir != "/" {
2751 if _, exists := modulesInDir[dir]; exists {
2752 break
2753 }
2754 modulesInDir[dir] = nil
2755 dir = parentDir(dir)
2756 }
2757 }
2758
2759 // Make directories build their direct subdirectories
Colin Cross87d8b562017-04-25 10:01:55 -07002760 for _, dir := range dirs {
2761 p := parentDir(dir)
2762 if p != "." && p != "/" {
Colin Crossc3d87d32020-06-04 13:25:17 -07002763 modulesInDir[p] = append(modulesInDir[p], PathForPhony(ctx, mmTarget(dir)))
Colin Cross87d8b562017-04-25 10:01:55 -07002764 }
2765 }
2766
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002767 // Create a MODULES-IN-<directory> target that depends on all modules in a directory, and
2768 // depends on the MODULES-IN-* targets of all of its subdirectories that contain Android.bp
2769 // files.
Colin Cross1f8c52b2015-06-16 16:38:17 -07002770 for _, dir := range dirs {
Colin Crossc3d87d32020-06-04 13:25:17 -07002771 ctx.Phony(mmTarget(dir), modulesInDir[dir]...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002772 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002773
2774 // Create (host|host-cross|target)-<OS> phony rules to build a reduced checkbuild.
Jiyong Park1613e552020-09-14 19:43:17 +09002775 type osAndCross struct {
2776 os OsType
2777 hostCross bool
2778 }
2779 osDeps := map[osAndCross]Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08002780 ctx.VisitAllModules(func(module Module) {
2781 if module.Enabled() {
Jiyong Park1613e552020-09-14 19:43:17 +09002782 key := osAndCross{os: module.Target().Os, hostCross: module.Target().HostCross}
2783 osDeps[key] = append(osDeps[key], module.base().checkbuildFiles...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002784 }
2785 })
2786
Colin Cross0875c522017-11-28 17:34:01 -08002787 osClass := make(map[string]Paths)
Jiyong Park1613e552020-09-14 19:43:17 +09002788 for key, deps := range osDeps {
Dan Willemsen61d88b82017-09-20 17:29:08 -07002789 var className string
2790
Jiyong Park1613e552020-09-14 19:43:17 +09002791 switch key.os.Class {
Dan Willemsen61d88b82017-09-20 17:29:08 -07002792 case Host:
Jiyong Park1613e552020-09-14 19:43:17 +09002793 if key.hostCross {
2794 className = "host-cross"
2795 } else {
2796 className = "host"
2797 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002798 case Device:
2799 className = "target"
2800 default:
2801 continue
2802 }
2803
Jiyong Park1613e552020-09-14 19:43:17 +09002804 name := className + "-" + key.os.Name
Colin Crossc3d87d32020-06-04 13:25:17 -07002805 osClass[className] = append(osClass[className], PathForPhony(ctx, name))
Dan Willemsen61d88b82017-09-20 17:29:08 -07002806
Colin Crossc3d87d32020-06-04 13:25:17 -07002807 ctx.Phony(name, deps...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002808 }
2809
2810 // Wrap those into host|host-cross|target phony rules
Inseob Kim1a365c62019-06-08 15:47:51 +09002811 for _, class := range SortedStringKeys(osClass) {
Colin Crossc3d87d32020-06-04 13:25:17 -07002812 ctx.Phony(class, osClass[class]...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002813 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002814}
Colin Crossd779da42015-12-17 18:00:23 -08002815
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002816// Collect information for opening IDE project files in java/jdeps.go.
2817type IDEInfo interface {
2818 IDEInfo(ideInfo *IdeInfo)
2819 BaseModuleName() string
2820}
2821
2822// Extract the base module name from the Import name.
2823// Often the Import name has a prefix "prebuilt_".
2824// Remove the prefix explicitly if needed
2825// until we find a better solution to get the Import name.
2826type IDECustomizedModuleName interface {
2827 IDECustomizedModuleName() string
2828}
2829
2830type IdeInfo struct {
2831 Deps []string `json:"dependencies,omitempty"`
2832 Srcs []string `json:"srcs,omitempty"`
2833 Aidl_include_dirs []string `json:"aidl_include_dirs,omitempty"`
2834 Jarjar_rules []string `json:"jarjar_rules,omitempty"`
2835 Jars []string `json:"jars,omitempty"`
2836 Classes []string `json:"class,omitempty"`
2837 Installed_paths []string `json:"installed,omitempty"`
patricktu18c82ff2019-05-10 15:48:50 +08002838 SrcJars []string `json:"srcjars,omitempty"`
bralee1fbf4402020-05-21 10:11:59 +08002839 Paths []string `json:"path,omitempty"`
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002840}
Paul Duffinf88d8e02020-05-07 20:21:34 +01002841
2842func CheckBlueprintSyntax(ctx BaseModuleContext, filename string, contents string) []error {
2843 bpctx := ctx.blueprintBaseModuleContext()
2844 return blueprint.CheckBlueprintSyntax(bpctx.ModuleFactories(), filename, contents)
2845}