blob: fa2f108b4fac27a694f026366fa3e72fa4f9771e [file] [log] [blame]
Colin Cross3f40fa42015-01-30 17:27:36 -08001// Copyright 2015 Google Inc. All rights reserved.
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
Colin Cross635c3b02016-05-18 15:37:25 -070015package android
Colin Cross3f40fa42015-01-30 17:27:36 -080016
17import (
Colin Cross6ff51382015-12-17 16:39:19 -080018 "fmt"
Colin Cross988414c2020-01-11 01:11:46 +000019 "os"
Alex Lightfb4353d2019-01-17 13:57:45 -080020 "path"
Colin Cross3f40fa42015-01-30 17:27:36 -080021 "path/filepath"
Colin Crossd976af02020-11-16 22:44:30 -080022 "reflect"
Jiyong Park1c7e9622020-05-07 16:12:13 +090023 "regexp"
Colin Cross6ff51382015-12-17 16:39:19 -080024 "strings"
Colin Crossaabf6792017-11-29 00:27:14 -080025 "text/scanner"
Colin Crossf6566ed2015-03-24 11:13:38 -070026
27 "github.com/google/blueprint"
Colin Crossfe4bc362018-09-12 10:02:13 -070028 "github.com/google/blueprint/proptools"
Colin Cross3f40fa42015-01-30 17:27:36 -080029)
30
31var (
32 DeviceSharedLibrary = "shared_library"
33 DeviceStaticLibrary = "static_library"
34 DeviceExecutable = "executable"
35 HostSharedLibrary = "host_shared_library"
36 HostStaticLibrary = "host_static_library"
37 HostExecutable = "host_executable"
38)
39
Colin Crossae887032017-10-23 17:16:14 -070040type BuildParams struct {
Dan Willemsen9f3c5742016-11-03 14:28:31 -070041 Rule blueprint.Rule
Colin Cross33bfb0a2016-11-21 17:23:08 -080042 Deps blueprint.Deps
43 Depfile WritablePath
Colin Cross67a5c132017-05-09 13:45:28 -070044 Description string
Dan Willemsen9f3c5742016-11-03 14:28:31 -070045 Output WritablePath
46 Outputs WritablePaths
Jingwen Chence679d22020-09-23 04:30:02 +000047 SymlinkOutput WritablePath
48 SymlinkOutputs WritablePaths
Dan Willemsen9f3c5742016-11-03 14:28:31 -070049 ImplicitOutput WritablePath
50 ImplicitOutputs WritablePaths
51 Input Path
52 Inputs Paths
53 Implicit Path
54 Implicits Paths
55 OrderOnly Paths
Colin Cross824f1162020-07-16 13:07:51 -070056 Validation Path
57 Validations Paths
Dan Willemsen9f3c5742016-11-03 14:28:31 -070058 Default bool
59 Args map[string]string
Dan Willemsen34cc69e2015-09-23 15:26:20 -070060}
61
Colin Crossae887032017-10-23 17:16:14 -070062type ModuleBuildParams BuildParams
63
Colin Cross1184b642019-12-30 18:43:07 -080064// EarlyModuleContext provides methods that can be called early, as soon as the properties have
65// been parsed into the module and before any mutators have run.
66type EarlyModuleContext interface {
Colin Cross9f35c3d2020-09-16 19:04:41 -070067 // Module returns the current module as a Module. It should rarely be necessary, as the module already has a
68 // reference to itself.
Colin Cross1184b642019-12-30 18:43:07 -080069 Module() Module
Colin Cross9f35c3d2020-09-16 19:04:41 -070070
71 // ModuleName returns the name of the module. This is generally the value that was returned by Module.Name() when
72 // the module was created, but may have been modified by calls to BaseMutatorContext.Rename.
Colin Cross1184b642019-12-30 18:43:07 -080073 ModuleName() string
Colin Cross9f35c3d2020-09-16 19:04:41 -070074
75 // ModuleDir returns the path to the directory that contains the definition of the module.
Colin Cross1184b642019-12-30 18:43:07 -080076 ModuleDir() string
Colin Cross9f35c3d2020-09-16 19:04:41 -070077
78 // ModuleType returns the name of the module type that was used to create the module, as specified in
79 // RegisterModuleType.
Colin Cross1184b642019-12-30 18:43:07 -080080 ModuleType() string
Colin Cross9f35c3d2020-09-16 19:04:41 -070081
82 // BlueprintFile returns the name of the blueprint file that contains the definition of this
83 // module.
Colin Cross9d34f352019-11-22 16:03:51 -080084 BlueprintsFile() string
Colin Cross1184b642019-12-30 18:43:07 -080085
Colin Cross9f35c3d2020-09-16 19:04:41 -070086 // ContainsProperty returns true if the specified property name was set in the module definition.
Colin Cross1184b642019-12-30 18:43:07 -080087 ContainsProperty(name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -070088
89 // Errorf reports an error at the specified position of the module definition file.
Colin Cross1184b642019-12-30 18:43:07 -080090 Errorf(pos scanner.Position, fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -070091
92 // ModuleErrorf reports an error at the line number of the module type in the module definition.
Colin Cross1184b642019-12-30 18:43:07 -080093 ModuleErrorf(fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -070094
95 // PropertyErrorf reports an error at the line number of a property in the module definition.
Colin Cross1184b642019-12-30 18:43:07 -080096 PropertyErrorf(property, fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -070097
98 // Failed returns true if any errors have been reported. In most cases the module can continue with generating
99 // build rules after an error, allowing it to report additional errors in a single run, but in cases where the error
100 // has prevented the module from creating necessary data it can return early when Failed returns true.
Colin Cross1184b642019-12-30 18:43:07 -0800101 Failed() bool
102
Colin Cross9f35c3d2020-09-16 19:04:41 -0700103 // AddNinjaFileDeps adds dependencies on the specified files to the rule that creates the ninja manifest. The
104 // primary builder will be rerun whenever the specified files are modified.
Colin Cross1184b642019-12-30 18:43:07 -0800105 AddNinjaFileDeps(deps ...string)
106
107 DeviceSpecific() bool
108 SocSpecific() bool
109 ProductSpecific() bool
110 SystemExtSpecific() bool
111 Platform() bool
112
113 Config() Config
114 DeviceConfig() DeviceConfig
115
116 // Deprecated: use Config()
117 AConfig() Config
118
119 // GlobWithDeps returns a list of files that match the specified pattern but do not match any
120 // of the patterns in excludes. It also adds efficient dependencies to rerun the primary
121 // builder whenever a file matching the pattern as added or removed, without rerunning if a
122 // file that does not match the pattern is added to a searched directory.
123 GlobWithDeps(pattern string, excludes []string) ([]string, error)
124
125 Glob(globPattern string, excludes []string) Paths
126 GlobFiles(globPattern string, excludes []string) Paths
Colin Cross988414c2020-01-11 01:11:46 +0000127 IsSymlink(path Path) bool
128 Readlink(path Path) string
Colin Cross133ebef2020-08-14 17:38:45 -0700129
Colin Cross9f35c3d2020-09-16 19:04:41 -0700130 // Namespace returns the Namespace object provided by the NameInterface set by Context.SetNameInterface, or the
131 // default SimpleNameInterface if Context.SetNameInterface was not called.
Colin Cross133ebef2020-08-14 17:38:45 -0700132 Namespace() *Namespace
Colin Cross1184b642019-12-30 18:43:07 -0800133}
134
Colin Cross0ea8ba82019-06-06 14:33:29 -0700135// BaseModuleContext is the same as blueprint.BaseModuleContext except that Config() returns
Colin Crossdc35e212019-06-06 16:13:11 -0700136// a Config instead of an interface{}, and some methods have been wrapped to use an android.Module
137// instead of a blueprint.Module, plus some extra methods that return Android-specific information
Colin Cross0ea8ba82019-06-06 14:33:29 -0700138// about the current module.
139type BaseModuleContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800140 EarlyModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -0700141
Paul Duffinf88d8e02020-05-07 20:21:34 +0100142 blueprintBaseModuleContext() blueprint.BaseModuleContext
143
Colin Cross9f35c3d2020-09-16 19:04:41 -0700144 // OtherModuleName returns the name of another Module. See BaseModuleContext.ModuleName for more information.
145 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Colin Crossdc35e212019-06-06 16:13:11 -0700146 OtherModuleName(m blueprint.Module) string
Colin Cross9f35c3d2020-09-16 19:04:41 -0700147
148 // OtherModuleDir returns the directory of another Module. See BaseModuleContext.ModuleDir for more information.
149 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Colin Crossdc35e212019-06-06 16:13:11 -0700150 OtherModuleDir(m blueprint.Module) string
Colin Cross9f35c3d2020-09-16 19:04:41 -0700151
152 // OtherModuleErrorf reports an error on another Module. See BaseModuleContext.ModuleErrorf for more information.
153 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Colin Crossdc35e212019-06-06 16:13:11 -0700154 OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -0700155
156 // OtherModuleDependencyTag returns the dependency tag used to depend on a module, or nil if there is no dependency
157 // on the module. When called inside a Visit* method with current module being visited, and there are multiple
158 // dependencies on the module being visited, it returns the dependency tag used for the current dependency.
Colin Crossdc35e212019-06-06 16:13:11 -0700159 OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag
Colin Cross9f35c3d2020-09-16 19:04:41 -0700160
161 // OtherModuleExists returns true if a module with the specified name exists, as determined by the NameInterface
162 // passed to Context.SetNameInterface, or SimpleNameInterface if it was not called.
Colin Crossdc35e212019-06-06 16:13:11 -0700163 OtherModuleExists(name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -0700164
165 // OtherModuleDependencyVariantExists returns true if a module with the
166 // specified name and variant exists. The variant must match the given
167 // variations. It must also match all the non-local variations of the current
168 // module. In other words, it checks for the module AddVariationDependencies
169 // would add a dependency on with the same arguments.
Martin Stjernholm009a9dc2020-03-05 17:34:13 +0000170 OtherModuleDependencyVariantExists(variations []blueprint.Variation, name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -0700171
172 // OtherModuleReverseDependencyVariantExists returns true if a module with the
173 // specified name exists with the same variations as the current module. In
174 // other words, it checks for the module AddReverseDependency would add a
175 // dependency on with the same argument.
Martin Stjernholm009a9dc2020-03-05 17:34:13 +0000176 OtherModuleReverseDependencyVariantExists(name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -0700177
178 // OtherModuleType returns the type of another Module. See BaseModuleContext.ModuleType for more information.
179 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Jiyong Park9e6c2422019-08-09 20:39:45 +0900180 OtherModuleType(m blueprint.Module) string
Colin Crossdc35e212019-06-06 16:13:11 -0700181
Colin Crossd27e7b82020-07-02 11:38:17 -0700182 // OtherModuleProvider returns the value for a provider for the given module. If the value is
183 // not set it returns the zero value of the type of the provider, so the return value can always
184 // be type asserted to the type of the provider. The value returned may be a deep copy of the
185 // value originally passed to SetProvider.
186 OtherModuleProvider(m blueprint.Module, provider blueprint.ProviderKey) interface{}
187
188 // OtherModuleHasProvider returns true if the provider for the given module has been set.
189 OtherModuleHasProvider(m blueprint.Module, provider blueprint.ProviderKey) bool
190
191 // Provider returns the value for a provider for the current module. If the value is
192 // not set it returns the zero value of the type of the provider, so the return value can always
193 // be type asserted to the type of the provider. It panics if called before the appropriate
194 // mutator or GenerateBuildActions pass for the provider. The value returned may be a deep
195 // copy of the value originally passed to SetProvider.
196 Provider(provider blueprint.ProviderKey) interface{}
197
198 // HasProvider returns true if the provider for the current module has been set.
199 HasProvider(provider blueprint.ProviderKey) bool
200
201 // SetProvider sets the value for a provider for the current module. It panics if not called
202 // during the appropriate mutator or GenerateBuildActions pass for the provider, if the value
203 // is not of the appropriate type, or if the value has already been set. The value should not
204 // be modified after being passed to SetProvider.
205 SetProvider(provider blueprint.ProviderKey, value interface{})
206
Colin Crossdc35e212019-06-06 16:13:11 -0700207 GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module
Colin Cross9f35c3d2020-09-16 19:04:41 -0700208
209 // GetDirectDepWithTag returns the Module the direct dependency with the specified name, or nil if
210 // none exists. It panics if the dependency does not have the specified tag. It skips any
211 // dependencies that are not an android.Module.
Colin Crossdc35e212019-06-06 16:13:11 -0700212 GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module
Colin Cross9f35c3d2020-09-16 19:04:41 -0700213
214 // GetDirectDep returns the Module and DependencyTag for the direct dependency with the specified
215 // name, or nil if none exists. If there are multiple dependencies on the same module it returns
216 // the first DependencyTag. It skips any dependencies that are not an android.Module.
Colin Crossdc35e212019-06-06 16:13:11 -0700217 GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag)
218
Colin Cross9f35c3d2020-09-16 19:04:41 -0700219 // VisitDirectDepsBlueprint calls visit for each direct dependency. If there are multiple
220 // direct dependencies on the same module visit will be called multiple times on that module
221 // and OtherModuleDependencyTag will return a different tag for each.
222 //
223 // The Module passed to the visit function should not be retained outside of the visit
224 // function, it may be invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700225 VisitDirectDepsBlueprint(visit func(blueprint.Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700226
227 // VisitDirectDeps calls visit for each direct dependency. If there are multiple
228 // direct dependencies on the same module visit will be called multiple times on that module
229 // and OtherModuleDependencyTag will return a different tag for each. It skips any
230 // dependencies that are not an android.Module.
231 //
232 // The Module passed to the visit function should not be retained outside of the visit
233 // function, it may be invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700234 VisitDirectDeps(visit func(Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700235
Colin Crossdc35e212019-06-06 16:13:11 -0700236 VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700237
238 // VisitDirectDepsIf calls pred for each direct dependency, and if pred returns true calls visit. If there are
239 // multiple direct dependencies on the same module pred and visit will be called multiple times on that module and
240 // OtherModuleDependencyTag will return a different tag for each. It skips any
241 // dependencies that are not an android.Module.
242 //
243 // The Module passed to the visit function should not be retained outside of the visit function, it may be
244 // invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700245 VisitDirectDepsIf(pred func(Module) bool, visit func(Module))
246 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
247 VisitDepsDepthFirst(visit func(Module))
248 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
249 VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700250
251 // WalkDeps calls visit for each transitive dependency, traversing the dependency tree in top down order. visit may
252 // be called multiple times for the same (child, parent) pair if there are multiple direct dependencies between the
253 // child and parent with different tags. OtherModuleDependencyTag will return the tag for the currently visited
254 // (child, parent) pair. If visit returns false WalkDeps will not continue recursing down to child. It skips
255 // any dependencies that are not an android.Module.
256 //
257 // The Modules passed to the visit function should not be retained outside of the visit function, they may be
258 // invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700259 WalkDeps(visit func(Module, Module) bool)
Colin Cross9f35c3d2020-09-16 19:04:41 -0700260
261 // WalkDepsBlueprint calls visit for each transitive dependency, traversing the dependency
262 // tree in top down order. visit may be called multiple times for the same (child, parent)
263 // pair if there are multiple direct dependencies between the child and parent with different
264 // tags. OtherModuleDependencyTag will return the tag for the currently visited
265 // (child, parent) pair. If visit returns false WalkDeps will not continue recursing down
266 // to child.
267 //
268 // The Modules passed to the visit function should not be retained outside of the visit function, they may be
269 // invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700270 WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool)
Colin Cross9f35c3d2020-09-16 19:04:41 -0700271
Colin Crossdc35e212019-06-06 16:13:11 -0700272 // GetWalkPath is supposed to be called in visit function passed in WalkDeps()
273 // and returns a top-down dependency path from a start module to current child module.
274 GetWalkPath() []Module
275
Colin Cross4dfacf92020-09-16 19:22:27 -0700276 // PrimaryModule returns the first variant of the current module. Variants of a module are always visited in
277 // order by mutators and GenerateBuildActions, so the data created by the current mutator can be read from the
278 // Module returned by PrimaryModule without data races. This can be used to perform singleton actions that are
279 // only done once for all variants of a module.
280 PrimaryModule() Module
281
282 // FinalModule returns the last variant of the current module. Variants of a module are always visited in
283 // order by mutators and GenerateBuildActions, so the data created by the current mutator can be read from all
284 // variants using VisitAllModuleVariants if the current module == FinalModule(). This can be used to perform
285 // singleton actions that are only done once for all variants of a module.
286 FinalModule() Module
287
288 // VisitAllModuleVariants calls visit for each variant of the current module. Variants of a module are always
289 // visited in order by mutators and GenerateBuildActions, so the data created by the current mutator can be read
290 // from all variants if the current module == FinalModule(). Otherwise, care must be taken to not access any
291 // data modified by the current mutator.
292 VisitAllModuleVariants(visit func(Module))
293
Paul Duffinc5192442020-03-31 11:31:36 +0100294 // GetTagPath is supposed to be called in visit function passed in WalkDeps()
295 // and returns a top-down dependency tags path from a start module to current child module.
296 // It has one less entry than GetWalkPath() as it contains the dependency tags that
297 // exist between each adjacent pair of modules in the GetWalkPath().
298 // GetTagPath()[i] is the tag between GetWalkPath()[i] and GetWalkPath()[i+1]
299 GetTagPath() []blueprint.DependencyTag
300
Jiyong Park1c7e9622020-05-07 16:12:13 +0900301 // GetPathString is supposed to be called in visit function passed in WalkDeps()
302 // and returns a multi-line string showing the modules and dependency tags
303 // among them along the top-down dependency path from a start module to current child module.
304 // skipFirst when set to true, the output doesn't include the start module,
305 // which is already printed when this function is used along with ModuleErrorf().
306 GetPathString(skipFirst bool) string
307
Colin Crossdc35e212019-06-06 16:13:11 -0700308 AddMissingDependencies(missingDeps []string)
309
Colin Crossa1ad8d12016-06-01 17:09:44 -0700310 Target() Target
Colin Cross8b74d172016-09-13 09:59:14 -0700311 TargetPrimary() bool
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000312
313 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
314 // responsible for creating.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700315 MultiTargets() []Target
Colin Crossf6566ed2015-03-24 11:13:38 -0700316 Arch() Arch
Colin Crossa1ad8d12016-06-01 17:09:44 -0700317 Os() OsType
Colin Crossf6566ed2015-03-24 11:13:38 -0700318 Host() bool
319 Device() bool
Colin Cross0af4b842015-04-30 16:36:18 -0700320 Darwin() bool
Doug Horn21b94272019-01-16 12:06:11 -0800321 Fuchsia() bool
Colin Cross3edeee12017-04-04 12:59:48 -0700322 Windows() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700323 Debug() bool
Colin Cross1e7d3702016-08-24 15:25:47 -0700324 PrimaryArch() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700325}
326
Colin Cross1184b642019-12-30 18:43:07 -0800327// Deprecated: use EarlyModuleContext instead
Colin Cross635c3b02016-05-18 15:37:25 -0700328type BaseContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800329 EarlyModuleContext
Colin Crossaabf6792017-11-29 00:27:14 -0800330}
331
Colin Cross635c3b02016-05-18 15:37:25 -0700332type ModuleContext interface {
Colin Crossaabf6792017-11-29 00:27:14 -0800333 BaseModuleContext
Colin Cross3f40fa42015-01-30 17:27:36 -0800334
Colin Crossae887032017-10-23 17:16:14 -0700335 // Deprecated: use ModuleContext.Build instead.
Colin Cross0875c522017-11-28 17:34:01 -0800336 ModuleBuild(pctx PackageContext, params ModuleBuildParams)
Colin Cross8f101b42015-06-17 15:09:06 -0700337
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700338 ExpandSources(srcFiles, excludes []string) Paths
Colin Cross366938f2017-12-11 16:29:02 -0800339 ExpandSource(srcFile, prop string) Path
Colin Cross2383f3b2018-02-06 14:40:13 -0800340 ExpandOptionalSource(srcFile *string, prop string) OptionalPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700341
Colin Cross70dda7e2019-10-01 22:05:35 -0700342 InstallExecutable(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
343 InstallFile(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
344 InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath
345 InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700346 CheckbuildFile(srcPath Path)
Dan Willemsen6553f5e2016-03-10 18:14:25 -0800347
Colin Cross8d8f8e22016-08-03 11:57:50 -0700348 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700349 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700350 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800351 InstallInRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -0700352 InstallInVendorRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900353 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700354 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700355 InstallBypassMake() bool
Jiyong Park87788b52020-09-01 12:37:45 +0900356 InstallForceOS() (*OsType, *ArchType)
Nan Zhang6d34b302017-02-04 17:47:46 -0800357
358 RequiredModuleNames() []string
Sasha Smundakb6d23052019-04-01 18:37:36 -0700359 HostRequiredModuleNames() []string
360 TargetRequiredModuleNames() []string
Colin Cross3f68a132017-10-23 17:10:29 -0700361
Colin Cross3f68a132017-10-23 17:10:29 -0700362 ModuleSubDir() string
363
Colin Cross0875c522017-11-28 17:34:01 -0800364 Variable(pctx PackageContext, name, value string)
365 Rule(pctx PackageContext, name string, params blueprint.RuleParams, argNames ...string) blueprint.Rule
Colin Crossae887032017-10-23 17:16:14 -0700366 // Similar to blueprint.ModuleContext.Build, but takes Paths instead of []string,
367 // and performs more verification.
Colin Cross0875c522017-11-28 17:34:01 -0800368 Build(pctx PackageContext, params BuildParams)
Colin Crossc3d87d32020-06-04 13:25:17 -0700369 // Phony creates a Make-style phony rule, a rule with no commands that can depend on other
370 // phony rules or real files. Phony can be called on the same name multiple times to add
371 // additional dependencies.
372 Phony(phony string, deps ...Path)
Colin Cross3f68a132017-10-23 17:10:29 -0700373
Colin Cross9f35c3d2020-09-16 19:04:41 -0700374 // GetMissingDependencies returns the list of dependencies that were passed to AddDependencies or related methods,
375 // but do not exist.
Colin Cross3f68a132017-10-23 17:10:29 -0700376 GetMissingDependencies() []string
Colin Cross3f40fa42015-01-30 17:27:36 -0800377}
378
Colin Cross635c3b02016-05-18 15:37:25 -0700379type Module interface {
Colin Cross3f40fa42015-01-30 17:27:36 -0800380 blueprint.Module
381
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700382 // GenerateAndroidBuildActions is analogous to Blueprints' GenerateBuildActions,
383 // but GenerateAndroidBuildActions also has access to Android-specific information.
384 // For more information, see Module.GenerateBuildActions within Blueprint's module_ctx.go
Colin Cross635c3b02016-05-18 15:37:25 -0700385 GenerateAndroidBuildActions(ModuleContext)
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700386
Paul Duffin44f1d842020-06-26 20:17:02 +0100387 // Add dependencies to the components of a module, i.e. modules that are created
388 // by the module and which are considered to be part of the creating module.
389 //
390 // This is called before prebuilts are renamed so as to allow a dependency to be
391 // added directly to a prebuilt child module instead of depending on a source module
392 // and relying on prebuilt processing to switch to the prebuilt module if preferred.
393 //
394 // A dependency on a prebuilt must include the "prebuilt_" prefix.
395 ComponentDepsMutator(ctx BottomUpMutatorContext)
396
Colin Cross1e676be2016-10-12 14:38:15 -0700397 DepsMutator(BottomUpMutatorContext)
Colin Cross3f40fa42015-01-30 17:27:36 -0800398
Colin Cross635c3b02016-05-18 15:37:25 -0700399 base() *ModuleBase
Inseob Kimeec88e12020-01-22 11:11:29 +0900400 Disable()
Dan Willemsen0effe062015-11-30 16:06:01 -0800401 Enabled() bool
Colin Crossa1ad8d12016-06-01 17:09:44 -0700402 Target() Target
Anton Hansson1ee62c02020-06-30 11:51:53 +0100403 Owner() string
Dan Willemsen782a2d12015-12-21 14:55:28 -0800404 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700405 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700406 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800407 InstallInRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -0700408 InstallInVendorRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900409 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700410 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700411 InstallBypassMake() bool
Jiyong Park87788b52020-09-01 12:37:45 +0900412 InstallForceOS() (*OsType, *ArchType)
Colin Crossa2f296f2016-11-29 15:16:18 -0800413 SkipInstall()
Ulya Trafimovichb28cc372020-01-13 15:18:16 +0000414 IsSkipInstall() bool
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +0100415 MakeUninstallable()
Liz Kammer5ca3a622020-08-05 15:40:41 -0700416 ReplacedByPrebuilt()
417 IsReplacedByPrebuilt() bool
Jiyong Park374510b2018-03-19 18:23:01 +0900418 ExportedToMake() bool
Inseob Kim8471cda2019-11-15 09:59:12 +0900419 InitRc() Paths
420 VintfFragments() Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800421 NoticeFiles() Paths
Colin Cross36242852017-06-23 15:06:31 -0700422
423 AddProperties(props ...interface{})
424 GetProperties() []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700425
Colin Crossae887032017-10-23 17:16:14 -0700426 BuildParamsForTests() []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800427 RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800428 VariablesForTests() map[string]string
Paul Duffine2453c72019-05-31 14:00:04 +0100429
Colin Cross9a362232019-07-01 15:32:45 -0700430 // String returns a string that includes the module name and variants for printing during debugging.
431 String() string
432
Paul Duffine2453c72019-05-31 14:00:04 +0100433 // Get the qualified module id for this module.
434 qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName
435
436 // Get information about the properties that can contain visibility rules.
437 visibilityProperties() []visibilityProperty
Paul Duffin63c6e182019-07-24 14:24:38 +0100438
Jiyong Park6a8cf5f2019-12-30 16:31:09 +0900439 RequiredModuleNames() []string
440 HostRequiredModuleNames() []string
441 TargetRequiredModuleNames() []string
Colin Cross897266e2020-02-13 13:22:08 -0800442
Jiyong Park4dc2a1a2020-09-28 17:46:22 +0900443 FilesToInstall() InstallPaths
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
506 // A string tag to select the OutputFiles associated with the tag. Defaults to the
507 // the empty "" string.
508 Tag *string `android:"arch_variant"`
509}
510
Colin Crossfc754582016-05-17 16:34:16 -0700511type nameProperties struct {
512 // The name of the module. Must be unique across all modules.
Nan Zhang0007d812017-11-07 10:57:05 -0800513 Name *string
Colin Crossfc754582016-05-17 16:34:16 -0700514}
515
Colin Crossd976af02020-11-16 22:44:30 -0800516type enabledProperties struct {
Dan Willemsen0effe062015-11-30 16:06:01 -0800517 // emit build rules for this module
Paul Duffin54d9bb72020-02-12 10:20:56 +0000518 //
519 // Disabling a module should only be done for those modules that cannot be built
520 // in the current environment. Modules that can build in the current environment
521 // but are not usually required (e.g. superceded by a prebuilt) should not be
522 // disabled as that will prevent them from being built by the checkbuild target
523 // and so prevent early detection of changes that have broken those modules.
Dan Willemsen0effe062015-11-30 16:06:01 -0800524 Enabled *bool `android:"arch_variant"`
Colin Crossd976af02020-11-16 22:44:30 -0800525}
Colin Cross3f40fa42015-01-30 17:27:36 -0800526
Colin Crossd976af02020-11-16 22:44:30 -0800527type commonProperties struct {
Paul Duffin2e61fa62019-03-28 14:10:57 +0000528 // Controls the visibility of this module to other modules. Allowable values are one or more of
529 // these formats:
530 //
531 // ["//visibility:public"]: Anyone can use this module.
532 // ["//visibility:private"]: Only rules in the module's package (not its subpackages) can use
533 // this module.
Paul Duffin51084ff2020-05-05 19:19:22 +0100534 // ["//visibility:override"]: Discards any rules inherited from defaults or a creating module.
535 // Can only be used at the beginning of a list of visibility rules.
Paul Duffin2e61fa62019-03-28 14:10:57 +0000536 // ["//some/package:__pkg__", "//other/package:__pkg__"]: Only modules in some/package and
537 // other/package (defined in some/package/*.bp and other/package/*.bp) have access to
538 // this module. Note that sub-packages do not have access to the rule; for example,
539 // //some/package/foo:bar or //other/package/testing:bla wouldn't have access. __pkg__
540 // is a special module and must be used verbatim. It represents all of the modules in the
541 // package.
542 // ["//project:__subpackages__", "//other:__subpackages__"]: Only modules in packages project
543 // or other or in one of their sub-packages have access to this module. For example,
544 // //project:rule, //project/library:lib or //other/testing/internal:munge are allowed
545 // to depend on this rule (but not //independent:evil)
546 // ["//project"]: This is shorthand for ["//project:__pkg__"]
547 // [":__subpackages__"]: This is shorthand for ["//project:__subpackages__"] where
548 // //project is the module's package. e.g. using [":__subpackages__"] in
549 // packages/apps/Settings/Android.bp is equivalent to
550 // //packages/apps/Settings:__subpackages__.
551 // ["//visibility:legacy_public"]: The default visibility, behaves as //visibility:public
552 // for now. It is an error if it is used in a module.
Paul Duffine2453c72019-05-31 14:00:04 +0100553 //
554 // If a module does not specify the `visibility` property then it uses the
555 // `default_visibility` property of the `package` module in the module's package.
556 //
557 // If the `default_visibility` property is not set for the module's package then
Paul Duffine484f472019-06-20 16:38:08 +0100558 // it will use the `default_visibility` of its closest ancestor package for which
559 // a `default_visibility` property is specified.
560 //
561 // If no `default_visibility` property can be found then the module uses the
562 // global default of `//visibility:legacy_public`.
Paul Duffine2453c72019-05-31 14:00:04 +0100563 //
Paul Duffin95d53b52019-07-24 13:45:05 +0100564 // The `visibility` property has no effect on a defaults module although it does
565 // apply to any non-defaults module that uses it. To set the visibility of a
566 // defaults module, use the `defaults_visibility` property on the defaults module;
567 // not to be confused with the `default_visibility` property on the package module.
568 //
Paul Duffin2e61fa62019-03-28 14:10:57 +0000569 // See https://android.googlesource.com/platform/build/soong/+/master/README.md#visibility for
570 // more details.
571 Visibility []string
572
Colin Cross7d5136f2015-05-11 13:39:40 -0700573 // control whether this module compiles for 32-bit, 64-bit, or both. Possible values
Colin Cross3f40fa42015-01-30 17:27:36 -0800574 // are "32" (compile for 32-bit only), "64" (compile for 64-bit only), "both" (compile for both
575 // 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 +0000576 // platform).
Colin Cross7d716ba2017-11-01 10:38:29 -0700577 Compile_multilib *string `android:"arch_variant"`
Colin Cross69617d32016-09-06 10:39:07 -0700578
579 Target struct {
580 Host struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700581 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700582 }
583 Android struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700584 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700585 }
586 }
587
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000588 // If set to true then the archMutator will create variants for each arch specific target
589 // (e.g. 32/64) that the module is required to produce. If set to false then it will only
590 // create a variant for the architecture and will list the additional arch specific targets
591 // that the variant needs to produce in the CompileMultiTargets property.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700592 UseTargetVariants bool `blueprint:"mutated"`
593 Default_multilib string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800594
Dan Willemsen782a2d12015-12-21 14:55:28 -0800595 // whether this is a proprietary vendor module, and should be installed into /vendor
Colin Cross7d716ba2017-11-01 10:38:29 -0700596 Proprietary *bool
Dan Willemsen782a2d12015-12-21 14:55:28 -0800597
Colin Cross55708f32017-03-20 13:23:34 -0700598 // vendor who owns this module
Dan Willemsenefac4a82017-07-18 19:42:09 -0700599 Owner *string
Colin Cross55708f32017-03-20 13:23:34 -0700600
Jiyong Park2db76922017-11-08 16:03:48 +0900601 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
602 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
603 // Use `soc_specific` instead for better meaning.
Colin Cross7d716ba2017-11-01 10:38:29 -0700604 Vendor *bool
Dan Willemsenaa118f92017-04-06 12:49:58 -0700605
Jiyong Park2db76922017-11-08 16:03:48 +0900606 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
607 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
608 Soc_specific *bool
609
610 // whether this module is specific to a device, not only for SoC, but also for off-chip
611 // peripherals. When set to true, it is installed into /odm (or /vendor/odm if odm partition
612 // does not exist, or /system/vendor/odm if both odm and vendor partitions do not exist).
613 // This implies `soc_specific:true`.
614 Device_specific *bool
615
616 // whether this module is specific to a software configuration of a product (e.g. country,
Jaekyun Seok5cfbfbb2018-01-10 19:00:15 +0900617 // network operator, etc). When set to true, it is installed into /product (or
618 // /system/product if product partition does not exist).
Jiyong Park2db76922017-11-08 16:03:48 +0900619 Product_specific *bool
620
Justin Yund5f6c822019-06-25 16:47:17 +0900621 // whether this module extends system. When set to true, it is installed into /system_ext
622 // (or /system/system_ext if system_ext partition does not exist).
623 System_ext_specific *bool
624
Jiyong Parkf9332f12018-02-01 00:54:12 +0900625 // Whether this module is installed to recovery partition
626 Recovery *bool
627
Yifan Hong1b3348d2020-01-21 15:53:22 -0800628 // Whether this module is installed to ramdisk
629 Ramdisk *bool
630
Yifan Hong60e0cfb2020-10-21 15:17:56 -0700631 // Whether this module is installed to vendor ramdisk
632 Vendor_ramdisk *bool
633
dimitry1f33e402019-03-26 12:39:31 +0100634 // Whether this module is built for non-native architecures (also known as native bridge binary)
635 Native_bridge_supported *bool `android:"arch_variant"`
636
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700637 // init.rc files to be installed if this module is installed
Colin Cross0bab8772020-09-25 14:01:21 -0700638 Init_rc []string `android:"arch_variant,path"`
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700639
Steven Moreland57a23d22018-04-04 15:42:19 -0700640 // VINTF manifest fragments to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800641 Vintf_fragments []string `android:"path"`
Steven Moreland57a23d22018-04-04 15:42:19 -0700642
Chris Wolfe998306e2016-08-15 14:47:23 -0400643 // names of other modules to install if this module is installed
Colin Crossc602b7d2017-05-05 13:36:36 -0700644 Required []string `android:"arch_variant"`
Chris Wolfe998306e2016-08-15 14:47:23 -0400645
Sasha Smundakb6d23052019-04-01 18:37:36 -0700646 // names of other modules to install on host if this module is installed
647 Host_required []string `android:"arch_variant"`
648
649 // names of other modules to install on target if this module is installed
650 Target_required []string `android:"arch_variant"`
651
Colin Cross5aac3622017-08-31 15:07:09 -0700652 // relative path to a file to include in the list of notices for the device
Colin Cross27b922f2019-03-04 22:35:41 -0800653 Notice *string `android:"path"`
Colin Cross5aac3622017-08-31 15:07:09 -0700654
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000655 // The OsType of artifacts that this module variant is responsible for creating.
656 //
657 // Set by osMutator
658 CompileOS OsType `blueprint:"mutated"`
659
660 // The Target of artifacts that this module variant is responsible for creating.
661 //
662 // Set by archMutator
663 CompileTarget Target `blueprint:"mutated"`
664
665 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
666 // responsible for creating.
667 //
668 // By default this is nil as, where necessary, separate variants are created for the
669 // different multilib types supported and that information is encapsulated in the
670 // CompileTarget so the module variant simply needs to create artifacts for that.
671 //
672 // However, if UseTargetVariants is set to false (e.g. by
673 // InitAndroidMultiTargetsArchModule) then no separate variants are created for the
674 // multilib targets. Instead a single variant is created for the architecture and
675 // this contains the multilib specific targets that this variant should create.
676 //
677 // Set by archMutator
Colin Crossee0bc3b2018-10-02 22:01:37 -0700678 CompileMultiTargets []Target `blueprint:"mutated"`
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000679
680 // True if the module variant's CompileTarget is the primary target
681 //
682 // Set by archMutator
683 CompilePrimary bool `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800684
685 // Set by InitAndroidModule
686 HostOrDeviceSupported HostOrDeviceSupported `blueprint:"mutated"`
Dan Willemsen0b24c742016-10-04 15:13:37 -0700687 ArchSpecific bool `blueprint:"mutated"`
Colin Crossce75d2c2016-10-06 16:12:58 -0700688
Paul Duffin1356d8c2020-02-25 19:26:33 +0000689 // If set to true then a CommonOS variant will be created which will have dependencies
690 // on all its OsType specific variants. Used by sdk/module_exports to create a snapshot
691 // that covers all os and architecture variants.
692 //
693 // The OsType specific variants can be retrieved by calling
694 // GetOsSpecificVariantsOfCommonOSVariant
695 //
696 // Set at module initialization time by calling InitCommonOSAndroidMultiTargetsArchModule
697 CreateCommonOSVariant bool `blueprint:"mutated"`
698
699 // If set to true then this variant is the CommonOS variant that has dependencies on its
700 // OsType specific variants.
701 //
702 // Set by osMutator.
703 CommonOSVariant bool `blueprint:"mutated"`
704
Colin Crossce75d2c2016-10-06 16:12:58 -0700705 SkipInstall bool `blueprint:"mutated"`
Jeff Gaston088e29e2017-11-29 16:47:17 -0800706
Liz Kammer5ca3a622020-08-05 15:40:41 -0700707 // Whether the module has been replaced by a prebuilt
708 ReplacedByPrebuilt bool `blueprint:"mutated"`
709
Justin Yun32f053b2020-07-31 23:07:17 +0900710 // Disabled by mutators. If set to true, it overrides Enabled property.
711 ForcedDisabled bool `blueprint:"mutated"`
712
Jeff Gaston088e29e2017-11-29 16:47:17 -0800713 NamespaceExportedToMake bool `blueprint:"mutated"`
Colin Cross6c4f21f2019-06-06 15:41:36 -0700714
715 MissingDeps []string `blueprint:"mutated"`
Colin Cross9a362232019-07-01 15:32:45 -0700716
717 // Name and variant strings stored by mutators to enable Module.String()
718 DebugName string `blueprint:"mutated"`
719 DebugMutators []string `blueprint:"mutated"`
720 DebugVariations []string `blueprint:"mutated"`
Colin Cross7228ecd2019-11-18 16:00:16 -0800721
722 // set by ImageMutator
723 ImageVariation string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800724}
725
Paul Duffined875132020-09-02 13:08:57 +0100726type distProperties struct {
727 // configuration to distribute output files from this module to the distribution
728 // directory (default: $OUT/dist, configurable with $DIST_DIR)
729 Dist Dist `android:"arch_variant"`
730
731 // a list of configurations to distribute output files from this module to the
732 // distribution directory (default: $OUT/dist, configurable with $DIST_DIR)
733 Dists []Dist `android:"arch_variant"`
734}
735
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000736// A map of OutputFile tag keys to Paths, for disting purposes.
737type TaggedDistFiles map[string]Paths
738
739func MakeDefaultDistFiles(paths ...Path) TaggedDistFiles {
Jingwen Chen7b27ca72020-07-24 09:13:49 +0000740 for _, path := range paths {
741 if path == nil {
742 panic("The path to a dist file cannot be nil.")
743 }
744 }
745
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000746 // The default OutputFile tag is the empty "" string.
747 return TaggedDistFiles{"": paths}
748}
749
Colin Cross3f40fa42015-01-30 17:27:36 -0800750type hostAndDeviceProperties struct {
Colin Cross4e81d702018-11-09 10:36:55 -0800751 // If set to true, build a variant of the module for the host. Defaults to false.
752 Host_supported *bool
753
754 // If set to true, build a variant of the module for the device. Defaults to true.
Colin Crossa4190c12016-07-12 13:11:25 -0700755 Device_supported *bool
Colin Cross3f40fa42015-01-30 17:27:36 -0800756}
757
Colin Crossc472d572015-03-17 15:06:21 -0700758type Multilib string
759
760const (
Colin Cross6b4a32d2017-12-05 13:42:45 -0800761 MultilibBoth Multilib = "both"
762 MultilibFirst Multilib = "first"
763 MultilibCommon Multilib = "common"
764 MultilibCommonFirst Multilib = "common_first"
765 MultilibDefault Multilib = ""
Colin Crossc472d572015-03-17 15:06:21 -0700766)
767
Colin Crossa1ad8d12016-06-01 17:09:44 -0700768type HostOrDeviceSupported int
769
770const (
Colin Cross34037c62020-11-17 13:19:17 -0800771 hostSupported = 1 << iota
772 hostCrossSupported
773 deviceSupported
774 hostDefault
775 deviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700776
777 // Host and HostCross are built by default. Device is not supported.
Colin Cross34037c62020-11-17 13:19:17 -0800778 HostSupported = hostSupported | hostCrossSupported | hostDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700779
780 // Host is built by default. HostCross and Device are not supported.
Colin Cross34037c62020-11-17 13:19:17 -0800781 HostSupportedNoCross = hostSupported | hostDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700782
783 // Device is built by default. Host and HostCross are not supported.
Colin Cross34037c62020-11-17 13:19:17 -0800784 DeviceSupported = deviceSupported | deviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700785
786 // Device is built by default. Host and HostCross are supported.
Colin Cross34037c62020-11-17 13:19:17 -0800787 HostAndDeviceSupported = hostSupported | hostCrossSupported | deviceSupported | deviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700788
789 // Host, HostCross, and Device are built by default.
Colin Cross34037c62020-11-17 13:19:17 -0800790 HostAndDeviceDefault = hostSupported | hostCrossSupported | hostDefault |
791 deviceSupported | deviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700792
793 // Nothing is supported. This is not exposed to the user, but used to mark a
794 // host only module as unsupported when the module type is not supported on
795 // the host OS. E.g. benchmarks are supported on Linux but not Darwin.
Colin Cross34037c62020-11-17 13:19:17 -0800796 NeitherHostNorDeviceSupported = 0
Colin Crossa1ad8d12016-06-01 17:09:44 -0700797)
798
Jiyong Park2db76922017-11-08 16:03:48 +0900799type moduleKind int
800
801const (
802 platformModule moduleKind = iota
803 deviceSpecificModule
804 socSpecificModule
805 productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900806 systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900807)
808
809func (k moduleKind) String() string {
810 switch k {
811 case platformModule:
812 return "platform"
813 case deviceSpecificModule:
814 return "device-specific"
815 case socSpecificModule:
816 return "soc-specific"
817 case productSpecificModule:
818 return "product-specific"
Justin Yund5f6c822019-06-25 16:47:17 +0900819 case systemExtSpecificModule:
820 return "systemext-specific"
Jiyong Park2db76922017-11-08 16:03:48 +0900821 default:
822 panic(fmt.Errorf("unknown module kind %d", k))
823 }
824}
825
Colin Cross9d34f352019-11-22 16:03:51 -0800826func initAndroidModuleBase(m Module) {
827 m.base().module = m
828}
829
Colin Cross36242852017-06-23 15:06:31 -0700830func InitAndroidModule(m Module) {
Colin Cross9d34f352019-11-22 16:03:51 -0800831 initAndroidModuleBase(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800832 base := m.base()
Colin Cross5049f022015-03-18 13:28:46 -0700833
Colin Cross36242852017-06-23 15:06:31 -0700834 m.AddProperties(
Colin Crossfc754582016-05-17 16:34:16 -0700835 &base.nameProperties,
Colin Crossd976af02020-11-16 22:44:30 -0800836 &base.enabledProperties,
Paul Duffined875132020-09-02 13:08:57 +0100837 &base.commonProperties,
838 &base.distProperties)
Colin Cross18c46802019-09-24 22:19:02 -0700839
Colin Crosseabaedd2020-02-06 17:01:55 -0800840 initProductVariableModule(m)
Colin Cross18c46802019-09-24 22:19:02 -0700841
Colin Crossa3a97412019-03-18 12:24:29 -0700842 base.generalProperties = m.GetProperties()
Pirama Arumuga Nainar955dc492018-04-17 14:58:42 -0700843 base.customizableProperties = m.GetProperties()
Paul Duffin63c6e182019-07-24 14:24:38 +0100844
845 // The default_visibility property needs to be checked and parsed by the visibility module during
Paul Duffin5ec73ec2020-05-01 17:52:01 +0100846 // its checking and parsing phases so make it the primary visibility property.
847 setPrimaryVisibilityProperty(m, "visibility", &base.commonProperties.Visibility)
Colin Cross5049f022015-03-18 13:28:46 -0700848}
849
Colin Cross36242852017-06-23 15:06:31 -0700850func InitAndroidArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
851 InitAndroidModule(m)
Colin Cross5049f022015-03-18 13:28:46 -0700852
853 base := m.base()
Colin Cross3f40fa42015-01-30 17:27:36 -0800854 base.commonProperties.HostOrDeviceSupported = hod
Colin Cross69617d32016-09-06 10:39:07 -0700855 base.commonProperties.Default_multilib = string(defaultMultilib)
Dan Willemsen0b24c742016-10-04 15:13:37 -0700856 base.commonProperties.ArchSpecific = true
Colin Crossee0bc3b2018-10-02 22:01:37 -0700857 base.commonProperties.UseTargetVariants = true
Colin Cross3f40fa42015-01-30 17:27:36 -0800858
Colin Cross34037c62020-11-17 13:19:17 -0800859 if hod&hostSupported != 0 && hod&deviceSupported != 0 {
Colin Cross36242852017-06-23 15:06:31 -0700860 m.AddProperties(&base.hostAndDeviceProperties)
Colin Cross3f40fa42015-01-30 17:27:36 -0800861 }
862
Colin Cross36242852017-06-23 15:06:31 -0700863 InitArchModule(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800864}
865
Colin Crossee0bc3b2018-10-02 22:01:37 -0700866func InitAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
867 InitAndroidArchModule(m, hod, defaultMultilib)
868 m.base().commonProperties.UseTargetVariants = false
869}
870
Paul Duffin1356d8c2020-02-25 19:26:33 +0000871// As InitAndroidMultiTargetsArchModule except it creates an additional CommonOS variant that
872// has dependencies on all the OsType specific variants.
873func InitCommonOSAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
874 InitAndroidArchModule(m, hod, defaultMultilib)
875 m.base().commonProperties.UseTargetVariants = false
876 m.base().commonProperties.CreateCommonOSVariant = true
877}
878
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800879// A ModuleBase object contains the properties that are common to all Android
Colin Cross3f40fa42015-01-30 17:27:36 -0800880// modules. It should be included as an anonymous field in every module
881// struct definition. InitAndroidModule should then be called from the module's
882// factory function, and the return values from InitAndroidModule should be
883// returned from the factory function.
884//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800885// The ModuleBase type is responsible for implementing the GenerateBuildActions
886// method to support the blueprint.Module interface. This method will then call
887// the module's GenerateAndroidBuildActions method once for each build variant
Colin Cross25de6c32019-06-06 14:29:25 -0700888// that is to be built. GenerateAndroidBuildActions is passed a ModuleContext
889// rather than the usual blueprint.ModuleContext.
890// ModuleContext exposes extra functionality specific to the Android build
Colin Cross3f40fa42015-01-30 17:27:36 -0800891// system including details about the particular build variant that is to be
892// generated.
893//
894// For example:
895//
896// import (
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800897// "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -0800898// )
899//
900// type myModule struct {
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800901// android.ModuleBase
Colin Cross3f40fa42015-01-30 17:27:36 -0800902// properties struct {
903// MyProperty string
904// }
905// }
906//
Colin Cross36242852017-06-23 15:06:31 -0700907// func NewMyModule() android.Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800908// m := &myModule{}
Colin Cross36242852017-06-23 15:06:31 -0700909// m.AddProperties(&m.properties)
910// android.InitAndroidModule(m)
911// return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800912// }
913//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800914// func (m *myModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800915// // Get the CPU architecture for the current build variant.
916// variantArch := ctx.Arch()
917//
918// // ...
919// }
Colin Cross635c3b02016-05-18 15:37:25 -0700920type ModuleBase struct {
Colin Cross3f40fa42015-01-30 17:27:36 -0800921 // Putting the curiously recurring thing pointing to the thing that contains
922 // the thing pattern to good use.
Colin Cross36242852017-06-23 15:06:31 -0700923 // TODO: remove this
Colin Cross635c3b02016-05-18 15:37:25 -0700924 module Module
Colin Cross3f40fa42015-01-30 17:27:36 -0800925
Colin Crossfc754582016-05-17 16:34:16 -0700926 nameProperties nameProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800927 commonProperties commonProperties
Paul Duffined875132020-09-02 13:08:57 +0100928 distProperties distProperties
Colin Cross18c46802019-09-24 22:19:02 -0700929 variableProperties interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800930 hostAndDeviceProperties hostAndDeviceProperties
931 generalProperties []interface{}
Colin Crossc17727d2018-10-24 12:42:09 -0700932 archProperties [][]interface{}
Colin Crossa120ec12016-08-19 16:07:38 -0700933 customizableProperties []interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800934
Colin Crossd976af02020-11-16 22:44:30 -0800935 // The enabled property is special-cased so that the osMutator can skip creating variants
936 // that are disabled.
937 enabledProperties enabledProperties
938 archEnabledProperties *archPropRoot
939
Paul Duffin63c6e182019-07-24 14:24:38 +0100940 // Information about all the properties on the module that contains visibility rules that need
941 // checking.
942 visibilityPropertyInfo []visibilityProperty
943
944 // The primary visibility property, may be nil, that controls access to the module.
945 primaryVisibilityProperty visibilityProperty
946
Colin Cross3f40fa42015-01-30 17:27:36 -0800947 noAddressSanitizer bool
Colin Cross897266e2020-02-13 13:22:08 -0800948 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700949 checkbuildFiles Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800950 noticeFiles Paths
Colin Crossc3d87d32020-06-04 13:25:17 -0700951 phonies map[string]Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -0700952
953 // Used by buildTargetSingleton to create checkbuild and per-directory build targets
954 // Only set on the final variant of each module
Colin Cross0875c522017-11-28 17:34:01 -0800955 installTarget WritablePath
956 checkbuildTarget WritablePath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700957 blueprintDir string
Colin Crossa120ec12016-08-19 16:07:38 -0700958
Colin Cross178a5092016-09-13 13:42:32 -0700959 hooks hooks
Colin Cross36242852017-06-23 15:06:31 -0700960
961 registerProps []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700962
963 // For tests
Colin Crossae887032017-10-23 17:16:14 -0700964 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800965 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800966 variables map[string]string
Colin Crossa9d8bee2018-10-02 13:59:46 -0700967
Inseob Kim8471cda2019-11-15 09:59:12 +0900968 initRcPaths Paths
969 vintfFragmentsPaths Paths
970
Jiyong Park1613e552020-09-14 19:43:17 +0900971 prefer32 func(ctx BaseModuleContext, base *ModuleBase, os OsType) bool
Colin Cross36242852017-06-23 15:06:31 -0700972}
973
Paul Duffin44f1d842020-06-26 20:17:02 +0100974func (m *ModuleBase) ComponentDepsMutator(BottomUpMutatorContext) {}
975
Colin Cross4157e882019-06-06 16:57:04 -0700976func (m *ModuleBase) DepsMutator(BottomUpMutatorContext) {}
Colin Cross5f692ec2019-02-01 16:53:07 -0800977
Colin Cross4157e882019-06-06 16:57:04 -0700978func (m *ModuleBase) AddProperties(props ...interface{}) {
979 m.registerProps = append(m.registerProps, props...)
Colin Cross36242852017-06-23 15:06:31 -0700980}
981
Colin Cross4157e882019-06-06 16:57:04 -0700982func (m *ModuleBase) GetProperties() []interface{} {
983 return m.registerProps
Colin Cross3f40fa42015-01-30 17:27:36 -0800984}
985
Colin Cross4157e882019-06-06 16:57:04 -0700986func (m *ModuleBase) BuildParamsForTests() []BuildParams {
987 return m.buildParams
Colin Crosscec81712017-07-13 14:43:27 -0700988}
989
Colin Cross4157e882019-06-06 16:57:04 -0700990func (m *ModuleBase) RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams {
991 return m.ruleParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800992}
993
Colin Cross4157e882019-06-06 16:57:04 -0700994func (m *ModuleBase) VariablesForTests() map[string]string {
995 return m.variables
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800996}
997
Jiyong Park1613e552020-09-14 19:43:17 +0900998func (m *ModuleBase) Prefer32(prefer32 func(ctx BaseModuleContext, base *ModuleBase, os OsType) bool) {
Colin Cross4157e882019-06-06 16:57:04 -0700999 m.prefer32 = prefer32
Colin Crossa9d8bee2018-10-02 13:59:46 -07001000}
1001
Colin Crossce75d2c2016-10-06 16:12:58 -07001002// Name returns the name of the module. It may be overridden by individual module types, for
1003// example prebuilts will prepend prebuilt_ to the name.
Colin Cross4157e882019-06-06 16:57:04 -07001004func (m *ModuleBase) Name() string {
1005 return String(m.nameProperties.Name)
Colin Crossfc754582016-05-17 16:34:16 -07001006}
1007
Colin Cross9a362232019-07-01 15:32:45 -07001008// String returns a string that includes the module name and variants for printing during debugging.
1009func (m *ModuleBase) String() string {
1010 sb := strings.Builder{}
1011 sb.WriteString(m.commonProperties.DebugName)
1012 sb.WriteString("{")
1013 for i := range m.commonProperties.DebugMutators {
1014 if i != 0 {
1015 sb.WriteString(",")
1016 }
1017 sb.WriteString(m.commonProperties.DebugMutators[i])
1018 sb.WriteString(":")
1019 sb.WriteString(m.commonProperties.DebugVariations[i])
1020 }
1021 sb.WriteString("}")
1022 return sb.String()
1023}
1024
Colin Crossce75d2c2016-10-06 16:12:58 -07001025// BaseModuleName returns the name of the module as specified in the blueprints file.
Colin Cross4157e882019-06-06 16:57:04 -07001026func (m *ModuleBase) BaseModuleName() string {
1027 return String(m.nameProperties.Name)
Colin Crossce75d2c2016-10-06 16:12:58 -07001028}
1029
Colin Cross4157e882019-06-06 16:57:04 -07001030func (m *ModuleBase) base() *ModuleBase {
1031 return m
Colin Cross3f40fa42015-01-30 17:27:36 -08001032}
1033
Paul Duffine2453c72019-05-31 14:00:04 +01001034func (m *ModuleBase) qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName {
1035 return qualifiedModuleName{pkg: ctx.ModuleDir(), name: ctx.ModuleName()}
1036}
1037
1038func (m *ModuleBase) visibilityProperties() []visibilityProperty {
Paul Duffin63c6e182019-07-24 14:24:38 +01001039 return m.visibilityPropertyInfo
1040}
1041
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001042func (m *ModuleBase) Dists() []Dist {
Paul Duffined875132020-09-02 13:08:57 +01001043 if len(m.distProperties.Dist.Targets) > 0 {
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001044 // Make a copy of the underlying Dists slice to protect against
1045 // backing array modifications with repeated calls to this method.
Paul Duffined875132020-09-02 13:08:57 +01001046 distsCopy := append([]Dist(nil), m.distProperties.Dists...)
1047 return append(distsCopy, m.distProperties.Dist)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001048 } else {
Paul Duffined875132020-09-02 13:08:57 +01001049 return m.distProperties.Dists
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001050 }
1051}
1052
1053func (m *ModuleBase) GenerateTaggedDistFiles(ctx BaseModuleContext) TaggedDistFiles {
1054 distFiles := make(TaggedDistFiles)
1055 for _, dist := range m.Dists() {
1056 var tag string
1057 var distFilesForTag Paths
1058 if dist.Tag == nil {
1059 tag = ""
1060 } else {
1061 tag = *dist.Tag
1062 }
1063 distFilesForTag, err := m.base().module.(OutputFileProducer).OutputFiles(tag)
1064 if err != nil {
1065 ctx.PropertyErrorf("dist.tag", "%s", err.Error())
1066 }
1067 for _, distFile := range distFilesForTag {
1068 if distFile != nil && !distFiles[tag].containsPath(distFile) {
1069 distFiles[tag] = append(distFiles[tag], distFile)
1070 }
1071 }
1072 }
1073
1074 return distFiles
1075}
1076
Colin Cross4157e882019-06-06 16:57:04 -07001077func (m *ModuleBase) Target() Target {
1078 return m.commonProperties.CompileTarget
Dan Willemsen490fd492015-11-24 17:53:15 -08001079}
1080
Colin Cross4157e882019-06-06 16:57:04 -07001081func (m *ModuleBase) TargetPrimary() bool {
1082 return m.commonProperties.CompilePrimary
Colin Cross8b74d172016-09-13 09:59:14 -07001083}
1084
Colin Cross4157e882019-06-06 16:57:04 -07001085func (m *ModuleBase) MultiTargets() []Target {
1086 return m.commonProperties.CompileMultiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07001087}
1088
Colin Cross4157e882019-06-06 16:57:04 -07001089func (m *ModuleBase) Os() OsType {
1090 return m.Target().Os
Dan Willemsen490fd492015-11-24 17:53:15 -08001091}
1092
Colin Cross4157e882019-06-06 16:57:04 -07001093func (m *ModuleBase) Host() bool {
Jiyong Park1613e552020-09-14 19:43:17 +09001094 return m.Os().Class == Host
Dan Willemsen97750522016-02-09 17:43:51 -08001095}
1096
Yo Chiangbba545e2020-06-09 16:15:37 +08001097func (m *ModuleBase) Device() bool {
1098 return m.Os().Class == Device
1099}
1100
Colin Cross4157e882019-06-06 16:57:04 -07001101func (m *ModuleBase) Arch() Arch {
1102 return m.Target().Arch
Dan Willemsen97750522016-02-09 17:43:51 -08001103}
1104
Colin Cross4157e882019-06-06 16:57:04 -07001105func (m *ModuleBase) ArchSpecific() bool {
1106 return m.commonProperties.ArchSpecific
Dan Willemsen0b24c742016-10-04 15:13:37 -07001107}
1108
Paul Duffin1356d8c2020-02-25 19:26:33 +00001109// True if the current variant is a CommonOS variant, false otherwise.
1110func (m *ModuleBase) IsCommonOSVariant() bool {
1111 return m.commonProperties.CommonOSVariant
1112}
1113
Colin Cross34037c62020-11-17 13:19:17 -08001114// supportsTarget returns true if the given Target is supported by the current module.
1115func (m *ModuleBase) supportsTarget(target Target) bool {
1116 switch target.Os.Class {
1117 case Host:
1118 if target.HostCross {
1119 return m.HostCrossSupported()
1120 } else {
1121 return m.HostSupported()
Colin Crossa1ad8d12016-06-01 17:09:44 -07001122 }
Colin Cross34037c62020-11-17 13:19:17 -08001123 case Device:
1124 return m.DeviceSupported()
Colin Crossa1ad8d12016-06-01 17:09:44 -07001125 default:
Jiyong Park1613e552020-09-14 19:43:17 +09001126 return false
Colin Crossa1ad8d12016-06-01 17:09:44 -07001127 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001128}
1129
Colin Crossd976af02020-11-16 22:44:30 -08001130// osEnabled returns true if the given OS is enabled for the current module.
1131func (m *ModuleBase) osEnabled(os OsType) bool {
1132 targetStruct := reflect.ValueOf(m.archEnabledProperties.Target)
1133
1134 if targetStruct.Kind() != reflect.Ptr || targetStruct.Type().Elem().Kind() != reflect.Struct {
1135 panic(fmt.Errorf("expected a pointer to a struct, found %s", targetStruct.Type()))
1136 }
1137
1138 if targetStruct.IsNil() {
1139 return !os.DefaultDisabled
1140 }
1141
1142 osStruct := targetStruct.Elem().FieldByName(os.Field)
1143
1144 if targetStruct.Kind() != reflect.Ptr || targetStruct.Type().Elem().Kind() != reflect.Struct {
1145 panic(fmt.Errorf("expected a pointer to a struct, found %s", targetStruct.Type()))
1146 }
1147
1148 if osStruct.IsNil() {
1149 return !os.DefaultDisabled
1150 }
1151
1152 enabledField := osStruct.Elem().FieldByName("Enabled")
1153
1154 return proptools.BoolDefault(enabledField.Interface().(*bool), !os.DefaultDisabled)
1155}
1156
Colin Cross34037c62020-11-17 13:19:17 -08001157// DeviceSupported returns true if the current module is supported and enabled for device targets,
1158// i.e. the factory method set the HostOrDeviceSupported value to include device support and
1159// the device support is enabled by default or enabled by the device_supported property.
Colin Cross4157e882019-06-06 16:57:04 -07001160func (m *ModuleBase) DeviceSupported() bool {
Colin Cross34037c62020-11-17 13:19:17 -08001161 hod := m.commonProperties.HostOrDeviceSupported
1162 // deviceEnabled is true if the device_supported property is true or the HostOrDeviceSupported
1163 // value has the deviceDefault bit set.
1164 deviceEnabled := proptools.BoolDefault(m.hostAndDeviceProperties.Device_supported, hod&deviceDefault != 0)
1165 return hod&deviceSupported != 0 && deviceEnabled
Colin Cross3f40fa42015-01-30 17:27:36 -08001166}
1167
Colin Cross34037c62020-11-17 13:19:17 -08001168// HostSupported returns true if the current module is supported and enabled for host targets,
1169// i.e. the factory method set the HostOrDeviceSupported value to include host support and
1170// the host support is enabled by default or enabled by the host_supported property.
Paul Duffine44358f2019-11-26 18:04:12 +00001171func (m *ModuleBase) HostSupported() bool {
Colin Cross34037c62020-11-17 13:19:17 -08001172 hod := m.commonProperties.HostOrDeviceSupported
1173 // hostEnabled is true if the host_supported property is true or the HostOrDeviceSupported
1174 // value has the hostDefault bit set.
1175 hostEnabled := proptools.BoolDefault(m.hostAndDeviceProperties.Host_supported, hod&hostDefault != 0)
1176 return hod&hostSupported != 0 && hostEnabled
1177}
1178
1179// HostCrossSupported returns true if the current module is supported and enabled for host cross
1180// targets, i.e. the factory method set the HostOrDeviceSupported value to include host cross
1181// support and the host cross support is enabled by default or enabled by the
1182// host_supported property.
1183func (m *ModuleBase) HostCrossSupported() bool {
1184 hod := m.commonProperties.HostOrDeviceSupported
1185 // hostEnabled is true if the host_supported property is true or the HostOrDeviceSupported
1186 // value has the hostDefault bit set.
1187 hostEnabled := proptools.BoolDefault(m.hostAndDeviceProperties.Host_supported, hod&hostDefault != 0)
1188 return hod&hostCrossSupported != 0 && hostEnabled
Paul Duffine44358f2019-11-26 18:04:12 +00001189}
1190
Colin Cross4157e882019-06-06 16:57:04 -07001191func (m *ModuleBase) Platform() bool {
Justin Yund5f6c822019-06-25 16:47:17 +09001192 return !m.DeviceSpecific() && !m.SocSpecific() && !m.ProductSpecific() && !m.SystemExtSpecific()
Jiyong Parkc678ad32018-04-10 13:07:10 +09001193}
1194
Colin Cross4157e882019-06-06 16:57:04 -07001195func (m *ModuleBase) DeviceSpecific() bool {
1196 return Bool(m.commonProperties.Device_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +09001197}
1198
Colin Cross4157e882019-06-06 16:57:04 -07001199func (m *ModuleBase) SocSpecific() bool {
1200 return Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +09001201}
1202
Colin Cross4157e882019-06-06 16:57:04 -07001203func (m *ModuleBase) ProductSpecific() bool {
1204 return Bool(m.commonProperties.Product_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +09001205}
1206
Justin Yund5f6c822019-06-25 16:47:17 +09001207func (m *ModuleBase) SystemExtSpecific() bool {
1208 return Bool(m.commonProperties.System_ext_specific)
Dario Frenifd05a742018-05-29 13:28:54 +01001209}
1210
Colin Crossc2d24052020-05-13 11:05:02 -07001211// RequiresStableAPIs returns true if the module will be installed to a partition that may
1212// be updated separately from the system image.
1213func (m *ModuleBase) RequiresStableAPIs(ctx BaseModuleContext) bool {
1214 return m.SocSpecific() || m.DeviceSpecific() ||
1215 (m.ProductSpecific() && ctx.Config().EnforceProductPartitionInterface())
1216}
1217
Bill Peckhamfff3f8a2020-03-20 18:33:20 -07001218func (m *ModuleBase) PartitionTag(config DeviceConfig) string {
1219 partition := "system"
1220 if m.SocSpecific() {
1221 // A SoC-specific module could be on the vendor partition at
1222 // "vendor" or the system partition at "system/vendor".
1223 if config.VendorPath() == "vendor" {
1224 partition = "vendor"
1225 }
1226 } else if m.DeviceSpecific() {
1227 // A device-specific module could be on the odm partition at
1228 // "odm", the vendor partition at "vendor/odm", or the system
1229 // partition at "system/vendor/odm".
1230 if config.OdmPath() == "odm" {
1231 partition = "odm"
Ramy Medhat944839a2020-03-31 22:14:52 -04001232 } else if strings.HasPrefix(config.OdmPath(), "vendor/") {
Bill Peckhamfff3f8a2020-03-20 18:33:20 -07001233 partition = "vendor"
1234 }
1235 } else if m.ProductSpecific() {
1236 // A product-specific module could be on the product partition
1237 // at "product" or the system partition at "system/product".
1238 if config.ProductPath() == "product" {
1239 partition = "product"
1240 }
1241 } else if m.SystemExtSpecific() {
1242 // A system_ext-specific module could be on the system_ext
1243 // partition at "system_ext" or the system partition at
1244 // "system/system_ext".
1245 if config.SystemExtPath() == "system_ext" {
1246 partition = "system_ext"
1247 }
1248 }
1249 return partition
1250}
1251
Colin Cross4157e882019-06-06 16:57:04 -07001252func (m *ModuleBase) Enabled() bool {
Justin Yun32f053b2020-07-31 23:07:17 +09001253 if m.commonProperties.ForcedDisabled {
1254 return false
1255 }
Colin Crossd976af02020-11-16 22:44:30 -08001256 return proptools.BoolDefault(m.enabledProperties.Enabled, !m.Os().DefaultDisabled)
Colin Cross3f40fa42015-01-30 17:27:36 -08001257}
1258
Inseob Kimeec88e12020-01-22 11:11:29 +09001259func (m *ModuleBase) Disable() {
Justin Yun32f053b2020-07-31 23:07:17 +09001260 m.commonProperties.ForcedDisabled = true
Inseob Kimeec88e12020-01-22 11:11:29 +09001261}
1262
Colin Cross4157e882019-06-06 16:57:04 -07001263func (m *ModuleBase) SkipInstall() {
1264 m.commonProperties.SkipInstall = true
Colin Crossce75d2c2016-10-06 16:12:58 -07001265}
1266
Ulya Trafimovichb28cc372020-01-13 15:18:16 +00001267func (m *ModuleBase) IsSkipInstall() bool {
1268 return m.commonProperties.SkipInstall == true
1269}
1270
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001271// Similar to SkipInstall, but if the AndroidMk entry would set
1272// LOCAL_UNINSTALLABLE_MODULE then this variant may still output that entry
1273// rather than leaving it out altogether. That happens in cases where it would
1274// have other side effects, in particular when it adds a NOTICE file target,
1275// which other install targets might depend on.
1276func (m *ModuleBase) MakeUninstallable() {
1277 m.SkipInstall()
1278}
1279
Liz Kammer5ca3a622020-08-05 15:40:41 -07001280func (m *ModuleBase) ReplacedByPrebuilt() {
1281 m.commonProperties.ReplacedByPrebuilt = true
1282 m.SkipInstall()
1283}
1284
1285func (m *ModuleBase) IsReplacedByPrebuilt() bool {
1286 return m.commonProperties.ReplacedByPrebuilt
1287}
1288
Colin Cross4157e882019-06-06 16:57:04 -07001289func (m *ModuleBase) ExportedToMake() bool {
1290 return m.commonProperties.NamespaceExportedToMake
Jiyong Park374510b2018-03-19 18:23:01 +09001291}
1292
Colin Cross897266e2020-02-13 13:22:08 -08001293func (m *ModuleBase) computeInstallDeps(ctx blueprint.ModuleContext) InstallPaths {
Colin Crossb5ae1932020-11-17 06:32:06 +00001294
Colin Cross897266e2020-02-13 13:22:08 -08001295 var result InstallPaths
Colin Crossb5ae1932020-11-17 06:32:06 +00001296 // TODO(ccross): we need to use WalkDeps and have some way to know which dependencies require installation
1297 ctx.VisitDepsDepthFirst(func(m blueprint.Module) {
1298 if a, ok := m.(Module); ok {
1299 result = append(result, a.FilesToInstall()...)
Colin Cross897266e2020-02-13 13:22:08 -08001300 }
1301 })
Colin Cross3f40fa42015-01-30 17:27:36 -08001302
1303 return result
1304}
1305
Jiyong Park4dc2a1a2020-09-28 17:46:22 +09001306func (m *ModuleBase) FilesToInstall() InstallPaths {
Colin Cross4157e882019-06-06 16:57:04 -07001307 return m.installFiles
Colin Cross3f40fa42015-01-30 17:27:36 -08001308}
1309
Colin Cross4157e882019-06-06 16:57:04 -07001310func (m *ModuleBase) NoAddressSanitizer() bool {
1311 return m.noAddressSanitizer
Colin Cross3f40fa42015-01-30 17:27:36 -08001312}
1313
Colin Cross4157e882019-06-06 16:57:04 -07001314func (m *ModuleBase) InstallInData() bool {
Dan Willemsen782a2d12015-12-21 14:55:28 -08001315 return false
1316}
1317
Jaewoong Jung0949f312019-09-11 10:25:18 -07001318func (m *ModuleBase) InstallInTestcases() bool {
1319 return false
1320}
1321
Colin Cross4157e882019-06-06 16:57:04 -07001322func (m *ModuleBase) InstallInSanitizerDir() bool {
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001323 return false
1324}
1325
Yifan Hong1b3348d2020-01-21 15:53:22 -08001326func (m *ModuleBase) InstallInRamdisk() bool {
1327 return Bool(m.commonProperties.Ramdisk)
1328}
1329
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001330func (m *ModuleBase) InstallInVendorRamdisk() bool {
1331 return Bool(m.commonProperties.Vendor_ramdisk)
1332}
1333
Colin Cross4157e882019-06-06 16:57:04 -07001334func (m *ModuleBase) InstallInRecovery() bool {
1335 return Bool(m.commonProperties.Recovery)
Jiyong Parkf9332f12018-02-01 00:54:12 +09001336}
1337
Colin Cross90ba5f42019-10-02 11:10:58 -07001338func (m *ModuleBase) InstallInRoot() bool {
1339 return false
1340}
1341
Colin Cross607d8582019-07-29 16:44:46 -07001342func (m *ModuleBase) InstallBypassMake() bool {
1343 return false
1344}
1345
Jiyong Park87788b52020-09-01 12:37:45 +09001346func (m *ModuleBase) InstallForceOS() (*OsType, *ArchType) {
1347 return nil, nil
Colin Cross6e359402020-02-10 15:29:54 -08001348}
1349
Colin Cross4157e882019-06-06 16:57:04 -07001350func (m *ModuleBase) Owner() string {
1351 return String(m.commonProperties.Owner)
Sundong Ahn4fd04bb2018-08-31 18:01:37 +09001352}
1353
Bob Badoura75b0572020-02-18 20:21:55 -08001354func (m *ModuleBase) NoticeFiles() Paths {
1355 return m.noticeFiles
Jiyong Park52818fc2019-03-18 12:01:38 +09001356}
1357
Colin Cross7228ecd2019-11-18 16:00:16 -08001358func (m *ModuleBase) setImageVariation(variant string) {
1359 m.commonProperties.ImageVariation = variant
1360}
1361
1362func (m *ModuleBase) ImageVariation() blueprint.Variation {
1363 return blueprint.Variation{
1364 Mutator: "image",
1365 Variation: m.base().commonProperties.ImageVariation,
1366 }
1367}
1368
Paul Duffin9b76c0b2020-03-12 10:24:35 +00001369func (m *ModuleBase) getVariationByMutatorName(mutator string) string {
1370 for i, v := range m.commonProperties.DebugMutators {
1371 if v == mutator {
1372 return m.commonProperties.DebugVariations[i]
1373 }
1374 }
1375
1376 return ""
1377}
1378
Yifan Hong1b3348d2020-01-21 15:53:22 -08001379func (m *ModuleBase) InRamdisk() bool {
1380 return m.base().commonProperties.ImageVariation == RamdiskVariation
1381}
1382
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001383func (m *ModuleBase) InVendorRamdisk() bool {
1384 return m.base().commonProperties.ImageVariation == VendorRamdiskVariation
1385}
1386
Colin Cross7228ecd2019-11-18 16:00:16 -08001387func (m *ModuleBase) InRecovery() bool {
1388 return m.base().commonProperties.ImageVariation == RecoveryVariation
1389}
1390
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09001391func (m *ModuleBase) RequiredModuleNames() []string {
1392 return m.base().commonProperties.Required
1393}
1394
1395func (m *ModuleBase) HostRequiredModuleNames() []string {
1396 return m.base().commonProperties.Host_required
1397}
1398
1399func (m *ModuleBase) TargetRequiredModuleNames() []string {
1400 return m.base().commonProperties.Target_required
1401}
1402
Inseob Kim8471cda2019-11-15 09:59:12 +09001403func (m *ModuleBase) InitRc() Paths {
1404 return append(Paths{}, m.initRcPaths...)
1405}
1406
1407func (m *ModuleBase) VintfFragments() Paths {
1408 return append(Paths{}, m.vintfFragmentsPaths...)
1409}
1410
Colin Cross4157e882019-06-06 16:57:04 -07001411func (m *ModuleBase) generateModuleTarget(ctx ModuleContext) {
Colin Cross897266e2020-02-13 13:22:08 -08001412 var allInstalledFiles InstallPaths
1413 var allCheckbuildFiles Paths
Colin Cross0875c522017-11-28 17:34:01 -08001414 ctx.VisitAllModuleVariants(func(module Module) {
1415 a := module.base()
Colin Crossc9404352015-03-26 16:10:12 -07001416 allInstalledFiles = append(allInstalledFiles, a.installFiles...)
1417 allCheckbuildFiles = append(allCheckbuildFiles, a.checkbuildFiles...)
Colin Cross3f40fa42015-01-30 17:27:36 -08001418 })
1419
Colin Cross0875c522017-11-28 17:34:01 -08001420 var deps Paths
Colin Cross9454bfa2015-03-17 13:24:18 -07001421
Colin Cross133ebef2020-08-14 17:38:45 -07001422 namespacePrefix := ctx.Namespace().id
Jeff Gaston088e29e2017-11-29 16:47:17 -08001423 if namespacePrefix != "" {
1424 namespacePrefix = namespacePrefix + "-"
1425 }
1426
Colin Cross3f40fa42015-01-30 17:27:36 -08001427 if len(allInstalledFiles) > 0 {
Colin Crossc3d87d32020-06-04 13:25:17 -07001428 name := namespacePrefix + ctx.ModuleName() + "-install"
1429 ctx.Phony(name, allInstalledFiles.Paths()...)
1430 m.installTarget = PathForPhony(ctx, name)
1431 deps = append(deps, m.installTarget)
Colin Cross9454bfa2015-03-17 13:24:18 -07001432 }
1433
1434 if len(allCheckbuildFiles) > 0 {
Colin Crossc3d87d32020-06-04 13:25:17 -07001435 name := namespacePrefix + ctx.ModuleName() + "-checkbuild"
1436 ctx.Phony(name, allCheckbuildFiles...)
1437 m.checkbuildTarget = PathForPhony(ctx, name)
1438 deps = append(deps, m.checkbuildTarget)
Colin Cross9454bfa2015-03-17 13:24:18 -07001439 }
1440
1441 if len(deps) > 0 {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001442 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08001443 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001444 suffix = "-soong"
1445 }
1446
Colin Crossc3d87d32020-06-04 13:25:17 -07001447 ctx.Phony(namespacePrefix+ctx.ModuleName()+suffix, deps...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07001448
Colin Cross4157e882019-06-06 16:57:04 -07001449 m.blueprintDir = ctx.ModuleDir()
Colin Cross3f40fa42015-01-30 17:27:36 -08001450 }
1451}
1452
Colin Crossc34d2322020-01-03 15:23:27 -08001453func determineModuleKind(m *ModuleBase, ctx blueprint.EarlyModuleContext) moduleKind {
Colin Cross4157e882019-06-06 16:57:04 -07001454 var socSpecific = Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
1455 var deviceSpecific = Bool(m.commonProperties.Device_specific)
1456 var productSpecific = Bool(m.commonProperties.Product_specific)
Justin Yund5f6c822019-06-25 16:47:17 +09001457 var systemExtSpecific = Bool(m.commonProperties.System_ext_specific)
Jiyong Park2db76922017-11-08 16:03:48 +09001458
Dario Frenifd05a742018-05-29 13:28:54 +01001459 msg := "conflicting value set here"
1460 if socSpecific && deviceSpecific {
1461 ctx.PropertyErrorf("device_specific", "a module cannot be specific to SoC and device at the same time.")
Colin Cross4157e882019-06-06 16:57:04 -07001462 if Bool(m.commonProperties.Vendor) {
Jiyong Park2db76922017-11-08 16:03:48 +09001463 ctx.PropertyErrorf("vendor", msg)
1464 }
Colin Cross4157e882019-06-06 16:57:04 -07001465 if Bool(m.commonProperties.Proprietary) {
Jiyong Park2db76922017-11-08 16:03:48 +09001466 ctx.PropertyErrorf("proprietary", msg)
1467 }
Colin Cross4157e882019-06-06 16:57:04 -07001468 if Bool(m.commonProperties.Soc_specific) {
Jiyong Park2db76922017-11-08 16:03:48 +09001469 ctx.PropertyErrorf("soc_specific", msg)
1470 }
1471 }
1472
Justin Yund5f6c822019-06-25 16:47:17 +09001473 if productSpecific && systemExtSpecific {
1474 ctx.PropertyErrorf("product_specific", "a module cannot be specific to product and system_ext at the same time.")
1475 ctx.PropertyErrorf("system_ext_specific", msg)
Dario Frenifd05a742018-05-29 13:28:54 +01001476 }
1477
Justin Yund5f6c822019-06-25 16:47:17 +09001478 if (socSpecific || deviceSpecific) && (productSpecific || systemExtSpecific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001479 if productSpecific {
1480 ctx.PropertyErrorf("product_specific", "a module cannot be specific to SoC or device and product at the same time.")
1481 } else {
Justin Yund5f6c822019-06-25 16:47:17 +09001482 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 +01001483 }
1484 if deviceSpecific {
1485 ctx.PropertyErrorf("device_specific", msg)
1486 } else {
Colin Cross4157e882019-06-06 16:57:04 -07001487 if Bool(m.commonProperties.Vendor) {
Dario Frenifd05a742018-05-29 13:28:54 +01001488 ctx.PropertyErrorf("vendor", msg)
1489 }
Colin Cross4157e882019-06-06 16:57:04 -07001490 if Bool(m.commonProperties.Proprietary) {
Dario Frenifd05a742018-05-29 13:28:54 +01001491 ctx.PropertyErrorf("proprietary", msg)
1492 }
Colin Cross4157e882019-06-06 16:57:04 -07001493 if Bool(m.commonProperties.Soc_specific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001494 ctx.PropertyErrorf("soc_specific", msg)
1495 }
1496 }
1497 }
1498
Jiyong Park2db76922017-11-08 16:03:48 +09001499 if productSpecific {
1500 return productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +09001501 } else if systemExtSpecific {
1502 return systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001503 } else if deviceSpecific {
1504 return deviceSpecificModule
1505 } else if socSpecific {
1506 return socSpecificModule
1507 } else {
1508 return platformModule
1509 }
1510}
1511
Colin Crossc34d2322020-01-03 15:23:27 -08001512func (m *ModuleBase) earlyModuleContextFactory(ctx blueprint.EarlyModuleContext) earlyModuleContext {
Colin Cross1184b642019-12-30 18:43:07 -08001513 return earlyModuleContext{
Colin Crossc34d2322020-01-03 15:23:27 -08001514 EarlyModuleContext: ctx,
1515 kind: determineModuleKind(m, ctx),
1516 config: ctx.Config().(Config),
Colin Cross3f40fa42015-01-30 17:27:36 -08001517 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001518}
1519
Colin Cross1184b642019-12-30 18:43:07 -08001520func (m *ModuleBase) baseModuleContextFactory(ctx blueprint.BaseModuleContext) baseModuleContext {
1521 return baseModuleContext{
1522 bp: ctx,
1523 earlyModuleContext: m.earlyModuleContextFactory(ctx),
1524 os: m.commonProperties.CompileOS,
1525 target: m.commonProperties.CompileTarget,
1526 targetPrimary: m.commonProperties.CompilePrimary,
1527 multiTargets: m.commonProperties.CompileMultiTargets,
1528 }
1529}
1530
Colin Cross4157e882019-06-06 16:57:04 -07001531func (m *ModuleBase) GenerateBuildActions(blueprintCtx blueprint.ModuleContext) {
Colin Cross25de6c32019-06-06 14:29:25 -07001532 ctx := &moduleContext{
Colin Cross0ea8ba82019-06-06 14:33:29 -07001533 module: m.module,
Colin Crossdc35e212019-06-06 16:13:11 -07001534 bp: blueprintCtx,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001535 baseModuleContext: m.baseModuleContextFactory(blueprintCtx),
1536 installDeps: m.computeInstallDeps(blueprintCtx),
1537 installFiles: m.installFiles,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001538 variables: make(map[string]string),
Colin Cross3f40fa42015-01-30 17:27:36 -08001539 }
1540
Colin Cross6c4f21f2019-06-06 15:41:36 -07001541 // Temporarily continue to call blueprintCtx.GetMissingDependencies() to maintain the previous behavior of never
1542 // reporting missing dependency errors in Blueprint when AllowMissingDependencies == true.
1543 // TODO: This will be removed once defaults modules handle missing dependency errors
1544 blueprintCtx.GetMissingDependencies()
1545
Colin Crossdc35e212019-06-06 16:13:11 -07001546 // For the final GenerateAndroidBuildActions pass, require that all visited dependencies Soong modules and
Paul Duffin1356d8c2020-02-25 19:26:33 +00001547 // are enabled. Unless the module is a CommonOS variant which may have dependencies on disabled variants
1548 // (because the dependencies are added before the modules are disabled). The
1549 // GetOsSpecificVariantsOfCommonOSVariant(...) method will ensure that the disabled variants are
1550 // ignored.
1551 ctx.baseModuleContext.strictVisitDeps = !m.IsCommonOSVariant()
Colin Crossdc35e212019-06-06 16:13:11 -07001552
Colin Cross4c83e5c2019-02-25 14:54:28 -08001553 if ctx.config.captureBuild {
1554 ctx.ruleParams = make(map[blueprint.Rule]blueprint.RuleParams)
1555 }
1556
Colin Cross67a5c132017-05-09 13:45:28 -07001557 desc := "//" + ctx.ModuleDir() + ":" + ctx.ModuleName() + " "
1558 var suffix []string
Colin Cross0875c522017-11-28 17:34:01 -08001559 if ctx.Os().Class != Device && ctx.Os().Class != Generic {
1560 suffix = append(suffix, ctx.Os().String())
Colin Cross67a5c132017-05-09 13:45:28 -07001561 }
Colin Cross0875c522017-11-28 17:34:01 -08001562 if !ctx.PrimaryArch() {
1563 suffix = append(suffix, ctx.Arch().ArchType.String())
Colin Cross67a5c132017-05-09 13:45:28 -07001564 }
Colin Cross56a83212020-09-15 18:30:11 -07001565 if apexInfo := ctx.Provider(ApexInfoProvider).(ApexInfo); !apexInfo.IsForPlatform() {
1566 suffix = append(suffix, apexInfo.ApexVariationName)
Dan Willemsenb13a9482020-02-14 11:25:54 -08001567 }
Colin Cross67a5c132017-05-09 13:45:28 -07001568
1569 ctx.Variable(pctx, "moduleDesc", desc)
1570
1571 s := ""
1572 if len(suffix) > 0 {
1573 s = " [" + strings.Join(suffix, " ") + "]"
1574 }
1575 ctx.Variable(pctx, "moduleDescSuffix", s)
1576
Dan Willemsen569edc52018-11-19 09:33:29 -08001577 // Some common property checks for properties that will be used later in androidmk.go
Paul Duffined875132020-09-02 13:08:57 +01001578 if m.distProperties.Dist.Dest != nil {
1579 _, err := validateSafePath(*m.distProperties.Dist.Dest)
Dan Willemsen569edc52018-11-19 09:33:29 -08001580 if err != nil {
1581 ctx.PropertyErrorf("dist.dest", "%s", err.Error())
1582 }
1583 }
Paul Duffined875132020-09-02 13:08:57 +01001584 if m.distProperties.Dist.Dir != nil {
1585 _, err := validateSafePath(*m.distProperties.Dist.Dir)
Dan Willemsen569edc52018-11-19 09:33:29 -08001586 if err != nil {
1587 ctx.PropertyErrorf("dist.dir", "%s", err.Error())
1588 }
1589 }
Paul Duffined875132020-09-02 13:08:57 +01001590 if m.distProperties.Dist.Suffix != nil {
1591 if strings.Contains(*m.distProperties.Dist.Suffix, "/") {
Dan Willemsen569edc52018-11-19 09:33:29 -08001592 ctx.PropertyErrorf("dist.suffix", "Suffix may not contain a '/' character.")
1593 }
1594 }
1595
Colin Cross4157e882019-06-06 16:57:04 -07001596 if m.Enabled() {
Jooyung Hand48f3c32019-08-23 11:18:57 +09001597 // ensure all direct android.Module deps are enabled
1598 ctx.VisitDirectDepsBlueprint(func(bm blueprint.Module) {
1599 if _, ok := bm.(Module); ok {
1600 ctx.validateAndroidModule(bm, ctx.baseModuleContext.strictVisitDeps)
1601 }
1602 })
1603
Bob Badoura75b0572020-02-18 20:21:55 -08001604 m.noticeFiles = make([]Path, 0)
1605 optPath := OptionalPath{}
1606 notice := proptools.StringDefault(m.commonProperties.Notice, "")
Colin Cross4157e882019-06-06 16:57:04 -07001607 if module := SrcIsModule(notice); module != "" {
Bob Badoura75b0572020-02-18 20:21:55 -08001608 optPath = ctx.ExpandOptionalSource(&notice, "notice")
1609 } else if notice != "" {
Jiyong Park52818fc2019-03-18 12:01:38 +09001610 noticePath := filepath.Join(ctx.ModuleDir(), notice)
Bob Badoura75b0572020-02-18 20:21:55 -08001611 optPath = ExistentPathForSource(ctx, noticePath)
1612 }
1613 if optPath.Valid() {
1614 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1615 } else {
1616 for _, notice = range []string{"LICENSE", "LICENCE", "NOTICE"} {
1617 noticePath := filepath.Join(ctx.ModuleDir(), notice)
1618 optPath = ExistentPathForSource(ctx, noticePath)
1619 if optPath.Valid() {
1620 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1621 }
1622 }
Jaewoong Jung62707f72018-11-16 13:26:43 -08001623 }
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001624
1625 m.module.GenerateAndroidBuildActions(ctx)
1626 if ctx.Failed() {
1627 return
1628 }
1629
1630 m.installFiles = append(m.installFiles, ctx.installFiles...)
1631 m.checkbuildFiles = append(m.checkbuildFiles, ctx.checkbuildFiles...)
Inseob Kim8471cda2019-11-15 09:59:12 +09001632 m.initRcPaths = PathsForModuleSrc(ctx, m.commonProperties.Init_rc)
1633 m.vintfFragmentsPaths = PathsForModuleSrc(ctx, m.commonProperties.Vintf_fragments)
Colin Crossc3d87d32020-06-04 13:25:17 -07001634 for k, v := range ctx.phonies {
1635 m.phonies[k] = append(m.phonies[k], v...)
1636 }
Colin Crossdc35e212019-06-06 16:13:11 -07001637 } else if ctx.Config().AllowMissingDependencies() {
1638 // If the module is not enabled it will not create any build rules, nothing will call
1639 // ctx.GetMissingDependencies(), and blueprint will consider the missing dependencies to be unhandled
1640 // and report them as an error even when AllowMissingDependencies = true. Call
1641 // ctx.GetMissingDependencies() here to tell blueprint not to handle them.
1642 ctx.GetMissingDependencies()
Colin Cross3f40fa42015-01-30 17:27:36 -08001643 }
1644
Colin Cross4157e882019-06-06 16:57:04 -07001645 if m == ctx.FinalModule().(Module).base() {
1646 m.generateModuleTarget(ctx)
Colin Cross9b1d13d2016-09-19 15:18:11 -07001647 if ctx.Failed() {
1648 return
1649 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001650 }
Colin Crosscec81712017-07-13 14:43:27 -07001651
Colin Cross4157e882019-06-06 16:57:04 -07001652 m.buildParams = ctx.buildParams
1653 m.ruleParams = ctx.ruleParams
1654 m.variables = ctx.variables
Colin Cross3f40fa42015-01-30 17:27:36 -08001655}
1656
Colin Cross1184b642019-12-30 18:43:07 -08001657type earlyModuleContext struct {
Colin Crossc34d2322020-01-03 15:23:27 -08001658 blueprint.EarlyModuleContext
Colin Cross1184b642019-12-30 18:43:07 -08001659
1660 kind moduleKind
1661 config Config
1662}
1663
1664func (e *earlyModuleContext) Glob(globPattern string, excludes []string) Paths {
1665 ret, err := e.GlobWithDeps(globPattern, excludes)
1666 if err != nil {
1667 e.ModuleErrorf("glob: %s", err.Error())
1668 }
1669 return pathsForModuleSrcFromFullPath(e, ret, true)
1670}
1671
1672func (e *earlyModuleContext) GlobFiles(globPattern string, excludes []string) Paths {
1673 ret, err := e.GlobWithDeps(globPattern, excludes)
1674 if err != nil {
1675 e.ModuleErrorf("glob: %s", err.Error())
1676 }
1677 return pathsForModuleSrcFromFullPath(e, ret, false)
1678}
1679
Colin Cross988414c2020-01-11 01:11:46 +00001680func (b *earlyModuleContext) IsSymlink(path Path) bool {
1681 fileInfo, err := b.config.fs.Lstat(path.String())
1682 if err != nil {
1683 b.ModuleErrorf("os.Lstat(%q) failed: %s", path.String(), err)
1684 }
1685 return fileInfo.Mode()&os.ModeSymlink == os.ModeSymlink
1686}
1687
1688func (b *earlyModuleContext) Readlink(path Path) string {
1689 dest, err := b.config.fs.Readlink(path.String())
1690 if err != nil {
1691 b.ModuleErrorf("os.Readlink(%q) failed: %s", path.String(), err)
1692 }
1693 return dest
1694}
1695
Colin Cross1184b642019-12-30 18:43:07 -08001696func (e *earlyModuleContext) Module() Module {
Colin Crossc34d2322020-01-03 15:23:27 -08001697 module, _ := e.EarlyModuleContext.Module().(Module)
Colin Cross1184b642019-12-30 18:43:07 -08001698 return module
1699}
1700
1701func (e *earlyModuleContext) Config() Config {
Colin Crossc34d2322020-01-03 15:23:27 -08001702 return e.EarlyModuleContext.Config().(Config)
Colin Cross1184b642019-12-30 18:43:07 -08001703}
1704
1705func (e *earlyModuleContext) AConfig() Config {
1706 return e.config
1707}
1708
1709func (e *earlyModuleContext) DeviceConfig() DeviceConfig {
1710 return DeviceConfig{e.config.deviceConfig}
1711}
1712
1713func (e *earlyModuleContext) Platform() bool {
1714 return e.kind == platformModule
1715}
1716
1717func (e *earlyModuleContext) DeviceSpecific() bool {
1718 return e.kind == deviceSpecificModule
1719}
1720
1721func (e *earlyModuleContext) SocSpecific() bool {
1722 return e.kind == socSpecificModule
1723}
1724
1725func (e *earlyModuleContext) ProductSpecific() bool {
1726 return e.kind == productSpecificModule
1727}
1728
1729func (e *earlyModuleContext) SystemExtSpecific() bool {
1730 return e.kind == systemExtSpecificModule
1731}
1732
Colin Cross133ebef2020-08-14 17:38:45 -07001733func (e *earlyModuleContext) Namespace() *Namespace {
1734 return e.EarlyModuleContext.Namespace().(*Namespace)
1735}
1736
Colin Cross1184b642019-12-30 18:43:07 -08001737type baseModuleContext struct {
1738 bp blueprint.BaseModuleContext
1739 earlyModuleContext
Colin Crossfb0c16e2019-11-20 17:12:35 -08001740 os OsType
Colin Cross8b74d172016-09-13 09:59:14 -07001741 target Target
Colin Crossee0bc3b2018-10-02 22:01:37 -07001742 multiTargets []Target
Colin Cross8b74d172016-09-13 09:59:14 -07001743 targetPrimary bool
1744 debug bool
Colin Crossdc35e212019-06-06 16:13:11 -07001745
1746 walkPath []Module
Paul Duffinc5192442020-03-31 11:31:36 +01001747 tagPath []blueprint.DependencyTag
Colin Crossdc35e212019-06-06 16:13:11 -07001748
1749 strictVisitDeps bool // If true, enforce that all dependencies are enabled
Colin Crossf6566ed2015-03-24 11:13:38 -07001750}
1751
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001752func (b *baseModuleContext) OtherModuleName(m blueprint.Module) string {
1753 return b.bp.OtherModuleName(m)
1754}
1755func (b *baseModuleContext) OtherModuleDir(m blueprint.Module) string { return b.bp.OtherModuleDir(m) }
Colin Cross1184b642019-12-30 18:43:07 -08001756func (b *baseModuleContext) OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{}) {
Jooyung Hancd87c692020-02-26 02:05:18 +09001757 b.bp.OtherModuleErrorf(m, fmt, args...)
Colin Cross1184b642019-12-30 18:43:07 -08001758}
1759func (b *baseModuleContext) OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag {
1760 return b.bp.OtherModuleDependencyTag(m)
1761}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001762func (b *baseModuleContext) OtherModuleExists(name string) bool { return b.bp.OtherModuleExists(name) }
Martin Stjernholm009a9dc2020-03-05 17:34:13 +00001763func (b *baseModuleContext) OtherModuleDependencyVariantExists(variations []blueprint.Variation, name string) bool {
1764 return b.bp.OtherModuleDependencyVariantExists(variations, name)
1765}
1766func (b *baseModuleContext) OtherModuleReverseDependencyVariantExists(name string) bool {
1767 return b.bp.OtherModuleReverseDependencyVariantExists(name)
1768}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001769func (b *baseModuleContext) OtherModuleType(m blueprint.Module) string {
1770 return b.bp.OtherModuleType(m)
1771}
Colin Crossd27e7b82020-07-02 11:38:17 -07001772func (b *baseModuleContext) OtherModuleProvider(m blueprint.Module, provider blueprint.ProviderKey) interface{} {
1773 return b.bp.OtherModuleProvider(m, provider)
1774}
1775func (b *baseModuleContext) OtherModuleHasProvider(m blueprint.Module, provider blueprint.ProviderKey) bool {
1776 return b.bp.OtherModuleHasProvider(m, provider)
1777}
1778func (b *baseModuleContext) Provider(provider blueprint.ProviderKey) interface{} {
1779 return b.bp.Provider(provider)
1780}
1781func (b *baseModuleContext) HasProvider(provider blueprint.ProviderKey) bool {
1782 return b.bp.HasProvider(provider)
1783}
1784func (b *baseModuleContext) SetProvider(provider blueprint.ProviderKey, value interface{}) {
1785 b.bp.SetProvider(provider, value)
1786}
Colin Cross1184b642019-12-30 18:43:07 -08001787
1788func (b *baseModuleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1789 return b.bp.GetDirectDepWithTag(name, tag)
1790}
1791
Paul Duffinf88d8e02020-05-07 20:21:34 +01001792func (b *baseModuleContext) blueprintBaseModuleContext() blueprint.BaseModuleContext {
1793 return b.bp
1794}
1795
Colin Cross25de6c32019-06-06 14:29:25 -07001796type moduleContext struct {
Colin Crossdc35e212019-06-06 16:13:11 -07001797 bp blueprint.ModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -07001798 baseModuleContext
Colin Cross897266e2020-02-13 13:22:08 -08001799 installDeps InstallPaths
1800 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001801 checkbuildFiles Paths
Colin Cross8d8f8e22016-08-03 11:57:50 -07001802 module Module
Colin Crossc3d87d32020-06-04 13:25:17 -07001803 phonies map[string]Paths
Colin Crosscec81712017-07-13 14:43:27 -07001804
1805 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001806 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001807 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001808 variables map[string]string
Colin Cross6ff51382015-12-17 16:39:19 -08001809}
1810
Colin Crossb88b3c52019-06-10 15:15:17 -07001811func (m *moduleContext) ninjaError(params BuildParams, err error) (PackageContext, BuildParams) {
1812 return pctx, BuildParams{
Colin Cross4b69c492019-06-07 13:06:06 -07001813 Rule: ErrorRule,
1814 Description: params.Description,
1815 Output: params.Output,
1816 Outputs: params.Outputs,
1817 ImplicitOutput: params.ImplicitOutput,
1818 ImplicitOutputs: params.ImplicitOutputs,
Colin Cross6ff51382015-12-17 16:39:19 -08001819 Args: map[string]string{
1820 "error": err.Error(),
1821 },
Colin Crossb88b3c52019-06-10 15:15:17 -07001822 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001823}
1824
Colin Cross25de6c32019-06-06 14:29:25 -07001825func (m *moduleContext) ModuleBuild(pctx PackageContext, params ModuleBuildParams) {
1826 m.Build(pctx, BuildParams(params))
Colin Cross3f40fa42015-01-30 17:27:36 -08001827}
1828
Jingwen Chence679d22020-09-23 04:30:02 +00001829func validateBuildParams(params blueprint.BuildParams) error {
1830 // Validate that the symlink outputs are declared outputs or implicit outputs
1831 allOutputs := map[string]bool{}
1832 for _, output := range params.Outputs {
1833 allOutputs[output] = true
1834 }
1835 for _, output := range params.ImplicitOutputs {
1836 allOutputs[output] = true
1837 }
1838 for _, symlinkOutput := range params.SymlinkOutputs {
1839 if !allOutputs[symlinkOutput] {
1840 return fmt.Errorf(
1841 "Symlink output %s is not a declared output or implicit output",
1842 symlinkOutput)
1843 }
1844 }
1845 return nil
1846}
1847
1848// Convert build parameters from their concrete Android types into their string representations,
1849// and combine the singular and plural fields of the same type (e.g. Output and Outputs).
Colin Cross0875c522017-11-28 17:34:01 -08001850func convertBuildParams(params BuildParams) blueprint.BuildParams {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001851 bparams := blueprint.BuildParams{
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001852 Rule: params.Rule,
Colin Cross0875c522017-11-28 17:34:01 -08001853 Description: params.Description,
Colin Cross33bfb0a2016-11-21 17:23:08 -08001854 Deps: params.Deps,
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001855 Outputs: params.Outputs.Strings(),
1856 ImplicitOutputs: params.ImplicitOutputs.Strings(),
Jingwen Chence679d22020-09-23 04:30:02 +00001857 SymlinkOutputs: params.SymlinkOutputs.Strings(),
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001858 Inputs: params.Inputs.Strings(),
1859 Implicits: params.Implicits.Strings(),
1860 OrderOnly: params.OrderOnly.Strings(),
Colin Cross824f1162020-07-16 13:07:51 -07001861 Validations: params.Validations.Strings(),
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001862 Args: params.Args,
1863 Optional: !params.Default,
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001864 }
1865
Colin Cross33bfb0a2016-11-21 17:23:08 -08001866 if params.Depfile != nil {
1867 bparams.Depfile = params.Depfile.String()
1868 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001869 if params.Output != nil {
1870 bparams.Outputs = append(bparams.Outputs, params.Output.String())
1871 }
Jingwen Chence679d22020-09-23 04:30:02 +00001872 if params.SymlinkOutput != nil {
1873 bparams.SymlinkOutputs = append(bparams.SymlinkOutputs, params.SymlinkOutput.String())
1874 }
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001875 if params.ImplicitOutput != nil {
1876 bparams.ImplicitOutputs = append(bparams.ImplicitOutputs, params.ImplicitOutput.String())
1877 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001878 if params.Input != nil {
1879 bparams.Inputs = append(bparams.Inputs, params.Input.String())
1880 }
1881 if params.Implicit != nil {
1882 bparams.Implicits = append(bparams.Implicits, params.Implicit.String())
1883 }
Colin Cross824f1162020-07-16 13:07:51 -07001884 if params.Validation != nil {
1885 bparams.Validations = append(bparams.Validations, params.Validation.String())
1886 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001887
Colin Cross0b9f31f2019-02-28 11:00:01 -08001888 bparams.Outputs = proptools.NinjaEscapeList(bparams.Outputs)
1889 bparams.ImplicitOutputs = proptools.NinjaEscapeList(bparams.ImplicitOutputs)
Jingwen Chence679d22020-09-23 04:30:02 +00001890 bparams.SymlinkOutputs = proptools.NinjaEscapeList(bparams.SymlinkOutputs)
Colin Cross0b9f31f2019-02-28 11:00:01 -08001891 bparams.Inputs = proptools.NinjaEscapeList(bparams.Inputs)
1892 bparams.Implicits = proptools.NinjaEscapeList(bparams.Implicits)
1893 bparams.OrderOnly = proptools.NinjaEscapeList(bparams.OrderOnly)
Colin Cross824f1162020-07-16 13:07:51 -07001894 bparams.Validations = proptools.NinjaEscapeList(bparams.Validations)
1895 bparams.Depfile = proptools.NinjaEscape(bparams.Depfile)
Colin Crossfe4bc362018-09-12 10:02:13 -07001896
Colin Cross0875c522017-11-28 17:34:01 -08001897 return bparams
1898}
1899
Colin Cross25de6c32019-06-06 14:29:25 -07001900func (m *moduleContext) Variable(pctx PackageContext, name, value string) {
1901 if m.config.captureBuild {
1902 m.variables[name] = value
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001903 }
1904
Colin Crossdc35e212019-06-06 16:13:11 -07001905 m.bp.Variable(pctx.PackageContext, name, value)
Colin Cross0875c522017-11-28 17:34:01 -08001906}
1907
Colin Cross25de6c32019-06-06 14:29:25 -07001908func (m *moduleContext) Rule(pctx PackageContext, name string, params blueprint.RuleParams,
Colin Cross0875c522017-11-28 17:34:01 -08001909 argNames ...string) blueprint.Rule {
1910
Ramy Medhat944839a2020-03-31 22:14:52 -04001911 if m.config.UseRemoteBuild() {
1912 if params.Pool == nil {
1913 // When USE_GOMA=true or USE_RBE=true are set and the rule is not supported by goma/RBE, restrict
1914 // jobs to the local parallelism value
1915 params.Pool = localPool
1916 } else if params.Pool == remotePool {
1917 // remotePool is a fake pool used to identify rule that are supported for remoting. If the rule's
1918 // pool is the remotePool, replace with nil so that ninja runs it at NINJA_REMOTE_NUM_JOBS
1919 // parallelism.
1920 params.Pool = nil
1921 }
Colin Cross2e2dbc22019-09-25 13:31:46 -07001922 }
1923
Colin Crossdc35e212019-06-06 16:13:11 -07001924 rule := m.bp.Rule(pctx.PackageContext, name, params, argNames...)
Colin Cross4c83e5c2019-02-25 14:54:28 -08001925
Colin Cross25de6c32019-06-06 14:29:25 -07001926 if m.config.captureBuild {
1927 m.ruleParams[rule] = params
Colin Cross4c83e5c2019-02-25 14:54:28 -08001928 }
1929
1930 return rule
Colin Cross0875c522017-11-28 17:34:01 -08001931}
1932
Colin Cross25de6c32019-06-06 14:29:25 -07001933func (m *moduleContext) Build(pctx PackageContext, params BuildParams) {
Colin Crossb88b3c52019-06-10 15:15:17 -07001934 if params.Description != "" {
1935 params.Description = "${moduleDesc}" + params.Description + "${moduleDescSuffix}"
1936 }
1937
1938 if missingDeps := m.GetMissingDependencies(); len(missingDeps) > 0 {
1939 pctx, params = m.ninjaError(params, fmt.Errorf("module %s missing dependencies: %s\n",
1940 m.ModuleName(), strings.Join(missingDeps, ", ")))
1941 }
1942
Colin Cross25de6c32019-06-06 14:29:25 -07001943 if m.config.captureBuild {
1944 m.buildParams = append(m.buildParams, params)
Colin Cross0875c522017-11-28 17:34:01 -08001945 }
1946
Jingwen Chence679d22020-09-23 04:30:02 +00001947 bparams := convertBuildParams(params)
1948 err := validateBuildParams(bparams)
1949 if err != nil {
1950 m.ModuleErrorf(
1951 "%s: build parameter validation failed: %s",
1952 m.ModuleName(),
1953 err.Error())
1954 }
1955 m.bp.Build(pctx.PackageContext, bparams)
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001956}
Colin Crossc3d87d32020-06-04 13:25:17 -07001957
1958func (m *moduleContext) Phony(name string, deps ...Path) {
1959 addPhony(m.config, name, deps...)
1960}
1961
Colin Cross25de6c32019-06-06 14:29:25 -07001962func (m *moduleContext) GetMissingDependencies() []string {
Colin Cross6c4f21f2019-06-06 15:41:36 -07001963 var missingDeps []string
1964 missingDeps = append(missingDeps, m.Module().base().commonProperties.MissingDeps...)
Colin Crossdc35e212019-06-06 16:13:11 -07001965 missingDeps = append(missingDeps, m.bp.GetMissingDependencies()...)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001966 missingDeps = FirstUniqueStrings(missingDeps)
1967 return missingDeps
Colin Cross6ff51382015-12-17 16:39:19 -08001968}
1969
Colin Crossdc35e212019-06-06 16:13:11 -07001970func (b *baseModuleContext) AddMissingDependencies(deps []string) {
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001971 if deps != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001972 missingDeps := &b.Module().base().commonProperties.MissingDeps
Colin Cross6c4f21f2019-06-06 15:41:36 -07001973 *missingDeps = append(*missingDeps, deps...)
1974 *missingDeps = FirstUniqueStrings(*missingDeps)
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001975 }
1976}
1977
Colin Crossdc35e212019-06-06 16:13:11 -07001978func (b *baseModuleContext) validateAndroidModule(module blueprint.Module, strict bool) Module {
Colin Crossd11fcda2017-10-23 17:59:01 -07001979 aModule, _ := module.(Module)
Colin Crossdc35e212019-06-06 16:13:11 -07001980
1981 if !strict {
1982 return aModule
1983 }
1984
Colin Cross380c69a2019-06-10 17:49:58 +00001985 if aModule == nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001986 b.ModuleErrorf("module %q not an android module", b.OtherModuleName(module))
Colin Cross380c69a2019-06-10 17:49:58 +00001987 return nil
1988 }
1989
1990 if !aModule.Enabled() {
Colin Crossdc35e212019-06-06 16:13:11 -07001991 if b.Config().AllowMissingDependencies() {
1992 b.AddMissingDependencies([]string{b.OtherModuleName(aModule)})
Colin Cross380c69a2019-06-10 17:49:58 +00001993 } else {
Colin Crossdc35e212019-06-06 16:13:11 -07001994 b.ModuleErrorf("depends on disabled module %q", b.OtherModuleName(aModule))
Colin Cross380c69a2019-06-10 17:49:58 +00001995 }
1996 return nil
1997 }
Colin Crossd11fcda2017-10-23 17:59:01 -07001998 return aModule
1999}
2000
Colin Crossdc35e212019-06-06 16:13:11 -07002001func (b *baseModuleContext) getDirectDepInternal(name string, tag blueprint.DependencyTag) (blueprint.Module, blueprint.DependencyTag) {
Jiyong Parkf2976302019-04-17 21:47:37 +09002002 type dep struct {
2003 mod blueprint.Module
2004 tag blueprint.DependencyTag
2005 }
2006 var deps []dep
Colin Crossdc35e212019-06-06 16:13:11 -07002007 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07002008 if aModule, _ := module.(Module); aModule != nil && aModule.base().BaseModuleName() == name {
Colin Cross1184b642019-12-30 18:43:07 -08002009 returnedTag := b.bp.OtherModuleDependencyTag(aModule)
Jiyong Parkf2976302019-04-17 21:47:37 +09002010 if tag == nil || returnedTag == tag {
2011 deps = append(deps, dep{aModule, returnedTag})
2012 }
2013 }
2014 })
2015 if len(deps) == 1 {
2016 return deps[0].mod, deps[0].tag
2017 } else if len(deps) >= 2 {
2018 panic(fmt.Errorf("Multiple dependencies having same BaseModuleName() %q found from %q",
Colin Crossdc35e212019-06-06 16:13:11 -07002019 name, b.ModuleName()))
Jiyong Parkf2976302019-04-17 21:47:37 +09002020 } else {
2021 return nil, nil
2022 }
2023}
2024
Colin Crossdc35e212019-06-06 16:13:11 -07002025func (b *baseModuleContext) GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module {
Colin Cross0ef08162019-05-01 15:50:51 -07002026 var deps []Module
Colin Crossdc35e212019-06-06 16:13:11 -07002027 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07002028 if aModule, _ := module.(Module); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08002029 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Cross0ef08162019-05-01 15:50:51 -07002030 deps = append(deps, aModule)
2031 }
2032 }
2033 })
2034 return deps
2035}
2036
Colin Cross25de6c32019-06-06 14:29:25 -07002037func (m *moduleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
2038 module, _ := m.getDirectDepInternal(name, tag)
2039 return module
Jiyong Parkf2976302019-04-17 21:47:37 +09002040}
2041
Colin Crossdc35e212019-06-06 16:13:11 -07002042func (b *baseModuleContext) GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag) {
2043 return b.getDirectDepInternal(name, nil)
Jiyong Parkf2976302019-04-17 21:47:37 +09002044}
2045
Colin Crossdc35e212019-06-06 16:13:11 -07002046func (b *baseModuleContext) VisitDirectDepsBlueprint(visit func(blueprint.Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002047 b.bp.VisitDirectDeps(visit)
Colin Cross35143d02017-11-16 00:11:20 -08002048}
2049
Colin Crossdc35e212019-06-06 16:13:11 -07002050func (b *baseModuleContext) VisitDirectDeps(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002051 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07002052 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07002053 visit(aModule)
2054 }
2055 })
2056}
2057
Colin Crossdc35e212019-06-06 16:13:11 -07002058func (b *baseModuleContext) VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002059 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07002060 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08002061 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Crossee6143c2017-12-30 17:54:27 -08002062 visit(aModule)
2063 }
2064 }
2065 })
2066}
2067
Colin Crossdc35e212019-06-06 16:13:11 -07002068func (b *baseModuleContext) VisitDirectDepsIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002069 b.bp.VisitDirectDepsIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07002070 // pred
2071 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07002072 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07002073 return pred(aModule)
2074 } else {
2075 return false
2076 }
2077 },
2078 // visit
2079 func(module blueprint.Module) {
2080 visit(module.(Module))
2081 })
2082}
2083
Colin Crossdc35e212019-06-06 16:13:11 -07002084func (b *baseModuleContext) VisitDepsDepthFirst(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002085 b.bp.VisitDepsDepthFirst(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07002086 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07002087 visit(aModule)
2088 }
2089 })
2090}
2091
Colin Crossdc35e212019-06-06 16:13:11 -07002092func (b *baseModuleContext) VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002093 b.bp.VisitDepsDepthFirstIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07002094 // pred
2095 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07002096 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07002097 return pred(aModule)
2098 } else {
2099 return false
2100 }
2101 },
2102 // visit
2103 func(module blueprint.Module) {
2104 visit(module.(Module))
2105 })
2106}
2107
Colin Crossdc35e212019-06-06 16:13:11 -07002108func (b *baseModuleContext) WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool) {
Colin Cross1184b642019-12-30 18:43:07 -08002109 b.bp.WalkDeps(visit)
Alex Light778127a2019-02-27 14:19:50 -08002110}
2111
Colin Crossdc35e212019-06-06 16:13:11 -07002112func (b *baseModuleContext) WalkDeps(visit func(Module, Module) bool) {
2113 b.walkPath = []Module{b.Module()}
Paul Duffinc5192442020-03-31 11:31:36 +01002114 b.tagPath = []blueprint.DependencyTag{}
Colin Cross1184b642019-12-30 18:43:07 -08002115 b.bp.WalkDeps(func(child, parent blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07002116 childAndroidModule, _ := child.(Module)
2117 parentAndroidModule, _ := parent.(Module)
Colin Crossd11fcda2017-10-23 17:59:01 -07002118 if childAndroidModule != nil && parentAndroidModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07002119 // record walkPath before visit
2120 for b.walkPath[len(b.walkPath)-1] != parentAndroidModule {
2121 b.walkPath = b.walkPath[0 : len(b.walkPath)-1]
Paul Duffinc5192442020-03-31 11:31:36 +01002122 b.tagPath = b.tagPath[0 : len(b.tagPath)-1]
Colin Crossdc35e212019-06-06 16:13:11 -07002123 }
2124 b.walkPath = append(b.walkPath, childAndroidModule)
Paul Duffinc5192442020-03-31 11:31:36 +01002125 b.tagPath = append(b.tagPath, b.OtherModuleDependencyTag(childAndroidModule))
Colin Crossd11fcda2017-10-23 17:59:01 -07002126 return visit(childAndroidModule, parentAndroidModule)
2127 } else {
2128 return false
2129 }
2130 })
2131}
2132
Colin Crossdc35e212019-06-06 16:13:11 -07002133func (b *baseModuleContext) GetWalkPath() []Module {
2134 return b.walkPath
2135}
2136
Paul Duffinc5192442020-03-31 11:31:36 +01002137func (b *baseModuleContext) GetTagPath() []blueprint.DependencyTag {
2138 return b.tagPath
2139}
2140
Colin Cross4dfacf92020-09-16 19:22:27 -07002141func (b *baseModuleContext) VisitAllModuleVariants(visit func(Module)) {
2142 b.bp.VisitAllModuleVariants(func(module blueprint.Module) {
2143 visit(module.(Module))
2144 })
2145}
2146
2147func (b *baseModuleContext) PrimaryModule() Module {
2148 return b.bp.PrimaryModule().(Module)
2149}
2150
2151func (b *baseModuleContext) FinalModule() Module {
2152 return b.bp.FinalModule().(Module)
2153}
2154
Jiyong Park1c7e9622020-05-07 16:12:13 +09002155// A regexp for removing boilerplate from BaseDependencyTag from the string representation of
2156// a dependency tag.
Colin Cross6e511a92020-07-27 21:26:48 -07002157var tagCleaner = regexp.MustCompile(`\QBaseDependencyTag:{}\E(, )?`)
Jiyong Park1c7e9622020-05-07 16:12:13 +09002158
2159// PrettyPrintTag returns string representation of the tag, but prefers
2160// custom String() method if available.
2161func PrettyPrintTag(tag blueprint.DependencyTag) string {
2162 // Use tag's custom String() method if available.
2163 if stringer, ok := tag.(fmt.Stringer); ok {
2164 return stringer.String()
2165 }
2166
2167 // Otherwise, get a default string representation of the tag's struct.
Colin Cross6e511a92020-07-27 21:26:48 -07002168 tagString := fmt.Sprintf("%T: %+v", tag, tag)
Jiyong Park1c7e9622020-05-07 16:12:13 +09002169
2170 // Remove the boilerplate from BaseDependencyTag as it adds no value.
2171 tagString = tagCleaner.ReplaceAllString(tagString, "")
2172 return tagString
2173}
2174
2175func (b *baseModuleContext) GetPathString(skipFirst bool) string {
2176 sb := strings.Builder{}
2177 tagPath := b.GetTagPath()
2178 walkPath := b.GetWalkPath()
2179 if !skipFirst {
2180 sb.WriteString(walkPath[0].String())
2181 }
2182 for i, m := range walkPath[1:] {
2183 sb.WriteString("\n")
2184 sb.WriteString(fmt.Sprintf(" via tag %s\n", PrettyPrintTag(tagPath[i])))
2185 sb.WriteString(fmt.Sprintf(" -> %s", m.String()))
2186 }
2187 return sb.String()
2188}
2189
Colin Crossdc35e212019-06-06 16:13:11 -07002190func (m *moduleContext) ModuleSubDir() string {
2191 return m.bp.ModuleSubDir()
Colin Cross0875c522017-11-28 17:34:01 -08002192}
2193
Colin Cross0ea8ba82019-06-06 14:33:29 -07002194func (b *baseModuleContext) Target() Target {
Colin Cross25de6c32019-06-06 14:29:25 -07002195 return b.target
Colin Crossa1ad8d12016-06-01 17:09:44 -07002196}
2197
Colin Cross0ea8ba82019-06-06 14:33:29 -07002198func (b *baseModuleContext) TargetPrimary() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002199 return b.targetPrimary
Colin Cross8b74d172016-09-13 09:59:14 -07002200}
2201
Colin Cross0ea8ba82019-06-06 14:33:29 -07002202func (b *baseModuleContext) MultiTargets() []Target {
Colin Cross25de6c32019-06-06 14:29:25 -07002203 return b.multiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07002204}
2205
Colin Cross0ea8ba82019-06-06 14:33:29 -07002206func (b *baseModuleContext) Arch() Arch {
Colin Cross25de6c32019-06-06 14:29:25 -07002207 return b.target.Arch
Colin Cross3f40fa42015-01-30 17:27:36 -08002208}
2209
Colin Cross0ea8ba82019-06-06 14:33:29 -07002210func (b *baseModuleContext) Os() OsType {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002211 return b.os
Dan Willemsen490fd492015-11-24 17:53:15 -08002212}
2213
Colin Cross0ea8ba82019-06-06 14:33:29 -07002214func (b *baseModuleContext) Host() bool {
Jiyong Park1613e552020-09-14 19:43:17 +09002215 return b.os.Class == Host
Colin Crossf6566ed2015-03-24 11:13:38 -07002216}
2217
Colin Cross0ea8ba82019-06-06 14:33:29 -07002218func (b *baseModuleContext) Device() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002219 return b.os.Class == Device
Colin Crossf6566ed2015-03-24 11:13:38 -07002220}
2221
Colin Cross0ea8ba82019-06-06 14:33:29 -07002222func (b *baseModuleContext) Darwin() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002223 return b.os == Darwin
Colin Cross0af4b842015-04-30 16:36:18 -07002224}
2225
Colin Cross0ea8ba82019-06-06 14:33:29 -07002226func (b *baseModuleContext) Fuchsia() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002227 return b.os == Fuchsia
Doug Horn21b94272019-01-16 12:06:11 -08002228}
2229
Colin Cross0ea8ba82019-06-06 14:33:29 -07002230func (b *baseModuleContext) Windows() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002231 return b.os == Windows
Colin Cross3edeee12017-04-04 12:59:48 -07002232}
2233
Colin Cross0ea8ba82019-06-06 14:33:29 -07002234func (b *baseModuleContext) Debug() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002235 return b.debug
Colin Crossf6566ed2015-03-24 11:13:38 -07002236}
2237
Colin Cross0ea8ba82019-06-06 14:33:29 -07002238func (b *baseModuleContext) PrimaryArch() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002239 if len(b.config.Targets[b.target.Os]) <= 1 {
Colin Cross67a5c132017-05-09 13:45:28 -07002240 return true
2241 }
Colin Cross25de6c32019-06-06 14:29:25 -07002242 return b.target.Arch.ArchType == b.config.Targets[b.target.Os][0].Arch.ArchType
Colin Cross1e7d3702016-08-24 15:25:47 -07002243}
2244
Jiyong Park5baac542018-08-28 09:55:37 +09002245// Makes this module a platform module, i.e. not specific to soc, device,
Justin Yund5f6c822019-06-25 16:47:17 +09002246// product, or system_ext.
Colin Cross4157e882019-06-06 16:57:04 -07002247func (m *ModuleBase) MakeAsPlatform() {
2248 m.commonProperties.Vendor = boolPtr(false)
2249 m.commonProperties.Proprietary = boolPtr(false)
2250 m.commonProperties.Soc_specific = boolPtr(false)
2251 m.commonProperties.Product_specific = boolPtr(false)
Justin Yund5f6c822019-06-25 16:47:17 +09002252 m.commonProperties.System_ext_specific = boolPtr(false)
Jiyong Park5baac542018-08-28 09:55:37 +09002253}
2254
Colin Cross4157e882019-06-06 16:57:04 -07002255func (m *ModuleBase) EnableNativeBridgeSupportByDefault() {
2256 m.commonProperties.Native_bridge_supported = boolPtr(true)
dimitry03dc3f62019-05-09 14:07:34 +02002257}
2258
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09002259func (m *ModuleBase) MakeAsSystemExt() {
Jooyung Han91df2082019-11-20 01:49:42 +09002260 m.commonProperties.Vendor = boolPtr(false)
2261 m.commonProperties.Proprietary = boolPtr(false)
2262 m.commonProperties.Soc_specific = boolPtr(false)
2263 m.commonProperties.Product_specific = boolPtr(false)
2264 m.commonProperties.System_ext_specific = boolPtr(true)
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09002265}
2266
Jooyung Han344d5432019-08-23 11:17:39 +09002267// IsNativeBridgeSupported returns true if "native_bridge_supported" is explicitly set as "true"
2268func (m *ModuleBase) IsNativeBridgeSupported() bool {
2269 return proptools.Bool(m.commonProperties.Native_bridge_supported)
2270}
2271
Colin Cross25de6c32019-06-06 14:29:25 -07002272func (m *moduleContext) InstallInData() bool {
2273 return m.module.InstallInData()
Dan Willemsen782a2d12015-12-21 14:55:28 -08002274}
2275
Jaewoong Jung0949f312019-09-11 10:25:18 -07002276func (m *moduleContext) InstallInTestcases() bool {
2277 return m.module.InstallInTestcases()
2278}
2279
Colin Cross25de6c32019-06-06 14:29:25 -07002280func (m *moduleContext) InstallInSanitizerDir() bool {
2281 return m.module.InstallInSanitizerDir()
Vishwath Mohan1dd88392017-03-29 22:00:18 -07002282}
2283
Yifan Hong1b3348d2020-01-21 15:53:22 -08002284func (m *moduleContext) InstallInRamdisk() bool {
2285 return m.module.InstallInRamdisk()
2286}
2287
Yifan Hong60e0cfb2020-10-21 15:17:56 -07002288func (m *moduleContext) InstallInVendorRamdisk() bool {
2289 return m.module.InstallInVendorRamdisk()
2290}
2291
Colin Cross25de6c32019-06-06 14:29:25 -07002292func (m *moduleContext) InstallInRecovery() bool {
2293 return m.module.InstallInRecovery()
Jiyong Parkf9332f12018-02-01 00:54:12 +09002294}
2295
Colin Cross90ba5f42019-10-02 11:10:58 -07002296func (m *moduleContext) InstallInRoot() bool {
2297 return m.module.InstallInRoot()
2298}
2299
Colin Cross607d8582019-07-29 16:44:46 -07002300func (m *moduleContext) InstallBypassMake() bool {
2301 return m.module.InstallBypassMake()
2302}
2303
Jiyong Park87788b52020-09-01 12:37:45 +09002304func (m *moduleContext) InstallForceOS() (*OsType, *ArchType) {
Colin Cross6e359402020-02-10 15:29:54 -08002305 return m.module.InstallForceOS()
2306}
2307
Colin Cross70dda7e2019-10-01 22:05:35 -07002308func (m *moduleContext) skipInstall(fullInstallPath InstallPath) bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002309 if m.module.base().commonProperties.SkipInstall {
Colin Cross893d8162017-04-26 17:34:03 -07002310 return true
2311 }
2312
Colin Cross3607f212018-05-07 15:28:05 -07002313 // We'll need a solution for choosing which of modules with the same name in different
2314 // namespaces to install. For now, reuse the list of namespaces exported to Make as the
2315 // list of namespaces to install in a Soong-only build.
Colin Cross25de6c32019-06-06 14:29:25 -07002316 if !m.module.base().commonProperties.NamespaceExportedToMake {
Colin Cross3607f212018-05-07 15:28:05 -07002317 return true
2318 }
2319
Colin Cross25de6c32019-06-06 14:29:25 -07002320 if m.Device() {
Colin Cross607d8582019-07-29 16:44:46 -07002321 if m.Config().EmbeddedInMake() && !m.InstallBypassMake() {
Colin Cross893d8162017-04-26 17:34:03 -07002322 return true
2323 }
2324
Colin Cross25de6c32019-06-06 14:29:25 -07002325 if m.Config().SkipMegaDeviceInstall(fullInstallPath.String()) {
Colin Cross893d8162017-04-26 17:34:03 -07002326 return true
2327 }
2328 }
2329
2330 return false
2331}
2332
Colin Cross70dda7e2019-10-01 22:05:35 -07002333func (m *moduleContext) InstallFile(installPath InstallPath, name string, srcPath Path,
2334 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002335 return m.installFile(installPath, name, srcPath, Cp, deps)
Colin Cross5c517922017-08-31 12:29:17 -07002336}
2337
Colin Cross70dda7e2019-10-01 22:05:35 -07002338func (m *moduleContext) InstallExecutable(installPath InstallPath, name string, srcPath Path,
2339 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002340 return m.installFile(installPath, name, srcPath, CpExecutable, deps)
Colin Cross5c517922017-08-31 12:29:17 -07002341}
2342
Colin Cross70dda7e2019-10-01 22:05:35 -07002343func (m *moduleContext) installFile(installPath InstallPath, name string, srcPath Path,
2344 rule blueprint.Rule, deps []Path) InstallPath {
Colin Cross35cec122015-04-02 14:37:16 -07002345
Colin Cross25de6c32019-06-06 14:29:25 -07002346 fullInstallPath := installPath.Join(m, name)
David Srbecky07656412020-06-04 01:26:16 +01002347 m.module.base().hooks.runInstallHooks(m, srcPath, fullInstallPath, false)
Colin Cross3f40fa42015-01-30 17:27:36 -08002348
Colin Cross25de6c32019-06-06 14:29:25 -07002349 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07002350
Colin Cross897266e2020-02-13 13:22:08 -08002351 deps = append(deps, m.installDeps.Paths()...)
Colin Cross35cec122015-04-02 14:37:16 -07002352
Colin Cross89562dc2016-10-03 17:47:19 -07002353 var implicitDeps, orderOnlyDeps Paths
2354
Colin Cross25de6c32019-06-06 14:29:25 -07002355 if m.Host() {
Colin Cross89562dc2016-10-03 17:47:19 -07002356 // Installed host modules might be used during the build, depend directly on their
2357 // dependencies so their timestamp is updated whenever their dependency is updated
2358 implicitDeps = deps
2359 } else {
2360 orderOnlyDeps = deps
2361 }
2362
Colin Cross25de6c32019-06-06 14:29:25 -07002363 m.Build(pctx, BuildParams{
Colin Cross5c517922017-08-31 12:29:17 -07002364 Rule: rule,
Colin Cross67a5c132017-05-09 13:45:28 -07002365 Description: "install " + fullInstallPath.Base(),
2366 Output: fullInstallPath,
2367 Input: srcPath,
2368 Implicits: implicitDeps,
2369 OrderOnly: orderOnlyDeps,
Colin Cross25de6c32019-06-06 14:29:25 -07002370 Default: !m.Config().EmbeddedInMake(),
Dan Willemsen322acaf2016-01-12 23:07:05 -08002371 })
Colin Cross3f40fa42015-01-30 17:27:36 -08002372
Colin Cross25de6c32019-06-06 14:29:25 -07002373 m.installFiles = append(m.installFiles, fullInstallPath)
Dan Willemsen322acaf2016-01-12 23:07:05 -08002374 }
Colin Cross25de6c32019-06-06 14:29:25 -07002375 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross35cec122015-04-02 14:37:16 -07002376 return fullInstallPath
2377}
2378
Colin Cross70dda7e2019-10-01 22:05:35 -07002379func (m *moduleContext) InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002380 fullInstallPath := installPath.Join(m, name)
David Srbecky07656412020-06-04 01:26:16 +01002381 m.module.base().hooks.runInstallHooks(m, srcPath, fullInstallPath, true)
Colin Cross3854a602016-01-11 12:49:11 -08002382
Colin Cross25de6c32019-06-06 14:29:25 -07002383 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07002384
Alex Lightfb4353d2019-01-17 13:57:45 -08002385 relPath, err := filepath.Rel(path.Dir(fullInstallPath.String()), srcPath.String())
2386 if err != nil {
2387 panic(fmt.Sprintf("Unable to generate symlink between %q and %q: %s", fullInstallPath.Base(), srcPath.Base(), err))
2388 }
Colin Cross25de6c32019-06-06 14:29:25 -07002389 m.Build(pctx, BuildParams{
Colin Cross67a5c132017-05-09 13:45:28 -07002390 Rule: Symlink,
2391 Description: "install symlink " + fullInstallPath.Base(),
2392 Output: fullInstallPath,
Dan Willemsen40efa1c2020-01-14 15:19:52 -08002393 Input: srcPath,
Colin Cross25de6c32019-06-06 14:29:25 -07002394 Default: !m.Config().EmbeddedInMake(),
Colin Cross12fc4972016-01-11 12:49:11 -08002395 Args: map[string]string{
Alex Lightfb4353d2019-01-17 13:57:45 -08002396 "fromPath": relPath,
Colin Cross12fc4972016-01-11 12:49:11 -08002397 },
2398 })
Colin Cross3854a602016-01-11 12:49:11 -08002399
Colin Cross25de6c32019-06-06 14:29:25 -07002400 m.installFiles = append(m.installFiles, fullInstallPath)
2401 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross12fc4972016-01-11 12:49:11 -08002402 }
Colin Cross3854a602016-01-11 12:49:11 -08002403 return fullInstallPath
2404}
2405
Jiyong Parkf1194352019-02-25 11:05:47 +09002406// installPath/name -> absPath where absPath might be a path that is available only at runtime
2407// (e.g. /apex/...)
Colin Cross70dda7e2019-10-01 22:05:35 -07002408func (m *moduleContext) InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002409 fullInstallPath := installPath.Join(m, name)
David Srbecky07656412020-06-04 01:26:16 +01002410 m.module.base().hooks.runInstallHooks(m, nil, fullInstallPath, true)
Jiyong Parkf1194352019-02-25 11:05:47 +09002411
Colin Cross25de6c32019-06-06 14:29:25 -07002412 if !m.skipInstall(fullInstallPath) {
2413 m.Build(pctx, BuildParams{
Jiyong Parkf1194352019-02-25 11:05:47 +09002414 Rule: Symlink,
2415 Description: "install symlink " + fullInstallPath.Base() + " -> " + absPath,
2416 Output: fullInstallPath,
Colin Cross25de6c32019-06-06 14:29:25 -07002417 Default: !m.Config().EmbeddedInMake(),
Jiyong Parkf1194352019-02-25 11:05:47 +09002418 Args: map[string]string{
2419 "fromPath": absPath,
2420 },
2421 })
2422
Colin Cross25de6c32019-06-06 14:29:25 -07002423 m.installFiles = append(m.installFiles, fullInstallPath)
Jiyong Parkf1194352019-02-25 11:05:47 +09002424 }
2425 return fullInstallPath
2426}
2427
Colin Cross25de6c32019-06-06 14:29:25 -07002428func (m *moduleContext) CheckbuildFile(srcPath Path) {
2429 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross3f40fa42015-01-30 17:27:36 -08002430}
2431
Colin Cross41955e82019-05-29 14:40:35 -07002432// SrcIsModule decodes module references in the format ":name" into the module name, or empty string if the input
2433// was not a module reference.
2434func SrcIsModule(s string) (module string) {
Colin Cross068e0fe2016-12-13 15:23:47 -08002435 if len(s) > 1 && s[0] == ':' {
2436 return s[1:]
2437 }
2438 return ""
2439}
2440
Colin Cross41955e82019-05-29 14:40:35 -07002441// SrcIsModule decodes module references in the format ":name{.tag}" into the module name and tag, ":name" into the
2442// module name and an empty string for the tag, or empty strings if the input was not a module reference.
2443func SrcIsModuleWithTag(s string) (module, tag string) {
2444 if len(s) > 1 && s[0] == ':' {
2445 module = s[1:]
2446 if tagStart := strings.IndexByte(module, '{'); tagStart > 0 {
2447 if module[len(module)-1] == '}' {
2448 tag = module[tagStart+1 : len(module)-1]
2449 module = module[:tagStart]
2450 return module, tag
2451 }
2452 }
2453 return module, ""
2454 }
2455 return "", ""
Colin Cross068e0fe2016-12-13 15:23:47 -08002456}
2457
Colin Cross41955e82019-05-29 14:40:35 -07002458type sourceOrOutputDependencyTag struct {
2459 blueprint.BaseDependencyTag
2460 tag string
2461}
2462
2463func sourceOrOutputDepTag(tag string) blueprint.DependencyTag {
2464 return sourceOrOutputDependencyTag{tag: tag}
2465}
2466
2467var SourceDepTag = sourceOrOutputDepTag("")
Colin Cross068e0fe2016-12-13 15:23:47 -08002468
Colin Cross366938f2017-12-11 16:29:02 -08002469// Adds necessary dependencies to satisfy filegroup or generated sources modules listed in srcFiles
2470// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002471//
2472// Deprecated: tag the property with `android:"path"` instead.
Colin Cross068e0fe2016-12-13 15:23:47 -08002473func ExtractSourcesDeps(ctx BottomUpMutatorContext, srcFiles []string) {
Nan Zhang2439eb72017-04-10 11:27:50 -07002474 set := make(map[string]bool)
2475
Colin Cross068e0fe2016-12-13 15:23:47 -08002476 for _, s := range srcFiles {
Colin Cross41955e82019-05-29 14:40:35 -07002477 if m, t := SrcIsModuleWithTag(s); m != "" {
2478 if _, found := set[s]; found {
2479 ctx.ModuleErrorf("found source dependency duplicate: %q!", s)
Nan Zhang2439eb72017-04-10 11:27:50 -07002480 } else {
Colin Cross41955e82019-05-29 14:40:35 -07002481 set[s] = true
2482 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Nan Zhang2439eb72017-04-10 11:27:50 -07002483 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002484 }
2485 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002486}
2487
Colin Cross366938f2017-12-11 16:29:02 -08002488// Adds necessary dependencies to satisfy filegroup or generated sources modules specified in s
2489// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002490//
2491// Deprecated: tag the property with `android:"path"` instead.
Colin Cross366938f2017-12-11 16:29:02 -08002492func ExtractSourceDeps(ctx BottomUpMutatorContext, s *string) {
2493 if s != nil {
Colin Cross41955e82019-05-29 14:40:35 -07002494 if m, t := SrcIsModuleWithTag(*s); m != "" {
2495 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Colin Cross366938f2017-12-11 16:29:02 -08002496 }
2497 }
2498}
2499
Colin Cross41955e82019-05-29 14:40:35 -07002500// A module that implements SourceFileProducer can be referenced from any property that is tagged with `android:"path"`
2501// 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 -08002502type SourceFileProducer interface {
2503 Srcs() Paths
2504}
2505
Colin Cross41955e82019-05-29 14:40:35 -07002506// A module that implements OutputFileProducer can be referenced from any property that is tagged with `android:"path"`
Roland Levillain97c1f342019-11-22 14:20:54 +00002507// 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 -07002508// listed in the property.
2509type OutputFileProducer interface {
2510 OutputFiles(tag string) (Paths, error)
2511}
2512
Colin Cross5e708052019-08-06 13:59:50 -07002513// OutputFilesForModule returns the paths from an OutputFileProducer with the given tag. On error, including if the
2514// module produced zero paths, it reports errors to the ctx and returns nil.
2515func OutputFilesForModule(ctx PathContext, module blueprint.Module, tag string) Paths {
2516 paths, err := outputFilesForModule(ctx, module, tag)
2517 if err != nil {
2518 reportPathError(ctx, err)
2519 return nil
2520 }
2521 return paths
2522}
2523
2524// OutputFileForModule returns the path from an OutputFileProducer with the given tag. On error, including if the
2525// module produced zero or multiple paths, it reports errors to the ctx and returns nil.
2526func OutputFileForModule(ctx PathContext, module blueprint.Module, tag string) Path {
2527 paths, err := outputFilesForModule(ctx, module, tag)
2528 if err != nil {
2529 reportPathError(ctx, err)
2530 return nil
2531 }
2532 if len(paths) > 1 {
Ulya Trafimovich5ab276a2020-08-25 12:45:15 +01002533 ReportPathErrorf(ctx, "got multiple output files from module %q, expected exactly one",
Colin Cross5e708052019-08-06 13:59:50 -07002534 pathContextName(ctx, module))
2535 return nil
2536 }
2537 return paths[0]
2538}
2539
2540func outputFilesForModule(ctx PathContext, module blueprint.Module, tag string) (Paths, error) {
2541 if outputFileProducer, ok := module.(OutputFileProducer); ok {
2542 paths, err := outputFileProducer.OutputFiles(tag)
2543 if err != nil {
2544 return nil, fmt.Errorf("failed to get output file from module %q: %s",
2545 pathContextName(ctx, module), err.Error())
2546 }
2547 if len(paths) == 0 {
2548 return nil, fmt.Errorf("failed to get output files from module %q", pathContextName(ctx, module))
2549 }
2550 return paths, nil
2551 } else {
2552 return nil, fmt.Errorf("module %q is not an OutputFileProducer", pathContextName(ctx, module))
2553 }
2554}
2555
Colin Crossfe17f6f2019-03-28 19:30:56 -07002556type HostToolProvider interface {
2557 HostToolPath() OptionalPath
2558}
2559
Colin Cross27b922f2019-03-04 22:35:41 -08002560// Returns a list of paths expanded from globs and modules referenced using ":module" syntax. The property must
2561// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002562//
2563// Deprecated: use PathsForModuleSrc or PathsForModuleSrcExcludes instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002564func (m *moduleContext) ExpandSources(srcFiles, excludes []string) Paths {
2565 return PathsForModuleSrcExcludes(m, srcFiles, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07002566}
2567
Colin Cross2fafa3e2019-03-05 12:39:51 -08002568// Returns a single path expanded from globs and modules referenced using ":module" syntax. The property must
2569// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002570//
2571// Deprecated: use PathForModuleSrc instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002572func (m *moduleContext) ExpandSource(srcFile, prop string) Path {
2573 return PathForModuleSrc(m, srcFile)
Colin Cross2fafa3e2019-03-05 12:39:51 -08002574}
2575
2576// Returns an optional single path expanded from globs and modules referenced using ":module" syntax if
2577// the srcFile is non-nil. The property must be tagged with `android:"path" to support automatic source module
2578// dependency resolution.
Colin Cross25de6c32019-06-06 14:29:25 -07002579func (m *moduleContext) ExpandOptionalSource(srcFile *string, prop string) OptionalPath {
Colin Cross2fafa3e2019-03-05 12:39:51 -08002580 if srcFile != nil {
Colin Cross25de6c32019-06-06 14:29:25 -07002581 return OptionalPathForPath(PathForModuleSrc(m, *srcFile))
Colin Cross2fafa3e2019-03-05 12:39:51 -08002582 }
2583 return OptionalPath{}
2584}
2585
Colin Cross25de6c32019-06-06 14:29:25 -07002586func (m *moduleContext) RequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002587 return m.module.RequiredModuleNames()
Nan Zhang6d34b302017-02-04 17:47:46 -08002588}
2589
Colin Cross25de6c32019-06-06 14:29:25 -07002590func (m *moduleContext) HostRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002591 return m.module.HostRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002592}
2593
Colin Cross25de6c32019-06-06 14:29:25 -07002594func (m *moduleContext) TargetRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002595 return m.module.TargetRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002596}
2597
Colin Cross463a90e2015-06-17 14:20:06 -07002598func init() {
Colin Cross798bfce2016-10-12 14:28:16 -07002599 RegisterSingletonType("buildtarget", BuildTargetSingleton)
Colin Cross463a90e2015-06-17 14:20:06 -07002600}
2601
Colin Cross0875c522017-11-28 17:34:01 -08002602func BuildTargetSingleton() Singleton {
Colin Cross1f8c52b2015-06-16 16:38:17 -07002603 return &buildTargetSingleton{}
2604}
2605
Colin Cross87d8b562017-04-25 10:01:55 -07002606func parentDir(dir string) string {
2607 dir, _ = filepath.Split(dir)
2608 return filepath.Clean(dir)
2609}
2610
Colin Cross1f8c52b2015-06-16 16:38:17 -07002611type buildTargetSingleton struct{}
2612
Colin Cross0875c522017-11-28 17:34:01 -08002613func (c *buildTargetSingleton) GenerateBuildActions(ctx SingletonContext) {
2614 var checkbuildDeps Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07002615
Colin Crossc3d87d32020-06-04 13:25:17 -07002616 mmTarget := func(dir string) string {
2617 return "MODULES-IN-" + strings.Replace(filepath.Clean(dir), "/", "-", -1)
Colin Cross87d8b562017-04-25 10:01:55 -07002618 }
2619
Colin Cross0875c522017-11-28 17:34:01 -08002620 modulesInDir := make(map[string]Paths)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002621
Colin Cross0875c522017-11-28 17:34:01 -08002622 ctx.VisitAllModules(func(module Module) {
2623 blueprintDir := module.base().blueprintDir
2624 installTarget := module.base().installTarget
2625 checkbuildTarget := module.base().checkbuildTarget
Colin Cross1f8c52b2015-06-16 16:38:17 -07002626
Colin Cross0875c522017-11-28 17:34:01 -08002627 if checkbuildTarget != nil {
2628 checkbuildDeps = append(checkbuildDeps, checkbuildTarget)
2629 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], checkbuildTarget)
2630 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002631
Colin Cross0875c522017-11-28 17:34:01 -08002632 if installTarget != nil {
2633 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], installTarget)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002634 }
2635 })
2636
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002637 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08002638 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002639 suffix = "-soong"
2640 }
2641
Colin Cross1f8c52b2015-06-16 16:38:17 -07002642 // Create a top-level checkbuild target that depends on all modules
Colin Crossc3d87d32020-06-04 13:25:17 -07002643 ctx.Phony("checkbuild"+suffix, checkbuildDeps...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002644
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002645 // Make will generate the MODULES-IN-* targets
Colin Crossaabf6792017-11-29 00:27:14 -08002646 if ctx.Config().EmbeddedInMake() {
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002647 return
2648 }
2649
Colin Cross87d8b562017-04-25 10:01:55 -07002650 // Ensure ancestor directories are in modulesInDir
Inseob Kim1a365c62019-06-08 15:47:51 +09002651 dirs := SortedStringKeys(modulesInDir)
Colin Cross87d8b562017-04-25 10:01:55 -07002652 for _, dir := range dirs {
2653 dir := parentDir(dir)
2654 for dir != "." && dir != "/" {
2655 if _, exists := modulesInDir[dir]; exists {
2656 break
2657 }
2658 modulesInDir[dir] = nil
2659 dir = parentDir(dir)
2660 }
2661 }
2662
2663 // Make directories build their direct subdirectories
Colin Cross87d8b562017-04-25 10:01:55 -07002664 for _, dir := range dirs {
2665 p := parentDir(dir)
2666 if p != "." && p != "/" {
Colin Crossc3d87d32020-06-04 13:25:17 -07002667 modulesInDir[p] = append(modulesInDir[p], PathForPhony(ctx, mmTarget(dir)))
Colin Cross87d8b562017-04-25 10:01:55 -07002668 }
2669 }
2670
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002671 // Create a MODULES-IN-<directory> target that depends on all modules in a directory, and
2672 // depends on the MODULES-IN-* targets of all of its subdirectories that contain Android.bp
2673 // files.
Colin Cross1f8c52b2015-06-16 16:38:17 -07002674 for _, dir := range dirs {
Colin Crossc3d87d32020-06-04 13:25:17 -07002675 ctx.Phony(mmTarget(dir), modulesInDir[dir]...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002676 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002677
2678 // Create (host|host-cross|target)-<OS> phony rules to build a reduced checkbuild.
Jiyong Park1613e552020-09-14 19:43:17 +09002679 type osAndCross struct {
2680 os OsType
2681 hostCross bool
2682 }
2683 osDeps := map[osAndCross]Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08002684 ctx.VisitAllModules(func(module Module) {
2685 if module.Enabled() {
Jiyong Park1613e552020-09-14 19:43:17 +09002686 key := osAndCross{os: module.Target().Os, hostCross: module.Target().HostCross}
2687 osDeps[key] = append(osDeps[key], module.base().checkbuildFiles...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002688 }
2689 })
2690
Colin Cross0875c522017-11-28 17:34:01 -08002691 osClass := make(map[string]Paths)
Jiyong Park1613e552020-09-14 19:43:17 +09002692 for key, deps := range osDeps {
Dan Willemsen61d88b82017-09-20 17:29:08 -07002693 var className string
2694
Jiyong Park1613e552020-09-14 19:43:17 +09002695 switch key.os.Class {
Dan Willemsen61d88b82017-09-20 17:29:08 -07002696 case Host:
Jiyong Park1613e552020-09-14 19:43:17 +09002697 if key.hostCross {
2698 className = "host-cross"
2699 } else {
2700 className = "host"
2701 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002702 case Device:
2703 className = "target"
2704 default:
2705 continue
2706 }
2707
Jiyong Park1613e552020-09-14 19:43:17 +09002708 name := className + "-" + key.os.Name
Colin Crossc3d87d32020-06-04 13:25:17 -07002709 osClass[className] = append(osClass[className], PathForPhony(ctx, name))
Dan Willemsen61d88b82017-09-20 17:29:08 -07002710
Colin Crossc3d87d32020-06-04 13:25:17 -07002711 ctx.Phony(name, deps...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002712 }
2713
2714 // Wrap those into host|host-cross|target phony rules
Inseob Kim1a365c62019-06-08 15:47:51 +09002715 for _, class := range SortedStringKeys(osClass) {
Colin Crossc3d87d32020-06-04 13:25:17 -07002716 ctx.Phony(class, osClass[class]...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002717 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002718}
Colin Crossd779da42015-12-17 18:00:23 -08002719
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002720// Collect information for opening IDE project files in java/jdeps.go.
2721type IDEInfo interface {
2722 IDEInfo(ideInfo *IdeInfo)
2723 BaseModuleName() string
2724}
2725
2726// Extract the base module name from the Import name.
2727// Often the Import name has a prefix "prebuilt_".
2728// Remove the prefix explicitly if needed
2729// until we find a better solution to get the Import name.
2730type IDECustomizedModuleName interface {
2731 IDECustomizedModuleName() string
2732}
2733
2734type IdeInfo struct {
2735 Deps []string `json:"dependencies,omitempty"`
2736 Srcs []string `json:"srcs,omitempty"`
2737 Aidl_include_dirs []string `json:"aidl_include_dirs,omitempty"`
2738 Jarjar_rules []string `json:"jarjar_rules,omitempty"`
2739 Jars []string `json:"jars,omitempty"`
2740 Classes []string `json:"class,omitempty"`
2741 Installed_paths []string `json:"installed,omitempty"`
patricktu18c82ff2019-05-10 15:48:50 +08002742 SrcJars []string `json:"srcjars,omitempty"`
bralee1fbf4402020-05-21 10:11:59 +08002743 Paths []string `json:"path,omitempty"`
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002744}
Paul Duffinf88d8e02020-05-07 20:21:34 +01002745
2746func CheckBlueprintSyntax(ctx BaseModuleContext, filename string, contents string) []error {
2747 bpctx := ctx.blueprintBaseModuleContext()
2748 return blueprint.CheckBlueprintSyntax(bpctx.ModuleFactories(), filename, contents)
2749}