blob: c4e43c219ec3cde0bbd0c62b0cc4b060b7bac61f [file] [log] [blame]
Colin Cross3f40fa42015-01-30 17:27:36 -08001// Copyright 2015 Google Inc. All rights reserved.
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
Colin Cross635c3b02016-05-18 15:37:25 -070015package android
Colin Cross3f40fa42015-01-30 17:27:36 -080016
17import (
Colin Cross6ff51382015-12-17 16:39:19 -080018 "fmt"
Colin Cross988414c2020-01-11 01:11:46 +000019 "os"
Alex Lightfb4353d2019-01-17 13:57:45 -080020 "path"
Colin Cross3f40fa42015-01-30 17:27:36 -080021 "path/filepath"
Jiyong Park1c7e9622020-05-07 16:12:13 +090022 "regexp"
Colin Cross6ff51382015-12-17 16:39:19 -080023 "strings"
Colin Crossaabf6792017-11-29 00:27:14 -080024 "text/scanner"
Colin Crossf6566ed2015-03-24 11:13:38 -070025
26 "github.com/google/blueprint"
Colin Crossfe4bc362018-09-12 10:02:13 -070027 "github.com/google/blueprint/proptools"
Colin Cross3f40fa42015-01-30 17:27:36 -080028)
29
30var (
31 DeviceSharedLibrary = "shared_library"
32 DeviceStaticLibrary = "static_library"
33 DeviceExecutable = "executable"
34 HostSharedLibrary = "host_shared_library"
35 HostStaticLibrary = "host_static_library"
36 HostExecutable = "host_executable"
37)
38
Colin Crossae887032017-10-23 17:16:14 -070039type BuildParams struct {
Dan Willemsen9f3c5742016-11-03 14:28:31 -070040 Rule blueprint.Rule
Colin Cross33bfb0a2016-11-21 17:23:08 -080041 Deps blueprint.Deps
42 Depfile WritablePath
Colin Cross67a5c132017-05-09 13:45:28 -070043 Description string
Dan Willemsen9f3c5742016-11-03 14:28:31 -070044 Output WritablePath
45 Outputs WritablePaths
46 ImplicitOutput WritablePath
47 ImplicitOutputs WritablePaths
48 Input Path
49 Inputs Paths
50 Implicit Path
51 Implicits Paths
52 OrderOnly Paths
Colin Cross824f1162020-07-16 13:07:51 -070053 Validation Path
54 Validations Paths
Dan Willemsen9f3c5742016-11-03 14:28:31 -070055 Default bool
56 Args map[string]string
Dan Willemsen34cc69e2015-09-23 15:26:20 -070057}
58
Colin Crossae887032017-10-23 17:16:14 -070059type ModuleBuildParams BuildParams
60
Colin Cross1184b642019-12-30 18:43:07 -080061// EarlyModuleContext provides methods that can be called early, as soon as the properties have
62// been parsed into the module and before any mutators have run.
63type EarlyModuleContext interface {
Colin Cross9f35c3d2020-09-16 19:04:41 -070064 // Module returns the current module as a Module. It should rarely be necessary, as the module already has a
65 // reference to itself.
Colin Cross1184b642019-12-30 18:43:07 -080066 Module() Module
Colin Cross9f35c3d2020-09-16 19:04:41 -070067
68 // ModuleName returns the name of the module. This is generally the value that was returned by Module.Name() when
69 // the module was created, but may have been modified by calls to BaseMutatorContext.Rename.
Colin Cross1184b642019-12-30 18:43:07 -080070 ModuleName() string
Colin Cross9f35c3d2020-09-16 19:04:41 -070071
72 // ModuleDir returns the path to the directory that contains the definition of the module.
Colin Cross1184b642019-12-30 18:43:07 -080073 ModuleDir() string
Colin Cross9f35c3d2020-09-16 19:04:41 -070074
75 // ModuleType returns the name of the module type that was used to create the module, as specified in
76 // RegisterModuleType.
Colin Cross1184b642019-12-30 18:43:07 -080077 ModuleType() string
Colin Cross9f35c3d2020-09-16 19:04:41 -070078
79 // BlueprintFile returns the name of the blueprint file that contains the definition of this
80 // module.
Colin Cross9d34f352019-11-22 16:03:51 -080081 BlueprintsFile() string
Colin Cross1184b642019-12-30 18:43:07 -080082
Colin Cross9f35c3d2020-09-16 19:04:41 -070083 // ContainsProperty returns true if the specified property name was set in the module definition.
Colin Cross1184b642019-12-30 18:43:07 -080084 ContainsProperty(name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -070085
86 // Errorf reports an error at the specified position of the module definition file.
Colin Cross1184b642019-12-30 18:43:07 -080087 Errorf(pos scanner.Position, fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -070088
89 // ModuleErrorf reports an error at the line number of the module type in the module definition.
Colin Cross1184b642019-12-30 18:43:07 -080090 ModuleErrorf(fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -070091
92 // PropertyErrorf reports an error at the line number of a property in the module definition.
Colin Cross1184b642019-12-30 18:43:07 -080093 PropertyErrorf(property, fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -070094
95 // Failed returns true if any errors have been reported. In most cases the module can continue with generating
96 // build rules after an error, allowing it to report additional errors in a single run, but in cases where the error
97 // has prevented the module from creating necessary data it can return early when Failed returns true.
Colin Cross1184b642019-12-30 18:43:07 -080098 Failed() bool
99
Colin Cross9f35c3d2020-09-16 19:04:41 -0700100 // AddNinjaFileDeps adds dependencies on the specified files to the rule that creates the ninja manifest. The
101 // primary builder will be rerun whenever the specified files are modified.
Colin Cross1184b642019-12-30 18:43:07 -0800102 AddNinjaFileDeps(deps ...string)
103
104 DeviceSpecific() bool
105 SocSpecific() bool
106 ProductSpecific() bool
107 SystemExtSpecific() bool
108 Platform() bool
109
110 Config() Config
111 DeviceConfig() DeviceConfig
112
113 // Deprecated: use Config()
114 AConfig() Config
115
116 // GlobWithDeps returns a list of files that match the specified pattern but do not match any
117 // of the patterns in excludes. It also adds efficient dependencies to rerun the primary
118 // builder whenever a file matching the pattern as added or removed, without rerunning if a
119 // file that does not match the pattern is added to a searched directory.
120 GlobWithDeps(pattern string, excludes []string) ([]string, error)
121
122 Glob(globPattern string, excludes []string) Paths
123 GlobFiles(globPattern string, excludes []string) Paths
Colin Cross988414c2020-01-11 01:11:46 +0000124 IsSymlink(path Path) bool
125 Readlink(path Path) string
Colin Cross133ebef2020-08-14 17:38:45 -0700126
Colin Cross9f35c3d2020-09-16 19:04:41 -0700127 // Namespace returns the Namespace object provided by the NameInterface set by Context.SetNameInterface, or the
128 // default SimpleNameInterface if Context.SetNameInterface was not called.
Colin Cross133ebef2020-08-14 17:38:45 -0700129 Namespace() *Namespace
Colin Cross1184b642019-12-30 18:43:07 -0800130}
131
Colin Cross0ea8ba82019-06-06 14:33:29 -0700132// BaseModuleContext is the same as blueprint.BaseModuleContext except that Config() returns
Colin Crossdc35e212019-06-06 16:13:11 -0700133// a Config instead of an interface{}, and some methods have been wrapped to use an android.Module
134// instead of a blueprint.Module, plus some extra methods that return Android-specific information
Colin Cross0ea8ba82019-06-06 14:33:29 -0700135// about the current module.
136type BaseModuleContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800137 EarlyModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -0700138
Paul Duffinf88d8e02020-05-07 20:21:34 +0100139 blueprintBaseModuleContext() blueprint.BaseModuleContext
140
Colin Cross9f35c3d2020-09-16 19:04:41 -0700141 // OtherModuleName returns the name of another Module. See BaseModuleContext.ModuleName for more information.
142 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Colin Crossdc35e212019-06-06 16:13:11 -0700143 OtherModuleName(m blueprint.Module) string
Colin Cross9f35c3d2020-09-16 19:04:41 -0700144
145 // OtherModuleDir returns the directory of another Module. See BaseModuleContext.ModuleDir for more information.
146 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Colin Crossdc35e212019-06-06 16:13:11 -0700147 OtherModuleDir(m blueprint.Module) string
Colin Cross9f35c3d2020-09-16 19:04:41 -0700148
149 // OtherModuleErrorf reports an error on another Module. See BaseModuleContext.ModuleErrorf for more information.
150 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Colin Crossdc35e212019-06-06 16:13:11 -0700151 OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -0700152
153 // OtherModuleDependencyTag returns the dependency tag used to depend on a module, or nil if there is no dependency
154 // on the module. When called inside a Visit* method with current module being visited, and there are multiple
155 // dependencies on the module being visited, it returns the dependency tag used for the current dependency.
Colin Crossdc35e212019-06-06 16:13:11 -0700156 OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag
Colin Cross9f35c3d2020-09-16 19:04:41 -0700157
158 // OtherModuleExists returns true if a module with the specified name exists, as determined by the NameInterface
159 // passed to Context.SetNameInterface, or SimpleNameInterface if it was not called.
Colin Crossdc35e212019-06-06 16:13:11 -0700160 OtherModuleExists(name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -0700161
162 // OtherModuleDependencyVariantExists returns true if a module with the
163 // specified name and variant exists. The variant must match the given
164 // variations. It must also match all the non-local variations of the current
165 // module. In other words, it checks for the module AddVariationDependencies
166 // would add a dependency on with the same arguments.
Martin Stjernholm009a9dc2020-03-05 17:34:13 +0000167 OtherModuleDependencyVariantExists(variations []blueprint.Variation, name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -0700168
169 // OtherModuleReverseDependencyVariantExists returns true if a module with the
170 // specified name exists with the same variations as the current module. In
171 // other words, it checks for the module AddReverseDependency would add a
172 // dependency on with the same argument.
Martin Stjernholm009a9dc2020-03-05 17:34:13 +0000173 OtherModuleReverseDependencyVariantExists(name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -0700174
175 // OtherModuleType returns the type of another Module. See BaseModuleContext.ModuleType for more information.
176 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Jiyong Park9e6c2422019-08-09 20:39:45 +0900177 OtherModuleType(m blueprint.Module) string
Colin Crossdc35e212019-06-06 16:13:11 -0700178
Colin Crossd27e7b82020-07-02 11:38:17 -0700179 // OtherModuleProvider returns the value for a provider for the given module. If the value is
180 // not set it returns the zero value of the type of the provider, so the return value can always
181 // be type asserted to the type of the provider. The value returned may be a deep copy of the
182 // value originally passed to SetProvider.
183 OtherModuleProvider(m blueprint.Module, provider blueprint.ProviderKey) interface{}
184
185 // OtherModuleHasProvider returns true if the provider for the given module has been set.
186 OtherModuleHasProvider(m blueprint.Module, provider blueprint.ProviderKey) bool
187
188 // Provider returns the value for a provider for the current module. If the value is
189 // not set it returns the zero value of the type of the provider, so the return value can always
190 // be type asserted to the type of the provider. It panics if called before the appropriate
191 // mutator or GenerateBuildActions pass for the provider. The value returned may be a deep
192 // copy of the value originally passed to SetProvider.
193 Provider(provider blueprint.ProviderKey) interface{}
194
195 // HasProvider returns true if the provider for the current module has been set.
196 HasProvider(provider blueprint.ProviderKey) bool
197
198 // SetProvider sets the value for a provider for the current module. It panics if not called
199 // during the appropriate mutator or GenerateBuildActions pass for the provider, if the value
200 // is not of the appropriate type, or if the value has already been set. The value should not
201 // be modified after being passed to SetProvider.
202 SetProvider(provider blueprint.ProviderKey, value interface{})
203
Colin Crossdc35e212019-06-06 16:13:11 -0700204 GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module
Colin Cross9f35c3d2020-09-16 19:04:41 -0700205
206 // GetDirectDepWithTag returns the Module the direct dependency with the specified name, or nil if
207 // none exists. It panics if the dependency does not have the specified tag. It skips any
208 // dependencies that are not an android.Module.
Colin Crossdc35e212019-06-06 16:13:11 -0700209 GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module
Colin Cross9f35c3d2020-09-16 19:04:41 -0700210
211 // GetDirectDep returns the Module and DependencyTag for the direct dependency with the specified
212 // name, or nil if none exists. If there are multiple dependencies on the same module it returns
213 // the first DependencyTag. It skips any dependencies that are not an android.Module.
Colin Crossdc35e212019-06-06 16:13:11 -0700214 GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag)
215
Colin Cross9f35c3d2020-09-16 19:04:41 -0700216 // VisitDirectDepsBlueprint calls visit for each direct dependency. If there are multiple
217 // direct dependencies on the same module visit will be called multiple times on that module
218 // and OtherModuleDependencyTag will return a different tag for each.
219 //
220 // The Module passed to the visit function should not be retained outside of the visit
221 // function, it may be invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700222 VisitDirectDepsBlueprint(visit func(blueprint.Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700223
224 // VisitDirectDeps calls visit for each direct dependency. If there are multiple
225 // direct dependencies on the same module visit will be called multiple times on that module
226 // and OtherModuleDependencyTag will return a different tag for each. It skips any
227 // dependencies that are not an android.Module.
228 //
229 // The Module passed to the visit function should not be retained outside of the visit
230 // function, it may be invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700231 VisitDirectDeps(visit func(Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700232
Colin Crossdc35e212019-06-06 16:13:11 -0700233 VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700234
235 // VisitDirectDepsIf calls pred for each direct dependency, and if pred returns true calls visit. If there are
236 // multiple direct dependencies on the same module pred and visit will be called multiple times on that module and
237 // OtherModuleDependencyTag will return a different tag for each. It skips any
238 // dependencies that are not an android.Module.
239 //
240 // The Module passed to the visit function should not be retained outside of the visit function, it may be
241 // invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700242 VisitDirectDepsIf(pred func(Module) bool, visit func(Module))
243 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
244 VisitDepsDepthFirst(visit func(Module))
245 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
246 VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700247
248 // WalkDeps calls visit for each transitive dependency, traversing the dependency tree in top down order. visit may
249 // be called multiple times for the same (child, parent) pair if there are multiple direct dependencies between the
250 // child and parent with different tags. OtherModuleDependencyTag will return the tag for the currently visited
251 // (child, parent) pair. If visit returns false WalkDeps will not continue recursing down to child. It skips
252 // any dependencies that are not an android.Module.
253 //
254 // The Modules passed to the visit function should not be retained outside of the visit function, they may be
255 // invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700256 WalkDeps(visit func(Module, Module) bool)
Colin Cross9f35c3d2020-09-16 19:04:41 -0700257
258 // WalkDepsBlueprint calls visit for each transitive dependency, traversing the dependency
259 // tree in top down order. visit may be called multiple times for the same (child, parent)
260 // pair if there are multiple direct dependencies between the child and parent with different
261 // tags. OtherModuleDependencyTag will return the tag for the currently visited
262 // (child, parent) pair. If visit returns false WalkDeps will not continue recursing down
263 // to child.
264 //
265 // The Modules passed to the visit function should not be retained outside of the visit function, they may be
266 // invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700267 WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool)
Colin Cross9f35c3d2020-09-16 19:04:41 -0700268
Colin Crossdc35e212019-06-06 16:13:11 -0700269 // GetWalkPath is supposed to be called in visit function passed in WalkDeps()
270 // and returns a top-down dependency path from a start module to current child module.
271 GetWalkPath() []Module
272
Colin Cross4dfacf92020-09-16 19:22:27 -0700273 // PrimaryModule returns the first variant of the current module. Variants of a module are always visited in
274 // order by mutators and GenerateBuildActions, so the data created by the current mutator can be read from the
275 // Module returned by PrimaryModule without data races. This can be used to perform singleton actions that are
276 // only done once for all variants of a module.
277 PrimaryModule() Module
278
279 // FinalModule returns the last variant of the current module. Variants of a module are always visited in
280 // order by mutators and GenerateBuildActions, so the data created by the current mutator can be read from all
281 // variants using VisitAllModuleVariants if the current module == FinalModule(). This can be used to perform
282 // singleton actions that are only done once for all variants of a module.
283 FinalModule() Module
284
285 // VisitAllModuleVariants calls visit for each variant of the current module. Variants of a module are always
286 // visited in order by mutators and GenerateBuildActions, so the data created by the current mutator can be read
287 // from all variants if the current module == FinalModule(). Otherwise, care must be taken to not access any
288 // data modified by the current mutator.
289 VisitAllModuleVariants(visit func(Module))
290
Paul Duffinc5192442020-03-31 11:31:36 +0100291 // GetTagPath is supposed to be called in visit function passed in WalkDeps()
292 // and returns a top-down dependency tags path from a start module to current child module.
293 // It has one less entry than GetWalkPath() as it contains the dependency tags that
294 // exist between each adjacent pair of modules in the GetWalkPath().
295 // GetTagPath()[i] is the tag between GetWalkPath()[i] and GetWalkPath()[i+1]
296 GetTagPath() []blueprint.DependencyTag
297
Jiyong Park1c7e9622020-05-07 16:12:13 +0900298 // GetPathString is supposed to be called in visit function passed in WalkDeps()
299 // and returns a multi-line string showing the modules and dependency tags
300 // among them along the top-down dependency path from a start module to current child module.
301 // skipFirst when set to true, the output doesn't include the start module,
302 // which is already printed when this function is used along with ModuleErrorf().
303 GetPathString(skipFirst bool) string
304
Colin Crossdc35e212019-06-06 16:13:11 -0700305 AddMissingDependencies(missingDeps []string)
306
Colin Crossa1ad8d12016-06-01 17:09:44 -0700307 Target() Target
Colin Cross8b74d172016-09-13 09:59:14 -0700308 TargetPrimary() bool
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000309
310 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
311 // responsible for creating.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700312 MultiTargets() []Target
Colin Crossf6566ed2015-03-24 11:13:38 -0700313 Arch() Arch
Colin Crossa1ad8d12016-06-01 17:09:44 -0700314 Os() OsType
Colin Crossf6566ed2015-03-24 11:13:38 -0700315 Host() bool
316 Device() bool
Colin Cross0af4b842015-04-30 16:36:18 -0700317 Darwin() bool
Doug Horn21b94272019-01-16 12:06:11 -0800318 Fuchsia() bool
Colin Cross3edeee12017-04-04 12:59:48 -0700319 Windows() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700320 Debug() bool
Colin Cross1e7d3702016-08-24 15:25:47 -0700321 PrimaryArch() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700322}
323
Colin Cross1184b642019-12-30 18:43:07 -0800324// Deprecated: use EarlyModuleContext instead
Colin Cross635c3b02016-05-18 15:37:25 -0700325type BaseContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800326 EarlyModuleContext
Colin Crossaabf6792017-11-29 00:27:14 -0800327}
328
Colin Cross635c3b02016-05-18 15:37:25 -0700329type ModuleContext interface {
Colin Crossaabf6792017-11-29 00:27:14 -0800330 BaseModuleContext
Colin Cross3f40fa42015-01-30 17:27:36 -0800331
Colin Crossae887032017-10-23 17:16:14 -0700332 // Deprecated: use ModuleContext.Build instead.
Colin Cross0875c522017-11-28 17:34:01 -0800333 ModuleBuild(pctx PackageContext, params ModuleBuildParams)
Colin Cross8f101b42015-06-17 15:09:06 -0700334
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700335 ExpandSources(srcFiles, excludes []string) Paths
Colin Cross366938f2017-12-11 16:29:02 -0800336 ExpandSource(srcFile, prop string) Path
Colin Cross2383f3b2018-02-06 14:40:13 -0800337 ExpandOptionalSource(srcFile *string, prop string) OptionalPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700338
Colin Cross70dda7e2019-10-01 22:05:35 -0700339 InstallExecutable(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
340 InstallFile(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
341 InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath
342 InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700343 CheckbuildFile(srcPath Path)
Dan Willemsen6553f5e2016-03-10 18:14:25 -0800344
Colin Cross8d8f8e22016-08-03 11:57:50 -0700345 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700346 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700347 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800348 InstallInRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900349 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700350 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700351 InstallBypassMake() bool
Jiyong Park87788b52020-09-01 12:37:45 +0900352 InstallForceOS() (*OsType, *ArchType)
Nan Zhang6d34b302017-02-04 17:47:46 -0800353
354 RequiredModuleNames() []string
Sasha Smundakb6d23052019-04-01 18:37:36 -0700355 HostRequiredModuleNames() []string
356 TargetRequiredModuleNames() []string
Colin Cross3f68a132017-10-23 17:10:29 -0700357
Colin Cross3f68a132017-10-23 17:10:29 -0700358 ModuleSubDir() string
359
Colin Cross0875c522017-11-28 17:34:01 -0800360 Variable(pctx PackageContext, name, value string)
361 Rule(pctx PackageContext, name string, params blueprint.RuleParams, argNames ...string) blueprint.Rule
Colin Crossae887032017-10-23 17:16:14 -0700362 // Similar to blueprint.ModuleContext.Build, but takes Paths instead of []string,
363 // and performs more verification.
Colin Cross0875c522017-11-28 17:34:01 -0800364 Build(pctx PackageContext, params BuildParams)
Colin Crossc3d87d32020-06-04 13:25:17 -0700365 // Phony creates a Make-style phony rule, a rule with no commands that can depend on other
366 // phony rules or real files. Phony can be called on the same name multiple times to add
367 // additional dependencies.
368 Phony(phony string, deps ...Path)
Colin Cross3f68a132017-10-23 17:10:29 -0700369
Colin Cross9f35c3d2020-09-16 19:04:41 -0700370 // GetMissingDependencies returns the list of dependencies that were passed to AddDependencies or related methods,
371 // but do not exist.
Colin Cross3f68a132017-10-23 17:10:29 -0700372 GetMissingDependencies() []string
Colin Cross3f40fa42015-01-30 17:27:36 -0800373}
374
Colin Cross635c3b02016-05-18 15:37:25 -0700375type Module interface {
Colin Cross3f40fa42015-01-30 17:27:36 -0800376 blueprint.Module
377
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700378 // GenerateAndroidBuildActions is analogous to Blueprints' GenerateBuildActions,
379 // but GenerateAndroidBuildActions also has access to Android-specific information.
380 // For more information, see Module.GenerateBuildActions within Blueprint's module_ctx.go
Colin Cross635c3b02016-05-18 15:37:25 -0700381 GenerateAndroidBuildActions(ModuleContext)
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700382
Paul Duffin44f1d842020-06-26 20:17:02 +0100383 // Add dependencies to the components of a module, i.e. modules that are created
384 // by the module and which are considered to be part of the creating module.
385 //
386 // This is called before prebuilts are renamed so as to allow a dependency to be
387 // added directly to a prebuilt child module instead of depending on a source module
388 // and relying on prebuilt processing to switch to the prebuilt module if preferred.
389 //
390 // A dependency on a prebuilt must include the "prebuilt_" prefix.
391 ComponentDepsMutator(ctx BottomUpMutatorContext)
392
Colin Cross1e676be2016-10-12 14:38:15 -0700393 DepsMutator(BottomUpMutatorContext)
Colin Cross3f40fa42015-01-30 17:27:36 -0800394
Colin Cross635c3b02016-05-18 15:37:25 -0700395 base() *ModuleBase
Inseob Kimeec88e12020-01-22 11:11:29 +0900396 Disable()
Dan Willemsen0effe062015-11-30 16:06:01 -0800397 Enabled() bool
Colin Crossa1ad8d12016-06-01 17:09:44 -0700398 Target() Target
Anton Hansson1ee62c02020-06-30 11:51:53 +0100399 Owner() string
Dan Willemsen782a2d12015-12-21 14:55:28 -0800400 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700401 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700402 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800403 InstallInRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900404 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700405 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700406 InstallBypassMake() bool
Jiyong Park87788b52020-09-01 12:37:45 +0900407 InstallForceOS() (*OsType, *ArchType)
Colin Crossa2f296f2016-11-29 15:16:18 -0800408 SkipInstall()
Ulya Trafimovichb28cc372020-01-13 15:18:16 +0000409 IsSkipInstall() bool
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +0100410 MakeUninstallable()
Liz Kammer5ca3a622020-08-05 15:40:41 -0700411 ReplacedByPrebuilt()
412 IsReplacedByPrebuilt() bool
Jiyong Park374510b2018-03-19 18:23:01 +0900413 ExportedToMake() bool
Inseob Kim8471cda2019-11-15 09:59:12 +0900414 InitRc() Paths
415 VintfFragments() Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800416 NoticeFiles() Paths
Colin Cross36242852017-06-23 15:06:31 -0700417
418 AddProperties(props ...interface{})
419 GetProperties() []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700420
Colin Crossae887032017-10-23 17:16:14 -0700421 BuildParamsForTests() []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800422 RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800423 VariablesForTests() map[string]string
Paul Duffine2453c72019-05-31 14:00:04 +0100424
Colin Cross9a362232019-07-01 15:32:45 -0700425 // String returns a string that includes the module name and variants for printing during debugging.
426 String() string
427
Paul Duffine2453c72019-05-31 14:00:04 +0100428 // Get the qualified module id for this module.
429 qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName
430
431 // Get information about the properties that can contain visibility rules.
432 visibilityProperties() []visibilityProperty
Paul Duffin63c6e182019-07-24 14:24:38 +0100433
Jiyong Park6a8cf5f2019-12-30 16:31:09 +0900434 RequiredModuleNames() []string
435 HostRequiredModuleNames() []string
436 TargetRequiredModuleNames() []string
Colin Cross897266e2020-02-13 13:22:08 -0800437
438 filesToInstall() InstallPaths
Paul Duffine2453c72019-05-31 14:00:04 +0100439}
440
441// Qualified id for a module
442type qualifiedModuleName struct {
443 // The package (i.e. directory) in which the module is defined, without trailing /
444 pkg string
445
446 // The name of the module, empty string if package.
447 name string
448}
449
450func (q qualifiedModuleName) String() string {
451 if q.name == "" {
452 return "//" + q.pkg
453 }
454 return "//" + q.pkg + ":" + q.name
455}
456
Paul Duffine484f472019-06-20 16:38:08 +0100457func (q qualifiedModuleName) isRootPackage() bool {
458 return q.pkg == "" && q.name == ""
459}
460
Paul Duffine2453c72019-05-31 14:00:04 +0100461// Get the id for the package containing this module.
462func (q qualifiedModuleName) getContainingPackageId() qualifiedModuleName {
463 pkg := q.pkg
464 if q.name == "" {
Paul Duffine484f472019-06-20 16:38:08 +0100465 if pkg == "" {
466 panic(fmt.Errorf("Cannot get containing package id of root package"))
467 }
468
469 index := strings.LastIndex(pkg, "/")
470 if index == -1 {
471 pkg = ""
472 } else {
473 pkg = pkg[:index]
474 }
Paul Duffine2453c72019-05-31 14:00:04 +0100475 }
476 return newPackageId(pkg)
477}
478
479func newPackageId(pkg string) qualifiedModuleName {
480 // A qualified id for a package module has no name.
481 return qualifiedModuleName{pkg: pkg, name: ""}
Colin Cross3f40fa42015-01-30 17:27:36 -0800482}
483
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000484type Dist struct {
485 // Copy the output of this module to the $DIST_DIR when `dist` is specified on the
486 // command line and any of these targets are also on the command line, or otherwise
487 // built
488 Targets []string `android:"arch_variant"`
489
490 // The name of the output artifact. This defaults to the basename of the output of
491 // the module.
492 Dest *string `android:"arch_variant"`
493
494 // The directory within the dist directory to store the artifact. Defaults to the
495 // top level directory ("").
496 Dir *string `android:"arch_variant"`
497
498 // A suffix to add to the artifact file name (before any extension).
499 Suffix *string `android:"arch_variant"`
500
501 // A string tag to select the OutputFiles associated with the tag. Defaults to the
502 // the empty "" string.
503 Tag *string `android:"arch_variant"`
504}
505
Colin Crossfc754582016-05-17 16:34:16 -0700506type nameProperties struct {
507 // The name of the module. Must be unique across all modules.
Nan Zhang0007d812017-11-07 10:57:05 -0800508 Name *string
Colin Crossfc754582016-05-17 16:34:16 -0700509}
510
511type commonProperties struct {
Dan Willemsen0effe062015-11-30 16:06:01 -0800512 // emit build rules for this module
Paul Duffin54d9bb72020-02-12 10:20:56 +0000513 //
514 // Disabling a module should only be done for those modules that cannot be built
515 // in the current environment. Modules that can build in the current environment
516 // but are not usually required (e.g. superceded by a prebuilt) should not be
517 // disabled as that will prevent them from being built by the checkbuild target
518 // and so prevent early detection of changes that have broken those modules.
Dan Willemsen0effe062015-11-30 16:06:01 -0800519 Enabled *bool `android:"arch_variant"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800520
Paul Duffin2e61fa62019-03-28 14:10:57 +0000521 // Controls the visibility of this module to other modules. Allowable values are one or more of
522 // these formats:
523 //
524 // ["//visibility:public"]: Anyone can use this module.
525 // ["//visibility:private"]: Only rules in the module's package (not its subpackages) can use
526 // this module.
Paul Duffin51084ff2020-05-05 19:19:22 +0100527 // ["//visibility:override"]: Discards any rules inherited from defaults or a creating module.
528 // Can only be used at the beginning of a list of visibility rules.
Paul Duffin2e61fa62019-03-28 14:10:57 +0000529 // ["//some/package:__pkg__", "//other/package:__pkg__"]: Only modules in some/package and
530 // other/package (defined in some/package/*.bp and other/package/*.bp) have access to
531 // this module. Note that sub-packages do not have access to the rule; for example,
532 // //some/package/foo:bar or //other/package/testing:bla wouldn't have access. __pkg__
533 // is a special module and must be used verbatim. It represents all of the modules in the
534 // package.
535 // ["//project:__subpackages__", "//other:__subpackages__"]: Only modules in packages project
536 // or other or in one of their sub-packages have access to this module. For example,
537 // //project:rule, //project/library:lib or //other/testing/internal:munge are allowed
538 // to depend on this rule (but not //independent:evil)
539 // ["//project"]: This is shorthand for ["//project:__pkg__"]
540 // [":__subpackages__"]: This is shorthand for ["//project:__subpackages__"] where
541 // //project is the module's package. e.g. using [":__subpackages__"] in
542 // packages/apps/Settings/Android.bp is equivalent to
543 // //packages/apps/Settings:__subpackages__.
544 // ["//visibility:legacy_public"]: The default visibility, behaves as //visibility:public
545 // for now. It is an error if it is used in a module.
Paul Duffine2453c72019-05-31 14:00:04 +0100546 //
547 // If a module does not specify the `visibility` property then it uses the
548 // `default_visibility` property of the `package` module in the module's package.
549 //
550 // If the `default_visibility` property is not set for the module's package then
Paul Duffine484f472019-06-20 16:38:08 +0100551 // it will use the `default_visibility` of its closest ancestor package for which
552 // a `default_visibility` property is specified.
553 //
554 // If no `default_visibility` property can be found then the module uses the
555 // global default of `//visibility:legacy_public`.
Paul Duffine2453c72019-05-31 14:00:04 +0100556 //
Paul Duffin95d53b52019-07-24 13:45:05 +0100557 // The `visibility` property has no effect on a defaults module although it does
558 // apply to any non-defaults module that uses it. To set the visibility of a
559 // defaults module, use the `defaults_visibility` property on the defaults module;
560 // not to be confused with the `default_visibility` property on the package module.
561 //
Paul Duffin2e61fa62019-03-28 14:10:57 +0000562 // See https://android.googlesource.com/platform/build/soong/+/master/README.md#visibility for
563 // more details.
564 Visibility []string
565
Colin Cross7d5136f2015-05-11 13:39:40 -0700566 // control whether this module compiles for 32-bit, 64-bit, or both. Possible values
Colin Cross3f40fa42015-01-30 17:27:36 -0800567 // are "32" (compile for 32-bit only), "64" (compile for 64-bit only), "both" (compile for both
568 // 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 +0000569 // platform).
Colin Cross7d716ba2017-11-01 10:38:29 -0700570 Compile_multilib *string `android:"arch_variant"`
Colin Cross69617d32016-09-06 10:39:07 -0700571
572 Target struct {
573 Host struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700574 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700575 }
576 Android struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700577 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700578 }
579 }
580
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000581 // If set to true then the archMutator will create variants for each arch specific target
582 // (e.g. 32/64) that the module is required to produce. If set to false then it will only
583 // create a variant for the architecture and will list the additional arch specific targets
584 // that the variant needs to produce in the CompileMultiTargets property.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700585 UseTargetVariants bool `blueprint:"mutated"`
586 Default_multilib string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800587
Dan Willemsen782a2d12015-12-21 14:55:28 -0800588 // whether this is a proprietary vendor module, and should be installed into /vendor
Colin Cross7d716ba2017-11-01 10:38:29 -0700589 Proprietary *bool
Dan Willemsen782a2d12015-12-21 14:55:28 -0800590
Colin Cross55708f32017-03-20 13:23:34 -0700591 // vendor who owns this module
Dan Willemsenefac4a82017-07-18 19:42:09 -0700592 Owner *string
Colin Cross55708f32017-03-20 13:23:34 -0700593
Jiyong Park2db76922017-11-08 16:03:48 +0900594 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
595 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
596 // Use `soc_specific` instead for better meaning.
Colin Cross7d716ba2017-11-01 10:38:29 -0700597 Vendor *bool
Dan Willemsenaa118f92017-04-06 12:49:58 -0700598
Jiyong Park2db76922017-11-08 16:03:48 +0900599 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
600 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
601 Soc_specific *bool
602
603 // whether this module is specific to a device, not only for SoC, but also for off-chip
604 // peripherals. When set to true, it is installed into /odm (or /vendor/odm if odm partition
605 // does not exist, or /system/vendor/odm if both odm and vendor partitions do not exist).
606 // This implies `soc_specific:true`.
607 Device_specific *bool
608
609 // whether this module is specific to a software configuration of a product (e.g. country,
Jaekyun Seok5cfbfbb2018-01-10 19:00:15 +0900610 // network operator, etc). When set to true, it is installed into /product (or
611 // /system/product if product partition does not exist).
Jiyong Park2db76922017-11-08 16:03:48 +0900612 Product_specific *bool
613
Justin Yund5f6c822019-06-25 16:47:17 +0900614 // whether this module extends system. When set to true, it is installed into /system_ext
615 // (or /system/system_ext if system_ext partition does not exist).
616 System_ext_specific *bool
617
Jiyong Parkf9332f12018-02-01 00:54:12 +0900618 // Whether this module is installed to recovery partition
619 Recovery *bool
620
Yifan Hong1b3348d2020-01-21 15:53:22 -0800621 // Whether this module is installed to ramdisk
622 Ramdisk *bool
623
dimitry1f33e402019-03-26 12:39:31 +0100624 // Whether this module is built for non-native architecures (also known as native bridge binary)
625 Native_bridge_supported *bool `android:"arch_variant"`
626
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700627 // init.rc files to be installed if this module is installed
Colin Cross0bab8772020-09-25 14:01:21 -0700628 Init_rc []string `android:"arch_variant,path"`
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700629
Steven Moreland57a23d22018-04-04 15:42:19 -0700630 // VINTF manifest fragments to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800631 Vintf_fragments []string `android:"path"`
Steven Moreland57a23d22018-04-04 15:42:19 -0700632
Chris Wolfe998306e2016-08-15 14:47:23 -0400633 // names of other modules to install if this module is installed
Colin Crossc602b7d2017-05-05 13:36:36 -0700634 Required []string `android:"arch_variant"`
Chris Wolfe998306e2016-08-15 14:47:23 -0400635
Sasha Smundakb6d23052019-04-01 18:37:36 -0700636 // names of other modules to install on host if this module is installed
637 Host_required []string `android:"arch_variant"`
638
639 // names of other modules to install on target if this module is installed
640 Target_required []string `android:"arch_variant"`
641
Colin Cross5aac3622017-08-31 15:07:09 -0700642 // relative path to a file to include in the list of notices for the device
Colin Cross27b922f2019-03-04 22:35:41 -0800643 Notice *string `android:"path"`
Colin Cross5aac3622017-08-31 15:07:09 -0700644
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000645 // The OsType of artifacts that this module variant is responsible for creating.
646 //
647 // Set by osMutator
648 CompileOS OsType `blueprint:"mutated"`
649
650 // The Target of artifacts that this module variant is responsible for creating.
651 //
652 // Set by archMutator
653 CompileTarget Target `blueprint:"mutated"`
654
655 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
656 // responsible for creating.
657 //
658 // By default this is nil as, where necessary, separate variants are created for the
659 // different multilib types supported and that information is encapsulated in the
660 // CompileTarget so the module variant simply needs to create artifacts for that.
661 //
662 // However, if UseTargetVariants is set to false (e.g. by
663 // InitAndroidMultiTargetsArchModule) then no separate variants are created for the
664 // multilib targets. Instead a single variant is created for the architecture and
665 // this contains the multilib specific targets that this variant should create.
666 //
667 // Set by archMutator
Colin Crossee0bc3b2018-10-02 22:01:37 -0700668 CompileMultiTargets []Target `blueprint:"mutated"`
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000669
670 // True if the module variant's CompileTarget is the primary target
671 //
672 // Set by archMutator
673 CompilePrimary bool `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800674
675 // Set by InitAndroidModule
676 HostOrDeviceSupported HostOrDeviceSupported `blueprint:"mutated"`
Dan Willemsen0b24c742016-10-04 15:13:37 -0700677 ArchSpecific bool `blueprint:"mutated"`
Colin Crossce75d2c2016-10-06 16:12:58 -0700678
Paul Duffin1356d8c2020-02-25 19:26:33 +0000679 // If set to true then a CommonOS variant will be created which will have dependencies
680 // on all its OsType specific variants. Used by sdk/module_exports to create a snapshot
681 // that covers all os and architecture variants.
682 //
683 // The OsType specific variants can be retrieved by calling
684 // GetOsSpecificVariantsOfCommonOSVariant
685 //
686 // Set at module initialization time by calling InitCommonOSAndroidMultiTargetsArchModule
687 CreateCommonOSVariant bool `blueprint:"mutated"`
688
689 // If set to true then this variant is the CommonOS variant that has dependencies on its
690 // OsType specific variants.
691 //
692 // Set by osMutator.
693 CommonOSVariant bool `blueprint:"mutated"`
694
Colin Crossce75d2c2016-10-06 16:12:58 -0700695 SkipInstall bool `blueprint:"mutated"`
Jeff Gaston088e29e2017-11-29 16:47:17 -0800696
Liz Kammer5ca3a622020-08-05 15:40:41 -0700697 // Whether the module has been replaced by a prebuilt
698 ReplacedByPrebuilt bool `blueprint:"mutated"`
699
Justin Yun32f053b2020-07-31 23:07:17 +0900700 // Disabled by mutators. If set to true, it overrides Enabled property.
701 ForcedDisabled bool `blueprint:"mutated"`
702
Jeff Gaston088e29e2017-11-29 16:47:17 -0800703 NamespaceExportedToMake bool `blueprint:"mutated"`
Colin Cross6c4f21f2019-06-06 15:41:36 -0700704
705 MissingDeps []string `blueprint:"mutated"`
Colin Cross9a362232019-07-01 15:32:45 -0700706
707 // Name and variant strings stored by mutators to enable Module.String()
708 DebugName string `blueprint:"mutated"`
709 DebugMutators []string `blueprint:"mutated"`
710 DebugVariations []string `blueprint:"mutated"`
Colin Cross7228ecd2019-11-18 16:00:16 -0800711
712 // set by ImageMutator
713 ImageVariation string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800714}
715
Paul Duffined875132020-09-02 13:08:57 +0100716type distProperties struct {
717 // configuration to distribute output files from this module to the distribution
718 // directory (default: $OUT/dist, configurable with $DIST_DIR)
719 Dist Dist `android:"arch_variant"`
720
721 // a list of configurations to distribute output files from this module to the
722 // distribution directory (default: $OUT/dist, configurable with $DIST_DIR)
723 Dists []Dist `android:"arch_variant"`
724}
725
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000726// A map of OutputFile tag keys to Paths, for disting purposes.
727type TaggedDistFiles map[string]Paths
728
729func MakeDefaultDistFiles(paths ...Path) TaggedDistFiles {
Jingwen Chen7b27ca72020-07-24 09:13:49 +0000730 for _, path := range paths {
731 if path == nil {
732 panic("The path to a dist file cannot be nil.")
733 }
734 }
735
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000736 // The default OutputFile tag is the empty "" string.
737 return TaggedDistFiles{"": paths}
738}
739
Colin Cross3f40fa42015-01-30 17:27:36 -0800740type hostAndDeviceProperties struct {
Colin Cross4e81d702018-11-09 10:36:55 -0800741 // If set to true, build a variant of the module for the host. Defaults to false.
742 Host_supported *bool
743
744 // If set to true, build a variant of the module for the device. Defaults to true.
Colin Crossa4190c12016-07-12 13:11:25 -0700745 Device_supported *bool
Colin Cross3f40fa42015-01-30 17:27:36 -0800746}
747
Colin Crossc472d572015-03-17 15:06:21 -0700748type Multilib string
749
750const (
Colin Cross6b4a32d2017-12-05 13:42:45 -0800751 MultilibBoth Multilib = "both"
752 MultilibFirst Multilib = "first"
753 MultilibCommon Multilib = "common"
754 MultilibCommonFirst Multilib = "common_first"
755 MultilibDefault Multilib = ""
Colin Crossc472d572015-03-17 15:06:21 -0700756)
757
Colin Crossa1ad8d12016-06-01 17:09:44 -0700758type HostOrDeviceSupported int
759
760const (
761 _ HostOrDeviceSupported = iota
Dan Albert0981b5c2018-08-02 13:46:35 -0700762
763 // Host and HostCross are built by default. Device is not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700764 HostSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700765
766 // Host is built by default. HostCross and Device are not supported.
Dan Albertc6345fb2016-10-20 01:36:11 -0700767 HostSupportedNoCross
Dan Albert0981b5c2018-08-02 13:46:35 -0700768
769 // Device is built by default. Host and HostCross are not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700770 DeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700771
772 // Device is built by default. Host and HostCross are supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700773 HostAndDeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700774
775 // Host, HostCross, and Device are built by default.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700776 HostAndDeviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700777
778 // Nothing is supported. This is not exposed to the user, but used to mark a
779 // host only module as unsupported when the module type is not supported on
780 // the host OS. E.g. benchmarks are supported on Linux but not Darwin.
Dan Willemsen0b24c742016-10-04 15:13:37 -0700781 NeitherHostNorDeviceSupported
Colin Crossa1ad8d12016-06-01 17:09:44 -0700782)
783
Jiyong Park2db76922017-11-08 16:03:48 +0900784type moduleKind int
785
786const (
787 platformModule moduleKind = iota
788 deviceSpecificModule
789 socSpecificModule
790 productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900791 systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900792)
793
794func (k moduleKind) String() string {
795 switch k {
796 case platformModule:
797 return "platform"
798 case deviceSpecificModule:
799 return "device-specific"
800 case socSpecificModule:
801 return "soc-specific"
802 case productSpecificModule:
803 return "product-specific"
Justin Yund5f6c822019-06-25 16:47:17 +0900804 case systemExtSpecificModule:
805 return "systemext-specific"
Jiyong Park2db76922017-11-08 16:03:48 +0900806 default:
807 panic(fmt.Errorf("unknown module kind %d", k))
808 }
809}
810
Colin Cross9d34f352019-11-22 16:03:51 -0800811func initAndroidModuleBase(m Module) {
812 m.base().module = m
813}
814
Colin Cross36242852017-06-23 15:06:31 -0700815func InitAndroidModule(m Module) {
Colin Cross9d34f352019-11-22 16:03:51 -0800816 initAndroidModuleBase(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800817 base := m.base()
Colin Cross5049f022015-03-18 13:28:46 -0700818
Colin Cross36242852017-06-23 15:06:31 -0700819 m.AddProperties(
Colin Crossfc754582016-05-17 16:34:16 -0700820 &base.nameProperties,
Paul Duffined875132020-09-02 13:08:57 +0100821 &base.commonProperties,
822 &base.distProperties)
Colin Cross18c46802019-09-24 22:19:02 -0700823
Colin Crosseabaedd2020-02-06 17:01:55 -0800824 initProductVariableModule(m)
Colin Cross18c46802019-09-24 22:19:02 -0700825
Colin Crossa3a97412019-03-18 12:24:29 -0700826 base.generalProperties = m.GetProperties()
Pirama Arumuga Nainar955dc492018-04-17 14:58:42 -0700827 base.customizableProperties = m.GetProperties()
Paul Duffin63c6e182019-07-24 14:24:38 +0100828
829 // The default_visibility property needs to be checked and parsed by the visibility module during
Paul Duffin5ec73ec2020-05-01 17:52:01 +0100830 // its checking and parsing phases so make it the primary visibility property.
831 setPrimaryVisibilityProperty(m, "visibility", &base.commonProperties.Visibility)
Colin Cross5049f022015-03-18 13:28:46 -0700832}
833
Colin Cross36242852017-06-23 15:06:31 -0700834func InitAndroidArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
835 InitAndroidModule(m)
Colin Cross5049f022015-03-18 13:28:46 -0700836
837 base := m.base()
Colin Cross3f40fa42015-01-30 17:27:36 -0800838 base.commonProperties.HostOrDeviceSupported = hod
Colin Cross69617d32016-09-06 10:39:07 -0700839 base.commonProperties.Default_multilib = string(defaultMultilib)
Dan Willemsen0b24c742016-10-04 15:13:37 -0700840 base.commonProperties.ArchSpecific = true
Colin Crossee0bc3b2018-10-02 22:01:37 -0700841 base.commonProperties.UseTargetVariants = true
Colin Cross3f40fa42015-01-30 17:27:36 -0800842
Dan Willemsen218f6562015-07-08 18:13:11 -0700843 switch hod {
Nan Zhang1a0f09b2017-07-05 10:35:11 -0700844 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Cross36242852017-06-23 15:06:31 -0700845 m.AddProperties(&base.hostAndDeviceProperties)
Colin Cross3f40fa42015-01-30 17:27:36 -0800846 }
847
Colin Cross36242852017-06-23 15:06:31 -0700848 InitArchModule(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800849}
850
Colin Crossee0bc3b2018-10-02 22:01:37 -0700851func InitAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
852 InitAndroidArchModule(m, hod, defaultMultilib)
853 m.base().commonProperties.UseTargetVariants = false
854}
855
Paul Duffin1356d8c2020-02-25 19:26:33 +0000856// As InitAndroidMultiTargetsArchModule except it creates an additional CommonOS variant that
857// has dependencies on all the OsType specific variants.
858func InitCommonOSAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
859 InitAndroidArchModule(m, hod, defaultMultilib)
860 m.base().commonProperties.UseTargetVariants = false
861 m.base().commonProperties.CreateCommonOSVariant = true
862}
863
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800864// A ModuleBase object contains the properties that are common to all Android
Colin Cross3f40fa42015-01-30 17:27:36 -0800865// modules. It should be included as an anonymous field in every module
866// struct definition. InitAndroidModule should then be called from the module's
867// factory function, and the return values from InitAndroidModule should be
868// returned from the factory function.
869//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800870// The ModuleBase type is responsible for implementing the GenerateBuildActions
871// method to support the blueprint.Module interface. This method will then call
872// the module's GenerateAndroidBuildActions method once for each build variant
Colin Cross25de6c32019-06-06 14:29:25 -0700873// that is to be built. GenerateAndroidBuildActions is passed a ModuleContext
874// rather than the usual blueprint.ModuleContext.
875// ModuleContext exposes extra functionality specific to the Android build
Colin Cross3f40fa42015-01-30 17:27:36 -0800876// system including details about the particular build variant that is to be
877// generated.
878//
879// For example:
880//
881// import (
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800882// "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -0800883// )
884//
885// type myModule struct {
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800886// android.ModuleBase
Colin Cross3f40fa42015-01-30 17:27:36 -0800887// properties struct {
888// MyProperty string
889// }
890// }
891//
Colin Cross36242852017-06-23 15:06:31 -0700892// func NewMyModule() android.Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800893// m := &myModule{}
Colin Cross36242852017-06-23 15:06:31 -0700894// m.AddProperties(&m.properties)
895// android.InitAndroidModule(m)
896// return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800897// }
898//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800899// func (m *myModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800900// // Get the CPU architecture for the current build variant.
901// variantArch := ctx.Arch()
902//
903// // ...
904// }
Colin Cross635c3b02016-05-18 15:37:25 -0700905type ModuleBase struct {
Colin Cross3f40fa42015-01-30 17:27:36 -0800906 // Putting the curiously recurring thing pointing to the thing that contains
907 // the thing pattern to good use.
Colin Cross36242852017-06-23 15:06:31 -0700908 // TODO: remove this
Colin Cross635c3b02016-05-18 15:37:25 -0700909 module Module
Colin Cross3f40fa42015-01-30 17:27:36 -0800910
Colin Crossfc754582016-05-17 16:34:16 -0700911 nameProperties nameProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800912 commonProperties commonProperties
Paul Duffined875132020-09-02 13:08:57 +0100913 distProperties distProperties
Colin Cross18c46802019-09-24 22:19:02 -0700914 variableProperties interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800915 hostAndDeviceProperties hostAndDeviceProperties
916 generalProperties []interface{}
Colin Crossc17727d2018-10-24 12:42:09 -0700917 archProperties [][]interface{}
Colin Crossa120ec12016-08-19 16:07:38 -0700918 customizableProperties []interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800919
Paul Duffin63c6e182019-07-24 14:24:38 +0100920 // Information about all the properties on the module that contains visibility rules that need
921 // checking.
922 visibilityPropertyInfo []visibilityProperty
923
924 // The primary visibility property, may be nil, that controls access to the module.
925 primaryVisibilityProperty visibilityProperty
926
Colin Cross3f40fa42015-01-30 17:27:36 -0800927 noAddressSanitizer bool
Colin Cross897266e2020-02-13 13:22:08 -0800928 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700929 checkbuildFiles Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800930 noticeFiles Paths
Colin Crossc3d87d32020-06-04 13:25:17 -0700931 phonies map[string]Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -0700932
933 // Used by buildTargetSingleton to create checkbuild and per-directory build targets
934 // Only set on the final variant of each module
Colin Cross0875c522017-11-28 17:34:01 -0800935 installTarget WritablePath
936 checkbuildTarget WritablePath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700937 blueprintDir string
Colin Crossa120ec12016-08-19 16:07:38 -0700938
Colin Cross178a5092016-09-13 13:42:32 -0700939 hooks hooks
Colin Cross36242852017-06-23 15:06:31 -0700940
941 registerProps []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700942
943 // For tests
Colin Crossae887032017-10-23 17:16:14 -0700944 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800945 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800946 variables map[string]string
Colin Crossa9d8bee2018-10-02 13:59:46 -0700947
Inseob Kim8471cda2019-11-15 09:59:12 +0900948 initRcPaths Paths
949 vintfFragmentsPaths Paths
950
Jiyong Park1613e552020-09-14 19:43:17 +0900951 prefer32 func(ctx BaseModuleContext, base *ModuleBase, os OsType) bool
Colin Cross36242852017-06-23 15:06:31 -0700952}
953
Paul Duffin44f1d842020-06-26 20:17:02 +0100954func (m *ModuleBase) ComponentDepsMutator(BottomUpMutatorContext) {}
955
Colin Cross4157e882019-06-06 16:57:04 -0700956func (m *ModuleBase) DepsMutator(BottomUpMutatorContext) {}
Colin Cross5f692ec2019-02-01 16:53:07 -0800957
Colin Cross4157e882019-06-06 16:57:04 -0700958func (m *ModuleBase) AddProperties(props ...interface{}) {
959 m.registerProps = append(m.registerProps, props...)
Colin Cross36242852017-06-23 15:06:31 -0700960}
961
Colin Cross4157e882019-06-06 16:57:04 -0700962func (m *ModuleBase) GetProperties() []interface{} {
963 return m.registerProps
Colin Cross3f40fa42015-01-30 17:27:36 -0800964}
965
Colin Cross4157e882019-06-06 16:57:04 -0700966func (m *ModuleBase) BuildParamsForTests() []BuildParams {
967 return m.buildParams
Colin Crosscec81712017-07-13 14:43:27 -0700968}
969
Colin Cross4157e882019-06-06 16:57:04 -0700970func (m *ModuleBase) RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams {
971 return m.ruleParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800972}
973
Colin Cross4157e882019-06-06 16:57:04 -0700974func (m *ModuleBase) VariablesForTests() map[string]string {
975 return m.variables
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800976}
977
Jiyong Park1613e552020-09-14 19:43:17 +0900978func (m *ModuleBase) Prefer32(prefer32 func(ctx BaseModuleContext, base *ModuleBase, os OsType) bool) {
Colin Cross4157e882019-06-06 16:57:04 -0700979 m.prefer32 = prefer32
Colin Crossa9d8bee2018-10-02 13:59:46 -0700980}
981
Colin Crossce75d2c2016-10-06 16:12:58 -0700982// Name returns the name of the module. It may be overridden by individual module types, for
983// example prebuilts will prepend prebuilt_ to the name.
Colin Cross4157e882019-06-06 16:57:04 -0700984func (m *ModuleBase) Name() string {
985 return String(m.nameProperties.Name)
Colin Crossfc754582016-05-17 16:34:16 -0700986}
987
Colin Cross9a362232019-07-01 15:32:45 -0700988// String returns a string that includes the module name and variants for printing during debugging.
989func (m *ModuleBase) String() string {
990 sb := strings.Builder{}
991 sb.WriteString(m.commonProperties.DebugName)
992 sb.WriteString("{")
993 for i := range m.commonProperties.DebugMutators {
994 if i != 0 {
995 sb.WriteString(",")
996 }
997 sb.WriteString(m.commonProperties.DebugMutators[i])
998 sb.WriteString(":")
999 sb.WriteString(m.commonProperties.DebugVariations[i])
1000 }
1001 sb.WriteString("}")
1002 return sb.String()
1003}
1004
Colin Crossce75d2c2016-10-06 16:12:58 -07001005// BaseModuleName returns the name of the module as specified in the blueprints file.
Colin Cross4157e882019-06-06 16:57:04 -07001006func (m *ModuleBase) BaseModuleName() string {
1007 return String(m.nameProperties.Name)
Colin Crossce75d2c2016-10-06 16:12:58 -07001008}
1009
Colin Cross4157e882019-06-06 16:57:04 -07001010func (m *ModuleBase) base() *ModuleBase {
1011 return m
Colin Cross3f40fa42015-01-30 17:27:36 -08001012}
1013
Paul Duffine2453c72019-05-31 14:00:04 +01001014func (m *ModuleBase) qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName {
1015 return qualifiedModuleName{pkg: ctx.ModuleDir(), name: ctx.ModuleName()}
1016}
1017
1018func (m *ModuleBase) visibilityProperties() []visibilityProperty {
Paul Duffin63c6e182019-07-24 14:24:38 +01001019 return m.visibilityPropertyInfo
1020}
1021
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001022func (m *ModuleBase) Dists() []Dist {
Paul Duffined875132020-09-02 13:08:57 +01001023 if len(m.distProperties.Dist.Targets) > 0 {
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001024 // Make a copy of the underlying Dists slice to protect against
1025 // backing array modifications with repeated calls to this method.
Paul Duffined875132020-09-02 13:08:57 +01001026 distsCopy := append([]Dist(nil), m.distProperties.Dists...)
1027 return append(distsCopy, m.distProperties.Dist)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001028 } else {
Paul Duffined875132020-09-02 13:08:57 +01001029 return m.distProperties.Dists
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001030 }
1031}
1032
1033func (m *ModuleBase) GenerateTaggedDistFiles(ctx BaseModuleContext) TaggedDistFiles {
1034 distFiles := make(TaggedDistFiles)
1035 for _, dist := range m.Dists() {
1036 var tag string
1037 var distFilesForTag Paths
1038 if dist.Tag == nil {
1039 tag = ""
1040 } else {
1041 tag = *dist.Tag
1042 }
1043 distFilesForTag, err := m.base().module.(OutputFileProducer).OutputFiles(tag)
1044 if err != nil {
1045 ctx.PropertyErrorf("dist.tag", "%s", err.Error())
1046 }
1047 for _, distFile := range distFilesForTag {
1048 if distFile != nil && !distFiles[tag].containsPath(distFile) {
1049 distFiles[tag] = append(distFiles[tag], distFile)
1050 }
1051 }
1052 }
1053
1054 return distFiles
1055}
1056
Colin Cross4157e882019-06-06 16:57:04 -07001057func (m *ModuleBase) Target() Target {
1058 return m.commonProperties.CompileTarget
Dan Willemsen490fd492015-11-24 17:53:15 -08001059}
1060
Colin Cross4157e882019-06-06 16:57:04 -07001061func (m *ModuleBase) TargetPrimary() bool {
1062 return m.commonProperties.CompilePrimary
Colin Cross8b74d172016-09-13 09:59:14 -07001063}
1064
Colin Cross4157e882019-06-06 16:57:04 -07001065func (m *ModuleBase) MultiTargets() []Target {
1066 return m.commonProperties.CompileMultiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07001067}
1068
Colin Cross4157e882019-06-06 16:57:04 -07001069func (m *ModuleBase) Os() OsType {
1070 return m.Target().Os
Dan Willemsen490fd492015-11-24 17:53:15 -08001071}
1072
Colin Cross4157e882019-06-06 16:57:04 -07001073func (m *ModuleBase) Host() bool {
Jiyong Park1613e552020-09-14 19:43:17 +09001074 return m.Os().Class == Host
Dan Willemsen97750522016-02-09 17:43:51 -08001075}
1076
Yo Chiangbba545e2020-06-09 16:15:37 +08001077func (m *ModuleBase) Device() bool {
1078 return m.Os().Class == Device
1079}
1080
Colin Cross4157e882019-06-06 16:57:04 -07001081func (m *ModuleBase) Arch() Arch {
1082 return m.Target().Arch
Dan Willemsen97750522016-02-09 17:43:51 -08001083}
1084
Colin Cross4157e882019-06-06 16:57:04 -07001085func (m *ModuleBase) ArchSpecific() bool {
1086 return m.commonProperties.ArchSpecific
Dan Willemsen0b24c742016-10-04 15:13:37 -07001087}
1088
Paul Duffin1356d8c2020-02-25 19:26:33 +00001089// True if the current variant is a CommonOS variant, false otherwise.
1090func (m *ModuleBase) IsCommonOSVariant() bool {
1091 return m.commonProperties.CommonOSVariant
1092}
1093
Jiyong Park1613e552020-09-14 19:43:17 +09001094func (m *ModuleBase) supportsTarget(target Target, config Config) bool {
Colin Cross4157e882019-06-06 16:57:04 -07001095 switch m.commonProperties.HostOrDeviceSupported {
Colin Crossa1ad8d12016-06-01 17:09:44 -07001096 case HostSupported:
Jiyong Park1613e552020-09-14 19:43:17 +09001097 return target.Os.Class == Host
Dan Albertc6345fb2016-10-20 01:36:11 -07001098 case HostSupportedNoCross:
Jiyong Park1613e552020-09-14 19:43:17 +09001099 return target.Os.Class == Host && !target.HostCross
Colin Crossa1ad8d12016-06-01 17:09:44 -07001100 case DeviceSupported:
Jiyong Park1613e552020-09-14 19:43:17 +09001101 return target.Os.Class == Device
Dan Albert0981b5c2018-08-02 13:46:35 -07001102 case HostAndDeviceSupported, HostAndDeviceDefault:
Jiyong Park1613e552020-09-14 19:43:17 +09001103 supported := false
Colin Cross4157e882019-06-06 16:57:04 -07001104 if Bool(m.hostAndDeviceProperties.Host_supported) ||
1105 (m.commonProperties.HostOrDeviceSupported == HostAndDeviceDefault &&
1106 m.hostAndDeviceProperties.Host_supported == nil) {
Jiyong Park1613e552020-09-14 19:43:17 +09001107 supported = supported || target.Os.Class == Host
Colin Crossa1ad8d12016-06-01 17:09:44 -07001108 }
Colin Cross4157e882019-06-06 16:57:04 -07001109 if m.hostAndDeviceProperties.Device_supported == nil ||
1110 *m.hostAndDeviceProperties.Device_supported {
Jiyong Park1613e552020-09-14 19:43:17 +09001111 supported = supported || target.Os.Class == Device
Colin Crossa1ad8d12016-06-01 17:09:44 -07001112 }
1113 return supported
1114 default:
Jiyong Park1613e552020-09-14 19:43:17 +09001115 return false
Colin Crossa1ad8d12016-06-01 17:09:44 -07001116 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001117}
1118
Colin Cross4157e882019-06-06 16:57:04 -07001119func (m *ModuleBase) DeviceSupported() bool {
1120 return m.commonProperties.HostOrDeviceSupported == DeviceSupported ||
1121 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
1122 (m.hostAndDeviceProperties.Device_supported == nil ||
1123 *m.hostAndDeviceProperties.Device_supported)
Colin Cross3f40fa42015-01-30 17:27:36 -08001124}
1125
Paul Duffine44358f2019-11-26 18:04:12 +00001126func (m *ModuleBase) HostSupported() bool {
1127 return m.commonProperties.HostOrDeviceSupported == HostSupported ||
1128 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
1129 (m.hostAndDeviceProperties.Host_supported != nil &&
1130 *m.hostAndDeviceProperties.Host_supported)
1131}
1132
Colin Cross4157e882019-06-06 16:57:04 -07001133func (m *ModuleBase) Platform() bool {
Justin Yund5f6c822019-06-25 16:47:17 +09001134 return !m.DeviceSpecific() && !m.SocSpecific() && !m.ProductSpecific() && !m.SystemExtSpecific()
Jiyong Parkc678ad32018-04-10 13:07:10 +09001135}
1136
Colin Cross4157e882019-06-06 16:57:04 -07001137func (m *ModuleBase) DeviceSpecific() bool {
1138 return Bool(m.commonProperties.Device_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +09001139}
1140
Colin Cross4157e882019-06-06 16:57:04 -07001141func (m *ModuleBase) SocSpecific() bool {
1142 return Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +09001143}
1144
Colin Cross4157e882019-06-06 16:57:04 -07001145func (m *ModuleBase) ProductSpecific() bool {
1146 return Bool(m.commonProperties.Product_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +09001147}
1148
Justin Yund5f6c822019-06-25 16:47:17 +09001149func (m *ModuleBase) SystemExtSpecific() bool {
1150 return Bool(m.commonProperties.System_ext_specific)
Dario Frenifd05a742018-05-29 13:28:54 +01001151}
1152
Colin Crossc2d24052020-05-13 11:05:02 -07001153// RequiresStableAPIs returns true if the module will be installed to a partition that may
1154// be updated separately from the system image.
1155func (m *ModuleBase) RequiresStableAPIs(ctx BaseModuleContext) bool {
1156 return m.SocSpecific() || m.DeviceSpecific() ||
1157 (m.ProductSpecific() && ctx.Config().EnforceProductPartitionInterface())
1158}
1159
Bill Peckhamfff3f8a2020-03-20 18:33:20 -07001160func (m *ModuleBase) PartitionTag(config DeviceConfig) string {
1161 partition := "system"
1162 if m.SocSpecific() {
1163 // A SoC-specific module could be on the vendor partition at
1164 // "vendor" or the system partition at "system/vendor".
1165 if config.VendorPath() == "vendor" {
1166 partition = "vendor"
1167 }
1168 } else if m.DeviceSpecific() {
1169 // A device-specific module could be on the odm partition at
1170 // "odm", the vendor partition at "vendor/odm", or the system
1171 // partition at "system/vendor/odm".
1172 if config.OdmPath() == "odm" {
1173 partition = "odm"
Ramy Medhat944839a2020-03-31 22:14:52 -04001174 } else if strings.HasPrefix(config.OdmPath(), "vendor/") {
Bill Peckhamfff3f8a2020-03-20 18:33:20 -07001175 partition = "vendor"
1176 }
1177 } else if m.ProductSpecific() {
1178 // A product-specific module could be on the product partition
1179 // at "product" or the system partition at "system/product".
1180 if config.ProductPath() == "product" {
1181 partition = "product"
1182 }
1183 } else if m.SystemExtSpecific() {
1184 // A system_ext-specific module could be on the system_ext
1185 // partition at "system_ext" or the system partition at
1186 // "system/system_ext".
1187 if config.SystemExtPath() == "system_ext" {
1188 partition = "system_ext"
1189 }
1190 }
1191 return partition
1192}
1193
Colin Cross4157e882019-06-06 16:57:04 -07001194func (m *ModuleBase) Enabled() bool {
Justin Yun32f053b2020-07-31 23:07:17 +09001195 if m.commonProperties.ForcedDisabled {
1196 return false
1197 }
Colin Cross4157e882019-06-06 16:57:04 -07001198 if m.commonProperties.Enabled == nil {
1199 return !m.Os().DefaultDisabled
Dan Willemsen490fd492015-11-24 17:53:15 -08001200 }
Colin Cross4157e882019-06-06 16:57:04 -07001201 return *m.commonProperties.Enabled
Colin Cross3f40fa42015-01-30 17:27:36 -08001202}
1203
Inseob Kimeec88e12020-01-22 11:11:29 +09001204func (m *ModuleBase) Disable() {
Justin Yun32f053b2020-07-31 23:07:17 +09001205 m.commonProperties.ForcedDisabled = true
Inseob Kimeec88e12020-01-22 11:11:29 +09001206}
1207
Colin Cross4157e882019-06-06 16:57:04 -07001208func (m *ModuleBase) SkipInstall() {
1209 m.commonProperties.SkipInstall = true
Colin Crossce75d2c2016-10-06 16:12:58 -07001210}
1211
Ulya Trafimovichb28cc372020-01-13 15:18:16 +00001212func (m *ModuleBase) IsSkipInstall() bool {
1213 return m.commonProperties.SkipInstall == true
1214}
1215
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001216// Similar to SkipInstall, but if the AndroidMk entry would set
1217// LOCAL_UNINSTALLABLE_MODULE then this variant may still output that entry
1218// rather than leaving it out altogether. That happens in cases where it would
1219// have other side effects, in particular when it adds a NOTICE file target,
1220// which other install targets might depend on.
1221func (m *ModuleBase) MakeUninstallable() {
1222 m.SkipInstall()
1223}
1224
Liz Kammer5ca3a622020-08-05 15:40:41 -07001225func (m *ModuleBase) ReplacedByPrebuilt() {
1226 m.commonProperties.ReplacedByPrebuilt = true
1227 m.SkipInstall()
1228}
1229
1230func (m *ModuleBase) IsReplacedByPrebuilt() bool {
1231 return m.commonProperties.ReplacedByPrebuilt
1232}
1233
Colin Cross4157e882019-06-06 16:57:04 -07001234func (m *ModuleBase) ExportedToMake() bool {
1235 return m.commonProperties.NamespaceExportedToMake
Jiyong Park374510b2018-03-19 18:23:01 +09001236}
1237
Colin Cross897266e2020-02-13 13:22:08 -08001238func (m *ModuleBase) computeInstallDeps(ctx blueprint.ModuleContext) InstallPaths {
Colin Cross3f40fa42015-01-30 17:27:36 -08001239
Colin Cross897266e2020-02-13 13:22:08 -08001240 var result InstallPaths
Colin Cross6b753602018-06-21 13:03:07 -07001241 // TODO(ccross): we need to use WalkDeps and have some way to know which dependencies require installation
Colin Cross897266e2020-02-13 13:22:08 -08001242 ctx.VisitDepsDepthFirst(func(m blueprint.Module) {
1243 if a, ok := m.(Module); ok {
1244 result = append(result, a.filesToInstall()...)
1245 }
1246 })
Colin Cross3f40fa42015-01-30 17:27:36 -08001247
1248 return result
1249}
1250
Colin Cross897266e2020-02-13 13:22:08 -08001251func (m *ModuleBase) filesToInstall() InstallPaths {
Colin Cross4157e882019-06-06 16:57:04 -07001252 return m.installFiles
Colin Cross3f40fa42015-01-30 17:27:36 -08001253}
1254
Colin Cross4157e882019-06-06 16:57:04 -07001255func (m *ModuleBase) NoAddressSanitizer() bool {
1256 return m.noAddressSanitizer
Colin Cross3f40fa42015-01-30 17:27:36 -08001257}
1258
Colin Cross4157e882019-06-06 16:57:04 -07001259func (m *ModuleBase) InstallInData() bool {
Dan Willemsen782a2d12015-12-21 14:55:28 -08001260 return false
1261}
1262
Jaewoong Jung0949f312019-09-11 10:25:18 -07001263func (m *ModuleBase) InstallInTestcases() bool {
1264 return false
1265}
1266
Colin Cross4157e882019-06-06 16:57:04 -07001267func (m *ModuleBase) InstallInSanitizerDir() bool {
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001268 return false
1269}
1270
Yifan Hong1b3348d2020-01-21 15:53:22 -08001271func (m *ModuleBase) InstallInRamdisk() bool {
1272 return Bool(m.commonProperties.Ramdisk)
1273}
1274
Colin Cross4157e882019-06-06 16:57:04 -07001275func (m *ModuleBase) InstallInRecovery() bool {
1276 return Bool(m.commonProperties.Recovery)
Jiyong Parkf9332f12018-02-01 00:54:12 +09001277}
1278
Colin Cross90ba5f42019-10-02 11:10:58 -07001279func (m *ModuleBase) InstallInRoot() bool {
1280 return false
1281}
1282
Colin Cross607d8582019-07-29 16:44:46 -07001283func (m *ModuleBase) InstallBypassMake() bool {
1284 return false
1285}
1286
Jiyong Park87788b52020-09-01 12:37:45 +09001287func (m *ModuleBase) InstallForceOS() (*OsType, *ArchType) {
1288 return nil, nil
Colin Cross6e359402020-02-10 15:29:54 -08001289}
1290
Colin Cross4157e882019-06-06 16:57:04 -07001291func (m *ModuleBase) Owner() string {
1292 return String(m.commonProperties.Owner)
Sundong Ahn4fd04bb2018-08-31 18:01:37 +09001293}
1294
Bob Badoura75b0572020-02-18 20:21:55 -08001295func (m *ModuleBase) NoticeFiles() Paths {
1296 return m.noticeFiles
Jiyong Park52818fc2019-03-18 12:01:38 +09001297}
1298
Colin Cross7228ecd2019-11-18 16:00:16 -08001299func (m *ModuleBase) setImageVariation(variant string) {
1300 m.commonProperties.ImageVariation = variant
1301}
1302
1303func (m *ModuleBase) ImageVariation() blueprint.Variation {
1304 return blueprint.Variation{
1305 Mutator: "image",
1306 Variation: m.base().commonProperties.ImageVariation,
1307 }
1308}
1309
Paul Duffin9b76c0b2020-03-12 10:24:35 +00001310func (m *ModuleBase) getVariationByMutatorName(mutator string) string {
1311 for i, v := range m.commonProperties.DebugMutators {
1312 if v == mutator {
1313 return m.commonProperties.DebugVariations[i]
1314 }
1315 }
1316
1317 return ""
1318}
1319
Yifan Hong1b3348d2020-01-21 15:53:22 -08001320func (m *ModuleBase) InRamdisk() bool {
1321 return m.base().commonProperties.ImageVariation == RamdiskVariation
1322}
1323
Colin Cross7228ecd2019-11-18 16:00:16 -08001324func (m *ModuleBase) InRecovery() bool {
1325 return m.base().commonProperties.ImageVariation == RecoveryVariation
1326}
1327
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09001328func (m *ModuleBase) RequiredModuleNames() []string {
1329 return m.base().commonProperties.Required
1330}
1331
1332func (m *ModuleBase) HostRequiredModuleNames() []string {
1333 return m.base().commonProperties.Host_required
1334}
1335
1336func (m *ModuleBase) TargetRequiredModuleNames() []string {
1337 return m.base().commonProperties.Target_required
1338}
1339
Inseob Kim8471cda2019-11-15 09:59:12 +09001340func (m *ModuleBase) InitRc() Paths {
1341 return append(Paths{}, m.initRcPaths...)
1342}
1343
1344func (m *ModuleBase) VintfFragments() Paths {
1345 return append(Paths{}, m.vintfFragmentsPaths...)
1346}
1347
Colin Cross4157e882019-06-06 16:57:04 -07001348func (m *ModuleBase) generateModuleTarget(ctx ModuleContext) {
Colin Cross897266e2020-02-13 13:22:08 -08001349 var allInstalledFiles InstallPaths
1350 var allCheckbuildFiles Paths
Colin Cross0875c522017-11-28 17:34:01 -08001351 ctx.VisitAllModuleVariants(func(module Module) {
1352 a := module.base()
Colin Crossc9404352015-03-26 16:10:12 -07001353 allInstalledFiles = append(allInstalledFiles, a.installFiles...)
1354 allCheckbuildFiles = append(allCheckbuildFiles, a.checkbuildFiles...)
Colin Cross3f40fa42015-01-30 17:27:36 -08001355 })
1356
Colin Cross0875c522017-11-28 17:34:01 -08001357 var deps Paths
Colin Cross9454bfa2015-03-17 13:24:18 -07001358
Colin Cross133ebef2020-08-14 17:38:45 -07001359 namespacePrefix := ctx.Namespace().id
Jeff Gaston088e29e2017-11-29 16:47:17 -08001360 if namespacePrefix != "" {
1361 namespacePrefix = namespacePrefix + "-"
1362 }
1363
Colin Cross3f40fa42015-01-30 17:27:36 -08001364 if len(allInstalledFiles) > 0 {
Colin Crossc3d87d32020-06-04 13:25:17 -07001365 name := namespacePrefix + ctx.ModuleName() + "-install"
1366 ctx.Phony(name, allInstalledFiles.Paths()...)
1367 m.installTarget = PathForPhony(ctx, name)
1368 deps = append(deps, m.installTarget)
Colin Cross9454bfa2015-03-17 13:24:18 -07001369 }
1370
1371 if len(allCheckbuildFiles) > 0 {
Colin Crossc3d87d32020-06-04 13:25:17 -07001372 name := namespacePrefix + ctx.ModuleName() + "-checkbuild"
1373 ctx.Phony(name, allCheckbuildFiles...)
1374 m.checkbuildTarget = PathForPhony(ctx, name)
1375 deps = append(deps, m.checkbuildTarget)
Colin Cross9454bfa2015-03-17 13:24:18 -07001376 }
1377
1378 if len(deps) > 0 {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001379 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08001380 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001381 suffix = "-soong"
1382 }
1383
Colin Crossc3d87d32020-06-04 13:25:17 -07001384 ctx.Phony(namespacePrefix+ctx.ModuleName()+suffix, deps...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07001385
Colin Cross4157e882019-06-06 16:57:04 -07001386 m.blueprintDir = ctx.ModuleDir()
Colin Cross3f40fa42015-01-30 17:27:36 -08001387 }
1388}
1389
Colin Crossc34d2322020-01-03 15:23:27 -08001390func determineModuleKind(m *ModuleBase, ctx blueprint.EarlyModuleContext) moduleKind {
Colin Cross4157e882019-06-06 16:57:04 -07001391 var socSpecific = Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
1392 var deviceSpecific = Bool(m.commonProperties.Device_specific)
1393 var productSpecific = Bool(m.commonProperties.Product_specific)
Justin Yund5f6c822019-06-25 16:47:17 +09001394 var systemExtSpecific = Bool(m.commonProperties.System_ext_specific)
Jiyong Park2db76922017-11-08 16:03:48 +09001395
Dario Frenifd05a742018-05-29 13:28:54 +01001396 msg := "conflicting value set here"
1397 if socSpecific && deviceSpecific {
1398 ctx.PropertyErrorf("device_specific", "a module cannot be specific to SoC and device at the same time.")
Colin Cross4157e882019-06-06 16:57:04 -07001399 if Bool(m.commonProperties.Vendor) {
Jiyong Park2db76922017-11-08 16:03:48 +09001400 ctx.PropertyErrorf("vendor", msg)
1401 }
Colin Cross4157e882019-06-06 16:57:04 -07001402 if Bool(m.commonProperties.Proprietary) {
Jiyong Park2db76922017-11-08 16:03:48 +09001403 ctx.PropertyErrorf("proprietary", msg)
1404 }
Colin Cross4157e882019-06-06 16:57:04 -07001405 if Bool(m.commonProperties.Soc_specific) {
Jiyong Park2db76922017-11-08 16:03:48 +09001406 ctx.PropertyErrorf("soc_specific", msg)
1407 }
1408 }
1409
Justin Yund5f6c822019-06-25 16:47:17 +09001410 if productSpecific && systemExtSpecific {
1411 ctx.PropertyErrorf("product_specific", "a module cannot be specific to product and system_ext at the same time.")
1412 ctx.PropertyErrorf("system_ext_specific", msg)
Dario Frenifd05a742018-05-29 13:28:54 +01001413 }
1414
Justin Yund5f6c822019-06-25 16:47:17 +09001415 if (socSpecific || deviceSpecific) && (productSpecific || systemExtSpecific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001416 if productSpecific {
1417 ctx.PropertyErrorf("product_specific", "a module cannot be specific to SoC or device and product at the same time.")
1418 } else {
Justin Yund5f6c822019-06-25 16:47:17 +09001419 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 +01001420 }
1421 if deviceSpecific {
1422 ctx.PropertyErrorf("device_specific", msg)
1423 } else {
Colin Cross4157e882019-06-06 16:57:04 -07001424 if Bool(m.commonProperties.Vendor) {
Dario Frenifd05a742018-05-29 13:28:54 +01001425 ctx.PropertyErrorf("vendor", msg)
1426 }
Colin Cross4157e882019-06-06 16:57:04 -07001427 if Bool(m.commonProperties.Proprietary) {
Dario Frenifd05a742018-05-29 13:28:54 +01001428 ctx.PropertyErrorf("proprietary", msg)
1429 }
Colin Cross4157e882019-06-06 16:57:04 -07001430 if Bool(m.commonProperties.Soc_specific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001431 ctx.PropertyErrorf("soc_specific", msg)
1432 }
1433 }
1434 }
1435
Jiyong Park2db76922017-11-08 16:03:48 +09001436 if productSpecific {
1437 return productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +09001438 } else if systemExtSpecific {
1439 return systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001440 } else if deviceSpecific {
1441 return deviceSpecificModule
1442 } else if socSpecific {
1443 return socSpecificModule
1444 } else {
1445 return platformModule
1446 }
1447}
1448
Colin Crossc34d2322020-01-03 15:23:27 -08001449func (m *ModuleBase) earlyModuleContextFactory(ctx blueprint.EarlyModuleContext) earlyModuleContext {
Colin Cross1184b642019-12-30 18:43:07 -08001450 return earlyModuleContext{
Colin Crossc34d2322020-01-03 15:23:27 -08001451 EarlyModuleContext: ctx,
1452 kind: determineModuleKind(m, ctx),
1453 config: ctx.Config().(Config),
Colin Cross3f40fa42015-01-30 17:27:36 -08001454 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001455}
1456
Colin Cross1184b642019-12-30 18:43:07 -08001457func (m *ModuleBase) baseModuleContextFactory(ctx blueprint.BaseModuleContext) baseModuleContext {
1458 return baseModuleContext{
1459 bp: ctx,
1460 earlyModuleContext: m.earlyModuleContextFactory(ctx),
1461 os: m.commonProperties.CompileOS,
1462 target: m.commonProperties.CompileTarget,
1463 targetPrimary: m.commonProperties.CompilePrimary,
1464 multiTargets: m.commonProperties.CompileMultiTargets,
1465 }
1466}
1467
Colin Cross4157e882019-06-06 16:57:04 -07001468func (m *ModuleBase) GenerateBuildActions(blueprintCtx blueprint.ModuleContext) {
Colin Cross25de6c32019-06-06 14:29:25 -07001469 ctx := &moduleContext{
Colin Cross0ea8ba82019-06-06 14:33:29 -07001470 module: m.module,
Colin Crossdc35e212019-06-06 16:13:11 -07001471 bp: blueprintCtx,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001472 baseModuleContext: m.baseModuleContextFactory(blueprintCtx),
1473 installDeps: m.computeInstallDeps(blueprintCtx),
1474 installFiles: m.installFiles,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001475 variables: make(map[string]string),
Colin Cross3f40fa42015-01-30 17:27:36 -08001476 }
1477
Colin Cross6c4f21f2019-06-06 15:41:36 -07001478 // Temporarily continue to call blueprintCtx.GetMissingDependencies() to maintain the previous behavior of never
1479 // reporting missing dependency errors in Blueprint when AllowMissingDependencies == true.
1480 // TODO: This will be removed once defaults modules handle missing dependency errors
1481 blueprintCtx.GetMissingDependencies()
1482
Colin Crossdc35e212019-06-06 16:13:11 -07001483 // For the final GenerateAndroidBuildActions pass, require that all visited dependencies Soong modules and
Paul Duffin1356d8c2020-02-25 19:26:33 +00001484 // are enabled. Unless the module is a CommonOS variant which may have dependencies on disabled variants
1485 // (because the dependencies are added before the modules are disabled). The
1486 // GetOsSpecificVariantsOfCommonOSVariant(...) method will ensure that the disabled variants are
1487 // ignored.
1488 ctx.baseModuleContext.strictVisitDeps = !m.IsCommonOSVariant()
Colin Crossdc35e212019-06-06 16:13:11 -07001489
Colin Cross4c83e5c2019-02-25 14:54:28 -08001490 if ctx.config.captureBuild {
1491 ctx.ruleParams = make(map[blueprint.Rule]blueprint.RuleParams)
1492 }
1493
Colin Cross67a5c132017-05-09 13:45:28 -07001494 desc := "//" + ctx.ModuleDir() + ":" + ctx.ModuleName() + " "
1495 var suffix []string
Colin Cross0875c522017-11-28 17:34:01 -08001496 if ctx.Os().Class != Device && ctx.Os().Class != Generic {
1497 suffix = append(suffix, ctx.Os().String())
Colin Cross67a5c132017-05-09 13:45:28 -07001498 }
Colin Cross0875c522017-11-28 17:34:01 -08001499 if !ctx.PrimaryArch() {
1500 suffix = append(suffix, ctx.Arch().ArchType.String())
Colin Cross67a5c132017-05-09 13:45:28 -07001501 }
Dan Willemsenb13a9482020-02-14 11:25:54 -08001502 if apex, ok := m.module.(ApexModule); ok && !apex.IsForPlatform() {
Colin Crosse07f2312020-08-13 11:24:56 -07001503 suffix = append(suffix, apex.ApexVariationName())
Dan Willemsenb13a9482020-02-14 11:25:54 -08001504 }
Colin Cross67a5c132017-05-09 13:45:28 -07001505
1506 ctx.Variable(pctx, "moduleDesc", desc)
1507
1508 s := ""
1509 if len(suffix) > 0 {
1510 s = " [" + strings.Join(suffix, " ") + "]"
1511 }
1512 ctx.Variable(pctx, "moduleDescSuffix", s)
1513
Dan Willemsen569edc52018-11-19 09:33:29 -08001514 // Some common property checks for properties that will be used later in androidmk.go
Paul Duffined875132020-09-02 13:08:57 +01001515 if m.distProperties.Dist.Dest != nil {
1516 _, err := validateSafePath(*m.distProperties.Dist.Dest)
Dan Willemsen569edc52018-11-19 09:33:29 -08001517 if err != nil {
1518 ctx.PropertyErrorf("dist.dest", "%s", err.Error())
1519 }
1520 }
Paul Duffined875132020-09-02 13:08:57 +01001521 if m.distProperties.Dist.Dir != nil {
1522 _, err := validateSafePath(*m.distProperties.Dist.Dir)
Dan Willemsen569edc52018-11-19 09:33:29 -08001523 if err != nil {
1524 ctx.PropertyErrorf("dist.dir", "%s", err.Error())
1525 }
1526 }
Paul Duffined875132020-09-02 13:08:57 +01001527 if m.distProperties.Dist.Suffix != nil {
1528 if strings.Contains(*m.distProperties.Dist.Suffix, "/") {
Dan Willemsen569edc52018-11-19 09:33:29 -08001529 ctx.PropertyErrorf("dist.suffix", "Suffix may not contain a '/' character.")
1530 }
1531 }
1532
Colin Cross4157e882019-06-06 16:57:04 -07001533 if m.Enabled() {
Jooyung Hand48f3c32019-08-23 11:18:57 +09001534 // ensure all direct android.Module deps are enabled
1535 ctx.VisitDirectDepsBlueprint(func(bm blueprint.Module) {
1536 if _, ok := bm.(Module); ok {
1537 ctx.validateAndroidModule(bm, ctx.baseModuleContext.strictVisitDeps)
1538 }
1539 })
1540
Bob Badoura75b0572020-02-18 20:21:55 -08001541 m.noticeFiles = make([]Path, 0)
1542 optPath := OptionalPath{}
1543 notice := proptools.StringDefault(m.commonProperties.Notice, "")
Colin Cross4157e882019-06-06 16:57:04 -07001544 if module := SrcIsModule(notice); module != "" {
Bob Badoura75b0572020-02-18 20:21:55 -08001545 optPath = ctx.ExpandOptionalSource(&notice, "notice")
1546 } else if notice != "" {
Jiyong Park52818fc2019-03-18 12:01:38 +09001547 noticePath := filepath.Join(ctx.ModuleDir(), notice)
Bob Badoura75b0572020-02-18 20:21:55 -08001548 optPath = ExistentPathForSource(ctx, noticePath)
1549 }
1550 if optPath.Valid() {
1551 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1552 } else {
1553 for _, notice = range []string{"LICENSE", "LICENCE", "NOTICE"} {
1554 noticePath := filepath.Join(ctx.ModuleDir(), notice)
1555 optPath = ExistentPathForSource(ctx, noticePath)
1556 if optPath.Valid() {
1557 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1558 }
1559 }
Jaewoong Jung62707f72018-11-16 13:26:43 -08001560 }
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001561
1562 m.module.GenerateAndroidBuildActions(ctx)
1563 if ctx.Failed() {
1564 return
1565 }
1566
1567 m.installFiles = append(m.installFiles, ctx.installFiles...)
1568 m.checkbuildFiles = append(m.checkbuildFiles, ctx.checkbuildFiles...)
Inseob Kim8471cda2019-11-15 09:59:12 +09001569 m.initRcPaths = PathsForModuleSrc(ctx, m.commonProperties.Init_rc)
1570 m.vintfFragmentsPaths = PathsForModuleSrc(ctx, m.commonProperties.Vintf_fragments)
Colin Crossc3d87d32020-06-04 13:25:17 -07001571 for k, v := range ctx.phonies {
1572 m.phonies[k] = append(m.phonies[k], v...)
1573 }
Colin Crossdc35e212019-06-06 16:13:11 -07001574 } else if ctx.Config().AllowMissingDependencies() {
1575 // If the module is not enabled it will not create any build rules, nothing will call
1576 // ctx.GetMissingDependencies(), and blueprint will consider the missing dependencies to be unhandled
1577 // and report them as an error even when AllowMissingDependencies = true. Call
1578 // ctx.GetMissingDependencies() here to tell blueprint not to handle them.
1579 ctx.GetMissingDependencies()
Colin Cross3f40fa42015-01-30 17:27:36 -08001580 }
1581
Colin Cross4157e882019-06-06 16:57:04 -07001582 if m == ctx.FinalModule().(Module).base() {
1583 m.generateModuleTarget(ctx)
Colin Cross9b1d13d2016-09-19 15:18:11 -07001584 if ctx.Failed() {
1585 return
1586 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001587 }
Colin Crosscec81712017-07-13 14:43:27 -07001588
Colin Cross4157e882019-06-06 16:57:04 -07001589 m.buildParams = ctx.buildParams
1590 m.ruleParams = ctx.ruleParams
1591 m.variables = ctx.variables
Colin Cross3f40fa42015-01-30 17:27:36 -08001592}
1593
Colin Cross1184b642019-12-30 18:43:07 -08001594type earlyModuleContext struct {
Colin Crossc34d2322020-01-03 15:23:27 -08001595 blueprint.EarlyModuleContext
Colin Cross1184b642019-12-30 18:43:07 -08001596
1597 kind moduleKind
1598 config Config
1599}
1600
1601func (e *earlyModuleContext) Glob(globPattern string, excludes []string) Paths {
1602 ret, err := e.GlobWithDeps(globPattern, excludes)
1603 if err != nil {
1604 e.ModuleErrorf("glob: %s", err.Error())
1605 }
1606 return pathsForModuleSrcFromFullPath(e, ret, true)
1607}
1608
1609func (e *earlyModuleContext) GlobFiles(globPattern string, excludes []string) Paths {
1610 ret, err := e.GlobWithDeps(globPattern, excludes)
1611 if err != nil {
1612 e.ModuleErrorf("glob: %s", err.Error())
1613 }
1614 return pathsForModuleSrcFromFullPath(e, ret, false)
1615}
1616
Colin Cross988414c2020-01-11 01:11:46 +00001617func (b *earlyModuleContext) IsSymlink(path Path) bool {
1618 fileInfo, err := b.config.fs.Lstat(path.String())
1619 if err != nil {
1620 b.ModuleErrorf("os.Lstat(%q) failed: %s", path.String(), err)
1621 }
1622 return fileInfo.Mode()&os.ModeSymlink == os.ModeSymlink
1623}
1624
1625func (b *earlyModuleContext) Readlink(path Path) string {
1626 dest, err := b.config.fs.Readlink(path.String())
1627 if err != nil {
1628 b.ModuleErrorf("os.Readlink(%q) failed: %s", path.String(), err)
1629 }
1630 return dest
1631}
1632
Colin Cross1184b642019-12-30 18:43:07 -08001633func (e *earlyModuleContext) Module() Module {
Colin Crossc34d2322020-01-03 15:23:27 -08001634 module, _ := e.EarlyModuleContext.Module().(Module)
Colin Cross1184b642019-12-30 18:43:07 -08001635 return module
1636}
1637
1638func (e *earlyModuleContext) Config() Config {
Colin Crossc34d2322020-01-03 15:23:27 -08001639 return e.EarlyModuleContext.Config().(Config)
Colin Cross1184b642019-12-30 18:43:07 -08001640}
1641
1642func (e *earlyModuleContext) AConfig() Config {
1643 return e.config
1644}
1645
1646func (e *earlyModuleContext) DeviceConfig() DeviceConfig {
1647 return DeviceConfig{e.config.deviceConfig}
1648}
1649
1650func (e *earlyModuleContext) Platform() bool {
1651 return e.kind == platformModule
1652}
1653
1654func (e *earlyModuleContext) DeviceSpecific() bool {
1655 return e.kind == deviceSpecificModule
1656}
1657
1658func (e *earlyModuleContext) SocSpecific() bool {
1659 return e.kind == socSpecificModule
1660}
1661
1662func (e *earlyModuleContext) ProductSpecific() bool {
1663 return e.kind == productSpecificModule
1664}
1665
1666func (e *earlyModuleContext) SystemExtSpecific() bool {
1667 return e.kind == systemExtSpecificModule
1668}
1669
Colin Cross133ebef2020-08-14 17:38:45 -07001670func (e *earlyModuleContext) Namespace() *Namespace {
1671 return e.EarlyModuleContext.Namespace().(*Namespace)
1672}
1673
Colin Cross1184b642019-12-30 18:43:07 -08001674type baseModuleContext struct {
1675 bp blueprint.BaseModuleContext
1676 earlyModuleContext
Colin Crossfb0c16e2019-11-20 17:12:35 -08001677 os OsType
Colin Cross8b74d172016-09-13 09:59:14 -07001678 target Target
Colin Crossee0bc3b2018-10-02 22:01:37 -07001679 multiTargets []Target
Colin Cross8b74d172016-09-13 09:59:14 -07001680 targetPrimary bool
1681 debug bool
Colin Crossdc35e212019-06-06 16:13:11 -07001682
1683 walkPath []Module
Paul Duffinc5192442020-03-31 11:31:36 +01001684 tagPath []blueprint.DependencyTag
Colin Crossdc35e212019-06-06 16:13:11 -07001685
1686 strictVisitDeps bool // If true, enforce that all dependencies are enabled
Colin Crossf6566ed2015-03-24 11:13:38 -07001687}
1688
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001689func (b *baseModuleContext) OtherModuleName(m blueprint.Module) string {
1690 return b.bp.OtherModuleName(m)
1691}
1692func (b *baseModuleContext) OtherModuleDir(m blueprint.Module) string { return b.bp.OtherModuleDir(m) }
Colin Cross1184b642019-12-30 18:43:07 -08001693func (b *baseModuleContext) OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{}) {
Jooyung Hancd87c692020-02-26 02:05:18 +09001694 b.bp.OtherModuleErrorf(m, fmt, args...)
Colin Cross1184b642019-12-30 18:43:07 -08001695}
1696func (b *baseModuleContext) OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag {
1697 return b.bp.OtherModuleDependencyTag(m)
1698}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001699func (b *baseModuleContext) OtherModuleExists(name string) bool { return b.bp.OtherModuleExists(name) }
Martin Stjernholm009a9dc2020-03-05 17:34:13 +00001700func (b *baseModuleContext) OtherModuleDependencyVariantExists(variations []blueprint.Variation, name string) bool {
1701 return b.bp.OtherModuleDependencyVariantExists(variations, name)
1702}
1703func (b *baseModuleContext) OtherModuleReverseDependencyVariantExists(name string) bool {
1704 return b.bp.OtherModuleReverseDependencyVariantExists(name)
1705}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001706func (b *baseModuleContext) OtherModuleType(m blueprint.Module) string {
1707 return b.bp.OtherModuleType(m)
1708}
Colin Crossd27e7b82020-07-02 11:38:17 -07001709func (b *baseModuleContext) OtherModuleProvider(m blueprint.Module, provider blueprint.ProviderKey) interface{} {
1710 return b.bp.OtherModuleProvider(m, provider)
1711}
1712func (b *baseModuleContext) OtherModuleHasProvider(m blueprint.Module, provider blueprint.ProviderKey) bool {
1713 return b.bp.OtherModuleHasProvider(m, provider)
1714}
1715func (b *baseModuleContext) Provider(provider blueprint.ProviderKey) interface{} {
1716 return b.bp.Provider(provider)
1717}
1718func (b *baseModuleContext) HasProvider(provider blueprint.ProviderKey) bool {
1719 return b.bp.HasProvider(provider)
1720}
1721func (b *baseModuleContext) SetProvider(provider blueprint.ProviderKey, value interface{}) {
1722 b.bp.SetProvider(provider, value)
1723}
Colin Cross1184b642019-12-30 18:43:07 -08001724
1725func (b *baseModuleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1726 return b.bp.GetDirectDepWithTag(name, tag)
1727}
1728
Paul Duffinf88d8e02020-05-07 20:21:34 +01001729func (b *baseModuleContext) blueprintBaseModuleContext() blueprint.BaseModuleContext {
1730 return b.bp
1731}
1732
Colin Cross25de6c32019-06-06 14:29:25 -07001733type moduleContext struct {
Colin Crossdc35e212019-06-06 16:13:11 -07001734 bp blueprint.ModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -07001735 baseModuleContext
Colin Cross897266e2020-02-13 13:22:08 -08001736 installDeps InstallPaths
1737 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001738 checkbuildFiles Paths
Colin Cross8d8f8e22016-08-03 11:57:50 -07001739 module Module
Colin Crossc3d87d32020-06-04 13:25:17 -07001740 phonies map[string]Paths
Colin Crosscec81712017-07-13 14:43:27 -07001741
1742 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001743 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001744 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001745 variables map[string]string
Colin Cross6ff51382015-12-17 16:39:19 -08001746}
1747
Colin Crossb88b3c52019-06-10 15:15:17 -07001748func (m *moduleContext) ninjaError(params BuildParams, err error) (PackageContext, BuildParams) {
1749 return pctx, BuildParams{
Colin Cross4b69c492019-06-07 13:06:06 -07001750 Rule: ErrorRule,
1751 Description: params.Description,
1752 Output: params.Output,
1753 Outputs: params.Outputs,
1754 ImplicitOutput: params.ImplicitOutput,
1755 ImplicitOutputs: params.ImplicitOutputs,
Colin Cross6ff51382015-12-17 16:39:19 -08001756 Args: map[string]string{
1757 "error": err.Error(),
1758 },
Colin Crossb88b3c52019-06-10 15:15:17 -07001759 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001760}
1761
Colin Cross25de6c32019-06-06 14:29:25 -07001762func (m *moduleContext) ModuleBuild(pctx PackageContext, params ModuleBuildParams) {
1763 m.Build(pctx, BuildParams(params))
Colin Cross3f40fa42015-01-30 17:27:36 -08001764}
1765
Colin Cross0875c522017-11-28 17:34:01 -08001766func convertBuildParams(params BuildParams) blueprint.BuildParams {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001767 bparams := blueprint.BuildParams{
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001768 Rule: params.Rule,
Colin Cross0875c522017-11-28 17:34:01 -08001769 Description: params.Description,
Colin Cross33bfb0a2016-11-21 17:23:08 -08001770 Deps: params.Deps,
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001771 Outputs: params.Outputs.Strings(),
1772 ImplicitOutputs: params.ImplicitOutputs.Strings(),
1773 Inputs: params.Inputs.Strings(),
1774 Implicits: params.Implicits.Strings(),
1775 OrderOnly: params.OrderOnly.Strings(),
Colin Cross824f1162020-07-16 13:07:51 -07001776 Validations: params.Validations.Strings(),
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001777 Args: params.Args,
1778 Optional: !params.Default,
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001779 }
1780
Colin Cross33bfb0a2016-11-21 17:23:08 -08001781 if params.Depfile != nil {
1782 bparams.Depfile = params.Depfile.String()
1783 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001784 if params.Output != nil {
1785 bparams.Outputs = append(bparams.Outputs, params.Output.String())
1786 }
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001787 if params.ImplicitOutput != nil {
1788 bparams.ImplicitOutputs = append(bparams.ImplicitOutputs, params.ImplicitOutput.String())
1789 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001790 if params.Input != nil {
1791 bparams.Inputs = append(bparams.Inputs, params.Input.String())
1792 }
1793 if params.Implicit != nil {
1794 bparams.Implicits = append(bparams.Implicits, params.Implicit.String())
1795 }
Colin Cross824f1162020-07-16 13:07:51 -07001796 if params.Validation != nil {
1797 bparams.Validations = append(bparams.Validations, params.Validation.String())
1798 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001799
Colin Cross0b9f31f2019-02-28 11:00:01 -08001800 bparams.Outputs = proptools.NinjaEscapeList(bparams.Outputs)
1801 bparams.ImplicitOutputs = proptools.NinjaEscapeList(bparams.ImplicitOutputs)
1802 bparams.Inputs = proptools.NinjaEscapeList(bparams.Inputs)
1803 bparams.Implicits = proptools.NinjaEscapeList(bparams.Implicits)
1804 bparams.OrderOnly = proptools.NinjaEscapeList(bparams.OrderOnly)
Colin Cross824f1162020-07-16 13:07:51 -07001805 bparams.Validations = proptools.NinjaEscapeList(bparams.Validations)
1806 bparams.Depfile = proptools.NinjaEscape(bparams.Depfile)
Colin Crossfe4bc362018-09-12 10:02:13 -07001807
Colin Cross0875c522017-11-28 17:34:01 -08001808 return bparams
1809}
1810
Colin Cross25de6c32019-06-06 14:29:25 -07001811func (m *moduleContext) Variable(pctx PackageContext, name, value string) {
1812 if m.config.captureBuild {
1813 m.variables[name] = value
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001814 }
1815
Colin Crossdc35e212019-06-06 16:13:11 -07001816 m.bp.Variable(pctx.PackageContext, name, value)
Colin Cross0875c522017-11-28 17:34:01 -08001817}
1818
Colin Cross25de6c32019-06-06 14:29:25 -07001819func (m *moduleContext) Rule(pctx PackageContext, name string, params blueprint.RuleParams,
Colin Cross0875c522017-11-28 17:34:01 -08001820 argNames ...string) blueprint.Rule {
1821
Ramy Medhat944839a2020-03-31 22:14:52 -04001822 if m.config.UseRemoteBuild() {
1823 if params.Pool == nil {
1824 // When USE_GOMA=true or USE_RBE=true are set and the rule is not supported by goma/RBE, restrict
1825 // jobs to the local parallelism value
1826 params.Pool = localPool
1827 } else if params.Pool == remotePool {
1828 // remotePool is a fake pool used to identify rule that are supported for remoting. If the rule's
1829 // pool is the remotePool, replace with nil so that ninja runs it at NINJA_REMOTE_NUM_JOBS
1830 // parallelism.
1831 params.Pool = nil
1832 }
Colin Cross2e2dbc22019-09-25 13:31:46 -07001833 }
1834
Colin Crossdc35e212019-06-06 16:13:11 -07001835 rule := m.bp.Rule(pctx.PackageContext, name, params, argNames...)
Colin Cross4c83e5c2019-02-25 14:54:28 -08001836
Colin Cross25de6c32019-06-06 14:29:25 -07001837 if m.config.captureBuild {
1838 m.ruleParams[rule] = params
Colin Cross4c83e5c2019-02-25 14:54:28 -08001839 }
1840
1841 return rule
Colin Cross0875c522017-11-28 17:34:01 -08001842}
1843
Colin Cross25de6c32019-06-06 14:29:25 -07001844func (m *moduleContext) Build(pctx PackageContext, params BuildParams) {
Colin Crossb88b3c52019-06-10 15:15:17 -07001845 if params.Description != "" {
1846 params.Description = "${moduleDesc}" + params.Description + "${moduleDescSuffix}"
1847 }
1848
1849 if missingDeps := m.GetMissingDependencies(); len(missingDeps) > 0 {
1850 pctx, params = m.ninjaError(params, fmt.Errorf("module %s missing dependencies: %s\n",
1851 m.ModuleName(), strings.Join(missingDeps, ", ")))
1852 }
1853
Colin Cross25de6c32019-06-06 14:29:25 -07001854 if m.config.captureBuild {
1855 m.buildParams = append(m.buildParams, params)
Colin Cross0875c522017-11-28 17:34:01 -08001856 }
1857
Colin Crossdc35e212019-06-06 16:13:11 -07001858 m.bp.Build(pctx.PackageContext, convertBuildParams(params))
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001859}
Colin Crossc3d87d32020-06-04 13:25:17 -07001860
1861func (m *moduleContext) Phony(name string, deps ...Path) {
1862 addPhony(m.config, name, deps...)
1863}
1864
Colin Cross25de6c32019-06-06 14:29:25 -07001865func (m *moduleContext) GetMissingDependencies() []string {
Colin Cross6c4f21f2019-06-06 15:41:36 -07001866 var missingDeps []string
1867 missingDeps = append(missingDeps, m.Module().base().commonProperties.MissingDeps...)
Colin Crossdc35e212019-06-06 16:13:11 -07001868 missingDeps = append(missingDeps, m.bp.GetMissingDependencies()...)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001869 missingDeps = FirstUniqueStrings(missingDeps)
1870 return missingDeps
Colin Cross6ff51382015-12-17 16:39:19 -08001871}
1872
Colin Crossdc35e212019-06-06 16:13:11 -07001873func (b *baseModuleContext) AddMissingDependencies(deps []string) {
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001874 if deps != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001875 missingDeps := &b.Module().base().commonProperties.MissingDeps
Colin Cross6c4f21f2019-06-06 15:41:36 -07001876 *missingDeps = append(*missingDeps, deps...)
1877 *missingDeps = FirstUniqueStrings(*missingDeps)
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001878 }
1879}
1880
Colin Crossdc35e212019-06-06 16:13:11 -07001881func (b *baseModuleContext) validateAndroidModule(module blueprint.Module, strict bool) Module {
Colin Crossd11fcda2017-10-23 17:59:01 -07001882 aModule, _ := module.(Module)
Colin Crossdc35e212019-06-06 16:13:11 -07001883
1884 if !strict {
1885 return aModule
1886 }
1887
Colin Cross380c69a2019-06-10 17:49:58 +00001888 if aModule == nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001889 b.ModuleErrorf("module %q not an android module", b.OtherModuleName(module))
Colin Cross380c69a2019-06-10 17:49:58 +00001890 return nil
1891 }
1892
1893 if !aModule.Enabled() {
Colin Crossdc35e212019-06-06 16:13:11 -07001894 if b.Config().AllowMissingDependencies() {
1895 b.AddMissingDependencies([]string{b.OtherModuleName(aModule)})
Colin Cross380c69a2019-06-10 17:49:58 +00001896 } else {
Colin Crossdc35e212019-06-06 16:13:11 -07001897 b.ModuleErrorf("depends on disabled module %q", b.OtherModuleName(aModule))
Colin Cross380c69a2019-06-10 17:49:58 +00001898 }
1899 return nil
1900 }
Colin Crossd11fcda2017-10-23 17:59:01 -07001901 return aModule
1902}
1903
Colin Crossdc35e212019-06-06 16:13:11 -07001904func (b *baseModuleContext) getDirectDepInternal(name string, tag blueprint.DependencyTag) (blueprint.Module, blueprint.DependencyTag) {
Jiyong Parkf2976302019-04-17 21:47:37 +09001905 type dep struct {
1906 mod blueprint.Module
1907 tag blueprint.DependencyTag
1908 }
1909 var deps []dep
Colin Crossdc35e212019-06-06 16:13:11 -07001910 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001911 if aModule, _ := module.(Module); aModule != nil && aModule.base().BaseModuleName() == name {
Colin Cross1184b642019-12-30 18:43:07 -08001912 returnedTag := b.bp.OtherModuleDependencyTag(aModule)
Jiyong Parkf2976302019-04-17 21:47:37 +09001913 if tag == nil || returnedTag == tag {
1914 deps = append(deps, dep{aModule, returnedTag})
1915 }
1916 }
1917 })
1918 if len(deps) == 1 {
1919 return deps[0].mod, deps[0].tag
1920 } else if len(deps) >= 2 {
1921 panic(fmt.Errorf("Multiple dependencies having same BaseModuleName() %q found from %q",
Colin Crossdc35e212019-06-06 16:13:11 -07001922 name, b.ModuleName()))
Jiyong Parkf2976302019-04-17 21:47:37 +09001923 } else {
1924 return nil, nil
1925 }
1926}
1927
Colin Crossdc35e212019-06-06 16:13:11 -07001928func (b *baseModuleContext) GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module {
Colin Cross0ef08162019-05-01 15:50:51 -07001929 var deps []Module
Colin Crossdc35e212019-06-06 16:13:11 -07001930 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001931 if aModule, _ := module.(Module); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001932 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Cross0ef08162019-05-01 15:50:51 -07001933 deps = append(deps, aModule)
1934 }
1935 }
1936 })
1937 return deps
1938}
1939
Colin Cross25de6c32019-06-06 14:29:25 -07001940func (m *moduleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1941 module, _ := m.getDirectDepInternal(name, tag)
1942 return module
Jiyong Parkf2976302019-04-17 21:47:37 +09001943}
1944
Colin Crossdc35e212019-06-06 16:13:11 -07001945func (b *baseModuleContext) GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag) {
1946 return b.getDirectDepInternal(name, nil)
Jiyong Parkf2976302019-04-17 21:47:37 +09001947}
1948
Colin Crossdc35e212019-06-06 16:13:11 -07001949func (b *baseModuleContext) VisitDirectDepsBlueprint(visit func(blueprint.Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001950 b.bp.VisitDirectDeps(visit)
Colin Cross35143d02017-11-16 00:11:20 -08001951}
1952
Colin Crossdc35e212019-06-06 16:13:11 -07001953func (b *baseModuleContext) VisitDirectDeps(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001954 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001955 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001956 visit(aModule)
1957 }
1958 })
1959}
1960
Colin Crossdc35e212019-06-06 16:13:11 -07001961func (b *baseModuleContext) VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001962 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001963 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08001964 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Crossee6143c2017-12-30 17:54:27 -08001965 visit(aModule)
1966 }
1967 }
1968 })
1969}
1970
Colin Crossdc35e212019-06-06 16:13:11 -07001971func (b *baseModuleContext) VisitDirectDepsIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001972 b.bp.VisitDirectDepsIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001973 // pred
1974 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001975 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001976 return pred(aModule)
1977 } else {
1978 return false
1979 }
1980 },
1981 // visit
1982 func(module blueprint.Module) {
1983 visit(module.(Module))
1984 })
1985}
1986
Colin Crossdc35e212019-06-06 16:13:11 -07001987func (b *baseModuleContext) VisitDepsDepthFirst(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001988 b.bp.VisitDepsDepthFirst(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07001989 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001990 visit(aModule)
1991 }
1992 })
1993}
1994
Colin Crossdc35e212019-06-06 16:13:11 -07001995func (b *baseModuleContext) VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08001996 b.bp.VisitDepsDepthFirstIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001997 // pred
1998 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001999 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07002000 return pred(aModule)
2001 } else {
2002 return false
2003 }
2004 },
2005 // visit
2006 func(module blueprint.Module) {
2007 visit(module.(Module))
2008 })
2009}
2010
Colin Crossdc35e212019-06-06 16:13:11 -07002011func (b *baseModuleContext) WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool) {
Colin Cross1184b642019-12-30 18:43:07 -08002012 b.bp.WalkDeps(visit)
Alex Light778127a2019-02-27 14:19:50 -08002013}
2014
Colin Crossdc35e212019-06-06 16:13:11 -07002015func (b *baseModuleContext) WalkDeps(visit func(Module, Module) bool) {
2016 b.walkPath = []Module{b.Module()}
Paul Duffinc5192442020-03-31 11:31:36 +01002017 b.tagPath = []blueprint.DependencyTag{}
Colin Cross1184b642019-12-30 18:43:07 -08002018 b.bp.WalkDeps(func(child, parent blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07002019 childAndroidModule, _ := child.(Module)
2020 parentAndroidModule, _ := parent.(Module)
Colin Crossd11fcda2017-10-23 17:59:01 -07002021 if childAndroidModule != nil && parentAndroidModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07002022 // record walkPath before visit
2023 for b.walkPath[len(b.walkPath)-1] != parentAndroidModule {
2024 b.walkPath = b.walkPath[0 : len(b.walkPath)-1]
Paul Duffinc5192442020-03-31 11:31:36 +01002025 b.tagPath = b.tagPath[0 : len(b.tagPath)-1]
Colin Crossdc35e212019-06-06 16:13:11 -07002026 }
2027 b.walkPath = append(b.walkPath, childAndroidModule)
Paul Duffinc5192442020-03-31 11:31:36 +01002028 b.tagPath = append(b.tagPath, b.OtherModuleDependencyTag(childAndroidModule))
Colin Crossd11fcda2017-10-23 17:59:01 -07002029 return visit(childAndroidModule, parentAndroidModule)
2030 } else {
2031 return false
2032 }
2033 })
2034}
2035
Colin Crossdc35e212019-06-06 16:13:11 -07002036func (b *baseModuleContext) GetWalkPath() []Module {
2037 return b.walkPath
2038}
2039
Paul Duffinc5192442020-03-31 11:31:36 +01002040func (b *baseModuleContext) GetTagPath() []blueprint.DependencyTag {
2041 return b.tagPath
2042}
2043
Colin Cross4dfacf92020-09-16 19:22:27 -07002044func (b *baseModuleContext) VisitAllModuleVariants(visit func(Module)) {
2045 b.bp.VisitAllModuleVariants(func(module blueprint.Module) {
2046 visit(module.(Module))
2047 })
2048}
2049
2050func (b *baseModuleContext) PrimaryModule() Module {
2051 return b.bp.PrimaryModule().(Module)
2052}
2053
2054func (b *baseModuleContext) FinalModule() Module {
2055 return b.bp.FinalModule().(Module)
2056}
2057
Jiyong Park1c7e9622020-05-07 16:12:13 +09002058// A regexp for removing boilerplate from BaseDependencyTag from the string representation of
2059// a dependency tag.
Colin Cross6e511a92020-07-27 21:26:48 -07002060var tagCleaner = regexp.MustCompile(`\QBaseDependencyTag:{}\E(, )?`)
Jiyong Park1c7e9622020-05-07 16:12:13 +09002061
2062// PrettyPrintTag returns string representation of the tag, but prefers
2063// custom String() method if available.
2064func PrettyPrintTag(tag blueprint.DependencyTag) string {
2065 // Use tag's custom String() method if available.
2066 if stringer, ok := tag.(fmt.Stringer); ok {
2067 return stringer.String()
2068 }
2069
2070 // Otherwise, get a default string representation of the tag's struct.
Colin Cross6e511a92020-07-27 21:26:48 -07002071 tagString := fmt.Sprintf("%T: %+v", tag, tag)
Jiyong Park1c7e9622020-05-07 16:12:13 +09002072
2073 // Remove the boilerplate from BaseDependencyTag as it adds no value.
2074 tagString = tagCleaner.ReplaceAllString(tagString, "")
2075 return tagString
2076}
2077
2078func (b *baseModuleContext) GetPathString(skipFirst bool) string {
2079 sb := strings.Builder{}
2080 tagPath := b.GetTagPath()
2081 walkPath := b.GetWalkPath()
2082 if !skipFirst {
2083 sb.WriteString(walkPath[0].String())
2084 }
2085 for i, m := range walkPath[1:] {
2086 sb.WriteString("\n")
2087 sb.WriteString(fmt.Sprintf(" via tag %s\n", PrettyPrintTag(tagPath[i])))
2088 sb.WriteString(fmt.Sprintf(" -> %s", m.String()))
2089 }
2090 return sb.String()
2091}
2092
Colin Crossdc35e212019-06-06 16:13:11 -07002093func (m *moduleContext) ModuleSubDir() string {
2094 return m.bp.ModuleSubDir()
Colin Cross0875c522017-11-28 17:34:01 -08002095}
2096
Colin Cross0ea8ba82019-06-06 14:33:29 -07002097func (b *baseModuleContext) Target() Target {
Colin Cross25de6c32019-06-06 14:29:25 -07002098 return b.target
Colin Crossa1ad8d12016-06-01 17:09:44 -07002099}
2100
Colin Cross0ea8ba82019-06-06 14:33:29 -07002101func (b *baseModuleContext) TargetPrimary() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002102 return b.targetPrimary
Colin Cross8b74d172016-09-13 09:59:14 -07002103}
2104
Colin Cross0ea8ba82019-06-06 14:33:29 -07002105func (b *baseModuleContext) MultiTargets() []Target {
Colin Cross25de6c32019-06-06 14:29:25 -07002106 return b.multiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07002107}
2108
Colin Cross0ea8ba82019-06-06 14:33:29 -07002109func (b *baseModuleContext) Arch() Arch {
Colin Cross25de6c32019-06-06 14:29:25 -07002110 return b.target.Arch
Colin Cross3f40fa42015-01-30 17:27:36 -08002111}
2112
Colin Cross0ea8ba82019-06-06 14:33:29 -07002113func (b *baseModuleContext) Os() OsType {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002114 return b.os
Dan Willemsen490fd492015-11-24 17:53:15 -08002115}
2116
Colin Cross0ea8ba82019-06-06 14:33:29 -07002117func (b *baseModuleContext) Host() bool {
Jiyong Park1613e552020-09-14 19:43:17 +09002118 return b.os.Class == Host
Colin Crossf6566ed2015-03-24 11:13:38 -07002119}
2120
Colin Cross0ea8ba82019-06-06 14:33:29 -07002121func (b *baseModuleContext) Device() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002122 return b.os.Class == Device
Colin Crossf6566ed2015-03-24 11:13:38 -07002123}
2124
Colin Cross0ea8ba82019-06-06 14:33:29 -07002125func (b *baseModuleContext) Darwin() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002126 return b.os == Darwin
Colin Cross0af4b842015-04-30 16:36:18 -07002127}
2128
Colin Cross0ea8ba82019-06-06 14:33:29 -07002129func (b *baseModuleContext) Fuchsia() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002130 return b.os == Fuchsia
Doug Horn21b94272019-01-16 12:06:11 -08002131}
2132
Colin Cross0ea8ba82019-06-06 14:33:29 -07002133func (b *baseModuleContext) Windows() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002134 return b.os == Windows
Colin Cross3edeee12017-04-04 12:59:48 -07002135}
2136
Colin Cross0ea8ba82019-06-06 14:33:29 -07002137func (b *baseModuleContext) Debug() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002138 return b.debug
Colin Crossf6566ed2015-03-24 11:13:38 -07002139}
2140
Colin Cross0ea8ba82019-06-06 14:33:29 -07002141func (b *baseModuleContext) PrimaryArch() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002142 if len(b.config.Targets[b.target.Os]) <= 1 {
Colin Cross67a5c132017-05-09 13:45:28 -07002143 return true
2144 }
Colin Cross25de6c32019-06-06 14:29:25 -07002145 return b.target.Arch.ArchType == b.config.Targets[b.target.Os][0].Arch.ArchType
Colin Cross1e7d3702016-08-24 15:25:47 -07002146}
2147
Jiyong Park5baac542018-08-28 09:55:37 +09002148// Makes this module a platform module, i.e. not specific to soc, device,
Justin Yund5f6c822019-06-25 16:47:17 +09002149// product, or system_ext.
Colin Cross4157e882019-06-06 16:57:04 -07002150func (m *ModuleBase) MakeAsPlatform() {
2151 m.commonProperties.Vendor = boolPtr(false)
2152 m.commonProperties.Proprietary = boolPtr(false)
2153 m.commonProperties.Soc_specific = boolPtr(false)
2154 m.commonProperties.Product_specific = boolPtr(false)
Justin Yund5f6c822019-06-25 16:47:17 +09002155 m.commonProperties.System_ext_specific = boolPtr(false)
Jiyong Park5baac542018-08-28 09:55:37 +09002156}
2157
Colin Cross4157e882019-06-06 16:57:04 -07002158func (m *ModuleBase) EnableNativeBridgeSupportByDefault() {
2159 m.commonProperties.Native_bridge_supported = boolPtr(true)
dimitry03dc3f62019-05-09 14:07:34 +02002160}
2161
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09002162func (m *ModuleBase) MakeAsSystemExt() {
Jooyung Han91df2082019-11-20 01:49:42 +09002163 m.commonProperties.Vendor = boolPtr(false)
2164 m.commonProperties.Proprietary = boolPtr(false)
2165 m.commonProperties.Soc_specific = boolPtr(false)
2166 m.commonProperties.Product_specific = boolPtr(false)
2167 m.commonProperties.System_ext_specific = boolPtr(true)
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09002168}
2169
Jooyung Han344d5432019-08-23 11:17:39 +09002170// IsNativeBridgeSupported returns true if "native_bridge_supported" is explicitly set as "true"
2171func (m *ModuleBase) IsNativeBridgeSupported() bool {
2172 return proptools.Bool(m.commonProperties.Native_bridge_supported)
2173}
2174
Colin Cross25de6c32019-06-06 14:29:25 -07002175func (m *moduleContext) InstallInData() bool {
2176 return m.module.InstallInData()
Dan Willemsen782a2d12015-12-21 14:55:28 -08002177}
2178
Jaewoong Jung0949f312019-09-11 10:25:18 -07002179func (m *moduleContext) InstallInTestcases() bool {
2180 return m.module.InstallInTestcases()
2181}
2182
Colin Cross25de6c32019-06-06 14:29:25 -07002183func (m *moduleContext) InstallInSanitizerDir() bool {
2184 return m.module.InstallInSanitizerDir()
Vishwath Mohan1dd88392017-03-29 22:00:18 -07002185}
2186
Yifan Hong1b3348d2020-01-21 15:53:22 -08002187func (m *moduleContext) InstallInRamdisk() bool {
2188 return m.module.InstallInRamdisk()
2189}
2190
Colin Cross25de6c32019-06-06 14:29:25 -07002191func (m *moduleContext) InstallInRecovery() bool {
2192 return m.module.InstallInRecovery()
Jiyong Parkf9332f12018-02-01 00:54:12 +09002193}
2194
Colin Cross90ba5f42019-10-02 11:10:58 -07002195func (m *moduleContext) InstallInRoot() bool {
2196 return m.module.InstallInRoot()
2197}
2198
Colin Cross607d8582019-07-29 16:44:46 -07002199func (m *moduleContext) InstallBypassMake() bool {
2200 return m.module.InstallBypassMake()
2201}
2202
Jiyong Park87788b52020-09-01 12:37:45 +09002203func (m *moduleContext) InstallForceOS() (*OsType, *ArchType) {
Colin Cross6e359402020-02-10 15:29:54 -08002204 return m.module.InstallForceOS()
2205}
2206
Colin Cross70dda7e2019-10-01 22:05:35 -07002207func (m *moduleContext) skipInstall(fullInstallPath InstallPath) bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002208 if m.module.base().commonProperties.SkipInstall {
Colin Cross893d8162017-04-26 17:34:03 -07002209 return true
2210 }
2211
Colin Cross3607f212018-05-07 15:28:05 -07002212 // We'll need a solution for choosing which of modules with the same name in different
2213 // namespaces to install. For now, reuse the list of namespaces exported to Make as the
2214 // list of namespaces to install in a Soong-only build.
Colin Cross25de6c32019-06-06 14:29:25 -07002215 if !m.module.base().commonProperties.NamespaceExportedToMake {
Colin Cross3607f212018-05-07 15:28:05 -07002216 return true
2217 }
2218
Colin Cross25de6c32019-06-06 14:29:25 -07002219 if m.Device() {
Colin Cross607d8582019-07-29 16:44:46 -07002220 if m.Config().EmbeddedInMake() && !m.InstallBypassMake() {
Colin Cross893d8162017-04-26 17:34:03 -07002221 return true
2222 }
2223
Colin Cross25de6c32019-06-06 14:29:25 -07002224 if m.Config().SkipMegaDeviceInstall(fullInstallPath.String()) {
Colin Cross893d8162017-04-26 17:34:03 -07002225 return true
2226 }
2227 }
2228
2229 return false
2230}
2231
Colin Cross70dda7e2019-10-01 22:05:35 -07002232func (m *moduleContext) InstallFile(installPath InstallPath, name string, srcPath Path,
2233 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002234 return m.installFile(installPath, name, srcPath, Cp, deps)
Colin Cross5c517922017-08-31 12:29:17 -07002235}
2236
Colin Cross70dda7e2019-10-01 22:05:35 -07002237func (m *moduleContext) InstallExecutable(installPath InstallPath, name string, srcPath Path,
2238 deps ...Path) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002239 return m.installFile(installPath, name, srcPath, CpExecutable, deps)
Colin Cross5c517922017-08-31 12:29:17 -07002240}
2241
Colin Cross70dda7e2019-10-01 22:05:35 -07002242func (m *moduleContext) installFile(installPath InstallPath, name string, srcPath Path,
2243 rule blueprint.Rule, deps []Path) InstallPath {
Colin Cross35cec122015-04-02 14:37:16 -07002244
Colin Cross25de6c32019-06-06 14:29:25 -07002245 fullInstallPath := installPath.Join(m, name)
David Srbecky07656412020-06-04 01:26:16 +01002246 m.module.base().hooks.runInstallHooks(m, srcPath, fullInstallPath, false)
Colin Cross3f40fa42015-01-30 17:27:36 -08002247
Colin Cross25de6c32019-06-06 14:29:25 -07002248 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07002249
Colin Cross897266e2020-02-13 13:22:08 -08002250 deps = append(deps, m.installDeps.Paths()...)
Colin Cross35cec122015-04-02 14:37:16 -07002251
Colin Cross89562dc2016-10-03 17:47:19 -07002252 var implicitDeps, orderOnlyDeps Paths
2253
Colin Cross25de6c32019-06-06 14:29:25 -07002254 if m.Host() {
Colin Cross89562dc2016-10-03 17:47:19 -07002255 // Installed host modules might be used during the build, depend directly on their
2256 // dependencies so their timestamp is updated whenever their dependency is updated
2257 implicitDeps = deps
2258 } else {
2259 orderOnlyDeps = deps
2260 }
2261
Colin Cross25de6c32019-06-06 14:29:25 -07002262 m.Build(pctx, BuildParams{
Colin Cross5c517922017-08-31 12:29:17 -07002263 Rule: rule,
Colin Cross67a5c132017-05-09 13:45:28 -07002264 Description: "install " + fullInstallPath.Base(),
2265 Output: fullInstallPath,
2266 Input: srcPath,
2267 Implicits: implicitDeps,
2268 OrderOnly: orderOnlyDeps,
Colin Cross25de6c32019-06-06 14:29:25 -07002269 Default: !m.Config().EmbeddedInMake(),
Dan Willemsen322acaf2016-01-12 23:07:05 -08002270 })
Colin Cross3f40fa42015-01-30 17:27:36 -08002271
Colin Cross25de6c32019-06-06 14:29:25 -07002272 m.installFiles = append(m.installFiles, fullInstallPath)
Dan Willemsen322acaf2016-01-12 23:07:05 -08002273 }
Colin Cross25de6c32019-06-06 14:29:25 -07002274 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross35cec122015-04-02 14:37:16 -07002275 return fullInstallPath
2276}
2277
Colin Cross70dda7e2019-10-01 22:05:35 -07002278func (m *moduleContext) InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002279 fullInstallPath := installPath.Join(m, name)
David Srbecky07656412020-06-04 01:26:16 +01002280 m.module.base().hooks.runInstallHooks(m, srcPath, fullInstallPath, true)
Colin Cross3854a602016-01-11 12:49:11 -08002281
Colin Cross25de6c32019-06-06 14:29:25 -07002282 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07002283
Alex Lightfb4353d2019-01-17 13:57:45 -08002284 relPath, err := filepath.Rel(path.Dir(fullInstallPath.String()), srcPath.String())
2285 if err != nil {
2286 panic(fmt.Sprintf("Unable to generate symlink between %q and %q: %s", fullInstallPath.Base(), srcPath.Base(), err))
2287 }
Colin Cross25de6c32019-06-06 14:29:25 -07002288 m.Build(pctx, BuildParams{
Colin Cross67a5c132017-05-09 13:45:28 -07002289 Rule: Symlink,
2290 Description: "install symlink " + fullInstallPath.Base(),
2291 Output: fullInstallPath,
Dan Willemsen40efa1c2020-01-14 15:19:52 -08002292 Input: srcPath,
Colin Cross25de6c32019-06-06 14:29:25 -07002293 Default: !m.Config().EmbeddedInMake(),
Colin Cross12fc4972016-01-11 12:49:11 -08002294 Args: map[string]string{
Alex Lightfb4353d2019-01-17 13:57:45 -08002295 "fromPath": relPath,
Colin Cross12fc4972016-01-11 12:49:11 -08002296 },
2297 })
Colin Cross3854a602016-01-11 12:49:11 -08002298
Colin Cross25de6c32019-06-06 14:29:25 -07002299 m.installFiles = append(m.installFiles, fullInstallPath)
2300 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross12fc4972016-01-11 12:49:11 -08002301 }
Colin Cross3854a602016-01-11 12:49:11 -08002302 return fullInstallPath
2303}
2304
Jiyong Parkf1194352019-02-25 11:05:47 +09002305// installPath/name -> absPath where absPath might be a path that is available only at runtime
2306// (e.g. /apex/...)
Colin Cross70dda7e2019-10-01 22:05:35 -07002307func (m *moduleContext) InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002308 fullInstallPath := installPath.Join(m, name)
David Srbecky07656412020-06-04 01:26:16 +01002309 m.module.base().hooks.runInstallHooks(m, nil, fullInstallPath, true)
Jiyong Parkf1194352019-02-25 11:05:47 +09002310
Colin Cross25de6c32019-06-06 14:29:25 -07002311 if !m.skipInstall(fullInstallPath) {
2312 m.Build(pctx, BuildParams{
Jiyong Parkf1194352019-02-25 11:05:47 +09002313 Rule: Symlink,
2314 Description: "install symlink " + fullInstallPath.Base() + " -> " + absPath,
2315 Output: fullInstallPath,
Colin Cross25de6c32019-06-06 14:29:25 -07002316 Default: !m.Config().EmbeddedInMake(),
Jiyong Parkf1194352019-02-25 11:05:47 +09002317 Args: map[string]string{
2318 "fromPath": absPath,
2319 },
2320 })
2321
Colin Cross25de6c32019-06-06 14:29:25 -07002322 m.installFiles = append(m.installFiles, fullInstallPath)
Jiyong Parkf1194352019-02-25 11:05:47 +09002323 }
2324 return fullInstallPath
2325}
2326
Colin Cross25de6c32019-06-06 14:29:25 -07002327func (m *moduleContext) CheckbuildFile(srcPath Path) {
2328 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross3f40fa42015-01-30 17:27:36 -08002329}
2330
Colin Cross41955e82019-05-29 14:40:35 -07002331// SrcIsModule decodes module references in the format ":name" into the module name, or empty string if the input
2332// was not a module reference.
2333func SrcIsModule(s string) (module string) {
Colin Cross068e0fe2016-12-13 15:23:47 -08002334 if len(s) > 1 && s[0] == ':' {
2335 return s[1:]
2336 }
2337 return ""
2338}
2339
Colin Cross41955e82019-05-29 14:40:35 -07002340// SrcIsModule decodes module references in the format ":name{.tag}" into the module name and tag, ":name" into the
2341// module name and an empty string for the tag, or empty strings if the input was not a module reference.
2342func SrcIsModuleWithTag(s string) (module, tag string) {
2343 if len(s) > 1 && s[0] == ':' {
2344 module = s[1:]
2345 if tagStart := strings.IndexByte(module, '{'); tagStart > 0 {
2346 if module[len(module)-1] == '}' {
2347 tag = module[tagStart+1 : len(module)-1]
2348 module = module[:tagStart]
2349 return module, tag
2350 }
2351 }
2352 return module, ""
2353 }
2354 return "", ""
Colin Cross068e0fe2016-12-13 15:23:47 -08002355}
2356
Colin Cross41955e82019-05-29 14:40:35 -07002357type sourceOrOutputDependencyTag struct {
2358 blueprint.BaseDependencyTag
2359 tag string
2360}
2361
2362func sourceOrOutputDepTag(tag string) blueprint.DependencyTag {
2363 return sourceOrOutputDependencyTag{tag: tag}
2364}
2365
2366var SourceDepTag = sourceOrOutputDepTag("")
Colin Cross068e0fe2016-12-13 15:23:47 -08002367
Colin Cross366938f2017-12-11 16:29:02 -08002368// Adds necessary dependencies to satisfy filegroup or generated sources modules listed in srcFiles
2369// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002370//
2371// Deprecated: tag the property with `android:"path"` instead.
Colin Cross068e0fe2016-12-13 15:23:47 -08002372func ExtractSourcesDeps(ctx BottomUpMutatorContext, srcFiles []string) {
Nan Zhang2439eb72017-04-10 11:27:50 -07002373 set := make(map[string]bool)
2374
Colin Cross068e0fe2016-12-13 15:23:47 -08002375 for _, s := range srcFiles {
Colin Cross41955e82019-05-29 14:40:35 -07002376 if m, t := SrcIsModuleWithTag(s); m != "" {
2377 if _, found := set[s]; found {
2378 ctx.ModuleErrorf("found source dependency duplicate: %q!", s)
Nan Zhang2439eb72017-04-10 11:27:50 -07002379 } else {
Colin Cross41955e82019-05-29 14:40:35 -07002380 set[s] = true
2381 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Nan Zhang2439eb72017-04-10 11:27:50 -07002382 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002383 }
2384 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002385}
2386
Colin Cross366938f2017-12-11 16:29:02 -08002387// Adds necessary dependencies to satisfy filegroup or generated sources modules specified in s
2388// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002389//
2390// Deprecated: tag the property with `android:"path"` instead.
Colin Cross366938f2017-12-11 16:29:02 -08002391func ExtractSourceDeps(ctx BottomUpMutatorContext, s *string) {
2392 if s != nil {
Colin Cross41955e82019-05-29 14:40:35 -07002393 if m, t := SrcIsModuleWithTag(*s); m != "" {
2394 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Colin Cross366938f2017-12-11 16:29:02 -08002395 }
2396 }
2397}
2398
Colin Cross41955e82019-05-29 14:40:35 -07002399// A module that implements SourceFileProducer can be referenced from any property that is tagged with `android:"path"`
2400// 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 -08002401type SourceFileProducer interface {
2402 Srcs() Paths
2403}
2404
Colin Cross41955e82019-05-29 14:40:35 -07002405// A module that implements OutputFileProducer can be referenced from any property that is tagged with `android:"path"`
Roland Levillain97c1f342019-11-22 14:20:54 +00002406// 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 -07002407// listed in the property.
2408type OutputFileProducer interface {
2409 OutputFiles(tag string) (Paths, error)
2410}
2411
Colin Cross5e708052019-08-06 13:59:50 -07002412// OutputFilesForModule returns the paths from an OutputFileProducer with the given tag. On error, including if the
2413// module produced zero paths, it reports errors to the ctx and returns nil.
2414func OutputFilesForModule(ctx PathContext, module blueprint.Module, tag string) Paths {
2415 paths, err := outputFilesForModule(ctx, module, tag)
2416 if err != nil {
2417 reportPathError(ctx, err)
2418 return nil
2419 }
2420 return paths
2421}
2422
2423// OutputFileForModule returns the path from an OutputFileProducer with the given tag. On error, including if the
2424// module produced zero or multiple paths, it reports errors to the ctx and returns nil.
2425func OutputFileForModule(ctx PathContext, module blueprint.Module, tag string) Path {
2426 paths, err := outputFilesForModule(ctx, module, tag)
2427 if err != nil {
2428 reportPathError(ctx, err)
2429 return nil
2430 }
2431 if len(paths) > 1 {
Ulya Trafimovich5ab276a2020-08-25 12:45:15 +01002432 ReportPathErrorf(ctx, "got multiple output files from module %q, expected exactly one",
Colin Cross5e708052019-08-06 13:59:50 -07002433 pathContextName(ctx, module))
2434 return nil
2435 }
2436 return paths[0]
2437}
2438
2439func outputFilesForModule(ctx PathContext, module blueprint.Module, tag string) (Paths, error) {
2440 if outputFileProducer, ok := module.(OutputFileProducer); ok {
2441 paths, err := outputFileProducer.OutputFiles(tag)
2442 if err != nil {
2443 return nil, fmt.Errorf("failed to get output file from module %q: %s",
2444 pathContextName(ctx, module), err.Error())
2445 }
2446 if len(paths) == 0 {
2447 return nil, fmt.Errorf("failed to get output files from module %q", pathContextName(ctx, module))
2448 }
2449 return paths, nil
2450 } else {
2451 return nil, fmt.Errorf("module %q is not an OutputFileProducer", pathContextName(ctx, module))
2452 }
2453}
2454
Colin Crossfe17f6f2019-03-28 19:30:56 -07002455type HostToolProvider interface {
2456 HostToolPath() OptionalPath
2457}
2458
Colin Cross27b922f2019-03-04 22:35:41 -08002459// Returns a list of paths expanded from globs and modules referenced using ":module" syntax. The property must
2460// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002461//
2462// Deprecated: use PathsForModuleSrc or PathsForModuleSrcExcludes instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002463func (m *moduleContext) ExpandSources(srcFiles, excludes []string) Paths {
2464 return PathsForModuleSrcExcludes(m, srcFiles, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07002465}
2466
Colin Cross2fafa3e2019-03-05 12:39:51 -08002467// Returns a single path expanded from globs and modules referenced using ":module" syntax. The property must
2468// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002469//
2470// Deprecated: use PathForModuleSrc instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002471func (m *moduleContext) ExpandSource(srcFile, prop string) Path {
2472 return PathForModuleSrc(m, srcFile)
Colin Cross2fafa3e2019-03-05 12:39:51 -08002473}
2474
2475// Returns an optional single path expanded from globs and modules referenced using ":module" syntax if
2476// the srcFile is non-nil. The property must be tagged with `android:"path" to support automatic source module
2477// dependency resolution.
Colin Cross25de6c32019-06-06 14:29:25 -07002478func (m *moduleContext) ExpandOptionalSource(srcFile *string, prop string) OptionalPath {
Colin Cross2fafa3e2019-03-05 12:39:51 -08002479 if srcFile != nil {
Colin Cross25de6c32019-06-06 14:29:25 -07002480 return OptionalPathForPath(PathForModuleSrc(m, *srcFile))
Colin Cross2fafa3e2019-03-05 12:39:51 -08002481 }
2482 return OptionalPath{}
2483}
2484
Colin Cross25de6c32019-06-06 14:29:25 -07002485func (m *moduleContext) RequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002486 return m.module.RequiredModuleNames()
Nan Zhang6d34b302017-02-04 17:47:46 -08002487}
2488
Colin Cross25de6c32019-06-06 14:29:25 -07002489func (m *moduleContext) HostRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002490 return m.module.HostRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002491}
2492
Colin Cross25de6c32019-06-06 14:29:25 -07002493func (m *moduleContext) TargetRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002494 return m.module.TargetRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002495}
2496
Colin Cross463a90e2015-06-17 14:20:06 -07002497func init() {
Colin Cross798bfce2016-10-12 14:28:16 -07002498 RegisterSingletonType("buildtarget", BuildTargetSingleton)
Colin Cross463a90e2015-06-17 14:20:06 -07002499}
2500
Colin Cross0875c522017-11-28 17:34:01 -08002501func BuildTargetSingleton() Singleton {
Colin Cross1f8c52b2015-06-16 16:38:17 -07002502 return &buildTargetSingleton{}
2503}
2504
Colin Cross87d8b562017-04-25 10:01:55 -07002505func parentDir(dir string) string {
2506 dir, _ = filepath.Split(dir)
2507 return filepath.Clean(dir)
2508}
2509
Colin Cross1f8c52b2015-06-16 16:38:17 -07002510type buildTargetSingleton struct{}
2511
Colin Cross0875c522017-11-28 17:34:01 -08002512func (c *buildTargetSingleton) GenerateBuildActions(ctx SingletonContext) {
2513 var checkbuildDeps Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07002514
Colin Crossc3d87d32020-06-04 13:25:17 -07002515 mmTarget := func(dir string) string {
2516 return "MODULES-IN-" + strings.Replace(filepath.Clean(dir), "/", "-", -1)
Colin Cross87d8b562017-04-25 10:01:55 -07002517 }
2518
Colin Cross0875c522017-11-28 17:34:01 -08002519 modulesInDir := make(map[string]Paths)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002520
Colin Cross0875c522017-11-28 17:34:01 -08002521 ctx.VisitAllModules(func(module Module) {
2522 blueprintDir := module.base().blueprintDir
2523 installTarget := module.base().installTarget
2524 checkbuildTarget := module.base().checkbuildTarget
Colin Cross1f8c52b2015-06-16 16:38:17 -07002525
Colin Cross0875c522017-11-28 17:34:01 -08002526 if checkbuildTarget != nil {
2527 checkbuildDeps = append(checkbuildDeps, checkbuildTarget)
2528 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], checkbuildTarget)
2529 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002530
Colin Cross0875c522017-11-28 17:34:01 -08002531 if installTarget != nil {
2532 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], installTarget)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002533 }
2534 })
2535
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002536 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08002537 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002538 suffix = "-soong"
2539 }
2540
Colin Cross1f8c52b2015-06-16 16:38:17 -07002541 // Create a top-level checkbuild target that depends on all modules
Colin Crossc3d87d32020-06-04 13:25:17 -07002542 ctx.Phony("checkbuild"+suffix, checkbuildDeps...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002543
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002544 // Make will generate the MODULES-IN-* targets
Colin Crossaabf6792017-11-29 00:27:14 -08002545 if ctx.Config().EmbeddedInMake() {
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002546 return
2547 }
2548
Colin Cross87d8b562017-04-25 10:01:55 -07002549 // Ensure ancestor directories are in modulesInDir
Inseob Kim1a365c62019-06-08 15:47:51 +09002550 dirs := SortedStringKeys(modulesInDir)
Colin Cross87d8b562017-04-25 10:01:55 -07002551 for _, dir := range dirs {
2552 dir := parentDir(dir)
2553 for dir != "." && dir != "/" {
2554 if _, exists := modulesInDir[dir]; exists {
2555 break
2556 }
2557 modulesInDir[dir] = nil
2558 dir = parentDir(dir)
2559 }
2560 }
2561
2562 // Make directories build their direct subdirectories
Colin Cross87d8b562017-04-25 10:01:55 -07002563 for _, dir := range dirs {
2564 p := parentDir(dir)
2565 if p != "." && p != "/" {
Colin Crossc3d87d32020-06-04 13:25:17 -07002566 modulesInDir[p] = append(modulesInDir[p], PathForPhony(ctx, mmTarget(dir)))
Colin Cross87d8b562017-04-25 10:01:55 -07002567 }
2568 }
2569
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002570 // Create a MODULES-IN-<directory> target that depends on all modules in a directory, and
2571 // depends on the MODULES-IN-* targets of all of its subdirectories that contain Android.bp
2572 // files.
Colin Cross1f8c52b2015-06-16 16:38:17 -07002573 for _, dir := range dirs {
Colin Crossc3d87d32020-06-04 13:25:17 -07002574 ctx.Phony(mmTarget(dir), modulesInDir[dir]...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002575 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002576
2577 // Create (host|host-cross|target)-<OS> phony rules to build a reduced checkbuild.
Jiyong Park1613e552020-09-14 19:43:17 +09002578 type osAndCross struct {
2579 os OsType
2580 hostCross bool
2581 }
2582 osDeps := map[osAndCross]Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08002583 ctx.VisitAllModules(func(module Module) {
2584 if module.Enabled() {
Jiyong Park1613e552020-09-14 19:43:17 +09002585 key := osAndCross{os: module.Target().Os, hostCross: module.Target().HostCross}
2586 osDeps[key] = append(osDeps[key], module.base().checkbuildFiles...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002587 }
2588 })
2589
Colin Cross0875c522017-11-28 17:34:01 -08002590 osClass := make(map[string]Paths)
Jiyong Park1613e552020-09-14 19:43:17 +09002591 for key, deps := range osDeps {
Dan Willemsen61d88b82017-09-20 17:29:08 -07002592 var className string
2593
Jiyong Park1613e552020-09-14 19:43:17 +09002594 switch key.os.Class {
Dan Willemsen61d88b82017-09-20 17:29:08 -07002595 case Host:
Jiyong Park1613e552020-09-14 19:43:17 +09002596 if key.hostCross {
2597 className = "host-cross"
2598 } else {
2599 className = "host"
2600 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002601 case Device:
2602 className = "target"
2603 default:
2604 continue
2605 }
2606
Jiyong Park1613e552020-09-14 19:43:17 +09002607 name := className + "-" + key.os.Name
Colin Crossc3d87d32020-06-04 13:25:17 -07002608 osClass[className] = append(osClass[className], PathForPhony(ctx, name))
Dan Willemsen61d88b82017-09-20 17:29:08 -07002609
Colin Crossc3d87d32020-06-04 13:25:17 -07002610 ctx.Phony(name, deps...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002611 }
2612
2613 // Wrap those into host|host-cross|target phony rules
Inseob Kim1a365c62019-06-08 15:47:51 +09002614 for _, class := range SortedStringKeys(osClass) {
Colin Crossc3d87d32020-06-04 13:25:17 -07002615 ctx.Phony(class, osClass[class]...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002616 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002617}
Colin Crossd779da42015-12-17 18:00:23 -08002618
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002619// Collect information for opening IDE project files in java/jdeps.go.
2620type IDEInfo interface {
2621 IDEInfo(ideInfo *IdeInfo)
2622 BaseModuleName() string
2623}
2624
2625// Extract the base module name from the Import name.
2626// Often the Import name has a prefix "prebuilt_".
2627// Remove the prefix explicitly if needed
2628// until we find a better solution to get the Import name.
2629type IDECustomizedModuleName interface {
2630 IDECustomizedModuleName() string
2631}
2632
2633type IdeInfo struct {
2634 Deps []string `json:"dependencies,omitempty"`
2635 Srcs []string `json:"srcs,omitempty"`
2636 Aidl_include_dirs []string `json:"aidl_include_dirs,omitempty"`
2637 Jarjar_rules []string `json:"jarjar_rules,omitempty"`
2638 Jars []string `json:"jars,omitempty"`
2639 Classes []string `json:"class,omitempty"`
2640 Installed_paths []string `json:"installed,omitempty"`
patricktu18c82ff2019-05-10 15:48:50 +08002641 SrcJars []string `json:"srcjars,omitempty"`
bralee1fbf4402020-05-21 10:11:59 +08002642 Paths []string `json:"path,omitempty"`
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002643}
Paul Duffinf88d8e02020-05-07 20:21:34 +01002644
2645func CheckBlueprintSyntax(ctx BaseModuleContext, filename string, contents string) []error {
2646 bpctx := ctx.blueprintBaseModuleContext()
2647 return blueprint.CheckBlueprintSyntax(bpctx.ModuleFactories(), filename, contents)
2648}