blob: bbdeb2733c6c4d6c8d9738fb904951ae96ccc238 [file] [log] [blame]
Colin Cross3f40fa42015-01-30 17:27:36 -08001// Copyright 2015 Google Inc. All rights reserved.
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
Colin Cross635c3b02016-05-18 15:37:25 -070015package android
Colin Cross3f40fa42015-01-30 17:27:36 -080016
17import (
Colin Cross6ff51382015-12-17 16:39:19 -080018 "fmt"
Colin Cross988414c2020-01-11 01:11:46 +000019 "os"
Alex Lightfb4353d2019-01-17 13:57:45 -080020 "path"
Colin Cross3f40fa42015-01-30 17:27:36 -080021 "path/filepath"
Jiyong Park1c7e9622020-05-07 16:12:13 +090022 "regexp"
Colin Cross6ff51382015-12-17 16:39:19 -080023 "strings"
Colin Crossaabf6792017-11-29 00:27:14 -080024 "text/scanner"
Colin Crossf6566ed2015-03-24 11:13:38 -070025
26 "github.com/google/blueprint"
Colin Crossfe4bc362018-09-12 10:02:13 -070027 "github.com/google/blueprint/proptools"
Colin Cross3f40fa42015-01-30 17:27:36 -080028)
29
30var (
31 DeviceSharedLibrary = "shared_library"
32 DeviceStaticLibrary = "static_library"
33 DeviceExecutable = "executable"
34 HostSharedLibrary = "host_shared_library"
35 HostStaticLibrary = "host_static_library"
36 HostExecutable = "host_executable"
37)
38
Colin Crossae887032017-10-23 17:16:14 -070039type BuildParams struct {
Dan Willemsen9f3c5742016-11-03 14:28:31 -070040 Rule blueprint.Rule
Colin Cross33bfb0a2016-11-21 17:23:08 -080041 Deps blueprint.Deps
42 Depfile WritablePath
Colin Cross67a5c132017-05-09 13:45:28 -070043 Description string
Dan Willemsen9f3c5742016-11-03 14:28:31 -070044 Output WritablePath
45 Outputs WritablePaths
Jingwen Chence679d22020-09-23 04:30:02 +000046 SymlinkOutput WritablePath
47 SymlinkOutputs WritablePaths
Dan Willemsen9f3c5742016-11-03 14:28:31 -070048 ImplicitOutput WritablePath
49 ImplicitOutputs WritablePaths
50 Input Path
51 Inputs Paths
52 Implicit Path
53 Implicits Paths
54 OrderOnly Paths
Colin Cross824f1162020-07-16 13:07:51 -070055 Validation Path
56 Validations Paths
Dan Willemsen9f3c5742016-11-03 14:28:31 -070057 Default bool
58 Args map[string]string
Dan Willemsen34cc69e2015-09-23 15:26:20 -070059}
60
Colin Crossae887032017-10-23 17:16:14 -070061type ModuleBuildParams BuildParams
62
Colin Cross1184b642019-12-30 18:43:07 -080063// EarlyModuleContext provides methods that can be called early, as soon as the properties have
64// been parsed into the module and before any mutators have run.
65type EarlyModuleContext interface {
Colin Cross9f35c3d2020-09-16 19:04:41 -070066 // Module returns the current module as a Module. It should rarely be necessary, as the module already has a
67 // reference to itself.
Colin Cross1184b642019-12-30 18:43:07 -080068 Module() Module
Colin Cross9f35c3d2020-09-16 19:04:41 -070069
70 // ModuleName returns the name of the module. This is generally the value that was returned by Module.Name() when
71 // the module was created, but may have been modified by calls to BaseMutatorContext.Rename.
Colin Cross1184b642019-12-30 18:43:07 -080072 ModuleName() string
Colin Cross9f35c3d2020-09-16 19:04:41 -070073
74 // ModuleDir returns the path to the directory that contains the definition of the module.
Colin Cross1184b642019-12-30 18:43:07 -080075 ModuleDir() string
Colin Cross9f35c3d2020-09-16 19:04:41 -070076
77 // ModuleType returns the name of the module type that was used to create the module, as specified in
78 // RegisterModuleType.
Colin Cross1184b642019-12-30 18:43:07 -080079 ModuleType() string
Colin Cross9f35c3d2020-09-16 19:04:41 -070080
81 // BlueprintFile returns the name of the blueprint file that contains the definition of this
82 // module.
Colin Cross9d34f352019-11-22 16:03:51 -080083 BlueprintsFile() string
Colin Cross1184b642019-12-30 18:43:07 -080084
Colin Cross9f35c3d2020-09-16 19:04:41 -070085 // ContainsProperty returns true if the specified property name was set in the module definition.
Colin Cross1184b642019-12-30 18:43:07 -080086 ContainsProperty(name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -070087
88 // Errorf reports an error at the specified position of the module definition file.
Colin Cross1184b642019-12-30 18:43:07 -080089 Errorf(pos scanner.Position, fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -070090
91 // ModuleErrorf reports an error at the line number of the module type in the module definition.
Colin Cross1184b642019-12-30 18:43:07 -080092 ModuleErrorf(fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -070093
94 // PropertyErrorf reports an error at the line number of a property in the module definition.
Colin Cross1184b642019-12-30 18:43:07 -080095 PropertyErrorf(property, fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -070096
97 // Failed returns true if any errors have been reported. In most cases the module can continue with generating
98 // build rules after an error, allowing it to report additional errors in a single run, but in cases where the error
99 // has prevented the module from creating necessary data it can return early when Failed returns true.
Colin Cross1184b642019-12-30 18:43:07 -0800100 Failed() bool
101
Colin Cross9f35c3d2020-09-16 19:04:41 -0700102 // AddNinjaFileDeps adds dependencies on the specified files to the rule that creates the ninja manifest. The
103 // primary builder will be rerun whenever the specified files are modified.
Colin Cross1184b642019-12-30 18:43:07 -0800104 AddNinjaFileDeps(deps ...string)
105
106 DeviceSpecific() bool
107 SocSpecific() bool
108 ProductSpecific() bool
109 SystemExtSpecific() bool
110 Platform() bool
111
112 Config() Config
113 DeviceConfig() DeviceConfig
114
115 // Deprecated: use Config()
116 AConfig() Config
117
118 // GlobWithDeps returns a list of files that match the specified pattern but do not match any
119 // of the patterns in excludes. It also adds efficient dependencies to rerun the primary
120 // builder whenever a file matching the pattern as added or removed, without rerunning if a
121 // file that does not match the pattern is added to a searched directory.
122 GlobWithDeps(pattern string, excludes []string) ([]string, error)
123
124 Glob(globPattern string, excludes []string) Paths
125 GlobFiles(globPattern string, excludes []string) Paths
Colin Cross988414c2020-01-11 01:11:46 +0000126 IsSymlink(path Path) bool
127 Readlink(path Path) string
Colin Cross133ebef2020-08-14 17:38:45 -0700128
Colin Cross9f35c3d2020-09-16 19:04:41 -0700129 // Namespace returns the Namespace object provided by the NameInterface set by Context.SetNameInterface, or the
130 // default SimpleNameInterface if Context.SetNameInterface was not called.
Colin Cross133ebef2020-08-14 17:38:45 -0700131 Namespace() *Namespace
Colin Cross1184b642019-12-30 18:43:07 -0800132}
133
Colin Cross0ea8ba82019-06-06 14:33:29 -0700134// BaseModuleContext is the same as blueprint.BaseModuleContext except that Config() returns
Colin Crossdc35e212019-06-06 16:13:11 -0700135// a Config instead of an interface{}, and some methods have been wrapped to use an android.Module
136// instead of a blueprint.Module, plus some extra methods that return Android-specific information
Colin Cross0ea8ba82019-06-06 14:33:29 -0700137// about the current module.
138type BaseModuleContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800139 EarlyModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -0700140
Paul Duffinf88d8e02020-05-07 20:21:34 +0100141 blueprintBaseModuleContext() blueprint.BaseModuleContext
142
Colin Cross9f35c3d2020-09-16 19:04:41 -0700143 // OtherModuleName returns the name of another Module. See BaseModuleContext.ModuleName for more information.
144 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Colin Crossdc35e212019-06-06 16:13:11 -0700145 OtherModuleName(m blueprint.Module) string
Colin Cross9f35c3d2020-09-16 19:04:41 -0700146
147 // OtherModuleDir returns the directory of another Module. See BaseModuleContext.ModuleDir for more information.
148 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Colin Crossdc35e212019-06-06 16:13:11 -0700149 OtherModuleDir(m blueprint.Module) string
Colin Cross9f35c3d2020-09-16 19:04:41 -0700150
151 // OtherModuleErrorf reports an error on another Module. See BaseModuleContext.ModuleErrorf for more information.
152 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Colin Crossdc35e212019-06-06 16:13:11 -0700153 OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -0700154
155 // OtherModuleDependencyTag returns the dependency tag used to depend on a module, or nil if there is no dependency
156 // on the module. When called inside a Visit* method with current module being visited, and there are multiple
157 // dependencies on the module being visited, it returns the dependency tag used for the current dependency.
Colin Crossdc35e212019-06-06 16:13:11 -0700158 OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag
Colin Cross9f35c3d2020-09-16 19:04:41 -0700159
160 // OtherModuleExists returns true if a module with the specified name exists, as determined by the NameInterface
161 // passed to Context.SetNameInterface, or SimpleNameInterface if it was not called.
Colin Crossdc35e212019-06-06 16:13:11 -0700162 OtherModuleExists(name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -0700163
164 // OtherModuleDependencyVariantExists returns true if a module with the
165 // specified name and variant exists. The variant must match the given
166 // variations. It must also match all the non-local variations of the current
167 // module. In other words, it checks for the module AddVariationDependencies
168 // would add a dependency on with the same arguments.
Martin Stjernholm009a9dc2020-03-05 17:34:13 +0000169 OtherModuleDependencyVariantExists(variations []blueprint.Variation, name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -0700170
171 // OtherModuleReverseDependencyVariantExists returns true if a module with the
172 // specified name exists with the same variations as the current module. In
173 // other words, it checks for the module AddReverseDependency would add a
174 // dependency on with the same argument.
Martin Stjernholm009a9dc2020-03-05 17:34:13 +0000175 OtherModuleReverseDependencyVariantExists(name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -0700176
177 // OtherModuleType returns the type of another Module. See BaseModuleContext.ModuleType for more information.
178 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Jiyong Park9e6c2422019-08-09 20:39:45 +0900179 OtherModuleType(m blueprint.Module) string
Colin Crossdc35e212019-06-06 16:13:11 -0700180
Colin Crossd27e7b82020-07-02 11:38:17 -0700181 // OtherModuleProvider returns the value for a provider for the given module. If the value is
182 // not set it returns the zero value of the type of the provider, so the return value can always
183 // be type asserted to the type of the provider. The value returned may be a deep copy of the
184 // value originally passed to SetProvider.
185 OtherModuleProvider(m blueprint.Module, provider blueprint.ProviderKey) interface{}
186
187 // OtherModuleHasProvider returns true if the provider for the given module has been set.
188 OtherModuleHasProvider(m blueprint.Module, provider blueprint.ProviderKey) bool
189
190 // Provider returns the value for a provider for the current module. If the value is
191 // not set it returns the zero value of the type of the provider, so the return value can always
192 // be type asserted to the type of the provider. It panics if called before the appropriate
193 // mutator or GenerateBuildActions pass for the provider. The value returned may be a deep
194 // copy of the value originally passed to SetProvider.
195 Provider(provider blueprint.ProviderKey) interface{}
196
197 // HasProvider returns true if the provider for the current module has been set.
198 HasProvider(provider blueprint.ProviderKey) bool
199
200 // SetProvider sets the value for a provider for the current module. It panics if not called
201 // during the appropriate mutator or GenerateBuildActions pass for the provider, if the value
202 // is not of the appropriate type, or if the value has already been set. The value should not
203 // be modified after being passed to SetProvider.
204 SetProvider(provider blueprint.ProviderKey, value interface{})
205
Colin Crossdc35e212019-06-06 16:13:11 -0700206 GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module
Colin Cross9f35c3d2020-09-16 19:04:41 -0700207
208 // GetDirectDepWithTag returns the Module the direct dependency with the specified name, or nil if
209 // none exists. It panics if the dependency does not have the specified tag. It skips any
210 // dependencies that are not an android.Module.
Colin Crossdc35e212019-06-06 16:13:11 -0700211 GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module
Colin Cross9f35c3d2020-09-16 19:04:41 -0700212
213 // GetDirectDep returns the Module and DependencyTag for the direct dependency with the specified
214 // name, or nil if none exists. If there are multiple dependencies on the same module it returns
215 // the first DependencyTag. It skips any dependencies that are not an android.Module.
Colin Crossdc35e212019-06-06 16:13:11 -0700216 GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag)
217
Colin Cross9f35c3d2020-09-16 19:04:41 -0700218 // VisitDirectDepsBlueprint calls visit for each direct dependency. If there are multiple
219 // direct dependencies on the same module visit will be called multiple times on that module
220 // and OtherModuleDependencyTag will return a different tag for each.
221 //
222 // The Module passed to the visit function should not be retained outside of the visit
223 // function, it may be invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700224 VisitDirectDepsBlueprint(visit func(blueprint.Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700225
226 // VisitDirectDeps calls visit for each direct dependency. If there are multiple
227 // direct dependencies on the same module visit will be called multiple times on that module
228 // and OtherModuleDependencyTag will return a different tag for each. It skips any
229 // dependencies that are not an android.Module.
230 //
231 // The Module passed to the visit function should not be retained outside of the visit
232 // function, it may be invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700233 VisitDirectDeps(visit func(Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700234
Colin Crossdc35e212019-06-06 16:13:11 -0700235 VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700236
237 // VisitDirectDepsIf calls pred for each direct dependency, and if pred returns true calls visit. If there are
238 // multiple direct dependencies on the same module pred and visit will be called multiple times on that module and
239 // OtherModuleDependencyTag will return a different tag for each. It skips any
240 // dependencies that are not an android.Module.
241 //
242 // The Module passed to the visit function should not be retained outside of the visit function, it may be
243 // invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700244 VisitDirectDepsIf(pred func(Module) bool, visit func(Module))
245 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
246 VisitDepsDepthFirst(visit func(Module))
247 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
248 VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700249
250 // WalkDeps calls visit for each transitive dependency, traversing the dependency tree in top down order. visit may
251 // be called multiple times for the same (child, parent) pair if there are multiple direct dependencies between the
252 // child and parent with different tags. OtherModuleDependencyTag will return the tag for the currently visited
253 // (child, parent) pair. If visit returns false WalkDeps will not continue recursing down to child. It skips
254 // any dependencies that are not an android.Module.
255 //
256 // The Modules passed to the visit function should not be retained outside of the visit function, they may be
257 // invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700258 WalkDeps(visit func(Module, Module) bool)
Colin Cross9f35c3d2020-09-16 19:04:41 -0700259
260 // WalkDepsBlueprint calls visit for each transitive dependency, traversing the dependency
261 // tree in top down order. visit may be called multiple times for the same (child, parent)
262 // pair if there are multiple direct dependencies between the child and parent with different
263 // tags. OtherModuleDependencyTag will return the tag for the currently visited
264 // (child, parent) pair. If visit returns false WalkDeps will not continue recursing down
265 // to child.
266 //
267 // The Modules passed to the visit function should not be retained outside of the visit function, they may be
268 // invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700269 WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool)
Colin Cross9f35c3d2020-09-16 19:04:41 -0700270
Colin Crossdc35e212019-06-06 16:13:11 -0700271 // GetWalkPath is supposed to be called in visit function passed in WalkDeps()
272 // and returns a top-down dependency path from a start module to current child module.
273 GetWalkPath() []Module
274
Colin Cross4dfacf92020-09-16 19:22:27 -0700275 // PrimaryModule returns the first variant of the current module. Variants of a module are always visited in
276 // order by mutators and GenerateBuildActions, so the data created by the current mutator can be read from the
277 // Module returned by PrimaryModule without data races. This can be used to perform singleton actions that are
278 // only done once for all variants of a module.
279 PrimaryModule() Module
280
281 // FinalModule returns the last variant of the current module. Variants of a module are always visited in
282 // order by mutators and GenerateBuildActions, so the data created by the current mutator can be read from all
283 // variants using VisitAllModuleVariants if the current module == FinalModule(). This can be used to perform
284 // singleton actions that are only done once for all variants of a module.
285 FinalModule() Module
286
287 // VisitAllModuleVariants calls visit for each variant of the current module. Variants of a module are always
288 // visited in order by mutators and GenerateBuildActions, so the data created by the current mutator can be read
289 // from all variants if the current module == FinalModule(). Otherwise, care must be taken to not access any
290 // data modified by the current mutator.
291 VisitAllModuleVariants(visit func(Module))
292
Paul Duffinc5192442020-03-31 11:31:36 +0100293 // GetTagPath is supposed to be called in visit function passed in WalkDeps()
294 // and returns a top-down dependency tags path from a start module to current child module.
295 // It has one less entry than GetWalkPath() as it contains the dependency tags that
296 // exist between each adjacent pair of modules in the GetWalkPath().
297 // GetTagPath()[i] is the tag between GetWalkPath()[i] and GetWalkPath()[i+1]
298 GetTagPath() []blueprint.DependencyTag
299
Jiyong Park1c7e9622020-05-07 16:12:13 +0900300 // GetPathString is supposed to be called in visit function passed in WalkDeps()
301 // and returns a multi-line string showing the modules and dependency tags
302 // among them along the top-down dependency path from a start module to current child module.
303 // skipFirst when set to true, the output doesn't include the start module,
304 // which is already printed when this function is used along with ModuleErrorf().
305 GetPathString(skipFirst bool) string
306
Colin Crossdc35e212019-06-06 16:13:11 -0700307 AddMissingDependencies(missingDeps []string)
308
Colin Crossa1ad8d12016-06-01 17:09:44 -0700309 Target() Target
Colin Cross8b74d172016-09-13 09:59:14 -0700310 TargetPrimary() bool
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000311
312 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
313 // responsible for creating.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700314 MultiTargets() []Target
Colin Crossf6566ed2015-03-24 11:13:38 -0700315 Arch() Arch
Colin Crossa1ad8d12016-06-01 17:09:44 -0700316 Os() OsType
Colin Crossf6566ed2015-03-24 11:13:38 -0700317 Host() bool
318 Device() bool
Colin Cross0af4b842015-04-30 16:36:18 -0700319 Darwin() bool
Doug Horn21b94272019-01-16 12:06:11 -0800320 Fuchsia() bool
Colin Cross3edeee12017-04-04 12:59:48 -0700321 Windows() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700322 Debug() bool
Colin Cross1e7d3702016-08-24 15:25:47 -0700323 PrimaryArch() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700324}
325
Colin Cross1184b642019-12-30 18:43:07 -0800326// Deprecated: use EarlyModuleContext instead
Colin Cross635c3b02016-05-18 15:37:25 -0700327type BaseContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800328 EarlyModuleContext
Colin Crossaabf6792017-11-29 00:27:14 -0800329}
330
Colin Cross635c3b02016-05-18 15:37:25 -0700331type ModuleContext interface {
Colin Crossaabf6792017-11-29 00:27:14 -0800332 BaseModuleContext
Colin Cross3f40fa42015-01-30 17:27:36 -0800333
Colin Crossae887032017-10-23 17:16:14 -0700334 // Deprecated: use ModuleContext.Build instead.
Colin Cross0875c522017-11-28 17:34:01 -0800335 ModuleBuild(pctx PackageContext, params ModuleBuildParams)
Colin Cross8f101b42015-06-17 15:09:06 -0700336
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700337 ExpandSources(srcFiles, excludes []string) Paths
Colin Cross366938f2017-12-11 16:29:02 -0800338 ExpandSource(srcFile, prop string) Path
Colin Cross2383f3b2018-02-06 14:40:13 -0800339 ExpandOptionalSource(srcFile *string, prop string) OptionalPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700340
Colin Cross70dda7e2019-10-01 22:05:35 -0700341 InstallExecutable(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
342 InstallFile(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
343 InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath
344 InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700345 CheckbuildFile(srcPath Path)
Dan Willemsen6553f5e2016-03-10 18:14:25 -0800346
Colin Cross8d8f8e22016-08-03 11:57:50 -0700347 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700348 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700349 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800350 InstallInRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -0700351 InstallInVendorRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900352 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700353 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700354 InstallBypassMake() bool
Jiyong Park87788b52020-09-01 12:37:45 +0900355 InstallForceOS() (*OsType, *ArchType)
Nan Zhang6d34b302017-02-04 17:47:46 -0800356
357 RequiredModuleNames() []string
Sasha Smundakb6d23052019-04-01 18:37:36 -0700358 HostRequiredModuleNames() []string
359 TargetRequiredModuleNames() []string
Colin Cross3f68a132017-10-23 17:10:29 -0700360
Colin Cross3f68a132017-10-23 17:10:29 -0700361 ModuleSubDir() string
362
Colin Cross0875c522017-11-28 17:34:01 -0800363 Variable(pctx PackageContext, name, value string)
364 Rule(pctx PackageContext, name string, params blueprint.RuleParams, argNames ...string) blueprint.Rule
Colin Crossae887032017-10-23 17:16:14 -0700365 // Similar to blueprint.ModuleContext.Build, but takes Paths instead of []string,
366 // and performs more verification.
Colin Cross0875c522017-11-28 17:34:01 -0800367 Build(pctx PackageContext, params BuildParams)
Colin Crossc3d87d32020-06-04 13:25:17 -0700368 // Phony creates a Make-style phony rule, a rule with no commands that can depend on other
369 // phony rules or real files. Phony can be called on the same name multiple times to add
370 // additional dependencies.
371 Phony(phony string, deps ...Path)
Colin Cross3f68a132017-10-23 17:10:29 -0700372
Colin Cross9f35c3d2020-09-16 19:04:41 -0700373 // GetMissingDependencies returns the list of dependencies that were passed to AddDependencies or related methods,
374 // but do not exist.
Colin Cross3f68a132017-10-23 17:10:29 -0700375 GetMissingDependencies() []string
Colin Cross3f40fa42015-01-30 17:27:36 -0800376}
377
Colin Cross635c3b02016-05-18 15:37:25 -0700378type Module interface {
Colin Cross3f40fa42015-01-30 17:27:36 -0800379 blueprint.Module
380
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700381 // GenerateAndroidBuildActions is analogous to Blueprints' GenerateBuildActions,
382 // but GenerateAndroidBuildActions also has access to Android-specific information.
383 // For more information, see Module.GenerateBuildActions within Blueprint's module_ctx.go
Colin Cross635c3b02016-05-18 15:37:25 -0700384 GenerateAndroidBuildActions(ModuleContext)
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700385
Paul Duffin44f1d842020-06-26 20:17:02 +0100386 // Add dependencies to the components of a module, i.e. modules that are created
387 // by the module and which are considered to be part of the creating module.
388 //
389 // This is called before prebuilts are renamed so as to allow a dependency to be
390 // added directly to a prebuilt child module instead of depending on a source module
391 // and relying on prebuilt processing to switch to the prebuilt module if preferred.
392 //
393 // A dependency on a prebuilt must include the "prebuilt_" prefix.
394 ComponentDepsMutator(ctx BottomUpMutatorContext)
395
Colin Cross1e676be2016-10-12 14:38:15 -0700396 DepsMutator(BottomUpMutatorContext)
Colin Cross3f40fa42015-01-30 17:27:36 -0800397
Colin Cross635c3b02016-05-18 15:37:25 -0700398 base() *ModuleBase
Inseob Kimeec88e12020-01-22 11:11:29 +0900399 Disable()
Dan Willemsen0effe062015-11-30 16:06:01 -0800400 Enabled() bool
Colin Crossa1ad8d12016-06-01 17:09:44 -0700401 Target() Target
Anton Hansson1ee62c02020-06-30 11:51:53 +0100402 Owner() string
Dan Willemsen782a2d12015-12-21 14:55:28 -0800403 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700404 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700405 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800406 InstallInRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -0700407 InstallInVendorRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900408 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700409 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700410 InstallBypassMake() bool
Jiyong Park87788b52020-09-01 12:37:45 +0900411 InstallForceOS() (*OsType, *ArchType)
Colin Crossa2f296f2016-11-29 15:16:18 -0800412 SkipInstall()
Ulya Trafimovichb28cc372020-01-13 15:18:16 +0000413 IsSkipInstall() bool
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +0100414 MakeUninstallable()
Liz Kammer5ca3a622020-08-05 15:40:41 -0700415 ReplacedByPrebuilt()
416 IsReplacedByPrebuilt() bool
Jiyong Park374510b2018-03-19 18:23:01 +0900417 ExportedToMake() bool
Inseob Kim8471cda2019-11-15 09:59:12 +0900418 InitRc() Paths
419 VintfFragments() Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800420 NoticeFiles() Paths
Colin Cross36242852017-06-23 15:06:31 -0700421
422 AddProperties(props ...interface{})
423 GetProperties() []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700424
Colin Crossae887032017-10-23 17:16:14 -0700425 BuildParamsForTests() []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800426 RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800427 VariablesForTests() map[string]string
Paul Duffine2453c72019-05-31 14:00:04 +0100428
Colin Cross9a362232019-07-01 15:32:45 -0700429 // String returns a string that includes the module name and variants for printing during debugging.
430 String() string
431
Paul Duffine2453c72019-05-31 14:00:04 +0100432 // Get the qualified module id for this module.
433 qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName
434
435 // Get information about the properties that can contain visibility rules.
436 visibilityProperties() []visibilityProperty
Paul Duffin63c6e182019-07-24 14:24:38 +0100437
Jiyong Park6a8cf5f2019-12-30 16:31:09 +0900438 RequiredModuleNames() []string
439 HostRequiredModuleNames() []string
440 TargetRequiredModuleNames() []string
Colin Cross897266e2020-02-13 13:22:08 -0800441
Jiyong Park4dc2a1a2020-09-28 17:46:22 +0900442 FilesToInstall() InstallPaths
Jiyong Park073ea552020-11-09 14:08:34 +0900443 PackagingSpecs() []PackagingSpec
Colin Crossffe6b9d2020-12-01 15:40:06 -0800444
445 // TransitivePackagingSpecs returns the PackagingSpecs for this module and any transitive
446 // dependencies with dependency tags for which IsInstallDepNeeded() returns true.
447 TransitivePackagingSpecs() []PackagingSpec
Paul Duffine2453c72019-05-31 14:00:04 +0100448}
449
450// Qualified id for a module
451type qualifiedModuleName struct {
452 // The package (i.e. directory) in which the module is defined, without trailing /
453 pkg string
454
455 // The name of the module, empty string if package.
456 name string
457}
458
459func (q qualifiedModuleName) String() string {
460 if q.name == "" {
461 return "//" + q.pkg
462 }
463 return "//" + q.pkg + ":" + q.name
464}
465
Paul Duffine484f472019-06-20 16:38:08 +0100466func (q qualifiedModuleName) isRootPackage() bool {
467 return q.pkg == "" && q.name == ""
468}
469
Paul Duffine2453c72019-05-31 14:00:04 +0100470// Get the id for the package containing this module.
471func (q qualifiedModuleName) getContainingPackageId() qualifiedModuleName {
472 pkg := q.pkg
473 if q.name == "" {
Paul Duffine484f472019-06-20 16:38:08 +0100474 if pkg == "" {
475 panic(fmt.Errorf("Cannot get containing package id of root package"))
476 }
477
478 index := strings.LastIndex(pkg, "/")
479 if index == -1 {
480 pkg = ""
481 } else {
482 pkg = pkg[:index]
483 }
Paul Duffine2453c72019-05-31 14:00:04 +0100484 }
485 return newPackageId(pkg)
486}
487
488func newPackageId(pkg string) qualifiedModuleName {
489 // A qualified id for a package module has no name.
490 return qualifiedModuleName{pkg: pkg, name: ""}
Colin Cross3f40fa42015-01-30 17:27:36 -0800491}
492
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000493type Dist struct {
494 // Copy the output of this module to the $DIST_DIR when `dist` is specified on the
495 // command line and any of these targets are also on the command line, or otherwise
496 // built
497 Targets []string `android:"arch_variant"`
498
499 // The name of the output artifact. This defaults to the basename of the output of
500 // the module.
501 Dest *string `android:"arch_variant"`
502
503 // The directory within the dist directory to store the artifact. Defaults to the
504 // top level directory ("").
505 Dir *string `android:"arch_variant"`
506
507 // A suffix to add to the artifact file name (before any extension).
508 Suffix *string `android:"arch_variant"`
509
Paul Duffin74f05592020-11-25 16:37:46 +0000510 // A string tag to select the OutputFiles associated with the tag.
511 //
512 // If no tag is specified then it will select the default dist paths provided
513 // by the module type. If a tag of "" is specified then it will return the
514 // default output files provided by the modules, i.e. the result of calling
515 // OutputFiles("").
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000516 Tag *string `android:"arch_variant"`
517}
518
Colin Crossfc754582016-05-17 16:34:16 -0700519type nameProperties struct {
520 // The name of the module. Must be unique across all modules.
Nan Zhang0007d812017-11-07 10:57:05 -0800521 Name *string
Colin Crossfc754582016-05-17 16:34:16 -0700522}
523
Colin Cross08d6f8f2020-11-19 02:33:19 +0000524type commonProperties struct {
Dan Willemsen0effe062015-11-30 16:06:01 -0800525 // emit build rules for this module
Paul Duffin54d9bb72020-02-12 10:20:56 +0000526 //
527 // Disabling a module should only be done for those modules that cannot be built
528 // in the current environment. Modules that can build in the current environment
529 // but are not usually required (e.g. superceded by a prebuilt) should not be
530 // disabled as that will prevent them from being built by the checkbuild target
531 // and so prevent early detection of changes that have broken those modules.
Dan Willemsen0effe062015-11-30 16:06:01 -0800532 Enabled *bool `android:"arch_variant"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800533
Paul Duffin2e61fa62019-03-28 14:10:57 +0000534 // Controls the visibility of this module to other modules. Allowable values are one or more of
535 // these formats:
536 //
537 // ["//visibility:public"]: Anyone can use this module.
538 // ["//visibility:private"]: Only rules in the module's package (not its subpackages) can use
539 // this module.
Paul Duffin51084ff2020-05-05 19:19:22 +0100540 // ["//visibility:override"]: Discards any rules inherited from defaults or a creating module.
541 // Can only be used at the beginning of a list of visibility rules.
Paul Duffin2e61fa62019-03-28 14:10:57 +0000542 // ["//some/package:__pkg__", "//other/package:__pkg__"]: Only modules in some/package and
543 // other/package (defined in some/package/*.bp and other/package/*.bp) have access to
544 // this module. Note that sub-packages do not have access to the rule; for example,
545 // //some/package/foo:bar or //other/package/testing:bla wouldn't have access. __pkg__
546 // is a special module and must be used verbatim. It represents all of the modules in the
547 // package.
548 // ["//project:__subpackages__", "//other:__subpackages__"]: Only modules in packages project
549 // or other or in one of their sub-packages have access to this module. For example,
550 // //project:rule, //project/library:lib or //other/testing/internal:munge are allowed
551 // to depend on this rule (but not //independent:evil)
552 // ["//project"]: This is shorthand for ["//project:__pkg__"]
553 // [":__subpackages__"]: This is shorthand for ["//project:__subpackages__"] where
554 // //project is the module's package. e.g. using [":__subpackages__"] in
555 // packages/apps/Settings/Android.bp is equivalent to
556 // //packages/apps/Settings:__subpackages__.
557 // ["//visibility:legacy_public"]: The default visibility, behaves as //visibility:public
558 // for now. It is an error if it is used in a module.
Paul Duffine2453c72019-05-31 14:00:04 +0100559 //
560 // If a module does not specify the `visibility` property then it uses the
561 // `default_visibility` property of the `package` module in the module's package.
562 //
563 // If the `default_visibility` property is not set for the module's package then
Paul Duffine484f472019-06-20 16:38:08 +0100564 // it will use the `default_visibility` of its closest ancestor package for which
565 // a `default_visibility` property is specified.
566 //
567 // If no `default_visibility` property can be found then the module uses the
568 // global default of `//visibility:legacy_public`.
Paul Duffine2453c72019-05-31 14:00:04 +0100569 //
Paul Duffin95d53b52019-07-24 13:45:05 +0100570 // The `visibility` property has no effect on a defaults module although it does
571 // apply to any non-defaults module that uses it. To set the visibility of a
572 // defaults module, use the `defaults_visibility` property on the defaults module;
573 // not to be confused with the `default_visibility` property on the package module.
574 //
Paul Duffin2e61fa62019-03-28 14:10:57 +0000575 // See https://android.googlesource.com/platform/build/soong/+/master/README.md#visibility for
576 // more details.
577 Visibility []string
578
Colin Cross7d5136f2015-05-11 13:39:40 -0700579 // control whether this module compiles for 32-bit, 64-bit, or both. Possible values
Colin Cross3f40fa42015-01-30 17:27:36 -0800580 // are "32" (compile for 32-bit only), "64" (compile for 64-bit only), "both" (compile for both
581 // 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 +0000582 // platform).
Colin Cross7d716ba2017-11-01 10:38:29 -0700583 Compile_multilib *string `android:"arch_variant"`
Colin Cross69617d32016-09-06 10:39:07 -0700584
585 Target struct {
586 Host struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700587 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700588 }
589 Android struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700590 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700591 }
592 }
593
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000594 // If set to true then the archMutator will create variants for each arch specific target
595 // (e.g. 32/64) that the module is required to produce. If set to false then it will only
596 // create a variant for the architecture and will list the additional arch specific targets
597 // that the variant needs to produce in the CompileMultiTargets property.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700598 UseTargetVariants bool `blueprint:"mutated"`
599 Default_multilib string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800600
Dan Willemsen782a2d12015-12-21 14:55:28 -0800601 // whether this is a proprietary vendor module, and should be installed into /vendor
Colin Cross7d716ba2017-11-01 10:38:29 -0700602 Proprietary *bool
Dan Willemsen782a2d12015-12-21 14:55:28 -0800603
Colin Cross55708f32017-03-20 13:23:34 -0700604 // vendor who owns this module
Dan Willemsenefac4a82017-07-18 19:42:09 -0700605 Owner *string
Colin Cross55708f32017-03-20 13:23:34 -0700606
Jiyong Park2db76922017-11-08 16:03:48 +0900607 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
608 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
609 // Use `soc_specific` instead for better meaning.
Colin Cross7d716ba2017-11-01 10:38:29 -0700610 Vendor *bool
Dan Willemsenaa118f92017-04-06 12:49:58 -0700611
Jiyong Park2db76922017-11-08 16:03:48 +0900612 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
613 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
614 Soc_specific *bool
615
616 // whether this module is specific to a device, not only for SoC, but also for off-chip
617 // peripherals. When set to true, it is installed into /odm (or /vendor/odm if odm partition
618 // does not exist, or /system/vendor/odm if both odm and vendor partitions do not exist).
619 // This implies `soc_specific:true`.
620 Device_specific *bool
621
622 // whether this module is specific to a software configuration of a product (e.g. country,
Jaekyun Seok5cfbfbb2018-01-10 19:00:15 +0900623 // network operator, etc). When set to true, it is installed into /product (or
624 // /system/product if product partition does not exist).
Jiyong Park2db76922017-11-08 16:03:48 +0900625 Product_specific *bool
626
Justin Yund5f6c822019-06-25 16:47:17 +0900627 // whether this module extends system. When set to true, it is installed into /system_ext
628 // (or /system/system_ext if system_ext partition does not exist).
629 System_ext_specific *bool
630
Jiyong Parkf9332f12018-02-01 00:54:12 +0900631 // Whether this module is installed to recovery partition
632 Recovery *bool
633
Yifan Hong1b3348d2020-01-21 15:53:22 -0800634 // Whether this module is installed to ramdisk
635 Ramdisk *bool
636
Yifan Hong60e0cfb2020-10-21 15:17:56 -0700637 // Whether this module is installed to vendor ramdisk
638 Vendor_ramdisk *bool
639
dimitry1f33e402019-03-26 12:39:31 +0100640 // Whether this module is built for non-native architecures (also known as native bridge binary)
641 Native_bridge_supported *bool `android:"arch_variant"`
642
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700643 // init.rc files to be installed if this module is installed
Colin Cross0bab8772020-09-25 14:01:21 -0700644 Init_rc []string `android:"arch_variant,path"`
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700645
Steven Moreland57a23d22018-04-04 15:42:19 -0700646 // VINTF manifest fragments to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800647 Vintf_fragments []string `android:"path"`
Steven Moreland57a23d22018-04-04 15:42:19 -0700648
Chris Wolfe998306e2016-08-15 14:47:23 -0400649 // names of other modules to install if this module is installed
Colin Crossc602b7d2017-05-05 13:36:36 -0700650 Required []string `android:"arch_variant"`
Chris Wolfe998306e2016-08-15 14:47:23 -0400651
Sasha Smundakb6d23052019-04-01 18:37:36 -0700652 // names of other modules to install on host if this module is installed
653 Host_required []string `android:"arch_variant"`
654
655 // names of other modules to install on target if this module is installed
656 Target_required []string `android:"arch_variant"`
657
Colin Cross5aac3622017-08-31 15:07:09 -0700658 // relative path to a file to include in the list of notices for the device
Colin Cross27b922f2019-03-04 22:35:41 -0800659 Notice *string `android:"path"`
Colin Cross5aac3622017-08-31 15:07:09 -0700660
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000661 // The OsType of artifacts that this module variant is responsible for creating.
662 //
663 // Set by osMutator
664 CompileOS OsType `blueprint:"mutated"`
665
666 // The Target of artifacts that this module variant is responsible for creating.
667 //
668 // Set by archMutator
669 CompileTarget Target `blueprint:"mutated"`
670
671 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
672 // responsible for creating.
673 //
674 // By default this is nil as, where necessary, separate variants are created for the
675 // different multilib types supported and that information is encapsulated in the
676 // CompileTarget so the module variant simply needs to create artifacts for that.
677 //
678 // However, if UseTargetVariants is set to false (e.g. by
679 // InitAndroidMultiTargetsArchModule) then no separate variants are created for the
680 // multilib targets. Instead a single variant is created for the architecture and
681 // this contains the multilib specific targets that this variant should create.
682 //
683 // Set by archMutator
Colin Crossee0bc3b2018-10-02 22:01:37 -0700684 CompileMultiTargets []Target `blueprint:"mutated"`
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000685
686 // True if the module variant's CompileTarget is the primary target
687 //
688 // Set by archMutator
689 CompilePrimary bool `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800690
691 // Set by InitAndroidModule
692 HostOrDeviceSupported HostOrDeviceSupported `blueprint:"mutated"`
Dan Willemsen0b24c742016-10-04 15:13:37 -0700693 ArchSpecific bool `blueprint:"mutated"`
Colin Crossce75d2c2016-10-06 16:12:58 -0700694
Paul Duffin1356d8c2020-02-25 19:26:33 +0000695 // If set to true then a CommonOS variant will be created which will have dependencies
696 // on all its OsType specific variants. Used by sdk/module_exports to create a snapshot
697 // that covers all os and architecture variants.
698 //
699 // The OsType specific variants can be retrieved by calling
700 // GetOsSpecificVariantsOfCommonOSVariant
701 //
702 // Set at module initialization time by calling InitCommonOSAndroidMultiTargetsArchModule
703 CreateCommonOSVariant bool `blueprint:"mutated"`
704
705 // If set to true then this variant is the CommonOS variant that has dependencies on its
706 // OsType specific variants.
707 //
708 // Set by osMutator.
709 CommonOSVariant bool `blueprint:"mutated"`
710
Colin Crossce75d2c2016-10-06 16:12:58 -0700711 SkipInstall bool `blueprint:"mutated"`
Jeff Gaston088e29e2017-11-29 16:47:17 -0800712
Liz Kammer5ca3a622020-08-05 15:40:41 -0700713 // Whether the module has been replaced by a prebuilt
714 ReplacedByPrebuilt bool `blueprint:"mutated"`
715
Justin Yun32f053b2020-07-31 23:07:17 +0900716 // Disabled by mutators. If set to true, it overrides Enabled property.
717 ForcedDisabled bool `blueprint:"mutated"`
718
Jeff Gaston088e29e2017-11-29 16:47:17 -0800719 NamespaceExportedToMake bool `blueprint:"mutated"`
Colin Cross6c4f21f2019-06-06 15:41:36 -0700720
721 MissingDeps []string `blueprint:"mutated"`
Colin Cross9a362232019-07-01 15:32:45 -0700722
723 // Name and variant strings stored by mutators to enable Module.String()
724 DebugName string `blueprint:"mutated"`
725 DebugMutators []string `blueprint:"mutated"`
726 DebugVariations []string `blueprint:"mutated"`
Colin Cross7228ecd2019-11-18 16:00:16 -0800727
Colin Crossa6845402020-11-16 15:08:19 -0800728 // ImageVariation is set by ImageMutator to specify which image this variation is for,
729 // for example "" for core or "recovery" for recovery. It will often be set to one of the
730 // constants in image.go, but can also be set to a custom value by individual module types.
Colin Cross7228ecd2019-11-18 16:00:16 -0800731 ImageVariation string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800732}
733
Paul Duffined875132020-09-02 13:08:57 +0100734type distProperties struct {
735 // configuration to distribute output files from this module to the distribution
736 // directory (default: $OUT/dist, configurable with $DIST_DIR)
737 Dist Dist `android:"arch_variant"`
738
739 // a list of configurations to distribute output files from this module to the
740 // distribution directory (default: $OUT/dist, configurable with $DIST_DIR)
741 Dists []Dist `android:"arch_variant"`
742}
743
Paul Duffin74f05592020-11-25 16:37:46 +0000744// The key to use in TaggedDistFiles when a Dist structure does not specify a
745// tag property. This intentionally does not use "" as the default because that
746// would mean that an empty tag would have a different meaning when used in a dist
747// structure that when used to reference a specific set of output paths using the
748// :module{tag} syntax, which passes tag to the OutputFiles(tag) method.
749const DefaultDistTag = "<default-dist-tag>"
750
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000751// A map of OutputFile tag keys to Paths, for disting purposes.
752type TaggedDistFiles map[string]Paths
753
Paul Duffin74f05592020-11-25 16:37:46 +0000754// addPathsForTag adds a mapping from the tag to the paths. If the map is nil
755// then it will create a map, update it and then return it. If a mapping already
756// exists for the tag then the paths are appended to the end of the current list
757// of paths, ignoring any duplicates.
758func (t TaggedDistFiles) addPathsForTag(tag string, paths ...Path) TaggedDistFiles {
759 if t == nil {
760 t = make(TaggedDistFiles)
761 }
762
763 for _, distFile := range paths {
764 if distFile != nil && !t[tag].containsPath(distFile) {
765 t[tag] = append(t[tag], distFile)
766 }
767 }
768
769 return t
770}
771
772// merge merges the entries from the other TaggedDistFiles object into this one.
773// If the TaggedDistFiles is nil then it will create a new instance, merge the
774// other into it, and then return it.
775func (t TaggedDistFiles) merge(other TaggedDistFiles) TaggedDistFiles {
776 for tag, paths := range other {
777 t = t.addPathsForTag(tag, paths...)
778 }
779
780 return t
781}
782
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000783func MakeDefaultDistFiles(paths ...Path) TaggedDistFiles {
Jingwen Chen7b27ca72020-07-24 09:13:49 +0000784 for _, path := range paths {
785 if path == nil {
786 panic("The path to a dist file cannot be nil.")
787 }
788 }
789
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000790 // The default OutputFile tag is the empty "" string.
Paul Duffin74f05592020-11-25 16:37:46 +0000791 return TaggedDistFiles{DefaultDistTag: paths}
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000792}
793
Colin Cross3f40fa42015-01-30 17:27:36 -0800794type hostAndDeviceProperties struct {
Colin Cross4e81d702018-11-09 10:36:55 -0800795 // If set to true, build a variant of the module for the host. Defaults to false.
796 Host_supported *bool
797
798 // If set to true, build a variant of the module for the device. Defaults to true.
Colin Crossa4190c12016-07-12 13:11:25 -0700799 Device_supported *bool
Colin Cross3f40fa42015-01-30 17:27:36 -0800800}
801
Colin Crossc472d572015-03-17 15:06:21 -0700802type Multilib string
803
804const (
Colin Cross6b4a32d2017-12-05 13:42:45 -0800805 MultilibBoth Multilib = "both"
806 MultilibFirst Multilib = "first"
807 MultilibCommon Multilib = "common"
808 MultilibCommonFirst Multilib = "common_first"
809 MultilibDefault Multilib = ""
Colin Crossc472d572015-03-17 15:06:21 -0700810)
811
Colin Crossa1ad8d12016-06-01 17:09:44 -0700812type HostOrDeviceSupported int
813
814const (
Colin Cross34037c62020-11-17 13:19:17 -0800815 hostSupported = 1 << iota
816 hostCrossSupported
817 deviceSupported
818 hostDefault
819 deviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700820
821 // Host and HostCross are built by default. Device is not supported.
Colin Cross34037c62020-11-17 13:19:17 -0800822 HostSupported = hostSupported | hostCrossSupported | hostDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700823
824 // Host is built by default. HostCross and Device are not supported.
Colin Cross34037c62020-11-17 13:19:17 -0800825 HostSupportedNoCross = hostSupported | hostDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700826
827 // Device is built by default. Host and HostCross are not supported.
Colin Cross34037c62020-11-17 13:19:17 -0800828 DeviceSupported = deviceSupported | deviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700829
830 // Device is built by default. Host and HostCross are supported.
Colin Cross34037c62020-11-17 13:19:17 -0800831 HostAndDeviceSupported = hostSupported | hostCrossSupported | deviceSupported | deviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700832
833 // Host, HostCross, and Device are built by default.
Colin Cross34037c62020-11-17 13:19:17 -0800834 HostAndDeviceDefault = hostSupported | hostCrossSupported | hostDefault |
835 deviceSupported | deviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700836
837 // Nothing is supported. This is not exposed to the user, but used to mark a
838 // host only module as unsupported when the module type is not supported on
839 // the host OS. E.g. benchmarks are supported on Linux but not Darwin.
Colin Cross34037c62020-11-17 13:19:17 -0800840 NeitherHostNorDeviceSupported = 0
Colin Crossa1ad8d12016-06-01 17:09:44 -0700841)
842
Jiyong Park2db76922017-11-08 16:03:48 +0900843type moduleKind int
844
845const (
846 platformModule moduleKind = iota
847 deviceSpecificModule
848 socSpecificModule
849 productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900850 systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900851)
852
853func (k moduleKind) String() string {
854 switch k {
855 case platformModule:
856 return "platform"
857 case deviceSpecificModule:
858 return "device-specific"
859 case socSpecificModule:
860 return "soc-specific"
861 case productSpecificModule:
862 return "product-specific"
Justin Yund5f6c822019-06-25 16:47:17 +0900863 case systemExtSpecificModule:
864 return "systemext-specific"
Jiyong Park2db76922017-11-08 16:03:48 +0900865 default:
866 panic(fmt.Errorf("unknown module kind %d", k))
867 }
868}
869
Colin Cross9d34f352019-11-22 16:03:51 -0800870func initAndroidModuleBase(m Module) {
871 m.base().module = m
872}
873
Colin Crossa6845402020-11-16 15:08:19 -0800874// InitAndroidModule initializes the Module as an Android module that is not architecture-specific.
875// It adds the common properties, for example "name" and "enabled".
Colin Cross36242852017-06-23 15:06:31 -0700876func InitAndroidModule(m Module) {
Colin Cross9d34f352019-11-22 16:03:51 -0800877 initAndroidModuleBase(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800878 base := m.base()
Colin Cross5049f022015-03-18 13:28:46 -0700879
Colin Cross36242852017-06-23 15:06:31 -0700880 m.AddProperties(
Colin Crossfc754582016-05-17 16:34:16 -0700881 &base.nameProperties,
Paul Duffined875132020-09-02 13:08:57 +0100882 &base.commonProperties,
883 &base.distProperties)
Colin Cross18c46802019-09-24 22:19:02 -0700884
Colin Crosseabaedd2020-02-06 17:01:55 -0800885 initProductVariableModule(m)
Colin Cross18c46802019-09-24 22:19:02 -0700886
Colin Crossa3a97412019-03-18 12:24:29 -0700887 base.generalProperties = m.GetProperties()
Pirama Arumuga Nainar955dc492018-04-17 14:58:42 -0700888 base.customizableProperties = m.GetProperties()
Paul Duffin63c6e182019-07-24 14:24:38 +0100889
890 // The default_visibility property needs to be checked and parsed by the visibility module during
Paul Duffin5ec73ec2020-05-01 17:52:01 +0100891 // its checking and parsing phases so make it the primary visibility property.
892 setPrimaryVisibilityProperty(m, "visibility", &base.commonProperties.Visibility)
Colin Cross5049f022015-03-18 13:28:46 -0700893}
894
Colin Crossa6845402020-11-16 15:08:19 -0800895// InitAndroidArchModule initializes the Module as an Android module that is architecture-specific.
896// It adds the common properties, for example "name" and "enabled", as well as runtime generated
897// property structs for architecture-specific versions of generic properties tagged with
898// `android:"arch_variant"`.
899//
900// InitAndroidModule should not be called if InitAndroidArchModule was called.
Colin Cross36242852017-06-23 15:06:31 -0700901func InitAndroidArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
902 InitAndroidModule(m)
Colin Cross5049f022015-03-18 13:28:46 -0700903
904 base := m.base()
Colin Cross3f40fa42015-01-30 17:27:36 -0800905 base.commonProperties.HostOrDeviceSupported = hod
Colin Cross69617d32016-09-06 10:39:07 -0700906 base.commonProperties.Default_multilib = string(defaultMultilib)
Dan Willemsen0b24c742016-10-04 15:13:37 -0700907 base.commonProperties.ArchSpecific = true
Colin Crossee0bc3b2018-10-02 22:01:37 -0700908 base.commonProperties.UseTargetVariants = true
Colin Cross3f40fa42015-01-30 17:27:36 -0800909
Colin Cross34037c62020-11-17 13:19:17 -0800910 if hod&hostSupported != 0 && hod&deviceSupported != 0 {
Colin Cross36242852017-06-23 15:06:31 -0700911 m.AddProperties(&base.hostAndDeviceProperties)
Colin Cross3f40fa42015-01-30 17:27:36 -0800912 }
913
Colin Crossa6845402020-11-16 15:08:19 -0800914 initArchModule(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800915}
916
Colin Crossa6845402020-11-16 15:08:19 -0800917// InitAndroidMultiTargetsArchModule initializes the Module as an Android module that is
918// architecture-specific, but will only have a single variant per OS that handles all the
919// architectures simultaneously. The list of Targets that it must handle will be available from
920// ModuleContext.MultiTargets. It adds the common properties, for example "name" and "enabled", as
921// well as runtime generated property structs for architecture-specific versions of generic
922// properties tagged with `android:"arch_variant"`.
923//
924// InitAndroidModule or InitAndroidArchModule should not be called if
925// InitAndroidMultiTargetsArchModule was called.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700926func InitAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
927 InitAndroidArchModule(m, hod, defaultMultilib)
928 m.base().commonProperties.UseTargetVariants = false
929}
930
Colin Crossa6845402020-11-16 15:08:19 -0800931// InitCommonOSAndroidMultiTargetsArchModule initializes the Module as an Android module that is
932// architecture-specific, but will only have a single variant per OS that handles all the
933// architectures simultaneously, and will also have an additional CommonOS variant that has
934// dependencies on all the OS-specific variants. The list of Targets that it must handle will be
935// available from ModuleContext.MultiTargets. It adds the common properties, for example "name" and
936// "enabled", as well as runtime generated property structs for architecture-specific versions of
937// generic properties tagged with `android:"arch_variant"`.
938//
939// InitAndroidModule, InitAndroidArchModule or InitAndroidMultiTargetsArchModule should not be
940// called if InitCommonOSAndroidMultiTargetsArchModule was called.
Paul Duffin1356d8c2020-02-25 19:26:33 +0000941func InitCommonOSAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
942 InitAndroidArchModule(m, hod, defaultMultilib)
943 m.base().commonProperties.UseTargetVariants = false
944 m.base().commonProperties.CreateCommonOSVariant = true
945}
946
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800947// A ModuleBase object contains the properties that are common to all Android
Colin Cross3f40fa42015-01-30 17:27:36 -0800948// modules. It should be included as an anonymous field in every module
949// struct definition. InitAndroidModule should then be called from the module's
950// factory function, and the return values from InitAndroidModule should be
951// returned from the factory function.
952//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800953// The ModuleBase type is responsible for implementing the GenerateBuildActions
954// method to support the blueprint.Module interface. This method will then call
955// the module's GenerateAndroidBuildActions method once for each build variant
Colin Cross25de6c32019-06-06 14:29:25 -0700956// that is to be built. GenerateAndroidBuildActions is passed a ModuleContext
957// rather than the usual blueprint.ModuleContext.
958// ModuleContext exposes extra functionality specific to the Android build
Colin Cross3f40fa42015-01-30 17:27:36 -0800959// system including details about the particular build variant that is to be
960// generated.
961//
962// For example:
963//
964// import (
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800965// "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -0800966// )
967//
968// type myModule struct {
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800969// android.ModuleBase
Colin Cross3f40fa42015-01-30 17:27:36 -0800970// properties struct {
971// MyProperty string
972// }
973// }
974//
Colin Cross36242852017-06-23 15:06:31 -0700975// func NewMyModule() android.Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800976// m := &myModule{}
Colin Cross36242852017-06-23 15:06:31 -0700977// m.AddProperties(&m.properties)
978// android.InitAndroidModule(m)
979// return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800980// }
981//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800982// func (m *myModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800983// // Get the CPU architecture for the current build variant.
984// variantArch := ctx.Arch()
985//
986// // ...
987// }
Colin Cross635c3b02016-05-18 15:37:25 -0700988type ModuleBase struct {
Colin Cross3f40fa42015-01-30 17:27:36 -0800989 // Putting the curiously recurring thing pointing to the thing that contains
990 // the thing pattern to good use.
Colin Cross36242852017-06-23 15:06:31 -0700991 // TODO: remove this
Colin Cross635c3b02016-05-18 15:37:25 -0700992 module Module
Colin Cross3f40fa42015-01-30 17:27:36 -0800993
Colin Crossfc754582016-05-17 16:34:16 -0700994 nameProperties nameProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800995 commonProperties commonProperties
Paul Duffined875132020-09-02 13:08:57 +0100996 distProperties distProperties
Colin Cross18c46802019-09-24 22:19:02 -0700997 variableProperties interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800998 hostAndDeviceProperties hostAndDeviceProperties
999 generalProperties []interface{}
Colin Crossc17727d2018-10-24 12:42:09 -07001000 archProperties [][]interface{}
Colin Crossa120ec12016-08-19 16:07:38 -07001001 customizableProperties []interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -08001002
Paul Duffin63c6e182019-07-24 14:24:38 +01001003 // Information about all the properties on the module that contains visibility rules that need
1004 // checking.
1005 visibilityPropertyInfo []visibilityProperty
1006
1007 // The primary visibility property, may be nil, that controls access to the module.
1008 primaryVisibilityProperty visibilityProperty
1009
Colin Crossffe6b9d2020-12-01 15:40:06 -08001010 noAddressSanitizer bool
1011 installFiles InstallPaths
1012 installFilesDepSet *installPathsDepSet
1013 checkbuildFiles Paths
1014 packagingSpecs []PackagingSpec
1015 packagingSpecsDepSet *packagingSpecsDepSet
1016 noticeFiles Paths
1017 phonies map[string]Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07001018
Paul Duffinaf970a22020-11-23 23:32:56 +00001019 // The files to copy to the dist as explicitly specified in the .bp file.
1020 distFiles TaggedDistFiles
1021
Colin Cross1f8c52b2015-06-16 16:38:17 -07001022 // Used by buildTargetSingleton to create checkbuild and per-directory build targets
1023 // Only set on the final variant of each module
Colin Cross0875c522017-11-28 17:34:01 -08001024 installTarget WritablePath
1025 checkbuildTarget WritablePath
Colin Cross1f8c52b2015-06-16 16:38:17 -07001026 blueprintDir string
Colin Crossa120ec12016-08-19 16:07:38 -07001027
Colin Cross178a5092016-09-13 13:42:32 -07001028 hooks hooks
Colin Cross36242852017-06-23 15:06:31 -07001029
1030 registerProps []interface{}
Colin Crosscec81712017-07-13 14:43:27 -07001031
1032 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001033 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001034 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001035 variables map[string]string
Colin Crossa9d8bee2018-10-02 13:59:46 -07001036
Inseob Kim8471cda2019-11-15 09:59:12 +09001037 initRcPaths Paths
1038 vintfFragmentsPaths Paths
1039
Jiyong Park1613e552020-09-14 19:43:17 +09001040 prefer32 func(ctx BaseModuleContext, base *ModuleBase, os OsType) bool
Colin Cross36242852017-06-23 15:06:31 -07001041}
1042
Paul Duffin44f1d842020-06-26 20:17:02 +01001043func (m *ModuleBase) ComponentDepsMutator(BottomUpMutatorContext) {}
1044
Colin Cross4157e882019-06-06 16:57:04 -07001045func (m *ModuleBase) DepsMutator(BottomUpMutatorContext) {}
Colin Cross5f692ec2019-02-01 16:53:07 -08001046
Colin Cross4157e882019-06-06 16:57:04 -07001047func (m *ModuleBase) AddProperties(props ...interface{}) {
1048 m.registerProps = append(m.registerProps, props...)
Colin Cross36242852017-06-23 15:06:31 -07001049}
1050
Colin Cross4157e882019-06-06 16:57:04 -07001051func (m *ModuleBase) GetProperties() []interface{} {
1052 return m.registerProps
Colin Cross3f40fa42015-01-30 17:27:36 -08001053}
1054
Colin Cross4157e882019-06-06 16:57:04 -07001055func (m *ModuleBase) BuildParamsForTests() []BuildParams {
1056 return m.buildParams
Colin Crosscec81712017-07-13 14:43:27 -07001057}
1058
Colin Cross4157e882019-06-06 16:57:04 -07001059func (m *ModuleBase) RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams {
1060 return m.ruleParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001061}
1062
Colin Cross4157e882019-06-06 16:57:04 -07001063func (m *ModuleBase) VariablesForTests() map[string]string {
1064 return m.variables
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001065}
1066
Jiyong Park1613e552020-09-14 19:43:17 +09001067func (m *ModuleBase) Prefer32(prefer32 func(ctx BaseModuleContext, base *ModuleBase, os OsType) bool) {
Colin Cross4157e882019-06-06 16:57:04 -07001068 m.prefer32 = prefer32
Colin Crossa9d8bee2018-10-02 13:59:46 -07001069}
1070
Colin Crossce75d2c2016-10-06 16:12:58 -07001071// Name returns the name of the module. It may be overridden by individual module types, for
1072// example prebuilts will prepend prebuilt_ to the name.
Colin Cross4157e882019-06-06 16:57:04 -07001073func (m *ModuleBase) Name() string {
1074 return String(m.nameProperties.Name)
Colin Crossfc754582016-05-17 16:34:16 -07001075}
1076
Colin Cross9a362232019-07-01 15:32:45 -07001077// String returns a string that includes the module name and variants for printing during debugging.
1078func (m *ModuleBase) String() string {
1079 sb := strings.Builder{}
1080 sb.WriteString(m.commonProperties.DebugName)
1081 sb.WriteString("{")
1082 for i := range m.commonProperties.DebugMutators {
1083 if i != 0 {
1084 sb.WriteString(",")
1085 }
1086 sb.WriteString(m.commonProperties.DebugMutators[i])
1087 sb.WriteString(":")
1088 sb.WriteString(m.commonProperties.DebugVariations[i])
1089 }
1090 sb.WriteString("}")
1091 return sb.String()
1092}
1093
Colin Crossce75d2c2016-10-06 16:12:58 -07001094// BaseModuleName returns the name of the module as specified in the blueprints file.
Colin Cross4157e882019-06-06 16:57:04 -07001095func (m *ModuleBase) BaseModuleName() string {
1096 return String(m.nameProperties.Name)
Colin Crossce75d2c2016-10-06 16:12:58 -07001097}
1098
Colin Cross4157e882019-06-06 16:57:04 -07001099func (m *ModuleBase) base() *ModuleBase {
1100 return m
Colin Cross3f40fa42015-01-30 17:27:36 -08001101}
1102
Paul Duffine2453c72019-05-31 14:00:04 +01001103func (m *ModuleBase) qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName {
1104 return qualifiedModuleName{pkg: ctx.ModuleDir(), name: ctx.ModuleName()}
1105}
1106
1107func (m *ModuleBase) visibilityProperties() []visibilityProperty {
Paul Duffin63c6e182019-07-24 14:24:38 +01001108 return m.visibilityPropertyInfo
1109}
1110
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001111func (m *ModuleBase) Dists() []Dist {
Paul Duffined875132020-09-02 13:08:57 +01001112 if len(m.distProperties.Dist.Targets) > 0 {
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001113 // Make a copy of the underlying Dists slice to protect against
1114 // backing array modifications with repeated calls to this method.
Paul Duffined875132020-09-02 13:08:57 +01001115 distsCopy := append([]Dist(nil), m.distProperties.Dists...)
1116 return append(distsCopy, m.distProperties.Dist)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001117 } else {
Paul Duffined875132020-09-02 13:08:57 +01001118 return m.distProperties.Dists
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001119 }
1120}
1121
1122func (m *ModuleBase) GenerateTaggedDistFiles(ctx BaseModuleContext) TaggedDistFiles {
Paul Duffin74f05592020-11-25 16:37:46 +00001123 var distFiles TaggedDistFiles
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001124 for _, dist := range m.Dists() {
Paul Duffin74f05592020-11-25 16:37:46 +00001125 // If no tag is specified then it means to use the default dist paths so use
1126 // the special tag name which represents that.
1127 tag := proptools.StringDefault(dist.Tag, DefaultDistTag)
1128
Paul Duffinaf970a22020-11-23 23:32:56 +00001129 if outputFileProducer, ok := m.module.(OutputFileProducer); ok {
1130 // Call the OutputFiles(tag) method to get the paths associated with the tag.
1131 distFilesForTag, err := outputFileProducer.OutputFiles(tag)
Paul Duffin74f05592020-11-25 16:37:46 +00001132
Paul Duffinaf970a22020-11-23 23:32:56 +00001133 // If the tag was not supported and is not DefaultDistTag then it is an error.
1134 // Failing to find paths for DefaultDistTag is not an error. It just means
1135 // that the module type requires the legacy behavior.
1136 if err != nil && tag != DefaultDistTag {
1137 ctx.PropertyErrorf("dist.tag", "%s", err.Error())
1138 }
1139
1140 distFiles = distFiles.addPathsForTag(tag, distFilesForTag...)
1141 } else if tag != DefaultDistTag {
1142 // If the tag was specified then it is an error if the module does not
1143 // implement OutputFileProducer because there is no other way of accessing
1144 // the paths for the specified tag.
1145 ctx.PropertyErrorf("dist.tag",
1146 "tag %s not supported because the module does not implement OutputFileProducer", tag)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001147 }
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001148 }
1149
1150 return distFiles
1151}
1152
Colin Cross4157e882019-06-06 16:57:04 -07001153func (m *ModuleBase) Target() Target {
1154 return m.commonProperties.CompileTarget
Dan Willemsen490fd492015-11-24 17:53:15 -08001155}
1156
Colin Cross4157e882019-06-06 16:57:04 -07001157func (m *ModuleBase) TargetPrimary() bool {
1158 return m.commonProperties.CompilePrimary
Colin Cross8b74d172016-09-13 09:59:14 -07001159}
1160
Colin Cross4157e882019-06-06 16:57:04 -07001161func (m *ModuleBase) MultiTargets() []Target {
1162 return m.commonProperties.CompileMultiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07001163}
1164
Colin Cross4157e882019-06-06 16:57:04 -07001165func (m *ModuleBase) Os() OsType {
1166 return m.Target().Os
Dan Willemsen490fd492015-11-24 17:53:15 -08001167}
1168
Colin Cross4157e882019-06-06 16:57:04 -07001169func (m *ModuleBase) Host() bool {
Jiyong Park1613e552020-09-14 19:43:17 +09001170 return m.Os().Class == Host
Dan Willemsen97750522016-02-09 17:43:51 -08001171}
1172
Yo Chiangbba545e2020-06-09 16:15:37 +08001173func (m *ModuleBase) Device() bool {
1174 return m.Os().Class == Device
1175}
1176
Colin Cross4157e882019-06-06 16:57:04 -07001177func (m *ModuleBase) Arch() Arch {
1178 return m.Target().Arch
Dan Willemsen97750522016-02-09 17:43:51 -08001179}
1180
Colin Cross4157e882019-06-06 16:57:04 -07001181func (m *ModuleBase) ArchSpecific() bool {
1182 return m.commonProperties.ArchSpecific
Dan Willemsen0b24c742016-10-04 15:13:37 -07001183}
1184
Paul Duffin1356d8c2020-02-25 19:26:33 +00001185// True if the current variant is a CommonOS variant, false otherwise.
1186func (m *ModuleBase) IsCommonOSVariant() bool {
1187 return m.commonProperties.CommonOSVariant
1188}
1189
Colin Cross34037c62020-11-17 13:19:17 -08001190// supportsTarget returns true if the given Target is supported by the current module.
1191func (m *ModuleBase) supportsTarget(target Target) bool {
1192 switch target.Os.Class {
1193 case Host:
1194 if target.HostCross {
1195 return m.HostCrossSupported()
1196 } else {
1197 return m.HostSupported()
Colin Crossa1ad8d12016-06-01 17:09:44 -07001198 }
Colin Cross34037c62020-11-17 13:19:17 -08001199 case Device:
1200 return m.DeviceSupported()
Colin Crossa1ad8d12016-06-01 17:09:44 -07001201 default:
Jiyong Park1613e552020-09-14 19:43:17 +09001202 return false
Colin Crossa1ad8d12016-06-01 17:09:44 -07001203 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001204}
1205
Colin Cross34037c62020-11-17 13:19:17 -08001206// DeviceSupported returns true if the current module is supported and enabled for device targets,
1207// i.e. the factory method set the HostOrDeviceSupported value to include device support and
1208// the device support is enabled by default or enabled by the device_supported property.
Colin Cross4157e882019-06-06 16:57:04 -07001209func (m *ModuleBase) DeviceSupported() bool {
Colin Cross34037c62020-11-17 13:19:17 -08001210 hod := m.commonProperties.HostOrDeviceSupported
1211 // deviceEnabled is true if the device_supported property is true or the HostOrDeviceSupported
1212 // value has the deviceDefault bit set.
1213 deviceEnabled := proptools.BoolDefault(m.hostAndDeviceProperties.Device_supported, hod&deviceDefault != 0)
1214 return hod&deviceSupported != 0 && deviceEnabled
Colin Cross3f40fa42015-01-30 17:27:36 -08001215}
1216
Colin Cross34037c62020-11-17 13:19:17 -08001217// HostSupported returns true if the current module is supported and enabled for host targets,
1218// i.e. the factory method set the HostOrDeviceSupported value to include host support and
1219// the host support is enabled by default or enabled by the host_supported property.
Paul Duffine44358f2019-11-26 18:04:12 +00001220func (m *ModuleBase) HostSupported() bool {
Colin Cross34037c62020-11-17 13:19:17 -08001221 hod := m.commonProperties.HostOrDeviceSupported
1222 // hostEnabled is true if the host_supported property is true or the HostOrDeviceSupported
1223 // value has the hostDefault bit set.
1224 hostEnabled := proptools.BoolDefault(m.hostAndDeviceProperties.Host_supported, hod&hostDefault != 0)
1225 return hod&hostSupported != 0 && hostEnabled
1226}
1227
1228// HostCrossSupported returns true if the current module is supported and enabled for host cross
1229// targets, i.e. the factory method set the HostOrDeviceSupported value to include host cross
1230// support and the host cross support is enabled by default or enabled by the
1231// host_supported property.
1232func (m *ModuleBase) HostCrossSupported() bool {
1233 hod := m.commonProperties.HostOrDeviceSupported
1234 // hostEnabled is true if the host_supported property is true or the HostOrDeviceSupported
1235 // value has the hostDefault bit set.
1236 hostEnabled := proptools.BoolDefault(m.hostAndDeviceProperties.Host_supported, hod&hostDefault != 0)
1237 return hod&hostCrossSupported != 0 && hostEnabled
Paul Duffine44358f2019-11-26 18:04:12 +00001238}
1239
Colin Cross4157e882019-06-06 16:57:04 -07001240func (m *ModuleBase) Platform() bool {
Justin Yund5f6c822019-06-25 16:47:17 +09001241 return !m.DeviceSpecific() && !m.SocSpecific() && !m.ProductSpecific() && !m.SystemExtSpecific()
Jiyong Parkc678ad32018-04-10 13:07:10 +09001242}
1243
Colin Cross4157e882019-06-06 16:57:04 -07001244func (m *ModuleBase) DeviceSpecific() bool {
1245 return Bool(m.commonProperties.Device_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +09001246}
1247
Colin Cross4157e882019-06-06 16:57:04 -07001248func (m *ModuleBase) SocSpecific() bool {
1249 return Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +09001250}
1251
Colin Cross4157e882019-06-06 16:57:04 -07001252func (m *ModuleBase) ProductSpecific() bool {
1253 return Bool(m.commonProperties.Product_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +09001254}
1255
Justin Yund5f6c822019-06-25 16:47:17 +09001256func (m *ModuleBase) SystemExtSpecific() bool {
1257 return Bool(m.commonProperties.System_ext_specific)
Dario Frenifd05a742018-05-29 13:28:54 +01001258}
1259
Colin Crossc2d24052020-05-13 11:05:02 -07001260// RequiresStableAPIs returns true if the module will be installed to a partition that may
1261// be updated separately from the system image.
1262func (m *ModuleBase) RequiresStableAPIs(ctx BaseModuleContext) bool {
1263 return m.SocSpecific() || m.DeviceSpecific() ||
1264 (m.ProductSpecific() && ctx.Config().EnforceProductPartitionInterface())
1265}
1266
Bill Peckhamfff3f8a2020-03-20 18:33:20 -07001267func (m *ModuleBase) PartitionTag(config DeviceConfig) string {
1268 partition := "system"
1269 if m.SocSpecific() {
1270 // A SoC-specific module could be on the vendor partition at
1271 // "vendor" or the system partition at "system/vendor".
1272 if config.VendorPath() == "vendor" {
1273 partition = "vendor"
1274 }
1275 } else if m.DeviceSpecific() {
1276 // A device-specific module could be on the odm partition at
1277 // "odm", the vendor partition at "vendor/odm", or the system
1278 // partition at "system/vendor/odm".
1279 if config.OdmPath() == "odm" {
1280 partition = "odm"
Ramy Medhat944839a2020-03-31 22:14:52 -04001281 } else if strings.HasPrefix(config.OdmPath(), "vendor/") {
Bill Peckhamfff3f8a2020-03-20 18:33:20 -07001282 partition = "vendor"
1283 }
1284 } else if m.ProductSpecific() {
1285 // A product-specific module could be on the product partition
1286 // at "product" or the system partition at "system/product".
1287 if config.ProductPath() == "product" {
1288 partition = "product"
1289 }
1290 } else if m.SystemExtSpecific() {
1291 // A system_ext-specific module could be on the system_ext
1292 // partition at "system_ext" or the system partition at
1293 // "system/system_ext".
1294 if config.SystemExtPath() == "system_ext" {
1295 partition = "system_ext"
1296 }
1297 }
1298 return partition
1299}
1300
Colin Cross4157e882019-06-06 16:57:04 -07001301func (m *ModuleBase) Enabled() bool {
Justin Yun32f053b2020-07-31 23:07:17 +09001302 if m.commonProperties.ForcedDisabled {
1303 return false
1304 }
Colin Cross08d6f8f2020-11-19 02:33:19 +00001305 if m.commonProperties.Enabled == nil {
1306 return !m.Os().DefaultDisabled
1307 }
1308 return *m.commonProperties.Enabled
Colin Cross3f40fa42015-01-30 17:27:36 -08001309}
1310
Inseob Kimeec88e12020-01-22 11:11:29 +09001311func (m *ModuleBase) Disable() {
Justin Yun32f053b2020-07-31 23:07:17 +09001312 m.commonProperties.ForcedDisabled = true
Inseob Kimeec88e12020-01-22 11:11:29 +09001313}
1314
Colin Cross4157e882019-06-06 16:57:04 -07001315func (m *ModuleBase) SkipInstall() {
1316 m.commonProperties.SkipInstall = true
Colin Crossce75d2c2016-10-06 16:12:58 -07001317}
1318
Ulya Trafimovichb28cc372020-01-13 15:18:16 +00001319func (m *ModuleBase) IsSkipInstall() bool {
1320 return m.commonProperties.SkipInstall == true
1321}
1322
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001323// Similar to SkipInstall, but if the AndroidMk entry would set
1324// LOCAL_UNINSTALLABLE_MODULE then this variant may still output that entry
1325// rather than leaving it out altogether. That happens in cases where it would
1326// have other side effects, in particular when it adds a NOTICE file target,
1327// which other install targets might depend on.
1328func (m *ModuleBase) MakeUninstallable() {
1329 m.SkipInstall()
1330}
1331
Liz Kammer5ca3a622020-08-05 15:40:41 -07001332func (m *ModuleBase) ReplacedByPrebuilt() {
1333 m.commonProperties.ReplacedByPrebuilt = true
1334 m.SkipInstall()
1335}
1336
1337func (m *ModuleBase) IsReplacedByPrebuilt() bool {
1338 return m.commonProperties.ReplacedByPrebuilt
1339}
1340
Colin Cross4157e882019-06-06 16:57:04 -07001341func (m *ModuleBase) ExportedToMake() bool {
1342 return m.commonProperties.NamespaceExportedToMake
Jiyong Park374510b2018-03-19 18:23:01 +09001343}
1344
Colin Crosse9fe2942020-11-10 18:12:15 -08001345// computeInstallDeps finds the installed paths of all dependencies that have a dependency
1346// tag that is annotated as needing installation via the IsInstallDepNeeded method.
Colin Crossffe6b9d2020-12-01 15:40:06 -08001347func (m *ModuleBase) computeInstallDeps(ctx ModuleContext) ([]*installPathsDepSet, []*packagingSpecsDepSet) {
Colin Cross5d583952020-11-24 16:21:24 -08001348 var installDeps []*installPathsDepSet
Colin Crossffe6b9d2020-12-01 15:40:06 -08001349 var packagingSpecs []*packagingSpecsDepSet
Colin Cross5d583952020-11-24 16:21:24 -08001350 ctx.VisitDirectDeps(func(dep Module) {
1351 if IsInstallDepNeeded(ctx.OtherModuleDependencyTag(dep)) {
1352 installDeps = append(installDeps, dep.base().installFilesDepSet)
Colin Crossffe6b9d2020-12-01 15:40:06 -08001353 packagingSpecs = append(packagingSpecs, dep.base().packagingSpecsDepSet)
Colin Cross897266e2020-02-13 13:22:08 -08001354 }
1355 })
Colin Cross3f40fa42015-01-30 17:27:36 -08001356
Colin Crossffe6b9d2020-12-01 15:40:06 -08001357 return installDeps, packagingSpecs
Colin Cross3f40fa42015-01-30 17:27:36 -08001358}
1359
Jiyong Park4dc2a1a2020-09-28 17:46:22 +09001360func (m *ModuleBase) FilesToInstall() InstallPaths {
Colin Cross4157e882019-06-06 16:57:04 -07001361 return m.installFiles
Colin Cross3f40fa42015-01-30 17:27:36 -08001362}
1363
Jiyong Park073ea552020-11-09 14:08:34 +09001364func (m *ModuleBase) PackagingSpecs() []PackagingSpec {
1365 return m.packagingSpecs
1366}
1367
Colin Crossffe6b9d2020-12-01 15:40:06 -08001368func (m *ModuleBase) TransitivePackagingSpecs() []PackagingSpec {
1369 return m.packagingSpecsDepSet.ToList()
1370}
1371
Colin Cross4157e882019-06-06 16:57:04 -07001372func (m *ModuleBase) NoAddressSanitizer() bool {
1373 return m.noAddressSanitizer
Colin Cross3f40fa42015-01-30 17:27:36 -08001374}
1375
Colin Cross4157e882019-06-06 16:57:04 -07001376func (m *ModuleBase) InstallInData() bool {
Dan Willemsen782a2d12015-12-21 14:55:28 -08001377 return false
1378}
1379
Jaewoong Jung0949f312019-09-11 10:25:18 -07001380func (m *ModuleBase) InstallInTestcases() bool {
1381 return false
1382}
1383
Colin Cross4157e882019-06-06 16:57:04 -07001384func (m *ModuleBase) InstallInSanitizerDir() bool {
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001385 return false
1386}
1387
Yifan Hong1b3348d2020-01-21 15:53:22 -08001388func (m *ModuleBase) InstallInRamdisk() bool {
1389 return Bool(m.commonProperties.Ramdisk)
1390}
1391
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001392func (m *ModuleBase) InstallInVendorRamdisk() bool {
1393 return Bool(m.commonProperties.Vendor_ramdisk)
1394}
1395
Colin Cross4157e882019-06-06 16:57:04 -07001396func (m *ModuleBase) InstallInRecovery() bool {
1397 return Bool(m.commonProperties.Recovery)
Jiyong Parkf9332f12018-02-01 00:54:12 +09001398}
1399
Colin Cross90ba5f42019-10-02 11:10:58 -07001400func (m *ModuleBase) InstallInRoot() bool {
1401 return false
1402}
1403
Colin Cross607d8582019-07-29 16:44:46 -07001404func (m *ModuleBase) InstallBypassMake() bool {
1405 return false
1406}
1407
Jiyong Park87788b52020-09-01 12:37:45 +09001408func (m *ModuleBase) InstallForceOS() (*OsType, *ArchType) {
1409 return nil, nil
Colin Cross6e359402020-02-10 15:29:54 -08001410}
1411
Colin Cross4157e882019-06-06 16:57:04 -07001412func (m *ModuleBase) Owner() string {
1413 return String(m.commonProperties.Owner)
Sundong Ahn4fd04bb2018-08-31 18:01:37 +09001414}
1415
Bob Badoura75b0572020-02-18 20:21:55 -08001416func (m *ModuleBase) NoticeFiles() Paths {
1417 return m.noticeFiles
Jiyong Park52818fc2019-03-18 12:01:38 +09001418}
1419
Colin Cross7228ecd2019-11-18 16:00:16 -08001420func (m *ModuleBase) setImageVariation(variant string) {
1421 m.commonProperties.ImageVariation = variant
1422}
1423
1424func (m *ModuleBase) ImageVariation() blueprint.Variation {
1425 return blueprint.Variation{
1426 Mutator: "image",
1427 Variation: m.base().commonProperties.ImageVariation,
1428 }
1429}
1430
Paul Duffin9b76c0b2020-03-12 10:24:35 +00001431func (m *ModuleBase) getVariationByMutatorName(mutator string) string {
1432 for i, v := range m.commonProperties.DebugMutators {
1433 if v == mutator {
1434 return m.commonProperties.DebugVariations[i]
1435 }
1436 }
1437
1438 return ""
1439}
1440
Yifan Hong1b3348d2020-01-21 15:53:22 -08001441func (m *ModuleBase) InRamdisk() bool {
1442 return m.base().commonProperties.ImageVariation == RamdiskVariation
1443}
1444
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001445func (m *ModuleBase) InVendorRamdisk() bool {
1446 return m.base().commonProperties.ImageVariation == VendorRamdiskVariation
1447}
1448
Colin Cross7228ecd2019-11-18 16:00:16 -08001449func (m *ModuleBase) InRecovery() bool {
1450 return m.base().commonProperties.ImageVariation == RecoveryVariation
1451}
1452
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09001453func (m *ModuleBase) RequiredModuleNames() []string {
1454 return m.base().commonProperties.Required
1455}
1456
1457func (m *ModuleBase) HostRequiredModuleNames() []string {
1458 return m.base().commonProperties.Host_required
1459}
1460
1461func (m *ModuleBase) TargetRequiredModuleNames() []string {
1462 return m.base().commonProperties.Target_required
1463}
1464
Inseob Kim8471cda2019-11-15 09:59:12 +09001465func (m *ModuleBase) InitRc() Paths {
1466 return append(Paths{}, m.initRcPaths...)
1467}
1468
1469func (m *ModuleBase) VintfFragments() Paths {
1470 return append(Paths{}, m.vintfFragmentsPaths...)
1471}
1472
Colin Cross4157e882019-06-06 16:57:04 -07001473func (m *ModuleBase) generateModuleTarget(ctx ModuleContext) {
Colin Cross897266e2020-02-13 13:22:08 -08001474 var allInstalledFiles InstallPaths
1475 var allCheckbuildFiles Paths
Colin Cross0875c522017-11-28 17:34:01 -08001476 ctx.VisitAllModuleVariants(func(module Module) {
1477 a := module.base()
Colin Crossc9404352015-03-26 16:10:12 -07001478 allInstalledFiles = append(allInstalledFiles, a.installFiles...)
1479 allCheckbuildFiles = append(allCheckbuildFiles, a.checkbuildFiles...)
Colin Cross3f40fa42015-01-30 17:27:36 -08001480 })
1481
Colin Cross0875c522017-11-28 17:34:01 -08001482 var deps Paths
Colin Cross9454bfa2015-03-17 13:24:18 -07001483
Colin Cross133ebef2020-08-14 17:38:45 -07001484 namespacePrefix := ctx.Namespace().id
Jeff Gaston088e29e2017-11-29 16:47:17 -08001485 if namespacePrefix != "" {
1486 namespacePrefix = namespacePrefix + "-"
1487 }
1488
Colin Cross3f40fa42015-01-30 17:27:36 -08001489 if len(allInstalledFiles) > 0 {
Colin Crossc3d87d32020-06-04 13:25:17 -07001490 name := namespacePrefix + ctx.ModuleName() + "-install"
1491 ctx.Phony(name, allInstalledFiles.Paths()...)
1492 m.installTarget = PathForPhony(ctx, name)
1493 deps = append(deps, m.installTarget)
Colin Cross9454bfa2015-03-17 13:24:18 -07001494 }
1495
1496 if len(allCheckbuildFiles) > 0 {
Colin Crossc3d87d32020-06-04 13:25:17 -07001497 name := namespacePrefix + ctx.ModuleName() + "-checkbuild"
1498 ctx.Phony(name, allCheckbuildFiles...)
1499 m.checkbuildTarget = PathForPhony(ctx, name)
1500 deps = append(deps, m.checkbuildTarget)
Colin Cross9454bfa2015-03-17 13:24:18 -07001501 }
1502
1503 if len(deps) > 0 {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001504 suffix := ""
Jingwen Chencda22c92020-11-23 00:22:30 -05001505 if ctx.Config().KatiEnabled() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001506 suffix = "-soong"
1507 }
1508
Colin Crossc3d87d32020-06-04 13:25:17 -07001509 ctx.Phony(namespacePrefix+ctx.ModuleName()+suffix, deps...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07001510
Colin Cross4157e882019-06-06 16:57:04 -07001511 m.blueprintDir = ctx.ModuleDir()
Colin Cross3f40fa42015-01-30 17:27:36 -08001512 }
1513}
1514
Colin Crossc34d2322020-01-03 15:23:27 -08001515func determineModuleKind(m *ModuleBase, ctx blueprint.EarlyModuleContext) moduleKind {
Colin Cross4157e882019-06-06 16:57:04 -07001516 var socSpecific = Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
1517 var deviceSpecific = Bool(m.commonProperties.Device_specific)
1518 var productSpecific = Bool(m.commonProperties.Product_specific)
Justin Yund5f6c822019-06-25 16:47:17 +09001519 var systemExtSpecific = Bool(m.commonProperties.System_ext_specific)
Jiyong Park2db76922017-11-08 16:03:48 +09001520
Dario Frenifd05a742018-05-29 13:28:54 +01001521 msg := "conflicting value set here"
1522 if socSpecific && deviceSpecific {
1523 ctx.PropertyErrorf("device_specific", "a module cannot be specific to SoC and device at the same time.")
Colin Cross4157e882019-06-06 16:57:04 -07001524 if Bool(m.commonProperties.Vendor) {
Jiyong Park2db76922017-11-08 16:03:48 +09001525 ctx.PropertyErrorf("vendor", msg)
1526 }
Colin Cross4157e882019-06-06 16:57:04 -07001527 if Bool(m.commonProperties.Proprietary) {
Jiyong Park2db76922017-11-08 16:03:48 +09001528 ctx.PropertyErrorf("proprietary", msg)
1529 }
Colin Cross4157e882019-06-06 16:57:04 -07001530 if Bool(m.commonProperties.Soc_specific) {
Jiyong Park2db76922017-11-08 16:03:48 +09001531 ctx.PropertyErrorf("soc_specific", msg)
1532 }
1533 }
1534
Justin Yund5f6c822019-06-25 16:47:17 +09001535 if productSpecific && systemExtSpecific {
1536 ctx.PropertyErrorf("product_specific", "a module cannot be specific to product and system_ext at the same time.")
1537 ctx.PropertyErrorf("system_ext_specific", msg)
Dario Frenifd05a742018-05-29 13:28:54 +01001538 }
1539
Justin Yund5f6c822019-06-25 16:47:17 +09001540 if (socSpecific || deviceSpecific) && (productSpecific || systemExtSpecific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001541 if productSpecific {
1542 ctx.PropertyErrorf("product_specific", "a module cannot be specific to SoC or device and product at the same time.")
1543 } else {
Justin Yund5f6c822019-06-25 16:47:17 +09001544 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 +01001545 }
1546 if deviceSpecific {
1547 ctx.PropertyErrorf("device_specific", msg)
1548 } else {
Colin Cross4157e882019-06-06 16:57:04 -07001549 if Bool(m.commonProperties.Vendor) {
Dario Frenifd05a742018-05-29 13:28:54 +01001550 ctx.PropertyErrorf("vendor", msg)
1551 }
Colin Cross4157e882019-06-06 16:57:04 -07001552 if Bool(m.commonProperties.Proprietary) {
Dario Frenifd05a742018-05-29 13:28:54 +01001553 ctx.PropertyErrorf("proprietary", msg)
1554 }
Colin Cross4157e882019-06-06 16:57:04 -07001555 if Bool(m.commonProperties.Soc_specific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001556 ctx.PropertyErrorf("soc_specific", msg)
1557 }
1558 }
1559 }
1560
Jiyong Park2db76922017-11-08 16:03:48 +09001561 if productSpecific {
1562 return productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +09001563 } else if systemExtSpecific {
1564 return systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001565 } else if deviceSpecific {
1566 return deviceSpecificModule
1567 } else if socSpecific {
1568 return socSpecificModule
1569 } else {
1570 return platformModule
1571 }
1572}
1573
Colin Crossc34d2322020-01-03 15:23:27 -08001574func (m *ModuleBase) earlyModuleContextFactory(ctx blueprint.EarlyModuleContext) earlyModuleContext {
Colin Cross1184b642019-12-30 18:43:07 -08001575 return earlyModuleContext{
Colin Crossc34d2322020-01-03 15:23:27 -08001576 EarlyModuleContext: ctx,
1577 kind: determineModuleKind(m, ctx),
1578 config: ctx.Config().(Config),
Colin Cross3f40fa42015-01-30 17:27:36 -08001579 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001580}
1581
Colin Cross1184b642019-12-30 18:43:07 -08001582func (m *ModuleBase) baseModuleContextFactory(ctx blueprint.BaseModuleContext) baseModuleContext {
1583 return baseModuleContext{
1584 bp: ctx,
1585 earlyModuleContext: m.earlyModuleContextFactory(ctx),
1586 os: m.commonProperties.CompileOS,
1587 target: m.commonProperties.CompileTarget,
1588 targetPrimary: m.commonProperties.CompilePrimary,
1589 multiTargets: m.commonProperties.CompileMultiTargets,
1590 }
1591}
1592
Colin Cross4157e882019-06-06 16:57:04 -07001593func (m *ModuleBase) GenerateBuildActions(blueprintCtx blueprint.ModuleContext) {
Colin Cross25de6c32019-06-06 14:29:25 -07001594 ctx := &moduleContext{
Colin Cross0ea8ba82019-06-06 14:33:29 -07001595 module: m.module,
Colin Crossdc35e212019-06-06 16:13:11 -07001596 bp: blueprintCtx,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001597 baseModuleContext: m.baseModuleContextFactory(blueprintCtx),
Colin Cross0ea8ba82019-06-06 14:33:29 -07001598 variables: make(map[string]string),
Colin Cross3f40fa42015-01-30 17:27:36 -08001599 }
1600
Colin Crossffe6b9d2020-12-01 15:40:06 -08001601 dependencyInstallFiles, dependencyPackagingSpecs := m.computeInstallDeps(ctx)
Colin Cross5d583952020-11-24 16:21:24 -08001602 // set m.installFilesDepSet to only the transitive dependencies to be used as the dependencies
1603 // of installed files of this module. It will be replaced by a depset including the installed
1604 // files of this module at the end for use by modules that depend on this one.
1605 m.installFilesDepSet = newInstallPathsDepSet(nil, dependencyInstallFiles)
1606
Colin Cross6c4f21f2019-06-06 15:41:36 -07001607 // Temporarily continue to call blueprintCtx.GetMissingDependencies() to maintain the previous behavior of never
1608 // reporting missing dependency errors in Blueprint when AllowMissingDependencies == true.
1609 // TODO: This will be removed once defaults modules handle missing dependency errors
1610 blueprintCtx.GetMissingDependencies()
1611
Colin Crossdc35e212019-06-06 16:13:11 -07001612 // For the final GenerateAndroidBuildActions pass, require that all visited dependencies Soong modules and
Paul Duffin1356d8c2020-02-25 19:26:33 +00001613 // are enabled. Unless the module is a CommonOS variant which may have dependencies on disabled variants
1614 // (because the dependencies are added before the modules are disabled). The
1615 // GetOsSpecificVariantsOfCommonOSVariant(...) method will ensure that the disabled variants are
1616 // ignored.
1617 ctx.baseModuleContext.strictVisitDeps = !m.IsCommonOSVariant()
Colin Crossdc35e212019-06-06 16:13:11 -07001618
Colin Cross4c83e5c2019-02-25 14:54:28 -08001619 if ctx.config.captureBuild {
1620 ctx.ruleParams = make(map[blueprint.Rule]blueprint.RuleParams)
1621 }
1622
Colin Cross67a5c132017-05-09 13:45:28 -07001623 desc := "//" + ctx.ModuleDir() + ":" + ctx.ModuleName() + " "
1624 var suffix []string
Colin Cross0875c522017-11-28 17:34:01 -08001625 if ctx.Os().Class != Device && ctx.Os().Class != Generic {
1626 suffix = append(suffix, ctx.Os().String())
Colin Cross67a5c132017-05-09 13:45:28 -07001627 }
Colin Cross0875c522017-11-28 17:34:01 -08001628 if !ctx.PrimaryArch() {
1629 suffix = append(suffix, ctx.Arch().ArchType.String())
Colin Cross67a5c132017-05-09 13:45:28 -07001630 }
Colin Cross56a83212020-09-15 18:30:11 -07001631 if apexInfo := ctx.Provider(ApexInfoProvider).(ApexInfo); !apexInfo.IsForPlatform() {
1632 suffix = append(suffix, apexInfo.ApexVariationName)
Dan Willemsenb13a9482020-02-14 11:25:54 -08001633 }
Colin Cross67a5c132017-05-09 13:45:28 -07001634
1635 ctx.Variable(pctx, "moduleDesc", desc)
1636
1637 s := ""
1638 if len(suffix) > 0 {
1639 s = " [" + strings.Join(suffix, " ") + "]"
1640 }
1641 ctx.Variable(pctx, "moduleDescSuffix", s)
1642
Dan Willemsen569edc52018-11-19 09:33:29 -08001643 // Some common property checks for properties that will be used later in androidmk.go
Paul Duffin89968e32020-11-23 18:17:03 +00001644 checkDistProperties(ctx, "dist", &m.distProperties.Dist)
1645 for i, _ := range m.distProperties.Dists {
1646 checkDistProperties(ctx, fmt.Sprintf("dists[%d]", i), &m.distProperties.Dists[i])
Dan Willemsen569edc52018-11-19 09:33:29 -08001647 }
1648
Colin Cross4157e882019-06-06 16:57:04 -07001649 if m.Enabled() {
Jooyung Hand48f3c32019-08-23 11:18:57 +09001650 // ensure all direct android.Module deps are enabled
1651 ctx.VisitDirectDepsBlueprint(func(bm blueprint.Module) {
1652 if _, ok := bm.(Module); ok {
1653 ctx.validateAndroidModule(bm, ctx.baseModuleContext.strictVisitDeps)
1654 }
1655 })
1656
Bob Badoura75b0572020-02-18 20:21:55 -08001657 m.noticeFiles = make([]Path, 0)
1658 optPath := OptionalPath{}
1659 notice := proptools.StringDefault(m.commonProperties.Notice, "")
Colin Cross4157e882019-06-06 16:57:04 -07001660 if module := SrcIsModule(notice); module != "" {
Bob Badoura75b0572020-02-18 20:21:55 -08001661 optPath = ctx.ExpandOptionalSource(&notice, "notice")
1662 } else if notice != "" {
Jiyong Park52818fc2019-03-18 12:01:38 +09001663 noticePath := filepath.Join(ctx.ModuleDir(), notice)
Bob Badoura75b0572020-02-18 20:21:55 -08001664 optPath = ExistentPathForSource(ctx, noticePath)
1665 }
1666 if optPath.Valid() {
1667 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1668 } else {
1669 for _, notice = range []string{"LICENSE", "LICENCE", "NOTICE"} {
1670 noticePath := filepath.Join(ctx.ModuleDir(), notice)
1671 optPath = ExistentPathForSource(ctx, noticePath)
1672 if optPath.Valid() {
1673 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1674 }
1675 }
Jaewoong Jung62707f72018-11-16 13:26:43 -08001676 }
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001677
1678 m.module.GenerateAndroidBuildActions(ctx)
1679 if ctx.Failed() {
1680 return
1681 }
1682
Paul Duffinaf970a22020-11-23 23:32:56 +00001683 // Create the set of tagged dist files after calling GenerateAndroidBuildActions
1684 // as GenerateTaggedDistFiles() calls OutputFiles(tag) and so relies on the
1685 // output paths being set which must be done before or during
1686 // GenerateAndroidBuildActions.
1687 m.distFiles = m.GenerateTaggedDistFiles(ctx)
1688 if ctx.Failed() {
1689 return
1690 }
1691
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001692 m.installFiles = append(m.installFiles, ctx.installFiles...)
1693 m.checkbuildFiles = append(m.checkbuildFiles, ctx.checkbuildFiles...)
Jiyong Park073ea552020-11-09 14:08:34 +09001694 m.packagingSpecs = append(m.packagingSpecs, ctx.packagingSpecs...)
Inseob Kim8471cda2019-11-15 09:59:12 +09001695 m.initRcPaths = PathsForModuleSrc(ctx, m.commonProperties.Init_rc)
1696 m.vintfFragmentsPaths = PathsForModuleSrc(ctx, m.commonProperties.Vintf_fragments)
Colin Crossc3d87d32020-06-04 13:25:17 -07001697 for k, v := range ctx.phonies {
1698 m.phonies[k] = append(m.phonies[k], v...)
1699 }
Colin Crossdc35e212019-06-06 16:13:11 -07001700 } else if ctx.Config().AllowMissingDependencies() {
1701 // If the module is not enabled it will not create any build rules, nothing will call
1702 // ctx.GetMissingDependencies(), and blueprint will consider the missing dependencies to be unhandled
1703 // and report them as an error even when AllowMissingDependencies = true. Call
1704 // ctx.GetMissingDependencies() here to tell blueprint not to handle them.
1705 ctx.GetMissingDependencies()
Colin Cross3f40fa42015-01-30 17:27:36 -08001706 }
1707
Colin Cross4157e882019-06-06 16:57:04 -07001708 if m == ctx.FinalModule().(Module).base() {
1709 m.generateModuleTarget(ctx)
Colin Cross9b1d13d2016-09-19 15:18:11 -07001710 if ctx.Failed() {
1711 return
1712 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001713 }
Colin Crosscec81712017-07-13 14:43:27 -07001714
Colin Cross5d583952020-11-24 16:21:24 -08001715 m.installFilesDepSet = newInstallPathsDepSet(m.installFiles, dependencyInstallFiles)
Colin Crossffe6b9d2020-12-01 15:40:06 -08001716 m.packagingSpecsDepSet = newPackagingSpecsDepSet(m.packagingSpecs, dependencyPackagingSpecs)
Colin Cross5d583952020-11-24 16:21:24 -08001717
Colin Cross4157e882019-06-06 16:57:04 -07001718 m.buildParams = ctx.buildParams
1719 m.ruleParams = ctx.ruleParams
1720 m.variables = ctx.variables
Colin Cross3f40fa42015-01-30 17:27:36 -08001721}
1722
Paul Duffin89968e32020-11-23 18:17:03 +00001723// Check the supplied dist structure to make sure that it is valid.
1724//
1725// property - the base property, e.g. dist or dists[1], which is combined with the
1726// name of the nested property to produce the full property, e.g. dist.dest or
1727// dists[1].dir.
1728func checkDistProperties(ctx *moduleContext, property string, dist *Dist) {
1729 if dist.Dest != nil {
1730 _, err := validateSafePath(*dist.Dest)
1731 if err != nil {
1732 ctx.PropertyErrorf(property+".dest", "%s", err.Error())
1733 }
1734 }
1735 if dist.Dir != nil {
1736 _, err := validateSafePath(*dist.Dir)
1737 if err != nil {
1738 ctx.PropertyErrorf(property+".dir", "%s", err.Error())
1739 }
1740 }
1741 if dist.Suffix != nil {
1742 if strings.Contains(*dist.Suffix, "/") {
1743 ctx.PropertyErrorf(property+".suffix", "Suffix may not contain a '/' character.")
1744 }
1745 }
1746
1747}
1748
Colin Cross1184b642019-12-30 18:43:07 -08001749type earlyModuleContext struct {
Colin Crossc34d2322020-01-03 15:23:27 -08001750 blueprint.EarlyModuleContext
Colin Cross1184b642019-12-30 18:43:07 -08001751
1752 kind moduleKind
1753 config Config
1754}
1755
1756func (e *earlyModuleContext) Glob(globPattern string, excludes []string) Paths {
1757 ret, err := e.GlobWithDeps(globPattern, excludes)
1758 if err != nil {
1759 e.ModuleErrorf("glob: %s", err.Error())
1760 }
1761 return pathsForModuleSrcFromFullPath(e, ret, true)
1762}
1763
1764func (e *earlyModuleContext) GlobFiles(globPattern string, excludes []string) Paths {
1765 ret, err := e.GlobWithDeps(globPattern, excludes)
1766 if err != nil {
1767 e.ModuleErrorf("glob: %s", err.Error())
1768 }
1769 return pathsForModuleSrcFromFullPath(e, ret, false)
1770}
1771
Colin Cross988414c2020-01-11 01:11:46 +00001772func (b *earlyModuleContext) IsSymlink(path Path) bool {
1773 fileInfo, err := b.config.fs.Lstat(path.String())
1774 if err != nil {
1775 b.ModuleErrorf("os.Lstat(%q) failed: %s", path.String(), err)
1776 }
1777 return fileInfo.Mode()&os.ModeSymlink == os.ModeSymlink
1778}
1779
1780func (b *earlyModuleContext) Readlink(path Path) string {
1781 dest, err := b.config.fs.Readlink(path.String())
1782 if err != nil {
1783 b.ModuleErrorf("os.Readlink(%q) failed: %s", path.String(), err)
1784 }
1785 return dest
1786}
1787
Colin Cross1184b642019-12-30 18:43:07 -08001788func (e *earlyModuleContext) Module() Module {
Colin Crossc34d2322020-01-03 15:23:27 -08001789 module, _ := e.EarlyModuleContext.Module().(Module)
Colin Cross1184b642019-12-30 18:43:07 -08001790 return module
1791}
1792
1793func (e *earlyModuleContext) Config() Config {
Colin Crossc34d2322020-01-03 15:23:27 -08001794 return e.EarlyModuleContext.Config().(Config)
Colin Cross1184b642019-12-30 18:43:07 -08001795}
1796
1797func (e *earlyModuleContext) AConfig() Config {
1798 return e.config
1799}
1800
1801func (e *earlyModuleContext) DeviceConfig() DeviceConfig {
1802 return DeviceConfig{e.config.deviceConfig}
1803}
1804
1805func (e *earlyModuleContext) Platform() bool {
1806 return e.kind == platformModule
1807}
1808
1809func (e *earlyModuleContext) DeviceSpecific() bool {
1810 return e.kind == deviceSpecificModule
1811}
1812
1813func (e *earlyModuleContext) SocSpecific() bool {
1814 return e.kind == socSpecificModule
1815}
1816
1817func (e *earlyModuleContext) ProductSpecific() bool {
1818 return e.kind == productSpecificModule
1819}
1820
1821func (e *earlyModuleContext) SystemExtSpecific() bool {
1822 return e.kind == systemExtSpecificModule
1823}
1824
Colin Cross133ebef2020-08-14 17:38:45 -07001825func (e *earlyModuleContext) Namespace() *Namespace {
1826 return e.EarlyModuleContext.Namespace().(*Namespace)
1827}
1828
Colin Cross1184b642019-12-30 18:43:07 -08001829type baseModuleContext struct {
1830 bp blueprint.BaseModuleContext
1831 earlyModuleContext
Colin Crossfb0c16e2019-11-20 17:12:35 -08001832 os OsType
Colin Cross8b74d172016-09-13 09:59:14 -07001833 target Target
Colin Crossee0bc3b2018-10-02 22:01:37 -07001834 multiTargets []Target
Colin Cross8b74d172016-09-13 09:59:14 -07001835 targetPrimary bool
1836 debug bool
Colin Crossdc35e212019-06-06 16:13:11 -07001837
1838 walkPath []Module
Paul Duffinc5192442020-03-31 11:31:36 +01001839 tagPath []blueprint.DependencyTag
Colin Crossdc35e212019-06-06 16:13:11 -07001840
1841 strictVisitDeps bool // If true, enforce that all dependencies are enabled
Colin Crossf6566ed2015-03-24 11:13:38 -07001842}
1843
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001844func (b *baseModuleContext) OtherModuleName(m blueprint.Module) string {
1845 return b.bp.OtherModuleName(m)
1846}
1847func (b *baseModuleContext) OtherModuleDir(m blueprint.Module) string { return b.bp.OtherModuleDir(m) }
Colin Cross1184b642019-12-30 18:43:07 -08001848func (b *baseModuleContext) OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{}) {
Jooyung Hancd87c692020-02-26 02:05:18 +09001849 b.bp.OtherModuleErrorf(m, fmt, args...)
Colin Cross1184b642019-12-30 18:43:07 -08001850}
1851func (b *baseModuleContext) OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag {
1852 return b.bp.OtherModuleDependencyTag(m)
1853}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001854func (b *baseModuleContext) OtherModuleExists(name string) bool { return b.bp.OtherModuleExists(name) }
Martin Stjernholm009a9dc2020-03-05 17:34:13 +00001855func (b *baseModuleContext) OtherModuleDependencyVariantExists(variations []blueprint.Variation, name string) bool {
1856 return b.bp.OtherModuleDependencyVariantExists(variations, name)
1857}
1858func (b *baseModuleContext) OtherModuleReverseDependencyVariantExists(name string) bool {
1859 return b.bp.OtherModuleReverseDependencyVariantExists(name)
1860}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001861func (b *baseModuleContext) OtherModuleType(m blueprint.Module) string {
1862 return b.bp.OtherModuleType(m)
1863}
Colin Crossd27e7b82020-07-02 11:38:17 -07001864func (b *baseModuleContext) OtherModuleProvider(m blueprint.Module, provider blueprint.ProviderKey) interface{} {
1865 return b.bp.OtherModuleProvider(m, provider)
1866}
1867func (b *baseModuleContext) OtherModuleHasProvider(m blueprint.Module, provider blueprint.ProviderKey) bool {
1868 return b.bp.OtherModuleHasProvider(m, provider)
1869}
1870func (b *baseModuleContext) Provider(provider blueprint.ProviderKey) interface{} {
1871 return b.bp.Provider(provider)
1872}
1873func (b *baseModuleContext) HasProvider(provider blueprint.ProviderKey) bool {
1874 return b.bp.HasProvider(provider)
1875}
1876func (b *baseModuleContext) SetProvider(provider blueprint.ProviderKey, value interface{}) {
1877 b.bp.SetProvider(provider, value)
1878}
Colin Cross1184b642019-12-30 18:43:07 -08001879
1880func (b *baseModuleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1881 return b.bp.GetDirectDepWithTag(name, tag)
1882}
1883
Paul Duffinf88d8e02020-05-07 20:21:34 +01001884func (b *baseModuleContext) blueprintBaseModuleContext() blueprint.BaseModuleContext {
1885 return b.bp
1886}
1887
Colin Cross25de6c32019-06-06 14:29:25 -07001888type moduleContext struct {
Colin Crossdc35e212019-06-06 16:13:11 -07001889 bp blueprint.ModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -07001890 baseModuleContext
Jiyong Park073ea552020-11-09 14:08:34 +09001891 packagingSpecs []PackagingSpec
Colin Cross897266e2020-02-13 13:22:08 -08001892 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001893 checkbuildFiles Paths
Colin Cross8d8f8e22016-08-03 11:57:50 -07001894 module Module
Colin Crossc3d87d32020-06-04 13:25:17 -07001895 phonies map[string]Paths
Colin Crosscec81712017-07-13 14:43:27 -07001896
1897 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001898 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001899 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001900 variables map[string]string
Colin Cross6ff51382015-12-17 16:39:19 -08001901}
1902
Colin Crossb88b3c52019-06-10 15:15:17 -07001903func (m *moduleContext) ninjaError(params BuildParams, err error) (PackageContext, BuildParams) {
1904 return pctx, BuildParams{
Colin Cross4b69c492019-06-07 13:06:06 -07001905 Rule: ErrorRule,
1906 Description: params.Description,
1907 Output: params.Output,
1908 Outputs: params.Outputs,
1909 ImplicitOutput: params.ImplicitOutput,
1910 ImplicitOutputs: params.ImplicitOutputs,
Colin Cross6ff51382015-12-17 16:39:19 -08001911 Args: map[string]string{
1912 "error": err.Error(),
1913 },
Colin Crossb88b3c52019-06-10 15:15:17 -07001914 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001915}
1916
Colin Cross25de6c32019-06-06 14:29:25 -07001917func (m *moduleContext) ModuleBuild(pctx PackageContext, params ModuleBuildParams) {
1918 m.Build(pctx, BuildParams(params))
Colin Cross3f40fa42015-01-30 17:27:36 -08001919}
1920
Jingwen Chence679d22020-09-23 04:30:02 +00001921func validateBuildParams(params blueprint.BuildParams) error {
1922 // Validate that the symlink outputs are declared outputs or implicit outputs
1923 allOutputs := map[string]bool{}
1924 for _, output := range params.Outputs {
1925 allOutputs[output] = true
1926 }
1927 for _, output := range params.ImplicitOutputs {
1928 allOutputs[output] = true
1929 }
1930 for _, symlinkOutput := range params.SymlinkOutputs {
1931 if !allOutputs[symlinkOutput] {
1932 return fmt.Errorf(
1933 "Symlink output %s is not a declared output or implicit output",
1934 symlinkOutput)
1935 }
1936 }
1937 return nil
1938}
1939
1940// Convert build parameters from their concrete Android types into their string representations,
1941// and combine the singular and plural fields of the same type (e.g. Output and Outputs).
Colin Cross0875c522017-11-28 17:34:01 -08001942func convertBuildParams(params BuildParams) blueprint.BuildParams {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001943 bparams := blueprint.BuildParams{
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001944 Rule: params.Rule,
Colin Cross0875c522017-11-28 17:34:01 -08001945 Description: params.Description,
Colin Cross33bfb0a2016-11-21 17:23:08 -08001946 Deps: params.Deps,
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001947 Outputs: params.Outputs.Strings(),
1948 ImplicitOutputs: params.ImplicitOutputs.Strings(),
Jingwen Chence679d22020-09-23 04:30:02 +00001949 SymlinkOutputs: params.SymlinkOutputs.Strings(),
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001950 Inputs: params.Inputs.Strings(),
1951 Implicits: params.Implicits.Strings(),
1952 OrderOnly: params.OrderOnly.Strings(),
Colin Cross824f1162020-07-16 13:07:51 -07001953 Validations: params.Validations.Strings(),
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001954 Args: params.Args,
1955 Optional: !params.Default,
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001956 }
1957
Colin Cross33bfb0a2016-11-21 17:23:08 -08001958 if params.Depfile != nil {
1959 bparams.Depfile = params.Depfile.String()
1960 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001961 if params.Output != nil {
1962 bparams.Outputs = append(bparams.Outputs, params.Output.String())
1963 }
Jingwen Chence679d22020-09-23 04:30:02 +00001964 if params.SymlinkOutput != nil {
1965 bparams.SymlinkOutputs = append(bparams.SymlinkOutputs, params.SymlinkOutput.String())
1966 }
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001967 if params.ImplicitOutput != nil {
1968 bparams.ImplicitOutputs = append(bparams.ImplicitOutputs, params.ImplicitOutput.String())
1969 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001970 if params.Input != nil {
1971 bparams.Inputs = append(bparams.Inputs, params.Input.String())
1972 }
1973 if params.Implicit != nil {
1974 bparams.Implicits = append(bparams.Implicits, params.Implicit.String())
1975 }
Colin Cross824f1162020-07-16 13:07:51 -07001976 if params.Validation != nil {
1977 bparams.Validations = append(bparams.Validations, params.Validation.String())
1978 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001979
Colin Cross0b9f31f2019-02-28 11:00:01 -08001980 bparams.Outputs = proptools.NinjaEscapeList(bparams.Outputs)
1981 bparams.ImplicitOutputs = proptools.NinjaEscapeList(bparams.ImplicitOutputs)
Jingwen Chence679d22020-09-23 04:30:02 +00001982 bparams.SymlinkOutputs = proptools.NinjaEscapeList(bparams.SymlinkOutputs)
Colin Cross0b9f31f2019-02-28 11:00:01 -08001983 bparams.Inputs = proptools.NinjaEscapeList(bparams.Inputs)
1984 bparams.Implicits = proptools.NinjaEscapeList(bparams.Implicits)
1985 bparams.OrderOnly = proptools.NinjaEscapeList(bparams.OrderOnly)
Colin Cross824f1162020-07-16 13:07:51 -07001986 bparams.Validations = proptools.NinjaEscapeList(bparams.Validations)
1987 bparams.Depfile = proptools.NinjaEscape(bparams.Depfile)
Colin Crossfe4bc362018-09-12 10:02:13 -07001988
Colin Cross0875c522017-11-28 17:34:01 -08001989 return bparams
1990}
1991
Colin Cross25de6c32019-06-06 14:29:25 -07001992func (m *moduleContext) Variable(pctx PackageContext, name, value string) {
1993 if m.config.captureBuild {
1994 m.variables[name] = value
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001995 }
1996
Colin Crossdc35e212019-06-06 16:13:11 -07001997 m.bp.Variable(pctx.PackageContext, name, value)
Colin Cross0875c522017-11-28 17:34:01 -08001998}
1999
Colin Cross25de6c32019-06-06 14:29:25 -07002000func (m *moduleContext) Rule(pctx PackageContext, name string, params blueprint.RuleParams,
Colin Cross0875c522017-11-28 17:34:01 -08002001 argNames ...string) blueprint.Rule {
2002
Ramy Medhat944839a2020-03-31 22:14:52 -04002003 if m.config.UseRemoteBuild() {
2004 if params.Pool == nil {
2005 // When USE_GOMA=true or USE_RBE=true are set and the rule is not supported by goma/RBE, restrict
2006 // jobs to the local parallelism value
2007 params.Pool = localPool
2008 } else if params.Pool == remotePool {
2009 // remotePool is a fake pool used to identify rule that are supported for remoting. If the rule's
2010 // pool is the remotePool, replace with nil so that ninja runs it at NINJA_REMOTE_NUM_JOBS
2011 // parallelism.
2012 params.Pool = nil
2013 }
Colin Cross2e2dbc22019-09-25 13:31:46 -07002014 }
2015
Colin Crossdc35e212019-06-06 16:13:11 -07002016 rule := m.bp.Rule(pctx.PackageContext, name, params, argNames...)
Colin Cross4c83e5c2019-02-25 14:54:28 -08002017
Colin Cross25de6c32019-06-06 14:29:25 -07002018 if m.config.captureBuild {
2019 m.ruleParams[rule] = params
Colin Cross4c83e5c2019-02-25 14:54:28 -08002020 }
2021
2022 return rule
Colin Cross0875c522017-11-28 17:34:01 -08002023}
2024
Colin Cross25de6c32019-06-06 14:29:25 -07002025func (m *moduleContext) Build(pctx PackageContext, params BuildParams) {
Colin Crossb88b3c52019-06-10 15:15:17 -07002026 if params.Description != "" {
2027 params.Description = "${moduleDesc}" + params.Description + "${moduleDescSuffix}"
2028 }
2029
2030 if missingDeps := m.GetMissingDependencies(); len(missingDeps) > 0 {
2031 pctx, params = m.ninjaError(params, fmt.Errorf("module %s missing dependencies: %s\n",
2032 m.ModuleName(), strings.Join(missingDeps, ", ")))
2033 }
2034
Colin Cross25de6c32019-06-06 14:29:25 -07002035 if m.config.captureBuild {
2036 m.buildParams = append(m.buildParams, params)
Colin Cross0875c522017-11-28 17:34:01 -08002037 }
2038
Jingwen Chence679d22020-09-23 04:30:02 +00002039 bparams := convertBuildParams(params)
2040 err := validateBuildParams(bparams)
2041 if err != nil {
2042 m.ModuleErrorf(
2043 "%s: build parameter validation failed: %s",
2044 m.ModuleName(),
2045 err.Error())
2046 }
2047 m.bp.Build(pctx.PackageContext, bparams)
Dan Willemsen34cc69e2015-09-23 15:26:20 -07002048}
Colin Crossc3d87d32020-06-04 13:25:17 -07002049
2050func (m *moduleContext) Phony(name string, deps ...Path) {
2051 addPhony(m.config, name, deps...)
2052}
2053
Colin Cross25de6c32019-06-06 14:29:25 -07002054func (m *moduleContext) GetMissingDependencies() []string {
Colin Cross6c4f21f2019-06-06 15:41:36 -07002055 var missingDeps []string
2056 missingDeps = append(missingDeps, m.Module().base().commonProperties.MissingDeps...)
Colin Crossdc35e212019-06-06 16:13:11 -07002057 missingDeps = append(missingDeps, m.bp.GetMissingDependencies()...)
Colin Cross6c4f21f2019-06-06 15:41:36 -07002058 missingDeps = FirstUniqueStrings(missingDeps)
2059 return missingDeps
Colin Cross6ff51382015-12-17 16:39:19 -08002060}
2061
Colin Crossdc35e212019-06-06 16:13:11 -07002062func (b *baseModuleContext) AddMissingDependencies(deps []string) {
Dan Willemsen6553f5e2016-03-10 18:14:25 -08002063 if deps != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07002064 missingDeps := &b.Module().base().commonProperties.MissingDeps
Colin Cross6c4f21f2019-06-06 15:41:36 -07002065 *missingDeps = append(*missingDeps, deps...)
2066 *missingDeps = FirstUniqueStrings(*missingDeps)
Dan Willemsen6553f5e2016-03-10 18:14:25 -08002067 }
2068}
2069
Colin Crossdc35e212019-06-06 16:13:11 -07002070func (b *baseModuleContext) validateAndroidModule(module blueprint.Module, strict bool) Module {
Colin Crossd11fcda2017-10-23 17:59:01 -07002071 aModule, _ := module.(Module)
Colin Crossdc35e212019-06-06 16:13:11 -07002072
2073 if !strict {
2074 return aModule
2075 }
2076
Colin Cross380c69a2019-06-10 17:49:58 +00002077 if aModule == nil {
Colin Crossdc35e212019-06-06 16:13:11 -07002078 b.ModuleErrorf("module %q not an android module", b.OtherModuleName(module))
Colin Cross380c69a2019-06-10 17:49:58 +00002079 return nil
2080 }
2081
2082 if !aModule.Enabled() {
Colin Crossdc35e212019-06-06 16:13:11 -07002083 if b.Config().AllowMissingDependencies() {
2084 b.AddMissingDependencies([]string{b.OtherModuleName(aModule)})
Colin Cross380c69a2019-06-10 17:49:58 +00002085 } else {
Colin Crossdc35e212019-06-06 16:13:11 -07002086 b.ModuleErrorf("depends on disabled module %q", b.OtherModuleName(aModule))
Colin Cross380c69a2019-06-10 17:49:58 +00002087 }
2088 return nil
2089 }
Colin Crossd11fcda2017-10-23 17:59:01 -07002090 return aModule
2091}
2092
Colin Crossdc35e212019-06-06 16:13:11 -07002093func (b *baseModuleContext) getDirectDepInternal(name string, tag blueprint.DependencyTag) (blueprint.Module, blueprint.DependencyTag) {
Jiyong Parkf2976302019-04-17 21:47:37 +09002094 type dep struct {
2095 mod blueprint.Module
2096 tag blueprint.DependencyTag
2097 }
2098 var deps []dep
Colin Crossdc35e212019-06-06 16:13:11 -07002099 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07002100 if aModule, _ := module.(Module); aModule != nil && aModule.base().BaseModuleName() == name {
Colin Cross1184b642019-12-30 18:43:07 -08002101 returnedTag := b.bp.OtherModuleDependencyTag(aModule)
Jiyong Parkf2976302019-04-17 21:47:37 +09002102 if tag == nil || returnedTag == tag {
2103 deps = append(deps, dep{aModule, returnedTag})
2104 }
2105 }
2106 })
2107 if len(deps) == 1 {
2108 return deps[0].mod, deps[0].tag
2109 } else if len(deps) >= 2 {
2110 panic(fmt.Errorf("Multiple dependencies having same BaseModuleName() %q found from %q",
Colin Crossdc35e212019-06-06 16:13:11 -07002111 name, b.ModuleName()))
Jiyong Parkf2976302019-04-17 21:47:37 +09002112 } else {
2113 return nil, nil
2114 }
2115}
2116
Colin Crossdc35e212019-06-06 16:13:11 -07002117func (b *baseModuleContext) GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module {
Colin Cross0ef08162019-05-01 15:50:51 -07002118 var deps []Module
Colin Crossdc35e212019-06-06 16:13:11 -07002119 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07002120 if aModule, _ := module.(Module); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08002121 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Cross0ef08162019-05-01 15:50:51 -07002122 deps = append(deps, aModule)
2123 }
2124 }
2125 })
2126 return deps
2127}
2128
Colin Cross25de6c32019-06-06 14:29:25 -07002129func (m *moduleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
2130 module, _ := m.getDirectDepInternal(name, tag)
2131 return module
Jiyong Parkf2976302019-04-17 21:47:37 +09002132}
2133
Colin Crossdc35e212019-06-06 16:13:11 -07002134func (b *baseModuleContext) GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag) {
2135 return b.getDirectDepInternal(name, nil)
Jiyong Parkf2976302019-04-17 21:47:37 +09002136}
2137
Colin Crossdc35e212019-06-06 16:13:11 -07002138func (b *baseModuleContext) VisitDirectDepsBlueprint(visit func(blueprint.Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002139 b.bp.VisitDirectDeps(visit)
Colin Cross35143d02017-11-16 00:11:20 -08002140}
2141
Colin Crossdc35e212019-06-06 16:13:11 -07002142func (b *baseModuleContext) VisitDirectDeps(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002143 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07002144 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07002145 visit(aModule)
2146 }
2147 })
2148}
2149
Colin Crossdc35e212019-06-06 16:13:11 -07002150func (b *baseModuleContext) VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002151 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07002152 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08002153 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Crossee6143c2017-12-30 17:54:27 -08002154 visit(aModule)
2155 }
2156 }
2157 })
2158}
2159
Colin Crossdc35e212019-06-06 16:13:11 -07002160func (b *baseModuleContext) VisitDirectDepsIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002161 b.bp.VisitDirectDepsIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07002162 // pred
2163 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07002164 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07002165 return pred(aModule)
2166 } else {
2167 return false
2168 }
2169 },
2170 // visit
2171 func(module blueprint.Module) {
2172 visit(module.(Module))
2173 })
2174}
2175
Colin Crossdc35e212019-06-06 16:13:11 -07002176func (b *baseModuleContext) VisitDepsDepthFirst(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002177 b.bp.VisitDepsDepthFirst(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07002178 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07002179 visit(aModule)
2180 }
2181 })
2182}
2183
Colin Crossdc35e212019-06-06 16:13:11 -07002184func (b *baseModuleContext) VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002185 b.bp.VisitDepsDepthFirstIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07002186 // pred
2187 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07002188 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07002189 return pred(aModule)
2190 } else {
2191 return false
2192 }
2193 },
2194 // visit
2195 func(module blueprint.Module) {
2196 visit(module.(Module))
2197 })
2198}
2199
Colin Crossdc35e212019-06-06 16:13:11 -07002200func (b *baseModuleContext) WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool) {
Colin Cross1184b642019-12-30 18:43:07 -08002201 b.bp.WalkDeps(visit)
Alex Light778127a2019-02-27 14:19:50 -08002202}
2203
Colin Crossdc35e212019-06-06 16:13:11 -07002204func (b *baseModuleContext) WalkDeps(visit func(Module, Module) bool) {
2205 b.walkPath = []Module{b.Module()}
Paul Duffinc5192442020-03-31 11:31:36 +01002206 b.tagPath = []blueprint.DependencyTag{}
Colin Cross1184b642019-12-30 18:43:07 -08002207 b.bp.WalkDeps(func(child, parent blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07002208 childAndroidModule, _ := child.(Module)
2209 parentAndroidModule, _ := parent.(Module)
Colin Crossd11fcda2017-10-23 17:59:01 -07002210 if childAndroidModule != nil && parentAndroidModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07002211 // record walkPath before visit
2212 for b.walkPath[len(b.walkPath)-1] != parentAndroidModule {
2213 b.walkPath = b.walkPath[0 : len(b.walkPath)-1]
Paul Duffinc5192442020-03-31 11:31:36 +01002214 b.tagPath = b.tagPath[0 : len(b.tagPath)-1]
Colin Crossdc35e212019-06-06 16:13:11 -07002215 }
2216 b.walkPath = append(b.walkPath, childAndroidModule)
Paul Duffinc5192442020-03-31 11:31:36 +01002217 b.tagPath = append(b.tagPath, b.OtherModuleDependencyTag(childAndroidModule))
Colin Crossd11fcda2017-10-23 17:59:01 -07002218 return visit(childAndroidModule, parentAndroidModule)
2219 } else {
2220 return false
2221 }
2222 })
2223}
2224
Colin Crossdc35e212019-06-06 16:13:11 -07002225func (b *baseModuleContext) GetWalkPath() []Module {
2226 return b.walkPath
2227}
2228
Paul Duffinc5192442020-03-31 11:31:36 +01002229func (b *baseModuleContext) GetTagPath() []blueprint.DependencyTag {
2230 return b.tagPath
2231}
2232
Colin Cross4dfacf92020-09-16 19:22:27 -07002233func (b *baseModuleContext) VisitAllModuleVariants(visit func(Module)) {
2234 b.bp.VisitAllModuleVariants(func(module blueprint.Module) {
2235 visit(module.(Module))
2236 })
2237}
2238
2239func (b *baseModuleContext) PrimaryModule() Module {
2240 return b.bp.PrimaryModule().(Module)
2241}
2242
2243func (b *baseModuleContext) FinalModule() Module {
2244 return b.bp.FinalModule().(Module)
2245}
2246
Jiyong Park1c7e9622020-05-07 16:12:13 +09002247// A regexp for removing boilerplate from BaseDependencyTag from the string representation of
2248// a dependency tag.
Colin Cross6e511a92020-07-27 21:26:48 -07002249var tagCleaner = regexp.MustCompile(`\QBaseDependencyTag:{}\E(, )?`)
Jiyong Park1c7e9622020-05-07 16:12:13 +09002250
2251// PrettyPrintTag returns string representation of the tag, but prefers
2252// custom String() method if available.
2253func PrettyPrintTag(tag blueprint.DependencyTag) string {
2254 // Use tag's custom String() method if available.
2255 if stringer, ok := tag.(fmt.Stringer); ok {
2256 return stringer.String()
2257 }
2258
2259 // Otherwise, get a default string representation of the tag's struct.
Colin Cross6e511a92020-07-27 21:26:48 -07002260 tagString := fmt.Sprintf("%T: %+v", tag, tag)
Jiyong Park1c7e9622020-05-07 16:12:13 +09002261
2262 // Remove the boilerplate from BaseDependencyTag as it adds no value.
2263 tagString = tagCleaner.ReplaceAllString(tagString, "")
2264 return tagString
2265}
2266
2267func (b *baseModuleContext) GetPathString(skipFirst bool) string {
2268 sb := strings.Builder{}
2269 tagPath := b.GetTagPath()
2270 walkPath := b.GetWalkPath()
2271 if !skipFirst {
2272 sb.WriteString(walkPath[0].String())
2273 }
2274 for i, m := range walkPath[1:] {
2275 sb.WriteString("\n")
2276 sb.WriteString(fmt.Sprintf(" via tag %s\n", PrettyPrintTag(tagPath[i])))
2277 sb.WriteString(fmt.Sprintf(" -> %s", m.String()))
2278 }
2279 return sb.String()
2280}
2281
Colin Crossdc35e212019-06-06 16:13:11 -07002282func (m *moduleContext) ModuleSubDir() string {
2283 return m.bp.ModuleSubDir()
Colin Cross0875c522017-11-28 17:34:01 -08002284}
2285
Colin Cross0ea8ba82019-06-06 14:33:29 -07002286func (b *baseModuleContext) Target() Target {
Colin Cross25de6c32019-06-06 14:29:25 -07002287 return b.target
Colin Crossa1ad8d12016-06-01 17:09:44 -07002288}
2289
Colin Cross0ea8ba82019-06-06 14:33:29 -07002290func (b *baseModuleContext) TargetPrimary() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002291 return b.targetPrimary
Colin Cross8b74d172016-09-13 09:59:14 -07002292}
2293
Colin Cross0ea8ba82019-06-06 14:33:29 -07002294func (b *baseModuleContext) MultiTargets() []Target {
Colin Cross25de6c32019-06-06 14:29:25 -07002295 return b.multiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07002296}
2297
Colin Cross0ea8ba82019-06-06 14:33:29 -07002298func (b *baseModuleContext) Arch() Arch {
Colin Cross25de6c32019-06-06 14:29:25 -07002299 return b.target.Arch
Colin Cross3f40fa42015-01-30 17:27:36 -08002300}
2301
Colin Cross0ea8ba82019-06-06 14:33:29 -07002302func (b *baseModuleContext) Os() OsType {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002303 return b.os
Dan Willemsen490fd492015-11-24 17:53:15 -08002304}
2305
Colin Cross0ea8ba82019-06-06 14:33:29 -07002306func (b *baseModuleContext) Host() bool {
Jiyong Park1613e552020-09-14 19:43:17 +09002307 return b.os.Class == Host
Colin Crossf6566ed2015-03-24 11:13:38 -07002308}
2309
Colin Cross0ea8ba82019-06-06 14:33:29 -07002310func (b *baseModuleContext) Device() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002311 return b.os.Class == Device
Colin Crossf6566ed2015-03-24 11:13:38 -07002312}
2313
Colin Cross0ea8ba82019-06-06 14:33:29 -07002314func (b *baseModuleContext) Darwin() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002315 return b.os == Darwin
Colin Cross0af4b842015-04-30 16:36:18 -07002316}
2317
Colin Cross0ea8ba82019-06-06 14:33:29 -07002318func (b *baseModuleContext) Fuchsia() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002319 return b.os == Fuchsia
Doug Horn21b94272019-01-16 12:06:11 -08002320}
2321
Colin Cross0ea8ba82019-06-06 14:33:29 -07002322func (b *baseModuleContext) Windows() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002323 return b.os == Windows
Colin Cross3edeee12017-04-04 12:59:48 -07002324}
2325
Colin Cross0ea8ba82019-06-06 14:33:29 -07002326func (b *baseModuleContext) Debug() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002327 return b.debug
Colin Crossf6566ed2015-03-24 11:13:38 -07002328}
2329
Colin Cross0ea8ba82019-06-06 14:33:29 -07002330func (b *baseModuleContext) PrimaryArch() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002331 if len(b.config.Targets[b.target.Os]) <= 1 {
Colin Cross67a5c132017-05-09 13:45:28 -07002332 return true
2333 }
Colin Cross25de6c32019-06-06 14:29:25 -07002334 return b.target.Arch.ArchType == b.config.Targets[b.target.Os][0].Arch.ArchType
Colin Cross1e7d3702016-08-24 15:25:47 -07002335}
2336
Jiyong Park5baac542018-08-28 09:55:37 +09002337// Makes this module a platform module, i.e. not specific to soc, device,
Justin Yund5f6c822019-06-25 16:47:17 +09002338// product, or system_ext.
Colin Cross4157e882019-06-06 16:57:04 -07002339func (m *ModuleBase) MakeAsPlatform() {
2340 m.commonProperties.Vendor = boolPtr(false)
2341 m.commonProperties.Proprietary = boolPtr(false)
2342 m.commonProperties.Soc_specific = boolPtr(false)
2343 m.commonProperties.Product_specific = boolPtr(false)
Justin Yund5f6c822019-06-25 16:47:17 +09002344 m.commonProperties.System_ext_specific = boolPtr(false)
Jiyong Park5baac542018-08-28 09:55:37 +09002345}
2346
Colin Cross4157e882019-06-06 16:57:04 -07002347func (m *ModuleBase) EnableNativeBridgeSupportByDefault() {
2348 m.commonProperties.Native_bridge_supported = boolPtr(true)
dimitry03dc3f62019-05-09 14:07:34 +02002349}
2350
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09002351func (m *ModuleBase) MakeAsSystemExt() {
Jooyung Han91df2082019-11-20 01:49:42 +09002352 m.commonProperties.Vendor = boolPtr(false)
2353 m.commonProperties.Proprietary = boolPtr(false)
2354 m.commonProperties.Soc_specific = boolPtr(false)
2355 m.commonProperties.Product_specific = boolPtr(false)
2356 m.commonProperties.System_ext_specific = boolPtr(true)
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09002357}
2358
Jooyung Han344d5432019-08-23 11:17:39 +09002359// IsNativeBridgeSupported returns true if "native_bridge_supported" is explicitly set as "true"
2360func (m *ModuleBase) IsNativeBridgeSupported() bool {
2361 return proptools.Bool(m.commonProperties.Native_bridge_supported)
2362}
2363
Colin Cross25de6c32019-06-06 14:29:25 -07002364func (m *moduleContext) InstallInData() bool {
2365 return m.module.InstallInData()
Dan Willemsen782a2d12015-12-21 14:55:28 -08002366}
2367
Jaewoong Jung0949f312019-09-11 10:25:18 -07002368func (m *moduleContext) InstallInTestcases() bool {
2369 return m.module.InstallInTestcases()
2370}
2371
Colin Cross25de6c32019-06-06 14:29:25 -07002372func (m *moduleContext) InstallInSanitizerDir() bool {
2373 return m.module.InstallInSanitizerDir()
Vishwath Mohan1dd88392017-03-29 22:00:18 -07002374}
2375
Yifan Hong1b3348d2020-01-21 15:53:22 -08002376func (m *moduleContext) InstallInRamdisk() bool {
2377 return m.module.InstallInRamdisk()
2378}
2379
Yifan Hong60e0cfb2020-10-21 15:17:56 -07002380func (m *moduleContext) InstallInVendorRamdisk() bool {
2381 return m.module.InstallInVendorRamdisk()
2382}
2383
Colin Cross25de6c32019-06-06 14:29:25 -07002384func (m *moduleContext) InstallInRecovery() bool {
2385 return m.module.InstallInRecovery()
Jiyong Parkf9332f12018-02-01 00:54:12 +09002386}
2387
Colin Cross90ba5f42019-10-02 11:10:58 -07002388func (m *moduleContext) InstallInRoot() bool {
2389 return m.module.InstallInRoot()
2390}
2391
Colin Cross607d8582019-07-29 16:44:46 -07002392func (m *moduleContext) InstallBypassMake() bool {
2393 return m.module.InstallBypassMake()
2394}
2395
Jiyong Park87788b52020-09-01 12:37:45 +09002396func (m *moduleContext) InstallForceOS() (*OsType, *ArchType) {
Colin Cross6e359402020-02-10 15:29:54 -08002397 return m.module.InstallForceOS()
2398}
2399
Colin Cross70dda7e2019-10-01 22:05:35 -07002400func (m *moduleContext) skipInstall(fullInstallPath InstallPath) bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002401 if m.module.base().commonProperties.SkipInstall {
Colin Cross893d8162017-04-26 17:34:03 -07002402 return true
2403 }
2404
Colin Cross3607f212018-05-07 15:28:05 -07002405 // We'll need a solution for choosing which of modules with the same name in different
2406 // namespaces to install. For now, reuse the list of namespaces exported to Make as the
2407 // list of namespaces to install in a Soong-only build.
Colin Cross25de6c32019-06-06 14:29:25 -07002408 if !m.module.base().commonProperties.NamespaceExportedToMake {
Colin Cross3607f212018-05-07 15:28:05 -07002409 return true
2410 }
2411
Colin Cross25de6c32019-06-06 14:29:25 -07002412 if m.Device() {
Jingwen Chencda22c92020-11-23 00:22:30 -05002413 if m.Config().KatiEnabled() && !m.InstallBypassMake() {
Colin Cross893d8162017-04-26 17:34:03 -07002414 return true
2415 }
Colin Cross893d8162017-04-26 17:34:03 -07002416 }
2417
2418 return false
2419}
2420
Colin Cross70dda7e2019-10-01 22:05:35 -07002421func (m *moduleContext) InstallFile(installPath InstallPath, name string, srcPath Path,
2422 deps ...Path) InstallPath {
Jiyong Park073ea552020-11-09 14:08:34 +09002423 return m.installFile(installPath, name, srcPath, deps, false)
Colin Cross5c517922017-08-31 12:29:17 -07002424}
2425
Colin Cross70dda7e2019-10-01 22:05:35 -07002426func (m *moduleContext) InstallExecutable(installPath InstallPath, name string, srcPath Path,
2427 deps ...Path) InstallPath {
Jiyong Park073ea552020-11-09 14:08:34 +09002428 return m.installFile(installPath, name, srcPath, deps, true)
Colin Cross5c517922017-08-31 12:29:17 -07002429}
2430
Jiyong Park073ea552020-11-09 14:08:34 +09002431func (m *moduleContext) installFile(installPath InstallPath, name string, srcPath Path, deps []Path, executable bool) InstallPath {
Colin Cross35cec122015-04-02 14:37:16 -07002432
Colin Cross25de6c32019-06-06 14:29:25 -07002433 fullInstallPath := installPath.Join(m, name)
David Srbecky07656412020-06-04 01:26:16 +01002434 m.module.base().hooks.runInstallHooks(m, srcPath, fullInstallPath, false)
Colin Cross3f40fa42015-01-30 17:27:36 -08002435
Colin Cross25de6c32019-06-06 14:29:25 -07002436 if !m.skipInstall(fullInstallPath) {
Colin Cross5d583952020-11-24 16:21:24 -08002437 deps = append(deps, m.module.base().installFilesDepSet.ToList().Paths()...)
Colin Cross35cec122015-04-02 14:37:16 -07002438
Colin Cross89562dc2016-10-03 17:47:19 -07002439 var implicitDeps, orderOnlyDeps Paths
2440
Colin Cross25de6c32019-06-06 14:29:25 -07002441 if m.Host() {
Colin Cross89562dc2016-10-03 17:47:19 -07002442 // Installed host modules might be used during the build, depend directly on their
2443 // dependencies so their timestamp is updated whenever their dependency is updated
2444 implicitDeps = deps
2445 } else {
2446 orderOnlyDeps = deps
2447 }
2448
Jiyong Park073ea552020-11-09 14:08:34 +09002449 rule := Cp
2450 if executable {
2451 rule = CpExecutable
2452 }
2453
Colin Cross25de6c32019-06-06 14:29:25 -07002454 m.Build(pctx, BuildParams{
Colin Cross5c517922017-08-31 12:29:17 -07002455 Rule: rule,
Colin Cross67a5c132017-05-09 13:45:28 -07002456 Description: "install " + fullInstallPath.Base(),
2457 Output: fullInstallPath,
2458 Input: srcPath,
2459 Implicits: implicitDeps,
2460 OrderOnly: orderOnlyDeps,
Jingwen Chencda22c92020-11-23 00:22:30 -05002461 Default: !m.Config().KatiEnabled(),
Dan Willemsen322acaf2016-01-12 23:07:05 -08002462 })
Colin Cross3f40fa42015-01-30 17:27:36 -08002463
Colin Cross25de6c32019-06-06 14:29:25 -07002464 m.installFiles = append(m.installFiles, fullInstallPath)
Dan Willemsen322acaf2016-01-12 23:07:05 -08002465 }
Jiyong Park073ea552020-11-09 14:08:34 +09002466
2467 m.packagingSpecs = append(m.packagingSpecs, PackagingSpec{
2468 relPathInPackage: Rel(m, fullInstallPath.PartitionDir(), fullInstallPath.String()),
2469 srcPath: srcPath,
2470 symlinkTarget: "",
2471 executable: executable,
2472 })
2473
Colin Cross25de6c32019-06-06 14:29:25 -07002474 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross35cec122015-04-02 14:37:16 -07002475 return fullInstallPath
2476}
2477
Colin Cross70dda7e2019-10-01 22:05:35 -07002478func (m *moduleContext) InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002479 fullInstallPath := installPath.Join(m, name)
David Srbecky07656412020-06-04 01:26:16 +01002480 m.module.base().hooks.runInstallHooks(m, srcPath, fullInstallPath, true)
Colin Cross3854a602016-01-11 12:49:11 -08002481
Jiyong Park073ea552020-11-09 14:08:34 +09002482 relPath, err := filepath.Rel(path.Dir(fullInstallPath.String()), srcPath.String())
2483 if err != nil {
2484 panic(fmt.Sprintf("Unable to generate symlink between %q and %q: %s", fullInstallPath.Base(), srcPath.Base(), err))
2485 }
Colin Cross25de6c32019-06-06 14:29:25 -07002486 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07002487
Colin Cross25de6c32019-06-06 14:29:25 -07002488 m.Build(pctx, BuildParams{
Colin Cross67a5c132017-05-09 13:45:28 -07002489 Rule: Symlink,
2490 Description: "install symlink " + fullInstallPath.Base(),
2491 Output: fullInstallPath,
Dan Willemsen40efa1c2020-01-14 15:19:52 -08002492 Input: srcPath,
Jingwen Chencda22c92020-11-23 00:22:30 -05002493 Default: !m.Config().KatiEnabled(),
Colin Cross12fc4972016-01-11 12:49:11 -08002494 Args: map[string]string{
Alex Lightfb4353d2019-01-17 13:57:45 -08002495 "fromPath": relPath,
Colin Cross12fc4972016-01-11 12:49:11 -08002496 },
2497 })
Colin Cross3854a602016-01-11 12:49:11 -08002498
Colin Cross25de6c32019-06-06 14:29:25 -07002499 m.installFiles = append(m.installFiles, fullInstallPath)
2500 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross12fc4972016-01-11 12:49:11 -08002501 }
Jiyong Park073ea552020-11-09 14:08:34 +09002502
2503 m.packagingSpecs = append(m.packagingSpecs, PackagingSpec{
2504 relPathInPackage: Rel(m, fullInstallPath.PartitionDir(), fullInstallPath.String()),
2505 srcPath: nil,
2506 symlinkTarget: relPath,
2507 executable: false,
2508 })
2509
Colin Cross3854a602016-01-11 12:49:11 -08002510 return fullInstallPath
2511}
2512
Jiyong Parkf1194352019-02-25 11:05:47 +09002513// installPath/name -> absPath where absPath might be a path that is available only at runtime
2514// (e.g. /apex/...)
Colin Cross70dda7e2019-10-01 22:05:35 -07002515func (m *moduleContext) InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002516 fullInstallPath := installPath.Join(m, name)
David Srbecky07656412020-06-04 01:26:16 +01002517 m.module.base().hooks.runInstallHooks(m, nil, fullInstallPath, true)
Jiyong Parkf1194352019-02-25 11:05:47 +09002518
Colin Cross25de6c32019-06-06 14:29:25 -07002519 if !m.skipInstall(fullInstallPath) {
2520 m.Build(pctx, BuildParams{
Jiyong Parkf1194352019-02-25 11:05:47 +09002521 Rule: Symlink,
2522 Description: "install symlink " + fullInstallPath.Base() + " -> " + absPath,
2523 Output: fullInstallPath,
Jingwen Chencda22c92020-11-23 00:22:30 -05002524 Default: !m.Config().KatiEnabled(),
Jiyong Parkf1194352019-02-25 11:05:47 +09002525 Args: map[string]string{
2526 "fromPath": absPath,
2527 },
2528 })
2529
Colin Cross25de6c32019-06-06 14:29:25 -07002530 m.installFiles = append(m.installFiles, fullInstallPath)
Jiyong Parkf1194352019-02-25 11:05:47 +09002531 }
Jiyong Park073ea552020-11-09 14:08:34 +09002532
2533 m.packagingSpecs = append(m.packagingSpecs, PackagingSpec{
2534 relPathInPackage: Rel(m, fullInstallPath.PartitionDir(), fullInstallPath.String()),
2535 srcPath: nil,
2536 symlinkTarget: absPath,
2537 executable: false,
2538 })
2539
Jiyong Parkf1194352019-02-25 11:05:47 +09002540 return fullInstallPath
2541}
2542
Colin Cross25de6c32019-06-06 14:29:25 -07002543func (m *moduleContext) CheckbuildFile(srcPath Path) {
2544 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross3f40fa42015-01-30 17:27:36 -08002545}
2546
Colin Cross41955e82019-05-29 14:40:35 -07002547// SrcIsModule decodes module references in the format ":name" into the module name, or empty string if the input
2548// was not a module reference.
2549func SrcIsModule(s string) (module string) {
Colin Cross068e0fe2016-12-13 15:23:47 -08002550 if len(s) > 1 && s[0] == ':' {
2551 return s[1:]
2552 }
2553 return ""
2554}
2555
Colin Cross41955e82019-05-29 14:40:35 -07002556// SrcIsModule decodes module references in the format ":name{.tag}" into the module name and tag, ":name" into the
2557// module name and an empty string for the tag, or empty strings if the input was not a module reference.
2558func SrcIsModuleWithTag(s string) (module, tag string) {
2559 if len(s) > 1 && s[0] == ':' {
2560 module = s[1:]
2561 if tagStart := strings.IndexByte(module, '{'); tagStart > 0 {
2562 if module[len(module)-1] == '}' {
2563 tag = module[tagStart+1 : len(module)-1]
2564 module = module[:tagStart]
2565 return module, tag
2566 }
2567 }
2568 return module, ""
2569 }
2570 return "", ""
Colin Cross068e0fe2016-12-13 15:23:47 -08002571}
2572
Colin Cross41955e82019-05-29 14:40:35 -07002573type sourceOrOutputDependencyTag struct {
2574 blueprint.BaseDependencyTag
2575 tag string
2576}
2577
2578func sourceOrOutputDepTag(tag string) blueprint.DependencyTag {
2579 return sourceOrOutputDependencyTag{tag: tag}
2580}
2581
2582var SourceDepTag = sourceOrOutputDepTag("")
Colin Cross068e0fe2016-12-13 15:23:47 -08002583
Colin Cross366938f2017-12-11 16:29:02 -08002584// Adds necessary dependencies to satisfy filegroup or generated sources modules listed in srcFiles
2585// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002586//
2587// Deprecated: tag the property with `android:"path"` instead.
Colin Cross068e0fe2016-12-13 15:23:47 -08002588func ExtractSourcesDeps(ctx BottomUpMutatorContext, srcFiles []string) {
Nan Zhang2439eb72017-04-10 11:27:50 -07002589 set := make(map[string]bool)
2590
Colin Cross068e0fe2016-12-13 15:23:47 -08002591 for _, s := range srcFiles {
Colin Cross41955e82019-05-29 14:40:35 -07002592 if m, t := SrcIsModuleWithTag(s); m != "" {
2593 if _, found := set[s]; found {
2594 ctx.ModuleErrorf("found source dependency duplicate: %q!", s)
Nan Zhang2439eb72017-04-10 11:27:50 -07002595 } else {
Colin Cross41955e82019-05-29 14:40:35 -07002596 set[s] = true
2597 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Nan Zhang2439eb72017-04-10 11:27:50 -07002598 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002599 }
2600 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002601}
2602
Colin Cross366938f2017-12-11 16:29:02 -08002603// Adds necessary dependencies to satisfy filegroup or generated sources modules specified in s
2604// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002605//
2606// Deprecated: tag the property with `android:"path"` instead.
Colin Cross366938f2017-12-11 16:29:02 -08002607func ExtractSourceDeps(ctx BottomUpMutatorContext, s *string) {
2608 if s != nil {
Colin Cross41955e82019-05-29 14:40:35 -07002609 if m, t := SrcIsModuleWithTag(*s); m != "" {
2610 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Colin Cross366938f2017-12-11 16:29:02 -08002611 }
2612 }
2613}
2614
Colin Cross41955e82019-05-29 14:40:35 -07002615// A module that implements SourceFileProducer can be referenced from any property that is tagged with `android:"path"`
2616// 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 -08002617type SourceFileProducer interface {
2618 Srcs() Paths
2619}
2620
Colin Cross41955e82019-05-29 14:40:35 -07002621// A module that implements OutputFileProducer can be referenced from any property that is tagged with `android:"path"`
Roland Levillain97c1f342019-11-22 14:20:54 +00002622// 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 -07002623// listed in the property.
2624type OutputFileProducer interface {
2625 OutputFiles(tag string) (Paths, error)
2626}
2627
Colin Cross5e708052019-08-06 13:59:50 -07002628// OutputFilesForModule returns the paths from an OutputFileProducer with the given tag. On error, including if the
2629// module produced zero paths, it reports errors to the ctx and returns nil.
2630func OutputFilesForModule(ctx PathContext, module blueprint.Module, tag string) Paths {
2631 paths, err := outputFilesForModule(ctx, module, tag)
2632 if err != nil {
2633 reportPathError(ctx, err)
2634 return nil
2635 }
2636 return paths
2637}
2638
2639// OutputFileForModule returns the path from an OutputFileProducer with the given tag. On error, including if the
2640// module produced zero or multiple paths, it reports errors to the ctx and returns nil.
2641func OutputFileForModule(ctx PathContext, module blueprint.Module, tag string) Path {
2642 paths, err := outputFilesForModule(ctx, module, tag)
2643 if err != nil {
2644 reportPathError(ctx, err)
2645 return nil
2646 }
2647 if len(paths) > 1 {
Ulya Trafimovich5ab276a2020-08-25 12:45:15 +01002648 ReportPathErrorf(ctx, "got multiple output files from module %q, expected exactly one",
Colin Cross5e708052019-08-06 13:59:50 -07002649 pathContextName(ctx, module))
2650 return nil
2651 }
2652 return paths[0]
2653}
2654
2655func outputFilesForModule(ctx PathContext, module blueprint.Module, tag string) (Paths, error) {
2656 if outputFileProducer, ok := module.(OutputFileProducer); ok {
2657 paths, err := outputFileProducer.OutputFiles(tag)
2658 if err != nil {
2659 return nil, fmt.Errorf("failed to get output file from module %q: %s",
2660 pathContextName(ctx, module), err.Error())
2661 }
2662 if len(paths) == 0 {
2663 return nil, fmt.Errorf("failed to get output files from module %q", pathContextName(ctx, module))
2664 }
2665 return paths, nil
Colin Cross74b1e2b2020-11-22 20:23:02 -08002666 } else if sourceFileProducer, ok := module.(SourceFileProducer); ok {
2667 if tag != "" {
2668 return nil, fmt.Errorf("module %q is a SourceFileProducer, not an OutputFileProducer, and so does not support tag %q", pathContextName(ctx, module), tag)
2669 }
2670 paths := sourceFileProducer.Srcs()
2671 if len(paths) == 0 {
2672 return nil, fmt.Errorf("failed to get output files from module %q", pathContextName(ctx, module))
2673 }
2674 return paths, nil
Colin Cross5e708052019-08-06 13:59:50 -07002675 } else {
2676 return nil, fmt.Errorf("module %q is not an OutputFileProducer", pathContextName(ctx, module))
2677 }
2678}
2679
Colin Crossfe17f6f2019-03-28 19:30:56 -07002680type HostToolProvider interface {
2681 HostToolPath() OptionalPath
2682}
2683
Colin Cross27b922f2019-03-04 22:35:41 -08002684// Returns a list of paths expanded from globs and modules referenced using ":module" syntax. The property must
2685// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002686//
2687// Deprecated: use PathsForModuleSrc or PathsForModuleSrcExcludes instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002688func (m *moduleContext) ExpandSources(srcFiles, excludes []string) Paths {
2689 return PathsForModuleSrcExcludes(m, srcFiles, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07002690}
2691
Colin Cross2fafa3e2019-03-05 12:39:51 -08002692// Returns a single path expanded from globs and modules referenced using ":module" syntax. The property must
2693// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002694//
2695// Deprecated: use PathForModuleSrc instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002696func (m *moduleContext) ExpandSource(srcFile, prop string) Path {
2697 return PathForModuleSrc(m, srcFile)
Colin Cross2fafa3e2019-03-05 12:39:51 -08002698}
2699
2700// Returns an optional single path expanded from globs and modules referenced using ":module" syntax if
2701// the srcFile is non-nil. The property must be tagged with `android:"path" to support automatic source module
2702// dependency resolution.
Colin Cross25de6c32019-06-06 14:29:25 -07002703func (m *moduleContext) ExpandOptionalSource(srcFile *string, prop string) OptionalPath {
Colin Cross2fafa3e2019-03-05 12:39:51 -08002704 if srcFile != nil {
Colin Cross25de6c32019-06-06 14:29:25 -07002705 return OptionalPathForPath(PathForModuleSrc(m, *srcFile))
Colin Cross2fafa3e2019-03-05 12:39:51 -08002706 }
2707 return OptionalPath{}
2708}
2709
Colin Cross25de6c32019-06-06 14:29:25 -07002710func (m *moduleContext) RequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002711 return m.module.RequiredModuleNames()
Nan Zhang6d34b302017-02-04 17:47:46 -08002712}
2713
Colin Cross25de6c32019-06-06 14:29:25 -07002714func (m *moduleContext) HostRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002715 return m.module.HostRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002716}
2717
Colin Cross25de6c32019-06-06 14:29:25 -07002718func (m *moduleContext) TargetRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002719 return m.module.TargetRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002720}
2721
Colin Cross463a90e2015-06-17 14:20:06 -07002722func init() {
Colin Cross798bfce2016-10-12 14:28:16 -07002723 RegisterSingletonType("buildtarget", BuildTargetSingleton)
Colin Cross463a90e2015-06-17 14:20:06 -07002724}
2725
Colin Cross0875c522017-11-28 17:34:01 -08002726func BuildTargetSingleton() Singleton {
Colin Cross1f8c52b2015-06-16 16:38:17 -07002727 return &buildTargetSingleton{}
2728}
2729
Colin Cross87d8b562017-04-25 10:01:55 -07002730func parentDir(dir string) string {
2731 dir, _ = filepath.Split(dir)
2732 return filepath.Clean(dir)
2733}
2734
Colin Cross1f8c52b2015-06-16 16:38:17 -07002735type buildTargetSingleton struct{}
2736
Colin Cross0875c522017-11-28 17:34:01 -08002737func (c *buildTargetSingleton) GenerateBuildActions(ctx SingletonContext) {
2738 var checkbuildDeps Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07002739
Colin Crossc3d87d32020-06-04 13:25:17 -07002740 mmTarget := func(dir string) string {
2741 return "MODULES-IN-" + strings.Replace(filepath.Clean(dir), "/", "-", -1)
Colin Cross87d8b562017-04-25 10:01:55 -07002742 }
2743
Colin Cross0875c522017-11-28 17:34:01 -08002744 modulesInDir := make(map[string]Paths)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002745
Colin Cross0875c522017-11-28 17:34:01 -08002746 ctx.VisitAllModules(func(module Module) {
2747 blueprintDir := module.base().blueprintDir
2748 installTarget := module.base().installTarget
2749 checkbuildTarget := module.base().checkbuildTarget
Colin Cross1f8c52b2015-06-16 16:38:17 -07002750
Colin Cross0875c522017-11-28 17:34:01 -08002751 if checkbuildTarget != nil {
2752 checkbuildDeps = append(checkbuildDeps, checkbuildTarget)
2753 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], checkbuildTarget)
2754 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002755
Colin Cross0875c522017-11-28 17:34:01 -08002756 if installTarget != nil {
2757 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], installTarget)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002758 }
2759 })
2760
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002761 suffix := ""
Jingwen Chencda22c92020-11-23 00:22:30 -05002762 if ctx.Config().KatiEnabled() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002763 suffix = "-soong"
2764 }
2765
Colin Cross1f8c52b2015-06-16 16:38:17 -07002766 // Create a top-level checkbuild target that depends on all modules
Colin Crossc3d87d32020-06-04 13:25:17 -07002767 ctx.Phony("checkbuild"+suffix, checkbuildDeps...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002768
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002769 // Make will generate the MODULES-IN-* targets
Jingwen Chencda22c92020-11-23 00:22:30 -05002770 if ctx.Config().KatiEnabled() {
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002771 return
2772 }
2773
Colin Cross87d8b562017-04-25 10:01:55 -07002774 // Ensure ancestor directories are in modulesInDir
Inseob Kim1a365c62019-06-08 15:47:51 +09002775 dirs := SortedStringKeys(modulesInDir)
Colin Cross87d8b562017-04-25 10:01:55 -07002776 for _, dir := range dirs {
2777 dir := parentDir(dir)
2778 for dir != "." && dir != "/" {
2779 if _, exists := modulesInDir[dir]; exists {
2780 break
2781 }
2782 modulesInDir[dir] = nil
2783 dir = parentDir(dir)
2784 }
2785 }
2786
2787 // Make directories build their direct subdirectories
Colin Cross87d8b562017-04-25 10:01:55 -07002788 for _, dir := range dirs {
2789 p := parentDir(dir)
2790 if p != "." && p != "/" {
Colin Crossc3d87d32020-06-04 13:25:17 -07002791 modulesInDir[p] = append(modulesInDir[p], PathForPhony(ctx, mmTarget(dir)))
Colin Cross87d8b562017-04-25 10:01:55 -07002792 }
2793 }
2794
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002795 // Create a MODULES-IN-<directory> target that depends on all modules in a directory, and
2796 // depends on the MODULES-IN-* targets of all of its subdirectories that contain Android.bp
2797 // files.
Colin Cross1f8c52b2015-06-16 16:38:17 -07002798 for _, dir := range dirs {
Colin Crossc3d87d32020-06-04 13:25:17 -07002799 ctx.Phony(mmTarget(dir), modulesInDir[dir]...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002800 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002801
2802 // Create (host|host-cross|target)-<OS> phony rules to build a reduced checkbuild.
Jiyong Park1613e552020-09-14 19:43:17 +09002803 type osAndCross struct {
2804 os OsType
2805 hostCross bool
2806 }
2807 osDeps := map[osAndCross]Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08002808 ctx.VisitAllModules(func(module Module) {
2809 if module.Enabled() {
Jiyong Park1613e552020-09-14 19:43:17 +09002810 key := osAndCross{os: module.Target().Os, hostCross: module.Target().HostCross}
2811 osDeps[key] = append(osDeps[key], module.base().checkbuildFiles...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002812 }
2813 })
2814
Colin Cross0875c522017-11-28 17:34:01 -08002815 osClass := make(map[string]Paths)
Jiyong Park1613e552020-09-14 19:43:17 +09002816 for key, deps := range osDeps {
Dan Willemsen61d88b82017-09-20 17:29:08 -07002817 var className string
2818
Jiyong Park1613e552020-09-14 19:43:17 +09002819 switch key.os.Class {
Dan Willemsen61d88b82017-09-20 17:29:08 -07002820 case Host:
Jiyong Park1613e552020-09-14 19:43:17 +09002821 if key.hostCross {
2822 className = "host-cross"
2823 } else {
2824 className = "host"
2825 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002826 case Device:
2827 className = "target"
2828 default:
2829 continue
2830 }
2831
Jiyong Park1613e552020-09-14 19:43:17 +09002832 name := className + "-" + key.os.Name
Colin Crossc3d87d32020-06-04 13:25:17 -07002833 osClass[className] = append(osClass[className], PathForPhony(ctx, name))
Dan Willemsen61d88b82017-09-20 17:29:08 -07002834
Colin Crossc3d87d32020-06-04 13:25:17 -07002835 ctx.Phony(name, deps...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002836 }
2837
2838 // Wrap those into host|host-cross|target phony rules
Inseob Kim1a365c62019-06-08 15:47:51 +09002839 for _, class := range SortedStringKeys(osClass) {
Colin Crossc3d87d32020-06-04 13:25:17 -07002840 ctx.Phony(class, osClass[class]...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002841 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002842}
Colin Crossd779da42015-12-17 18:00:23 -08002843
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002844// Collect information for opening IDE project files in java/jdeps.go.
2845type IDEInfo interface {
2846 IDEInfo(ideInfo *IdeInfo)
2847 BaseModuleName() string
2848}
2849
2850// Extract the base module name from the Import name.
2851// Often the Import name has a prefix "prebuilt_".
2852// Remove the prefix explicitly if needed
2853// until we find a better solution to get the Import name.
2854type IDECustomizedModuleName interface {
2855 IDECustomizedModuleName() string
2856}
2857
2858type IdeInfo struct {
2859 Deps []string `json:"dependencies,omitempty"`
2860 Srcs []string `json:"srcs,omitempty"`
2861 Aidl_include_dirs []string `json:"aidl_include_dirs,omitempty"`
2862 Jarjar_rules []string `json:"jarjar_rules,omitempty"`
2863 Jars []string `json:"jars,omitempty"`
2864 Classes []string `json:"class,omitempty"`
2865 Installed_paths []string `json:"installed,omitempty"`
patricktu18c82ff2019-05-10 15:48:50 +08002866 SrcJars []string `json:"srcjars,omitempty"`
bralee1fbf4402020-05-21 10:11:59 +08002867 Paths []string `json:"path,omitempty"`
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002868}
Paul Duffinf88d8e02020-05-07 20:21:34 +01002869
2870func CheckBlueprintSyntax(ctx BaseModuleContext, filename string, contents string) []error {
2871 bpctx := ctx.blueprintBaseModuleContext()
2872 return blueprint.CheckBlueprintSyntax(bpctx.ModuleFactories(), filename, contents)
2873}
Colin Cross5d583952020-11-24 16:21:24 -08002874
2875// installPathsDepSet is a thin type-safe wrapper around the generic depSet. It always uses
2876// topological order.
2877type installPathsDepSet struct {
2878 depSet
2879}
2880
2881// newInstallPathsDepSet returns an immutable packagingSpecsDepSet with the given direct and
2882// transitive contents.
2883func newInstallPathsDepSet(direct InstallPaths, transitive []*installPathsDepSet) *installPathsDepSet {
2884 return &installPathsDepSet{*newDepSet(TOPOLOGICAL, direct, transitive)}
2885}
2886
2887// ToList returns the installPathsDepSet flattened to a list in topological order.
2888func (d *installPathsDepSet) ToList() InstallPaths {
2889 if d == nil {
2890 return nil
2891 }
2892 return d.depSet.ToList().(InstallPaths)
2893}