blob: 072f41b4c2437111ed1874352ed7dddc961bfabb [file] [log] [blame]
Colin Cross3f40fa42015-01-30 17:27:36 -08001// Copyright 2015 Google Inc. All rights reserved.
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
Colin Cross635c3b02016-05-18 15:37:25 -070015package android
Colin Cross3f40fa42015-01-30 17:27:36 -080016
17import (
Colin Cross6ff51382015-12-17 16:39:19 -080018 "fmt"
Colin Cross988414c2020-01-11 01:11:46 +000019 "os"
Alex Lightfb4353d2019-01-17 13:57:45 -080020 "path"
Colin Cross3f40fa42015-01-30 17:27:36 -080021 "path/filepath"
Jiyong Park1c7e9622020-05-07 16:12:13 +090022 "regexp"
Colin Cross6ff51382015-12-17 16:39:19 -080023 "strings"
Colin Crossaabf6792017-11-29 00:27:14 -080024 "text/scanner"
Colin Crossf6566ed2015-03-24 11:13:38 -070025
26 "github.com/google/blueprint"
Colin Crossfe4bc362018-09-12 10:02:13 -070027 "github.com/google/blueprint/proptools"
Colin Cross3f40fa42015-01-30 17:27:36 -080028)
29
30var (
31 DeviceSharedLibrary = "shared_library"
32 DeviceStaticLibrary = "static_library"
33 DeviceExecutable = "executable"
34 HostSharedLibrary = "host_shared_library"
35 HostStaticLibrary = "host_static_library"
36 HostExecutable = "host_executable"
37)
38
Colin Crossae887032017-10-23 17:16:14 -070039type BuildParams struct {
Dan Willemsen9f3c5742016-11-03 14:28:31 -070040 Rule blueprint.Rule
Colin Cross33bfb0a2016-11-21 17:23:08 -080041 Deps blueprint.Deps
42 Depfile WritablePath
Colin Cross67a5c132017-05-09 13:45:28 -070043 Description string
Dan Willemsen9f3c5742016-11-03 14:28:31 -070044 Output WritablePath
45 Outputs WritablePaths
Jingwen Chence679d22020-09-23 04:30:02 +000046 SymlinkOutput WritablePath
47 SymlinkOutputs WritablePaths
Dan Willemsen9f3c5742016-11-03 14:28:31 -070048 ImplicitOutput WritablePath
49 ImplicitOutputs WritablePaths
50 Input Path
51 Inputs Paths
52 Implicit Path
53 Implicits Paths
54 OrderOnly Paths
Colin Cross824f1162020-07-16 13:07:51 -070055 Validation Path
56 Validations Paths
Dan Willemsen9f3c5742016-11-03 14:28:31 -070057 Default bool
58 Args map[string]string
Dan Willemsen34cc69e2015-09-23 15:26:20 -070059}
60
Colin Crossae887032017-10-23 17:16:14 -070061type ModuleBuildParams BuildParams
62
Colin Cross1184b642019-12-30 18:43:07 -080063// EarlyModuleContext provides methods that can be called early, as soon as the properties have
64// been parsed into the module and before any mutators have run.
65type EarlyModuleContext interface {
Colin Cross9f35c3d2020-09-16 19:04:41 -070066 // Module returns the current module as a Module. It should rarely be necessary, as the module already has a
67 // reference to itself.
Colin Cross1184b642019-12-30 18:43:07 -080068 Module() Module
Colin Cross9f35c3d2020-09-16 19:04:41 -070069
70 // ModuleName returns the name of the module. This is generally the value that was returned by Module.Name() when
71 // the module was created, but may have been modified by calls to BaseMutatorContext.Rename.
Colin Cross1184b642019-12-30 18:43:07 -080072 ModuleName() string
Colin Cross9f35c3d2020-09-16 19:04:41 -070073
74 // ModuleDir returns the path to the directory that contains the definition of the module.
Colin Cross1184b642019-12-30 18:43:07 -080075 ModuleDir() string
Colin Cross9f35c3d2020-09-16 19:04:41 -070076
77 // ModuleType returns the name of the module type that was used to create the module, as specified in
78 // RegisterModuleType.
Colin Cross1184b642019-12-30 18:43:07 -080079 ModuleType() string
Colin Cross9f35c3d2020-09-16 19:04:41 -070080
81 // BlueprintFile returns the name of the blueprint file that contains the definition of this
82 // module.
Colin Cross9d34f352019-11-22 16:03:51 -080083 BlueprintsFile() string
Colin Cross1184b642019-12-30 18:43:07 -080084
Colin Cross9f35c3d2020-09-16 19:04:41 -070085 // ContainsProperty returns true if the specified property name was set in the module definition.
Colin Cross1184b642019-12-30 18:43:07 -080086 ContainsProperty(name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -070087
88 // Errorf reports an error at the specified position of the module definition file.
Colin Cross1184b642019-12-30 18:43:07 -080089 Errorf(pos scanner.Position, fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -070090
91 // ModuleErrorf reports an error at the line number of the module type in the module definition.
Colin Cross1184b642019-12-30 18:43:07 -080092 ModuleErrorf(fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -070093
94 // PropertyErrorf reports an error at the line number of a property in the module definition.
Colin Cross1184b642019-12-30 18:43:07 -080095 PropertyErrorf(property, fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -070096
97 // Failed returns true if any errors have been reported. In most cases the module can continue with generating
98 // build rules after an error, allowing it to report additional errors in a single run, but in cases where the error
99 // has prevented the module from creating necessary data it can return early when Failed returns true.
Colin Cross1184b642019-12-30 18:43:07 -0800100 Failed() bool
101
Colin Cross9f35c3d2020-09-16 19:04:41 -0700102 // AddNinjaFileDeps adds dependencies on the specified files to the rule that creates the ninja manifest. The
103 // primary builder will be rerun whenever the specified files are modified.
Colin Cross1184b642019-12-30 18:43:07 -0800104 AddNinjaFileDeps(deps ...string)
105
106 DeviceSpecific() bool
107 SocSpecific() bool
108 ProductSpecific() bool
109 SystemExtSpecific() bool
110 Platform() bool
111
112 Config() Config
113 DeviceConfig() DeviceConfig
114
115 // Deprecated: use Config()
116 AConfig() Config
117
118 // GlobWithDeps returns a list of files that match the specified pattern but do not match any
119 // of the patterns in excludes. It also adds efficient dependencies to rerun the primary
120 // builder whenever a file matching the pattern as added or removed, without rerunning if a
121 // file that does not match the pattern is added to a searched directory.
122 GlobWithDeps(pattern string, excludes []string) ([]string, error)
123
124 Glob(globPattern string, excludes []string) Paths
125 GlobFiles(globPattern string, excludes []string) Paths
Colin Cross988414c2020-01-11 01:11:46 +0000126 IsSymlink(path Path) bool
127 Readlink(path Path) string
Colin Cross133ebef2020-08-14 17:38:45 -0700128
Colin Cross9f35c3d2020-09-16 19:04:41 -0700129 // Namespace returns the Namespace object provided by the NameInterface set by Context.SetNameInterface, or the
130 // default SimpleNameInterface if Context.SetNameInterface was not called.
Colin Cross133ebef2020-08-14 17:38:45 -0700131 Namespace() *Namespace
Colin Cross1184b642019-12-30 18:43:07 -0800132}
133
Colin Cross0ea8ba82019-06-06 14:33:29 -0700134// BaseModuleContext is the same as blueprint.BaseModuleContext except that Config() returns
Colin Crossdc35e212019-06-06 16:13:11 -0700135// a Config instead of an interface{}, and some methods have been wrapped to use an android.Module
136// instead of a blueprint.Module, plus some extra methods that return Android-specific information
Colin Cross0ea8ba82019-06-06 14:33:29 -0700137// about the current module.
138type BaseModuleContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800139 EarlyModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -0700140
Paul Duffinf88d8e02020-05-07 20:21:34 +0100141 blueprintBaseModuleContext() blueprint.BaseModuleContext
142
Colin Cross9f35c3d2020-09-16 19:04:41 -0700143 // OtherModuleName returns the name of another Module. See BaseModuleContext.ModuleName for more information.
144 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Colin Crossdc35e212019-06-06 16:13:11 -0700145 OtherModuleName(m blueprint.Module) string
Colin Cross9f35c3d2020-09-16 19:04:41 -0700146
147 // OtherModuleDir returns the directory of another Module. See BaseModuleContext.ModuleDir for more information.
148 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Colin Crossdc35e212019-06-06 16:13:11 -0700149 OtherModuleDir(m blueprint.Module) string
Colin Cross9f35c3d2020-09-16 19:04:41 -0700150
151 // OtherModuleErrorf reports an error on another Module. See BaseModuleContext.ModuleErrorf for more information.
152 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Colin Crossdc35e212019-06-06 16:13:11 -0700153 OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{})
Colin Cross9f35c3d2020-09-16 19:04:41 -0700154
155 // OtherModuleDependencyTag returns the dependency tag used to depend on a module, or nil if there is no dependency
156 // on the module. When called inside a Visit* method with current module being visited, and there are multiple
157 // dependencies on the module being visited, it returns the dependency tag used for the current dependency.
Colin Crossdc35e212019-06-06 16:13:11 -0700158 OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag
Colin Cross9f35c3d2020-09-16 19:04:41 -0700159
160 // OtherModuleExists returns true if a module with the specified name exists, as determined by the NameInterface
161 // passed to Context.SetNameInterface, or SimpleNameInterface if it was not called.
Colin Crossdc35e212019-06-06 16:13:11 -0700162 OtherModuleExists(name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -0700163
164 // OtherModuleDependencyVariantExists returns true if a module with the
165 // specified name and variant exists. The variant must match the given
166 // variations. It must also match all the non-local variations of the current
167 // module. In other words, it checks for the module AddVariationDependencies
168 // would add a dependency on with the same arguments.
Martin Stjernholm009a9dc2020-03-05 17:34:13 +0000169 OtherModuleDependencyVariantExists(variations []blueprint.Variation, name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -0700170
171 // OtherModuleReverseDependencyVariantExists returns true if a module with the
172 // specified name exists with the same variations as the current module. In
173 // other words, it checks for the module AddReverseDependency would add a
174 // dependency on with the same argument.
Martin Stjernholm009a9dc2020-03-05 17:34:13 +0000175 OtherModuleReverseDependencyVariantExists(name string) bool
Colin Cross9f35c3d2020-09-16 19:04:41 -0700176
177 // OtherModuleType returns the type of another Module. See BaseModuleContext.ModuleType for more information.
178 // It is intended for use inside the visit functions of Visit* and WalkDeps.
Jiyong Park9e6c2422019-08-09 20:39:45 +0900179 OtherModuleType(m blueprint.Module) string
Colin Crossdc35e212019-06-06 16:13:11 -0700180
Colin Crossd27e7b82020-07-02 11:38:17 -0700181 // OtherModuleProvider returns the value for a provider for the given module. If the value is
182 // not set it returns the zero value of the type of the provider, so the return value can always
183 // be type asserted to the type of the provider. The value returned may be a deep copy of the
184 // value originally passed to SetProvider.
185 OtherModuleProvider(m blueprint.Module, provider blueprint.ProviderKey) interface{}
186
187 // OtherModuleHasProvider returns true if the provider for the given module has been set.
188 OtherModuleHasProvider(m blueprint.Module, provider blueprint.ProviderKey) bool
189
190 // Provider returns the value for a provider for the current module. If the value is
191 // not set it returns the zero value of the type of the provider, so the return value can always
192 // be type asserted to the type of the provider. It panics if called before the appropriate
193 // mutator or GenerateBuildActions pass for the provider. The value returned may be a deep
194 // copy of the value originally passed to SetProvider.
195 Provider(provider blueprint.ProviderKey) interface{}
196
197 // HasProvider returns true if the provider for the current module has been set.
198 HasProvider(provider blueprint.ProviderKey) bool
199
200 // SetProvider sets the value for a provider for the current module. It panics if not called
201 // during the appropriate mutator or GenerateBuildActions pass for the provider, if the value
202 // is not of the appropriate type, or if the value has already been set. The value should not
203 // be modified after being passed to SetProvider.
204 SetProvider(provider blueprint.ProviderKey, value interface{})
205
Colin Crossdc35e212019-06-06 16:13:11 -0700206 GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module
Colin Cross9f35c3d2020-09-16 19:04:41 -0700207
208 // GetDirectDepWithTag returns the Module the direct dependency with the specified name, or nil if
209 // none exists. It panics if the dependency does not have the specified tag. It skips any
210 // dependencies that are not an android.Module.
Colin Crossdc35e212019-06-06 16:13:11 -0700211 GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module
Colin Cross9f35c3d2020-09-16 19:04:41 -0700212
213 // GetDirectDep returns the Module and DependencyTag for the direct dependency with the specified
214 // name, or nil if none exists. If there are multiple dependencies on the same module it returns
215 // the first DependencyTag. It skips any dependencies that are not an android.Module.
Colin Crossdc35e212019-06-06 16:13:11 -0700216 GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag)
217
Colin Cross9f35c3d2020-09-16 19:04:41 -0700218 // VisitDirectDepsBlueprint calls visit for each direct dependency. If there are multiple
219 // direct dependencies on the same module visit will be called multiple times on that module
220 // and OtherModuleDependencyTag will return a different tag for each.
221 //
222 // The Module passed to the visit function should not be retained outside of the visit
223 // function, it may be invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700224 VisitDirectDepsBlueprint(visit func(blueprint.Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700225
226 // VisitDirectDeps calls visit for each direct dependency. If there are multiple
227 // direct dependencies on the same module visit will be called multiple times on that module
228 // and OtherModuleDependencyTag will return a different tag for each. It skips any
229 // dependencies that are not an android.Module.
230 //
231 // The Module passed to the visit function should not be retained outside of the visit
232 // function, it may be invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700233 VisitDirectDeps(visit func(Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700234
Colin Crossdc35e212019-06-06 16:13:11 -0700235 VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700236
237 // VisitDirectDepsIf calls pred for each direct dependency, and if pred returns true calls visit. If there are
238 // multiple direct dependencies on the same module pred and visit will be called multiple times on that module and
239 // OtherModuleDependencyTag will return a different tag for each. It skips any
240 // dependencies that are not an android.Module.
241 //
242 // The Module passed to the visit function should not be retained outside of the visit function, it may be
243 // invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700244 VisitDirectDepsIf(pred func(Module) bool, visit func(Module))
245 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
246 VisitDepsDepthFirst(visit func(Module))
247 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
248 VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module))
Colin Cross9f35c3d2020-09-16 19:04:41 -0700249
250 // WalkDeps calls visit for each transitive dependency, traversing the dependency tree in top down order. visit may
251 // be called multiple times for the same (child, parent) pair if there are multiple direct dependencies between the
252 // child and parent with different tags. OtherModuleDependencyTag will return the tag for the currently visited
253 // (child, parent) pair. If visit returns false WalkDeps will not continue recursing down to child. It skips
254 // any dependencies that are not an android.Module.
255 //
256 // The Modules passed to the visit function should not be retained outside of the visit function, they may be
257 // invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700258 WalkDeps(visit func(Module, Module) bool)
Colin Cross9f35c3d2020-09-16 19:04:41 -0700259
260 // WalkDepsBlueprint calls visit for each transitive dependency, traversing the dependency
261 // tree in top down order. visit may be called multiple times for the same (child, parent)
262 // pair if there are multiple direct dependencies between the child and parent with different
263 // tags. OtherModuleDependencyTag will return the tag for the currently visited
264 // (child, parent) pair. If visit returns false WalkDeps will not continue recursing down
265 // to child.
266 //
267 // The Modules passed to the visit function should not be retained outside of the visit function, they may be
268 // invalidated by future mutators.
Colin Crossdc35e212019-06-06 16:13:11 -0700269 WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool)
Colin Cross9f35c3d2020-09-16 19:04:41 -0700270
Colin Crossdc35e212019-06-06 16:13:11 -0700271 // GetWalkPath is supposed to be called in visit function passed in WalkDeps()
272 // and returns a top-down dependency path from a start module to current child module.
273 GetWalkPath() []Module
274
Colin Cross4dfacf92020-09-16 19:22:27 -0700275 // PrimaryModule returns the first variant of the current module. Variants of a module are always visited in
276 // order by mutators and GenerateBuildActions, so the data created by the current mutator can be read from the
277 // Module returned by PrimaryModule without data races. This can be used to perform singleton actions that are
278 // only done once for all variants of a module.
279 PrimaryModule() Module
280
281 // FinalModule returns the last variant of the current module. Variants of a module are always visited in
282 // order by mutators and GenerateBuildActions, so the data created by the current mutator can be read from all
283 // variants using VisitAllModuleVariants if the current module == FinalModule(). This can be used to perform
284 // singleton actions that are only done once for all variants of a module.
285 FinalModule() Module
286
287 // VisitAllModuleVariants calls visit for each variant of the current module. Variants of a module are always
288 // visited in order by mutators and GenerateBuildActions, so the data created by the current mutator can be read
289 // from all variants if the current module == FinalModule(). Otherwise, care must be taken to not access any
290 // data modified by the current mutator.
291 VisitAllModuleVariants(visit func(Module))
292
Paul Duffinc5192442020-03-31 11:31:36 +0100293 // GetTagPath is supposed to be called in visit function passed in WalkDeps()
294 // and returns a top-down dependency tags path from a start module to current child module.
295 // It has one less entry than GetWalkPath() as it contains the dependency tags that
296 // exist between each adjacent pair of modules in the GetWalkPath().
297 // GetTagPath()[i] is the tag between GetWalkPath()[i] and GetWalkPath()[i+1]
298 GetTagPath() []blueprint.DependencyTag
299
Jiyong Park1c7e9622020-05-07 16:12:13 +0900300 // GetPathString is supposed to be called in visit function passed in WalkDeps()
301 // and returns a multi-line string showing the modules and dependency tags
302 // among them along the top-down dependency path from a start module to current child module.
303 // skipFirst when set to true, the output doesn't include the start module,
304 // which is already printed when this function is used along with ModuleErrorf().
305 GetPathString(skipFirst bool) string
306
Colin Crossdc35e212019-06-06 16:13:11 -0700307 AddMissingDependencies(missingDeps []string)
308
Colin Crossa1ad8d12016-06-01 17:09:44 -0700309 Target() Target
Colin Cross8b74d172016-09-13 09:59:14 -0700310 TargetPrimary() bool
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000311
312 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
313 // responsible for creating.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700314 MultiTargets() []Target
Colin Crossf6566ed2015-03-24 11:13:38 -0700315 Arch() Arch
Colin Crossa1ad8d12016-06-01 17:09:44 -0700316 Os() OsType
Colin Crossf6566ed2015-03-24 11:13:38 -0700317 Host() bool
318 Device() bool
Colin Cross0af4b842015-04-30 16:36:18 -0700319 Darwin() bool
Doug Horn21b94272019-01-16 12:06:11 -0800320 Fuchsia() bool
Colin Cross3edeee12017-04-04 12:59:48 -0700321 Windows() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700322 Debug() bool
Colin Cross1e7d3702016-08-24 15:25:47 -0700323 PrimaryArch() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700324}
325
Colin Cross1184b642019-12-30 18:43:07 -0800326// Deprecated: use EarlyModuleContext instead
Colin Cross635c3b02016-05-18 15:37:25 -0700327type BaseContext interface {
Colin Cross1184b642019-12-30 18:43:07 -0800328 EarlyModuleContext
Colin Crossaabf6792017-11-29 00:27:14 -0800329}
330
Colin Cross635c3b02016-05-18 15:37:25 -0700331type ModuleContext interface {
Colin Crossaabf6792017-11-29 00:27:14 -0800332 BaseModuleContext
Colin Cross3f40fa42015-01-30 17:27:36 -0800333
Colin Crossae887032017-10-23 17:16:14 -0700334 // Deprecated: use ModuleContext.Build instead.
Colin Cross0875c522017-11-28 17:34:01 -0800335 ModuleBuild(pctx PackageContext, params ModuleBuildParams)
Colin Cross8f101b42015-06-17 15:09:06 -0700336
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700337 ExpandSources(srcFiles, excludes []string) Paths
Colin Cross366938f2017-12-11 16:29:02 -0800338 ExpandSource(srcFile, prop string) Path
Colin Cross2383f3b2018-02-06 14:40:13 -0800339 ExpandOptionalSource(srcFile *string, prop string) OptionalPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700340
Colin Cross70dda7e2019-10-01 22:05:35 -0700341 InstallExecutable(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
342 InstallFile(installPath InstallPath, name string, srcPath Path, deps ...Path) InstallPath
343 InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath
344 InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700345 CheckbuildFile(srcPath Path)
Dan Willemsen6553f5e2016-03-10 18:14:25 -0800346
Colin Cross8d8f8e22016-08-03 11:57:50 -0700347 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700348 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700349 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800350 InstallInRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -0700351 InstallInVendorRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900352 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700353 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700354 InstallBypassMake() bool
Jiyong Park87788b52020-09-01 12:37:45 +0900355 InstallForceOS() (*OsType, *ArchType)
Nan Zhang6d34b302017-02-04 17:47:46 -0800356
357 RequiredModuleNames() []string
Sasha Smundakb6d23052019-04-01 18:37:36 -0700358 HostRequiredModuleNames() []string
359 TargetRequiredModuleNames() []string
Colin Cross3f68a132017-10-23 17:10:29 -0700360
Colin Cross3f68a132017-10-23 17:10:29 -0700361 ModuleSubDir() string
362
Colin Cross0875c522017-11-28 17:34:01 -0800363 Variable(pctx PackageContext, name, value string)
364 Rule(pctx PackageContext, name string, params blueprint.RuleParams, argNames ...string) blueprint.Rule
Colin Crossae887032017-10-23 17:16:14 -0700365 // Similar to blueprint.ModuleContext.Build, but takes Paths instead of []string,
366 // and performs more verification.
Colin Cross0875c522017-11-28 17:34:01 -0800367 Build(pctx PackageContext, params BuildParams)
Colin Crossc3d87d32020-06-04 13:25:17 -0700368 // Phony creates a Make-style phony rule, a rule with no commands that can depend on other
369 // phony rules or real files. Phony can be called on the same name multiple times to add
370 // additional dependencies.
371 Phony(phony string, deps ...Path)
Colin Cross3f68a132017-10-23 17:10:29 -0700372
Colin Cross9f35c3d2020-09-16 19:04:41 -0700373 // GetMissingDependencies returns the list of dependencies that were passed to AddDependencies or related methods,
374 // but do not exist.
Colin Cross3f68a132017-10-23 17:10:29 -0700375 GetMissingDependencies() []string
Colin Cross3f40fa42015-01-30 17:27:36 -0800376}
377
Colin Cross635c3b02016-05-18 15:37:25 -0700378type Module interface {
Colin Cross3f40fa42015-01-30 17:27:36 -0800379 blueprint.Module
380
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700381 // GenerateAndroidBuildActions is analogous to Blueprints' GenerateBuildActions,
382 // but GenerateAndroidBuildActions also has access to Android-specific information.
383 // For more information, see Module.GenerateBuildActions within Blueprint's module_ctx.go
Colin Cross635c3b02016-05-18 15:37:25 -0700384 GenerateAndroidBuildActions(ModuleContext)
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700385
Paul Duffin44f1d842020-06-26 20:17:02 +0100386 // Add dependencies to the components of a module, i.e. modules that are created
387 // by the module and which are considered to be part of the creating module.
388 //
389 // This is called before prebuilts are renamed so as to allow a dependency to be
390 // added directly to a prebuilt child module instead of depending on a source module
391 // and relying on prebuilt processing to switch to the prebuilt module if preferred.
392 //
393 // A dependency on a prebuilt must include the "prebuilt_" prefix.
394 ComponentDepsMutator(ctx BottomUpMutatorContext)
395
Colin Cross1e676be2016-10-12 14:38:15 -0700396 DepsMutator(BottomUpMutatorContext)
Colin Cross3f40fa42015-01-30 17:27:36 -0800397
Colin Cross635c3b02016-05-18 15:37:25 -0700398 base() *ModuleBase
Inseob Kimeec88e12020-01-22 11:11:29 +0900399 Disable()
Dan Willemsen0effe062015-11-30 16:06:01 -0800400 Enabled() bool
Colin Crossa1ad8d12016-06-01 17:09:44 -0700401 Target() Target
Anton Hansson1ee62c02020-06-30 11:51:53 +0100402 Owner() string
Dan Willemsen782a2d12015-12-21 14:55:28 -0800403 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700404 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700405 InstallInSanitizerDir() bool
Yifan Hong1b3348d2020-01-21 15:53:22 -0800406 InstallInRamdisk() bool
Yifan Hong60e0cfb2020-10-21 15:17:56 -0700407 InstallInVendorRamdisk() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900408 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700409 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700410 InstallBypassMake() bool
Jiyong Park87788b52020-09-01 12:37:45 +0900411 InstallForceOS() (*OsType, *ArchType)
Colin Crossa2f296f2016-11-29 15:16:18 -0800412 SkipInstall()
Ulya Trafimovichb28cc372020-01-13 15:18:16 +0000413 IsSkipInstall() bool
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +0100414 MakeUninstallable()
Liz Kammer5ca3a622020-08-05 15:40:41 -0700415 ReplacedByPrebuilt()
416 IsReplacedByPrebuilt() bool
Jiyong Park374510b2018-03-19 18:23:01 +0900417 ExportedToMake() bool
Inseob Kim8471cda2019-11-15 09:59:12 +0900418 InitRc() Paths
419 VintfFragments() Paths
Bob Badoura75b0572020-02-18 20:21:55 -0800420 NoticeFiles() Paths
Colin Cross36242852017-06-23 15:06:31 -0700421
422 AddProperties(props ...interface{})
423 GetProperties() []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700424
Colin Crossae887032017-10-23 17:16:14 -0700425 BuildParamsForTests() []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800426 RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800427 VariablesForTests() map[string]string
Paul Duffine2453c72019-05-31 14:00:04 +0100428
Colin Cross9a362232019-07-01 15:32:45 -0700429 // String returns a string that includes the module name and variants for printing during debugging.
430 String() string
431
Paul Duffine2453c72019-05-31 14:00:04 +0100432 // Get the qualified module id for this module.
433 qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName
434
435 // Get information about the properties that can contain visibility rules.
436 visibilityProperties() []visibilityProperty
Paul Duffin63c6e182019-07-24 14:24:38 +0100437
Jiyong Park6a8cf5f2019-12-30 16:31:09 +0900438 RequiredModuleNames() []string
439 HostRequiredModuleNames() []string
440 TargetRequiredModuleNames() []string
Colin Cross897266e2020-02-13 13:22:08 -0800441
Jiyong Park4dc2a1a2020-09-28 17:46:22 +0900442 FilesToInstall() InstallPaths
Jiyong Park073ea552020-11-09 14:08:34 +0900443 PackagingSpecs() []PackagingSpec
Paul Duffine2453c72019-05-31 14:00:04 +0100444}
445
446// Qualified id for a module
447type qualifiedModuleName struct {
448 // The package (i.e. directory) in which the module is defined, without trailing /
449 pkg string
450
451 // The name of the module, empty string if package.
452 name string
453}
454
455func (q qualifiedModuleName) String() string {
456 if q.name == "" {
457 return "//" + q.pkg
458 }
459 return "//" + q.pkg + ":" + q.name
460}
461
Paul Duffine484f472019-06-20 16:38:08 +0100462func (q qualifiedModuleName) isRootPackage() bool {
463 return q.pkg == "" && q.name == ""
464}
465
Paul Duffine2453c72019-05-31 14:00:04 +0100466// Get the id for the package containing this module.
467func (q qualifiedModuleName) getContainingPackageId() qualifiedModuleName {
468 pkg := q.pkg
469 if q.name == "" {
Paul Duffine484f472019-06-20 16:38:08 +0100470 if pkg == "" {
471 panic(fmt.Errorf("Cannot get containing package id of root package"))
472 }
473
474 index := strings.LastIndex(pkg, "/")
475 if index == -1 {
476 pkg = ""
477 } else {
478 pkg = pkg[:index]
479 }
Paul Duffine2453c72019-05-31 14:00:04 +0100480 }
481 return newPackageId(pkg)
482}
483
484func newPackageId(pkg string) qualifiedModuleName {
485 // A qualified id for a package module has no name.
486 return qualifiedModuleName{pkg: pkg, name: ""}
Colin Cross3f40fa42015-01-30 17:27:36 -0800487}
488
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000489type Dist struct {
490 // Copy the output of this module to the $DIST_DIR when `dist` is specified on the
491 // command line and any of these targets are also on the command line, or otherwise
492 // built
493 Targets []string `android:"arch_variant"`
494
495 // The name of the output artifact. This defaults to the basename of the output of
496 // the module.
497 Dest *string `android:"arch_variant"`
498
499 // The directory within the dist directory to store the artifact. Defaults to the
500 // top level directory ("").
501 Dir *string `android:"arch_variant"`
502
503 // A suffix to add to the artifact file name (before any extension).
504 Suffix *string `android:"arch_variant"`
505
506 // A string tag to select the OutputFiles associated with the tag. Defaults to the
507 // the empty "" string.
508 Tag *string `android:"arch_variant"`
509}
510
Colin Crossfc754582016-05-17 16:34:16 -0700511type nameProperties struct {
512 // The name of the module. Must be unique across all modules.
Nan Zhang0007d812017-11-07 10:57:05 -0800513 Name *string
Colin Crossfc754582016-05-17 16:34:16 -0700514}
515
Colin Cross08d6f8f2020-11-19 02:33:19 +0000516type commonProperties struct {
Dan Willemsen0effe062015-11-30 16:06:01 -0800517 // emit build rules for this module
Paul Duffin54d9bb72020-02-12 10:20:56 +0000518 //
519 // Disabling a module should only be done for those modules that cannot be built
520 // in the current environment. Modules that can build in the current environment
521 // but are not usually required (e.g. superceded by a prebuilt) should not be
522 // disabled as that will prevent them from being built by the checkbuild target
523 // and so prevent early detection of changes that have broken those modules.
Dan Willemsen0effe062015-11-30 16:06:01 -0800524 Enabled *bool `android:"arch_variant"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800525
Paul Duffin2e61fa62019-03-28 14:10:57 +0000526 // Controls the visibility of this module to other modules. Allowable values are one or more of
527 // these formats:
528 //
529 // ["//visibility:public"]: Anyone can use this module.
530 // ["//visibility:private"]: Only rules in the module's package (not its subpackages) can use
531 // this module.
Paul Duffin51084ff2020-05-05 19:19:22 +0100532 // ["//visibility:override"]: Discards any rules inherited from defaults or a creating module.
533 // Can only be used at the beginning of a list of visibility rules.
Paul Duffin2e61fa62019-03-28 14:10:57 +0000534 // ["//some/package:__pkg__", "//other/package:__pkg__"]: Only modules in some/package and
535 // other/package (defined in some/package/*.bp and other/package/*.bp) have access to
536 // this module. Note that sub-packages do not have access to the rule; for example,
537 // //some/package/foo:bar or //other/package/testing:bla wouldn't have access. __pkg__
538 // is a special module and must be used verbatim. It represents all of the modules in the
539 // package.
540 // ["//project:__subpackages__", "//other:__subpackages__"]: Only modules in packages project
541 // or other or in one of their sub-packages have access to this module. For example,
542 // //project:rule, //project/library:lib or //other/testing/internal:munge are allowed
543 // to depend on this rule (but not //independent:evil)
544 // ["//project"]: This is shorthand for ["//project:__pkg__"]
545 // [":__subpackages__"]: This is shorthand for ["//project:__subpackages__"] where
546 // //project is the module's package. e.g. using [":__subpackages__"] in
547 // packages/apps/Settings/Android.bp is equivalent to
548 // //packages/apps/Settings:__subpackages__.
549 // ["//visibility:legacy_public"]: The default visibility, behaves as //visibility:public
550 // for now. It is an error if it is used in a module.
Paul Duffine2453c72019-05-31 14:00:04 +0100551 //
552 // If a module does not specify the `visibility` property then it uses the
553 // `default_visibility` property of the `package` module in the module's package.
554 //
555 // If the `default_visibility` property is not set for the module's package then
Paul Duffine484f472019-06-20 16:38:08 +0100556 // it will use the `default_visibility` of its closest ancestor package for which
557 // a `default_visibility` property is specified.
558 //
559 // If no `default_visibility` property can be found then the module uses the
560 // global default of `//visibility:legacy_public`.
Paul Duffine2453c72019-05-31 14:00:04 +0100561 //
Paul Duffin95d53b52019-07-24 13:45:05 +0100562 // The `visibility` property has no effect on a defaults module although it does
563 // apply to any non-defaults module that uses it. To set the visibility of a
564 // defaults module, use the `defaults_visibility` property on the defaults module;
565 // not to be confused with the `default_visibility` property on the package module.
566 //
Paul Duffin2e61fa62019-03-28 14:10:57 +0000567 // See https://android.googlesource.com/platform/build/soong/+/master/README.md#visibility for
568 // more details.
569 Visibility []string
570
Colin Cross7d5136f2015-05-11 13:39:40 -0700571 // control whether this module compiles for 32-bit, 64-bit, or both. Possible values
Colin Cross3f40fa42015-01-30 17:27:36 -0800572 // are "32" (compile for 32-bit only), "64" (compile for 64-bit only), "both" (compile for both
573 // 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 +0000574 // platform).
Colin Cross7d716ba2017-11-01 10:38:29 -0700575 Compile_multilib *string `android:"arch_variant"`
Colin Cross69617d32016-09-06 10:39:07 -0700576
577 Target struct {
578 Host struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700579 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700580 }
581 Android struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700582 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700583 }
584 }
585
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000586 // If set to true then the archMutator will create variants for each arch specific target
587 // (e.g. 32/64) that the module is required to produce. If set to false then it will only
588 // create a variant for the architecture and will list the additional arch specific targets
589 // that the variant needs to produce in the CompileMultiTargets property.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700590 UseTargetVariants bool `blueprint:"mutated"`
591 Default_multilib string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800592
Dan Willemsen782a2d12015-12-21 14:55:28 -0800593 // whether this is a proprietary vendor module, and should be installed into /vendor
Colin Cross7d716ba2017-11-01 10:38:29 -0700594 Proprietary *bool
Dan Willemsen782a2d12015-12-21 14:55:28 -0800595
Colin Cross55708f32017-03-20 13:23:34 -0700596 // vendor who owns this module
Dan Willemsenefac4a82017-07-18 19:42:09 -0700597 Owner *string
Colin Cross55708f32017-03-20 13:23:34 -0700598
Jiyong Park2db76922017-11-08 16:03:48 +0900599 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
600 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
601 // Use `soc_specific` instead for better meaning.
Colin Cross7d716ba2017-11-01 10:38:29 -0700602 Vendor *bool
Dan Willemsenaa118f92017-04-06 12:49:58 -0700603
Jiyong Park2db76922017-11-08 16:03:48 +0900604 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
605 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
606 Soc_specific *bool
607
608 // whether this module is specific to a device, not only for SoC, but also for off-chip
609 // peripherals. When set to true, it is installed into /odm (or /vendor/odm if odm partition
610 // does not exist, or /system/vendor/odm if both odm and vendor partitions do not exist).
611 // This implies `soc_specific:true`.
612 Device_specific *bool
613
614 // whether this module is specific to a software configuration of a product (e.g. country,
Jaekyun Seok5cfbfbb2018-01-10 19:00:15 +0900615 // network operator, etc). When set to true, it is installed into /product (or
616 // /system/product if product partition does not exist).
Jiyong Park2db76922017-11-08 16:03:48 +0900617 Product_specific *bool
618
Justin Yund5f6c822019-06-25 16:47:17 +0900619 // whether this module extends system. When set to true, it is installed into /system_ext
620 // (or /system/system_ext if system_ext partition does not exist).
621 System_ext_specific *bool
622
Jiyong Parkf9332f12018-02-01 00:54:12 +0900623 // Whether this module is installed to recovery partition
624 Recovery *bool
625
Yifan Hong1b3348d2020-01-21 15:53:22 -0800626 // Whether this module is installed to ramdisk
627 Ramdisk *bool
628
Yifan Hong60e0cfb2020-10-21 15:17:56 -0700629 // Whether this module is installed to vendor ramdisk
630 Vendor_ramdisk *bool
631
dimitry1f33e402019-03-26 12:39:31 +0100632 // Whether this module is built for non-native architecures (also known as native bridge binary)
633 Native_bridge_supported *bool `android:"arch_variant"`
634
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700635 // init.rc files to be installed if this module is installed
Colin Cross0bab8772020-09-25 14:01:21 -0700636 Init_rc []string `android:"arch_variant,path"`
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700637
Steven Moreland57a23d22018-04-04 15:42:19 -0700638 // VINTF manifest fragments to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800639 Vintf_fragments []string `android:"path"`
Steven Moreland57a23d22018-04-04 15:42:19 -0700640
Chris Wolfe998306e2016-08-15 14:47:23 -0400641 // names of other modules to install if this module is installed
Colin Crossc602b7d2017-05-05 13:36:36 -0700642 Required []string `android:"arch_variant"`
Chris Wolfe998306e2016-08-15 14:47:23 -0400643
Sasha Smundakb6d23052019-04-01 18:37:36 -0700644 // names of other modules to install on host if this module is installed
645 Host_required []string `android:"arch_variant"`
646
647 // names of other modules to install on target if this module is installed
648 Target_required []string `android:"arch_variant"`
649
Colin Cross5aac3622017-08-31 15:07:09 -0700650 // relative path to a file to include in the list of notices for the device
Colin Cross27b922f2019-03-04 22:35:41 -0800651 Notice *string `android:"path"`
Colin Cross5aac3622017-08-31 15:07:09 -0700652
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000653 // The OsType of artifacts that this module variant is responsible for creating.
654 //
655 // Set by osMutator
656 CompileOS OsType `blueprint:"mutated"`
657
658 // The Target of artifacts that this module variant is responsible for creating.
659 //
660 // Set by archMutator
661 CompileTarget Target `blueprint:"mutated"`
662
663 // The additional arch specific targets (e.g. 32/64 bit) that this module variant is
664 // responsible for creating.
665 //
666 // By default this is nil as, where necessary, separate variants are created for the
667 // different multilib types supported and that information is encapsulated in the
668 // CompileTarget so the module variant simply needs to create artifacts for that.
669 //
670 // However, if UseTargetVariants is set to false (e.g. by
671 // InitAndroidMultiTargetsArchModule) then no separate variants are created for the
672 // multilib targets. Instead a single variant is created for the architecture and
673 // this contains the multilib specific targets that this variant should create.
674 //
675 // Set by archMutator
Colin Crossee0bc3b2018-10-02 22:01:37 -0700676 CompileMultiTargets []Target `blueprint:"mutated"`
Paul Duffinca7f0ef2020-02-25 15:50:49 +0000677
678 // True if the module variant's CompileTarget is the primary target
679 //
680 // Set by archMutator
681 CompilePrimary bool `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800682
683 // Set by InitAndroidModule
684 HostOrDeviceSupported HostOrDeviceSupported `blueprint:"mutated"`
Dan Willemsen0b24c742016-10-04 15:13:37 -0700685 ArchSpecific bool `blueprint:"mutated"`
Colin Crossce75d2c2016-10-06 16:12:58 -0700686
Paul Duffin1356d8c2020-02-25 19:26:33 +0000687 // If set to true then a CommonOS variant will be created which will have dependencies
688 // on all its OsType specific variants. Used by sdk/module_exports to create a snapshot
689 // that covers all os and architecture variants.
690 //
691 // The OsType specific variants can be retrieved by calling
692 // GetOsSpecificVariantsOfCommonOSVariant
693 //
694 // Set at module initialization time by calling InitCommonOSAndroidMultiTargetsArchModule
695 CreateCommonOSVariant bool `blueprint:"mutated"`
696
697 // If set to true then this variant is the CommonOS variant that has dependencies on its
698 // OsType specific variants.
699 //
700 // Set by osMutator.
701 CommonOSVariant bool `blueprint:"mutated"`
702
Colin Crossce75d2c2016-10-06 16:12:58 -0700703 SkipInstall bool `blueprint:"mutated"`
Jeff Gaston088e29e2017-11-29 16:47:17 -0800704
Liz Kammer5ca3a622020-08-05 15:40:41 -0700705 // Whether the module has been replaced by a prebuilt
706 ReplacedByPrebuilt bool `blueprint:"mutated"`
707
Justin Yun32f053b2020-07-31 23:07:17 +0900708 // Disabled by mutators. If set to true, it overrides Enabled property.
709 ForcedDisabled bool `blueprint:"mutated"`
710
Jeff Gaston088e29e2017-11-29 16:47:17 -0800711 NamespaceExportedToMake bool `blueprint:"mutated"`
Colin Cross6c4f21f2019-06-06 15:41:36 -0700712
713 MissingDeps []string `blueprint:"mutated"`
Colin Cross9a362232019-07-01 15:32:45 -0700714
715 // Name and variant strings stored by mutators to enable Module.String()
716 DebugName string `blueprint:"mutated"`
717 DebugMutators []string `blueprint:"mutated"`
718 DebugVariations []string `blueprint:"mutated"`
Colin Cross7228ecd2019-11-18 16:00:16 -0800719
Colin Crossa6845402020-11-16 15:08:19 -0800720 // ImageVariation is set by ImageMutator to specify which image this variation is for,
721 // for example "" for core or "recovery" for recovery. It will often be set to one of the
722 // constants in image.go, but can also be set to a custom value by individual module types.
Colin Cross7228ecd2019-11-18 16:00:16 -0800723 ImageVariation string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800724}
725
Paul Duffined875132020-09-02 13:08:57 +0100726type distProperties struct {
727 // configuration to distribute output files from this module to the distribution
728 // directory (default: $OUT/dist, configurable with $DIST_DIR)
729 Dist Dist `android:"arch_variant"`
730
731 // a list of configurations to distribute output files from this module to the
732 // distribution directory (default: $OUT/dist, configurable with $DIST_DIR)
733 Dists []Dist `android:"arch_variant"`
734}
735
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000736// A map of OutputFile tag keys to Paths, for disting purposes.
737type TaggedDistFiles map[string]Paths
738
739func MakeDefaultDistFiles(paths ...Path) TaggedDistFiles {
Jingwen Chen7b27ca72020-07-24 09:13:49 +0000740 for _, path := range paths {
741 if path == nil {
742 panic("The path to a dist file cannot be nil.")
743 }
744 }
745
Jingwen Chen40fd90a2020-06-15 05:24:19 +0000746 // The default OutputFile tag is the empty "" string.
747 return TaggedDistFiles{"": paths}
748}
749
Colin Cross3f40fa42015-01-30 17:27:36 -0800750type hostAndDeviceProperties struct {
Colin Cross4e81d702018-11-09 10:36:55 -0800751 // If set to true, build a variant of the module for the host. Defaults to false.
752 Host_supported *bool
753
754 // If set to true, build a variant of the module for the device. Defaults to true.
Colin Crossa4190c12016-07-12 13:11:25 -0700755 Device_supported *bool
Colin Cross3f40fa42015-01-30 17:27:36 -0800756}
757
Colin Crossc472d572015-03-17 15:06:21 -0700758type Multilib string
759
760const (
Colin Cross6b4a32d2017-12-05 13:42:45 -0800761 MultilibBoth Multilib = "both"
762 MultilibFirst Multilib = "first"
763 MultilibCommon Multilib = "common"
764 MultilibCommonFirst Multilib = "common_first"
765 MultilibDefault Multilib = ""
Colin Crossc472d572015-03-17 15:06:21 -0700766)
767
Colin Crossa1ad8d12016-06-01 17:09:44 -0700768type HostOrDeviceSupported int
769
770const (
Colin Cross34037c62020-11-17 13:19:17 -0800771 hostSupported = 1 << iota
772 hostCrossSupported
773 deviceSupported
774 hostDefault
775 deviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700776
777 // Host and HostCross are built by default. Device is not supported.
Colin Cross34037c62020-11-17 13:19:17 -0800778 HostSupported = hostSupported | hostCrossSupported | hostDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700779
780 // Host is built by default. HostCross and Device are not supported.
Colin Cross34037c62020-11-17 13:19:17 -0800781 HostSupportedNoCross = hostSupported | hostDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700782
783 // Device is built by default. Host and HostCross are not supported.
Colin Cross34037c62020-11-17 13:19:17 -0800784 DeviceSupported = deviceSupported | deviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700785
786 // Device is built by default. Host and HostCross are supported.
Colin Cross34037c62020-11-17 13:19:17 -0800787 HostAndDeviceSupported = hostSupported | hostCrossSupported | deviceSupported | deviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700788
789 // Host, HostCross, and Device are built by default.
Colin Cross34037c62020-11-17 13:19:17 -0800790 HostAndDeviceDefault = hostSupported | hostCrossSupported | hostDefault |
791 deviceSupported | deviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700792
793 // Nothing is supported. This is not exposed to the user, but used to mark a
794 // host only module as unsupported when the module type is not supported on
795 // the host OS. E.g. benchmarks are supported on Linux but not Darwin.
Colin Cross34037c62020-11-17 13:19:17 -0800796 NeitherHostNorDeviceSupported = 0
Colin Crossa1ad8d12016-06-01 17:09:44 -0700797)
798
Jiyong Park2db76922017-11-08 16:03:48 +0900799type moduleKind int
800
801const (
802 platformModule moduleKind = iota
803 deviceSpecificModule
804 socSpecificModule
805 productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900806 systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900807)
808
809func (k moduleKind) String() string {
810 switch k {
811 case platformModule:
812 return "platform"
813 case deviceSpecificModule:
814 return "device-specific"
815 case socSpecificModule:
816 return "soc-specific"
817 case productSpecificModule:
818 return "product-specific"
Justin Yund5f6c822019-06-25 16:47:17 +0900819 case systemExtSpecificModule:
820 return "systemext-specific"
Jiyong Park2db76922017-11-08 16:03:48 +0900821 default:
822 panic(fmt.Errorf("unknown module kind %d", k))
823 }
824}
825
Colin Cross9d34f352019-11-22 16:03:51 -0800826func initAndroidModuleBase(m Module) {
827 m.base().module = m
828}
829
Colin Crossa6845402020-11-16 15:08:19 -0800830// InitAndroidModule initializes the Module as an Android module that is not architecture-specific.
831// It adds the common properties, for example "name" and "enabled".
Colin Cross36242852017-06-23 15:06:31 -0700832func InitAndroidModule(m Module) {
Colin Cross9d34f352019-11-22 16:03:51 -0800833 initAndroidModuleBase(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800834 base := m.base()
Colin Cross5049f022015-03-18 13:28:46 -0700835
Colin Cross36242852017-06-23 15:06:31 -0700836 m.AddProperties(
Colin Crossfc754582016-05-17 16:34:16 -0700837 &base.nameProperties,
Paul Duffined875132020-09-02 13:08:57 +0100838 &base.commonProperties,
839 &base.distProperties)
Colin Cross18c46802019-09-24 22:19:02 -0700840
Colin Crosseabaedd2020-02-06 17:01:55 -0800841 initProductVariableModule(m)
Colin Cross18c46802019-09-24 22:19:02 -0700842
Colin Crossa3a97412019-03-18 12:24:29 -0700843 base.generalProperties = m.GetProperties()
Pirama Arumuga Nainar955dc492018-04-17 14:58:42 -0700844 base.customizableProperties = m.GetProperties()
Paul Duffin63c6e182019-07-24 14:24:38 +0100845
846 // The default_visibility property needs to be checked and parsed by the visibility module during
Paul Duffin5ec73ec2020-05-01 17:52:01 +0100847 // its checking and parsing phases so make it the primary visibility property.
848 setPrimaryVisibilityProperty(m, "visibility", &base.commonProperties.Visibility)
Colin Cross5049f022015-03-18 13:28:46 -0700849}
850
Colin Crossa6845402020-11-16 15:08:19 -0800851// InitAndroidArchModule initializes the Module as an Android module that is architecture-specific.
852// It adds the common properties, for example "name" and "enabled", as well as runtime generated
853// property structs for architecture-specific versions of generic properties tagged with
854// `android:"arch_variant"`.
855//
856// InitAndroidModule should not be called if InitAndroidArchModule was called.
Colin Cross36242852017-06-23 15:06:31 -0700857func InitAndroidArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
858 InitAndroidModule(m)
Colin Cross5049f022015-03-18 13:28:46 -0700859
860 base := m.base()
Colin Cross3f40fa42015-01-30 17:27:36 -0800861 base.commonProperties.HostOrDeviceSupported = hod
Colin Cross69617d32016-09-06 10:39:07 -0700862 base.commonProperties.Default_multilib = string(defaultMultilib)
Dan Willemsen0b24c742016-10-04 15:13:37 -0700863 base.commonProperties.ArchSpecific = true
Colin Crossee0bc3b2018-10-02 22:01:37 -0700864 base.commonProperties.UseTargetVariants = true
Colin Cross3f40fa42015-01-30 17:27:36 -0800865
Colin Cross34037c62020-11-17 13:19:17 -0800866 if hod&hostSupported != 0 && hod&deviceSupported != 0 {
Colin Cross36242852017-06-23 15:06:31 -0700867 m.AddProperties(&base.hostAndDeviceProperties)
Colin Cross3f40fa42015-01-30 17:27:36 -0800868 }
869
Colin Crossa6845402020-11-16 15:08:19 -0800870 initArchModule(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800871}
872
Colin Crossa6845402020-11-16 15:08:19 -0800873// InitAndroidMultiTargetsArchModule initializes the Module as an Android module that is
874// architecture-specific, but will only have a single variant per OS that handles all the
875// architectures simultaneously. The list of Targets that it must handle will be available from
876// ModuleContext.MultiTargets. It adds the common properties, for example "name" and "enabled", as
877// well as runtime generated property structs for architecture-specific versions of generic
878// properties tagged with `android:"arch_variant"`.
879//
880// InitAndroidModule or InitAndroidArchModule should not be called if
881// InitAndroidMultiTargetsArchModule was called.
Colin Crossee0bc3b2018-10-02 22:01:37 -0700882func InitAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
883 InitAndroidArchModule(m, hod, defaultMultilib)
884 m.base().commonProperties.UseTargetVariants = false
885}
886
Colin Crossa6845402020-11-16 15:08:19 -0800887// InitCommonOSAndroidMultiTargetsArchModule initializes the Module as an Android module that is
888// architecture-specific, but will only have a single variant per OS that handles all the
889// architectures simultaneously, and will also have an additional CommonOS variant that has
890// dependencies on all the OS-specific variants. The list of Targets that it must handle will be
891// available from ModuleContext.MultiTargets. It adds the common properties, for example "name" and
892// "enabled", as well as runtime generated property structs for architecture-specific versions of
893// generic properties tagged with `android:"arch_variant"`.
894//
895// InitAndroidModule, InitAndroidArchModule or InitAndroidMultiTargetsArchModule should not be
896// called if InitCommonOSAndroidMultiTargetsArchModule was called.
Paul Duffin1356d8c2020-02-25 19:26:33 +0000897func InitCommonOSAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
898 InitAndroidArchModule(m, hod, defaultMultilib)
899 m.base().commonProperties.UseTargetVariants = false
900 m.base().commonProperties.CreateCommonOSVariant = true
901}
902
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800903// A ModuleBase object contains the properties that are common to all Android
Colin Cross3f40fa42015-01-30 17:27:36 -0800904// modules. It should be included as an anonymous field in every module
905// struct definition. InitAndroidModule should then be called from the module's
906// factory function, and the return values from InitAndroidModule should be
907// returned from the factory function.
908//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800909// The ModuleBase type is responsible for implementing the GenerateBuildActions
910// method to support the blueprint.Module interface. This method will then call
911// the module's GenerateAndroidBuildActions method once for each build variant
Colin Cross25de6c32019-06-06 14:29:25 -0700912// that is to be built. GenerateAndroidBuildActions is passed a ModuleContext
913// rather than the usual blueprint.ModuleContext.
914// ModuleContext exposes extra functionality specific to the Android build
Colin Cross3f40fa42015-01-30 17:27:36 -0800915// system including details about the particular build variant that is to be
916// generated.
917//
918// For example:
919//
920// import (
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800921// "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -0800922// )
923//
924// type myModule struct {
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800925// android.ModuleBase
Colin Cross3f40fa42015-01-30 17:27:36 -0800926// properties struct {
927// MyProperty string
928// }
929// }
930//
Colin Cross36242852017-06-23 15:06:31 -0700931// func NewMyModule() android.Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800932// m := &myModule{}
Colin Cross36242852017-06-23 15:06:31 -0700933// m.AddProperties(&m.properties)
934// android.InitAndroidModule(m)
935// return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800936// }
937//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800938// func (m *myModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800939// // Get the CPU architecture for the current build variant.
940// variantArch := ctx.Arch()
941//
942// // ...
943// }
Colin Cross635c3b02016-05-18 15:37:25 -0700944type ModuleBase struct {
Colin Cross3f40fa42015-01-30 17:27:36 -0800945 // Putting the curiously recurring thing pointing to the thing that contains
946 // the thing pattern to good use.
Colin Cross36242852017-06-23 15:06:31 -0700947 // TODO: remove this
Colin Cross635c3b02016-05-18 15:37:25 -0700948 module Module
Colin Cross3f40fa42015-01-30 17:27:36 -0800949
Colin Crossfc754582016-05-17 16:34:16 -0700950 nameProperties nameProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800951 commonProperties commonProperties
Paul Duffined875132020-09-02 13:08:57 +0100952 distProperties distProperties
Colin Cross18c46802019-09-24 22:19:02 -0700953 variableProperties interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800954 hostAndDeviceProperties hostAndDeviceProperties
955 generalProperties []interface{}
Colin Crossc17727d2018-10-24 12:42:09 -0700956 archProperties [][]interface{}
Colin Crossa120ec12016-08-19 16:07:38 -0700957 customizableProperties []interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800958
Paul Duffin63c6e182019-07-24 14:24:38 +0100959 // Information about all the properties on the module that contains visibility rules that need
960 // checking.
961 visibilityPropertyInfo []visibilityProperty
962
963 // The primary visibility property, may be nil, that controls access to the module.
964 primaryVisibilityProperty visibilityProperty
965
Colin Cross3f40fa42015-01-30 17:27:36 -0800966 noAddressSanitizer bool
Colin Cross897266e2020-02-13 13:22:08 -0800967 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700968 checkbuildFiles Paths
Jiyong Park073ea552020-11-09 14:08:34 +0900969 packagingSpecs []PackagingSpec
Bob Badoura75b0572020-02-18 20:21:55 -0800970 noticeFiles Paths
Colin Crossc3d87d32020-06-04 13:25:17 -0700971 phonies map[string]Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -0700972
973 // Used by buildTargetSingleton to create checkbuild and per-directory build targets
974 // Only set on the final variant of each module
Colin Cross0875c522017-11-28 17:34:01 -0800975 installTarget WritablePath
976 checkbuildTarget WritablePath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700977 blueprintDir string
Colin Crossa120ec12016-08-19 16:07:38 -0700978
Colin Cross178a5092016-09-13 13:42:32 -0700979 hooks hooks
Colin Cross36242852017-06-23 15:06:31 -0700980
981 registerProps []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700982
983 // For tests
Colin Crossae887032017-10-23 17:16:14 -0700984 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800985 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800986 variables map[string]string
Colin Crossa9d8bee2018-10-02 13:59:46 -0700987
Inseob Kim8471cda2019-11-15 09:59:12 +0900988 initRcPaths Paths
989 vintfFragmentsPaths Paths
990
Jiyong Park1613e552020-09-14 19:43:17 +0900991 prefer32 func(ctx BaseModuleContext, base *ModuleBase, os OsType) bool
Colin Cross36242852017-06-23 15:06:31 -0700992}
993
Paul Duffin44f1d842020-06-26 20:17:02 +0100994func (m *ModuleBase) ComponentDepsMutator(BottomUpMutatorContext) {}
995
Colin Cross4157e882019-06-06 16:57:04 -0700996func (m *ModuleBase) DepsMutator(BottomUpMutatorContext) {}
Colin Cross5f692ec2019-02-01 16:53:07 -0800997
Colin Cross4157e882019-06-06 16:57:04 -0700998func (m *ModuleBase) AddProperties(props ...interface{}) {
999 m.registerProps = append(m.registerProps, props...)
Colin Cross36242852017-06-23 15:06:31 -07001000}
1001
Colin Cross4157e882019-06-06 16:57:04 -07001002func (m *ModuleBase) GetProperties() []interface{} {
1003 return m.registerProps
Colin Cross3f40fa42015-01-30 17:27:36 -08001004}
1005
Colin Cross4157e882019-06-06 16:57:04 -07001006func (m *ModuleBase) BuildParamsForTests() []BuildParams {
1007 return m.buildParams
Colin Crosscec81712017-07-13 14:43:27 -07001008}
1009
Colin Cross4157e882019-06-06 16:57:04 -07001010func (m *ModuleBase) RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams {
1011 return m.ruleParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001012}
1013
Colin Cross4157e882019-06-06 16:57:04 -07001014func (m *ModuleBase) VariablesForTests() map[string]string {
1015 return m.variables
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001016}
1017
Jiyong Park1613e552020-09-14 19:43:17 +09001018func (m *ModuleBase) Prefer32(prefer32 func(ctx BaseModuleContext, base *ModuleBase, os OsType) bool) {
Colin Cross4157e882019-06-06 16:57:04 -07001019 m.prefer32 = prefer32
Colin Crossa9d8bee2018-10-02 13:59:46 -07001020}
1021
Colin Crossce75d2c2016-10-06 16:12:58 -07001022// Name returns the name of the module. It may be overridden by individual module types, for
1023// example prebuilts will prepend prebuilt_ to the name.
Colin Cross4157e882019-06-06 16:57:04 -07001024func (m *ModuleBase) Name() string {
1025 return String(m.nameProperties.Name)
Colin Crossfc754582016-05-17 16:34:16 -07001026}
1027
Colin Cross9a362232019-07-01 15:32:45 -07001028// String returns a string that includes the module name and variants for printing during debugging.
1029func (m *ModuleBase) String() string {
1030 sb := strings.Builder{}
1031 sb.WriteString(m.commonProperties.DebugName)
1032 sb.WriteString("{")
1033 for i := range m.commonProperties.DebugMutators {
1034 if i != 0 {
1035 sb.WriteString(",")
1036 }
1037 sb.WriteString(m.commonProperties.DebugMutators[i])
1038 sb.WriteString(":")
1039 sb.WriteString(m.commonProperties.DebugVariations[i])
1040 }
1041 sb.WriteString("}")
1042 return sb.String()
1043}
1044
Colin Crossce75d2c2016-10-06 16:12:58 -07001045// BaseModuleName returns the name of the module as specified in the blueprints file.
Colin Cross4157e882019-06-06 16:57:04 -07001046func (m *ModuleBase) BaseModuleName() string {
1047 return String(m.nameProperties.Name)
Colin Crossce75d2c2016-10-06 16:12:58 -07001048}
1049
Colin Cross4157e882019-06-06 16:57:04 -07001050func (m *ModuleBase) base() *ModuleBase {
1051 return m
Colin Cross3f40fa42015-01-30 17:27:36 -08001052}
1053
Paul Duffine2453c72019-05-31 14:00:04 +01001054func (m *ModuleBase) qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName {
1055 return qualifiedModuleName{pkg: ctx.ModuleDir(), name: ctx.ModuleName()}
1056}
1057
1058func (m *ModuleBase) visibilityProperties() []visibilityProperty {
Paul Duffin63c6e182019-07-24 14:24:38 +01001059 return m.visibilityPropertyInfo
1060}
1061
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001062func (m *ModuleBase) Dists() []Dist {
Paul Duffined875132020-09-02 13:08:57 +01001063 if len(m.distProperties.Dist.Targets) > 0 {
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001064 // Make a copy of the underlying Dists slice to protect against
1065 // backing array modifications with repeated calls to this method.
Paul Duffined875132020-09-02 13:08:57 +01001066 distsCopy := append([]Dist(nil), m.distProperties.Dists...)
1067 return append(distsCopy, m.distProperties.Dist)
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001068 } else {
Paul Duffined875132020-09-02 13:08:57 +01001069 return m.distProperties.Dists
Jingwen Chen40fd90a2020-06-15 05:24:19 +00001070 }
1071}
1072
1073func (m *ModuleBase) GenerateTaggedDistFiles(ctx BaseModuleContext) TaggedDistFiles {
1074 distFiles := make(TaggedDistFiles)
1075 for _, dist := range m.Dists() {
1076 var tag string
1077 var distFilesForTag Paths
1078 if dist.Tag == nil {
1079 tag = ""
1080 } else {
1081 tag = *dist.Tag
1082 }
1083 distFilesForTag, err := m.base().module.(OutputFileProducer).OutputFiles(tag)
1084 if err != nil {
1085 ctx.PropertyErrorf("dist.tag", "%s", err.Error())
1086 }
1087 for _, distFile := range distFilesForTag {
1088 if distFile != nil && !distFiles[tag].containsPath(distFile) {
1089 distFiles[tag] = append(distFiles[tag], distFile)
1090 }
1091 }
1092 }
1093
1094 return distFiles
1095}
1096
Colin Cross4157e882019-06-06 16:57:04 -07001097func (m *ModuleBase) Target() Target {
1098 return m.commonProperties.CompileTarget
Dan Willemsen490fd492015-11-24 17:53:15 -08001099}
1100
Colin Cross4157e882019-06-06 16:57:04 -07001101func (m *ModuleBase) TargetPrimary() bool {
1102 return m.commonProperties.CompilePrimary
Colin Cross8b74d172016-09-13 09:59:14 -07001103}
1104
Colin Cross4157e882019-06-06 16:57:04 -07001105func (m *ModuleBase) MultiTargets() []Target {
1106 return m.commonProperties.CompileMultiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07001107}
1108
Colin Cross4157e882019-06-06 16:57:04 -07001109func (m *ModuleBase) Os() OsType {
1110 return m.Target().Os
Dan Willemsen490fd492015-11-24 17:53:15 -08001111}
1112
Colin Cross4157e882019-06-06 16:57:04 -07001113func (m *ModuleBase) Host() bool {
Jiyong Park1613e552020-09-14 19:43:17 +09001114 return m.Os().Class == Host
Dan Willemsen97750522016-02-09 17:43:51 -08001115}
1116
Yo Chiangbba545e2020-06-09 16:15:37 +08001117func (m *ModuleBase) Device() bool {
1118 return m.Os().Class == Device
1119}
1120
Colin Cross4157e882019-06-06 16:57:04 -07001121func (m *ModuleBase) Arch() Arch {
1122 return m.Target().Arch
Dan Willemsen97750522016-02-09 17:43:51 -08001123}
1124
Colin Cross4157e882019-06-06 16:57:04 -07001125func (m *ModuleBase) ArchSpecific() bool {
1126 return m.commonProperties.ArchSpecific
Dan Willemsen0b24c742016-10-04 15:13:37 -07001127}
1128
Paul Duffin1356d8c2020-02-25 19:26:33 +00001129// True if the current variant is a CommonOS variant, false otherwise.
1130func (m *ModuleBase) IsCommonOSVariant() bool {
1131 return m.commonProperties.CommonOSVariant
1132}
1133
Colin Cross34037c62020-11-17 13:19:17 -08001134// supportsTarget returns true if the given Target is supported by the current module.
1135func (m *ModuleBase) supportsTarget(target Target) bool {
1136 switch target.Os.Class {
1137 case Host:
1138 if target.HostCross {
1139 return m.HostCrossSupported()
1140 } else {
1141 return m.HostSupported()
Colin Crossa1ad8d12016-06-01 17:09:44 -07001142 }
Colin Cross34037c62020-11-17 13:19:17 -08001143 case Device:
1144 return m.DeviceSupported()
Colin Crossa1ad8d12016-06-01 17:09:44 -07001145 default:
Jiyong Park1613e552020-09-14 19:43:17 +09001146 return false
Colin Crossa1ad8d12016-06-01 17:09:44 -07001147 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001148}
1149
Colin Cross34037c62020-11-17 13:19:17 -08001150// DeviceSupported returns true if the current module is supported and enabled for device targets,
1151// i.e. the factory method set the HostOrDeviceSupported value to include device support and
1152// the device support is enabled by default or enabled by the device_supported property.
Colin Cross4157e882019-06-06 16:57:04 -07001153func (m *ModuleBase) DeviceSupported() bool {
Colin Cross34037c62020-11-17 13:19:17 -08001154 hod := m.commonProperties.HostOrDeviceSupported
1155 // deviceEnabled is true if the device_supported property is true or the HostOrDeviceSupported
1156 // value has the deviceDefault bit set.
1157 deviceEnabled := proptools.BoolDefault(m.hostAndDeviceProperties.Device_supported, hod&deviceDefault != 0)
1158 return hod&deviceSupported != 0 && deviceEnabled
Colin Cross3f40fa42015-01-30 17:27:36 -08001159}
1160
Colin Cross34037c62020-11-17 13:19:17 -08001161// HostSupported returns true if the current module is supported and enabled for host targets,
1162// i.e. the factory method set the HostOrDeviceSupported value to include host support and
1163// the host support is enabled by default or enabled by the host_supported property.
Paul Duffine44358f2019-11-26 18:04:12 +00001164func (m *ModuleBase) HostSupported() bool {
Colin Cross34037c62020-11-17 13:19:17 -08001165 hod := m.commonProperties.HostOrDeviceSupported
1166 // hostEnabled is true if the host_supported property is true or the HostOrDeviceSupported
1167 // value has the hostDefault bit set.
1168 hostEnabled := proptools.BoolDefault(m.hostAndDeviceProperties.Host_supported, hod&hostDefault != 0)
1169 return hod&hostSupported != 0 && hostEnabled
1170}
1171
1172// HostCrossSupported returns true if the current module is supported and enabled for host cross
1173// targets, i.e. the factory method set the HostOrDeviceSupported value to include host cross
1174// support and the host cross support is enabled by default or enabled by the
1175// host_supported property.
1176func (m *ModuleBase) HostCrossSupported() bool {
1177 hod := m.commonProperties.HostOrDeviceSupported
1178 // hostEnabled is true if the host_supported property is true or the HostOrDeviceSupported
1179 // value has the hostDefault bit set.
1180 hostEnabled := proptools.BoolDefault(m.hostAndDeviceProperties.Host_supported, hod&hostDefault != 0)
1181 return hod&hostCrossSupported != 0 && hostEnabled
Paul Duffine44358f2019-11-26 18:04:12 +00001182}
1183
Colin Cross4157e882019-06-06 16:57:04 -07001184func (m *ModuleBase) Platform() bool {
Justin Yund5f6c822019-06-25 16:47:17 +09001185 return !m.DeviceSpecific() && !m.SocSpecific() && !m.ProductSpecific() && !m.SystemExtSpecific()
Jiyong Parkc678ad32018-04-10 13:07:10 +09001186}
1187
Colin Cross4157e882019-06-06 16:57:04 -07001188func (m *ModuleBase) DeviceSpecific() bool {
1189 return Bool(m.commonProperties.Device_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +09001190}
1191
Colin Cross4157e882019-06-06 16:57:04 -07001192func (m *ModuleBase) SocSpecific() bool {
1193 return Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +09001194}
1195
Colin Cross4157e882019-06-06 16:57:04 -07001196func (m *ModuleBase) ProductSpecific() bool {
1197 return Bool(m.commonProperties.Product_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +09001198}
1199
Justin Yund5f6c822019-06-25 16:47:17 +09001200func (m *ModuleBase) SystemExtSpecific() bool {
1201 return Bool(m.commonProperties.System_ext_specific)
Dario Frenifd05a742018-05-29 13:28:54 +01001202}
1203
Colin Crossc2d24052020-05-13 11:05:02 -07001204// RequiresStableAPIs returns true if the module will be installed to a partition that may
1205// be updated separately from the system image.
1206func (m *ModuleBase) RequiresStableAPIs(ctx BaseModuleContext) bool {
1207 return m.SocSpecific() || m.DeviceSpecific() ||
1208 (m.ProductSpecific() && ctx.Config().EnforceProductPartitionInterface())
1209}
1210
Bill Peckhamfff3f8a2020-03-20 18:33:20 -07001211func (m *ModuleBase) PartitionTag(config DeviceConfig) string {
1212 partition := "system"
1213 if m.SocSpecific() {
1214 // A SoC-specific module could be on the vendor partition at
1215 // "vendor" or the system partition at "system/vendor".
1216 if config.VendorPath() == "vendor" {
1217 partition = "vendor"
1218 }
1219 } else if m.DeviceSpecific() {
1220 // A device-specific module could be on the odm partition at
1221 // "odm", the vendor partition at "vendor/odm", or the system
1222 // partition at "system/vendor/odm".
1223 if config.OdmPath() == "odm" {
1224 partition = "odm"
Ramy Medhat944839a2020-03-31 22:14:52 -04001225 } else if strings.HasPrefix(config.OdmPath(), "vendor/") {
Bill Peckhamfff3f8a2020-03-20 18:33:20 -07001226 partition = "vendor"
1227 }
1228 } else if m.ProductSpecific() {
1229 // A product-specific module could be on the product partition
1230 // at "product" or the system partition at "system/product".
1231 if config.ProductPath() == "product" {
1232 partition = "product"
1233 }
1234 } else if m.SystemExtSpecific() {
1235 // A system_ext-specific module could be on the system_ext
1236 // partition at "system_ext" or the system partition at
1237 // "system/system_ext".
1238 if config.SystemExtPath() == "system_ext" {
1239 partition = "system_ext"
1240 }
1241 }
1242 return partition
1243}
1244
Colin Cross4157e882019-06-06 16:57:04 -07001245func (m *ModuleBase) Enabled() bool {
Justin Yun32f053b2020-07-31 23:07:17 +09001246 if m.commonProperties.ForcedDisabled {
1247 return false
1248 }
Colin Cross08d6f8f2020-11-19 02:33:19 +00001249 if m.commonProperties.Enabled == nil {
1250 return !m.Os().DefaultDisabled
1251 }
1252 return *m.commonProperties.Enabled
Colin Cross3f40fa42015-01-30 17:27:36 -08001253}
1254
Inseob Kimeec88e12020-01-22 11:11:29 +09001255func (m *ModuleBase) Disable() {
Justin Yun32f053b2020-07-31 23:07:17 +09001256 m.commonProperties.ForcedDisabled = true
Inseob Kimeec88e12020-01-22 11:11:29 +09001257}
1258
Colin Cross4157e882019-06-06 16:57:04 -07001259func (m *ModuleBase) SkipInstall() {
1260 m.commonProperties.SkipInstall = true
Colin Crossce75d2c2016-10-06 16:12:58 -07001261}
1262
Ulya Trafimovichb28cc372020-01-13 15:18:16 +00001263func (m *ModuleBase) IsSkipInstall() bool {
1264 return m.commonProperties.SkipInstall == true
1265}
1266
Martin Stjernholm9e9bb7f2020-08-06 22:34:42 +01001267// Similar to SkipInstall, but if the AndroidMk entry would set
1268// LOCAL_UNINSTALLABLE_MODULE then this variant may still output that entry
1269// rather than leaving it out altogether. That happens in cases where it would
1270// have other side effects, in particular when it adds a NOTICE file target,
1271// which other install targets might depend on.
1272func (m *ModuleBase) MakeUninstallable() {
1273 m.SkipInstall()
1274}
1275
Liz Kammer5ca3a622020-08-05 15:40:41 -07001276func (m *ModuleBase) ReplacedByPrebuilt() {
1277 m.commonProperties.ReplacedByPrebuilt = true
1278 m.SkipInstall()
1279}
1280
1281func (m *ModuleBase) IsReplacedByPrebuilt() bool {
1282 return m.commonProperties.ReplacedByPrebuilt
1283}
1284
Colin Cross4157e882019-06-06 16:57:04 -07001285func (m *ModuleBase) ExportedToMake() bool {
1286 return m.commonProperties.NamespaceExportedToMake
Jiyong Park374510b2018-03-19 18:23:01 +09001287}
1288
Colin Crosse9fe2942020-11-10 18:12:15 -08001289// computeInstallDeps finds the installed paths of all dependencies that have a dependency
1290// tag that is annotated as needing installation via the IsInstallDepNeeded method.
Colin Cross897266e2020-02-13 13:22:08 -08001291func (m *ModuleBase) computeInstallDeps(ctx blueprint.ModuleContext) InstallPaths {
Colin Cross897266e2020-02-13 13:22:08 -08001292 var result InstallPaths
Colin Crosse9fe2942020-11-10 18:12:15 -08001293 ctx.WalkDeps(func(child, parent blueprint.Module) bool {
1294 if a, ok := child.(Module); ok {
1295 if IsInstallDepNeeded(ctx.OtherModuleDependencyTag(child)) {
1296 result = append(result, a.FilesToInstall()...)
1297 return true
1298 }
Colin Cross897266e2020-02-13 13:22:08 -08001299 }
Colin Crosse9fe2942020-11-10 18:12:15 -08001300 return false
Colin Cross897266e2020-02-13 13:22:08 -08001301 })
Colin Cross3f40fa42015-01-30 17:27:36 -08001302
1303 return result
1304}
1305
Jiyong Park4dc2a1a2020-09-28 17:46:22 +09001306func (m *ModuleBase) FilesToInstall() InstallPaths {
Colin Cross4157e882019-06-06 16:57:04 -07001307 return m.installFiles
Colin Cross3f40fa42015-01-30 17:27:36 -08001308}
1309
Jiyong Park073ea552020-11-09 14:08:34 +09001310func (m *ModuleBase) PackagingSpecs() []PackagingSpec {
1311 return m.packagingSpecs
1312}
1313
Colin Cross4157e882019-06-06 16:57:04 -07001314func (m *ModuleBase) NoAddressSanitizer() bool {
1315 return m.noAddressSanitizer
Colin Cross3f40fa42015-01-30 17:27:36 -08001316}
1317
Colin Cross4157e882019-06-06 16:57:04 -07001318func (m *ModuleBase) InstallInData() bool {
Dan Willemsen782a2d12015-12-21 14:55:28 -08001319 return false
1320}
1321
Jaewoong Jung0949f312019-09-11 10:25:18 -07001322func (m *ModuleBase) InstallInTestcases() bool {
1323 return false
1324}
1325
Colin Cross4157e882019-06-06 16:57:04 -07001326func (m *ModuleBase) InstallInSanitizerDir() bool {
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001327 return false
1328}
1329
Yifan Hong1b3348d2020-01-21 15:53:22 -08001330func (m *ModuleBase) InstallInRamdisk() bool {
1331 return Bool(m.commonProperties.Ramdisk)
1332}
1333
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001334func (m *ModuleBase) InstallInVendorRamdisk() bool {
1335 return Bool(m.commonProperties.Vendor_ramdisk)
1336}
1337
Colin Cross4157e882019-06-06 16:57:04 -07001338func (m *ModuleBase) InstallInRecovery() bool {
1339 return Bool(m.commonProperties.Recovery)
Jiyong Parkf9332f12018-02-01 00:54:12 +09001340}
1341
Colin Cross90ba5f42019-10-02 11:10:58 -07001342func (m *ModuleBase) InstallInRoot() bool {
1343 return false
1344}
1345
Colin Cross607d8582019-07-29 16:44:46 -07001346func (m *ModuleBase) InstallBypassMake() bool {
1347 return false
1348}
1349
Jiyong Park87788b52020-09-01 12:37:45 +09001350func (m *ModuleBase) InstallForceOS() (*OsType, *ArchType) {
1351 return nil, nil
Colin Cross6e359402020-02-10 15:29:54 -08001352}
1353
Colin Cross4157e882019-06-06 16:57:04 -07001354func (m *ModuleBase) Owner() string {
1355 return String(m.commonProperties.Owner)
Sundong Ahn4fd04bb2018-08-31 18:01:37 +09001356}
1357
Bob Badoura75b0572020-02-18 20:21:55 -08001358func (m *ModuleBase) NoticeFiles() Paths {
1359 return m.noticeFiles
Jiyong Park52818fc2019-03-18 12:01:38 +09001360}
1361
Colin Cross7228ecd2019-11-18 16:00:16 -08001362func (m *ModuleBase) setImageVariation(variant string) {
1363 m.commonProperties.ImageVariation = variant
1364}
1365
1366func (m *ModuleBase) ImageVariation() blueprint.Variation {
1367 return blueprint.Variation{
1368 Mutator: "image",
1369 Variation: m.base().commonProperties.ImageVariation,
1370 }
1371}
1372
Paul Duffin9b76c0b2020-03-12 10:24:35 +00001373func (m *ModuleBase) getVariationByMutatorName(mutator string) string {
1374 for i, v := range m.commonProperties.DebugMutators {
1375 if v == mutator {
1376 return m.commonProperties.DebugVariations[i]
1377 }
1378 }
1379
1380 return ""
1381}
1382
Yifan Hong1b3348d2020-01-21 15:53:22 -08001383func (m *ModuleBase) InRamdisk() bool {
1384 return m.base().commonProperties.ImageVariation == RamdiskVariation
1385}
1386
Yifan Hong60e0cfb2020-10-21 15:17:56 -07001387func (m *ModuleBase) InVendorRamdisk() bool {
1388 return m.base().commonProperties.ImageVariation == VendorRamdiskVariation
1389}
1390
Colin Cross7228ecd2019-11-18 16:00:16 -08001391func (m *ModuleBase) InRecovery() bool {
1392 return m.base().commonProperties.ImageVariation == RecoveryVariation
1393}
1394
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09001395func (m *ModuleBase) RequiredModuleNames() []string {
1396 return m.base().commonProperties.Required
1397}
1398
1399func (m *ModuleBase) HostRequiredModuleNames() []string {
1400 return m.base().commonProperties.Host_required
1401}
1402
1403func (m *ModuleBase) TargetRequiredModuleNames() []string {
1404 return m.base().commonProperties.Target_required
1405}
1406
Inseob Kim8471cda2019-11-15 09:59:12 +09001407func (m *ModuleBase) InitRc() Paths {
1408 return append(Paths{}, m.initRcPaths...)
1409}
1410
1411func (m *ModuleBase) VintfFragments() Paths {
1412 return append(Paths{}, m.vintfFragmentsPaths...)
1413}
1414
Colin Cross4157e882019-06-06 16:57:04 -07001415func (m *ModuleBase) generateModuleTarget(ctx ModuleContext) {
Colin Cross897266e2020-02-13 13:22:08 -08001416 var allInstalledFiles InstallPaths
1417 var allCheckbuildFiles Paths
Colin Cross0875c522017-11-28 17:34:01 -08001418 ctx.VisitAllModuleVariants(func(module Module) {
1419 a := module.base()
Colin Crossc9404352015-03-26 16:10:12 -07001420 allInstalledFiles = append(allInstalledFiles, a.installFiles...)
1421 allCheckbuildFiles = append(allCheckbuildFiles, a.checkbuildFiles...)
Colin Cross3f40fa42015-01-30 17:27:36 -08001422 })
1423
Colin Cross0875c522017-11-28 17:34:01 -08001424 var deps Paths
Colin Cross9454bfa2015-03-17 13:24:18 -07001425
Colin Cross133ebef2020-08-14 17:38:45 -07001426 namespacePrefix := ctx.Namespace().id
Jeff Gaston088e29e2017-11-29 16:47:17 -08001427 if namespacePrefix != "" {
1428 namespacePrefix = namespacePrefix + "-"
1429 }
1430
Colin Cross3f40fa42015-01-30 17:27:36 -08001431 if len(allInstalledFiles) > 0 {
Colin Crossc3d87d32020-06-04 13:25:17 -07001432 name := namespacePrefix + ctx.ModuleName() + "-install"
1433 ctx.Phony(name, allInstalledFiles.Paths()...)
1434 m.installTarget = PathForPhony(ctx, name)
1435 deps = append(deps, m.installTarget)
Colin Cross9454bfa2015-03-17 13:24:18 -07001436 }
1437
1438 if len(allCheckbuildFiles) > 0 {
Colin Crossc3d87d32020-06-04 13:25:17 -07001439 name := namespacePrefix + ctx.ModuleName() + "-checkbuild"
1440 ctx.Phony(name, allCheckbuildFiles...)
1441 m.checkbuildTarget = PathForPhony(ctx, name)
1442 deps = append(deps, m.checkbuildTarget)
Colin Cross9454bfa2015-03-17 13:24:18 -07001443 }
1444
1445 if len(deps) > 0 {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001446 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08001447 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001448 suffix = "-soong"
1449 }
1450
Colin Crossc3d87d32020-06-04 13:25:17 -07001451 ctx.Phony(namespacePrefix+ctx.ModuleName()+suffix, deps...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07001452
Colin Cross4157e882019-06-06 16:57:04 -07001453 m.blueprintDir = ctx.ModuleDir()
Colin Cross3f40fa42015-01-30 17:27:36 -08001454 }
1455}
1456
Colin Crossc34d2322020-01-03 15:23:27 -08001457func determineModuleKind(m *ModuleBase, ctx blueprint.EarlyModuleContext) moduleKind {
Colin Cross4157e882019-06-06 16:57:04 -07001458 var socSpecific = Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
1459 var deviceSpecific = Bool(m.commonProperties.Device_specific)
1460 var productSpecific = Bool(m.commonProperties.Product_specific)
Justin Yund5f6c822019-06-25 16:47:17 +09001461 var systemExtSpecific = Bool(m.commonProperties.System_ext_specific)
Jiyong Park2db76922017-11-08 16:03:48 +09001462
Dario Frenifd05a742018-05-29 13:28:54 +01001463 msg := "conflicting value set here"
1464 if socSpecific && deviceSpecific {
1465 ctx.PropertyErrorf("device_specific", "a module cannot be specific to SoC and device at the same time.")
Colin Cross4157e882019-06-06 16:57:04 -07001466 if Bool(m.commonProperties.Vendor) {
Jiyong Park2db76922017-11-08 16:03:48 +09001467 ctx.PropertyErrorf("vendor", msg)
1468 }
Colin Cross4157e882019-06-06 16:57:04 -07001469 if Bool(m.commonProperties.Proprietary) {
Jiyong Park2db76922017-11-08 16:03:48 +09001470 ctx.PropertyErrorf("proprietary", msg)
1471 }
Colin Cross4157e882019-06-06 16:57:04 -07001472 if Bool(m.commonProperties.Soc_specific) {
Jiyong Park2db76922017-11-08 16:03:48 +09001473 ctx.PropertyErrorf("soc_specific", msg)
1474 }
1475 }
1476
Justin Yund5f6c822019-06-25 16:47:17 +09001477 if productSpecific && systemExtSpecific {
1478 ctx.PropertyErrorf("product_specific", "a module cannot be specific to product and system_ext at the same time.")
1479 ctx.PropertyErrorf("system_ext_specific", msg)
Dario Frenifd05a742018-05-29 13:28:54 +01001480 }
1481
Justin Yund5f6c822019-06-25 16:47:17 +09001482 if (socSpecific || deviceSpecific) && (productSpecific || systemExtSpecific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001483 if productSpecific {
1484 ctx.PropertyErrorf("product_specific", "a module cannot be specific to SoC or device and product at the same time.")
1485 } else {
Justin Yund5f6c822019-06-25 16:47:17 +09001486 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 +01001487 }
1488 if deviceSpecific {
1489 ctx.PropertyErrorf("device_specific", msg)
1490 } else {
Colin Cross4157e882019-06-06 16:57:04 -07001491 if Bool(m.commonProperties.Vendor) {
Dario Frenifd05a742018-05-29 13:28:54 +01001492 ctx.PropertyErrorf("vendor", msg)
1493 }
Colin Cross4157e882019-06-06 16:57:04 -07001494 if Bool(m.commonProperties.Proprietary) {
Dario Frenifd05a742018-05-29 13:28:54 +01001495 ctx.PropertyErrorf("proprietary", msg)
1496 }
Colin Cross4157e882019-06-06 16:57:04 -07001497 if Bool(m.commonProperties.Soc_specific) {
Dario Frenifd05a742018-05-29 13:28:54 +01001498 ctx.PropertyErrorf("soc_specific", msg)
1499 }
1500 }
1501 }
1502
Jiyong Park2db76922017-11-08 16:03:48 +09001503 if productSpecific {
1504 return productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +09001505 } else if systemExtSpecific {
1506 return systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001507 } else if deviceSpecific {
1508 return deviceSpecificModule
1509 } else if socSpecific {
1510 return socSpecificModule
1511 } else {
1512 return platformModule
1513 }
1514}
1515
Colin Crossc34d2322020-01-03 15:23:27 -08001516func (m *ModuleBase) earlyModuleContextFactory(ctx blueprint.EarlyModuleContext) earlyModuleContext {
Colin Cross1184b642019-12-30 18:43:07 -08001517 return earlyModuleContext{
Colin Crossc34d2322020-01-03 15:23:27 -08001518 EarlyModuleContext: ctx,
1519 kind: determineModuleKind(m, ctx),
1520 config: ctx.Config().(Config),
Colin Cross3f40fa42015-01-30 17:27:36 -08001521 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001522}
1523
Colin Cross1184b642019-12-30 18:43:07 -08001524func (m *ModuleBase) baseModuleContextFactory(ctx blueprint.BaseModuleContext) baseModuleContext {
1525 return baseModuleContext{
1526 bp: ctx,
1527 earlyModuleContext: m.earlyModuleContextFactory(ctx),
1528 os: m.commonProperties.CompileOS,
1529 target: m.commonProperties.CompileTarget,
1530 targetPrimary: m.commonProperties.CompilePrimary,
1531 multiTargets: m.commonProperties.CompileMultiTargets,
1532 }
1533}
1534
Colin Cross4157e882019-06-06 16:57:04 -07001535func (m *ModuleBase) GenerateBuildActions(blueprintCtx blueprint.ModuleContext) {
Colin Cross25de6c32019-06-06 14:29:25 -07001536 ctx := &moduleContext{
Colin Cross0ea8ba82019-06-06 14:33:29 -07001537 module: m.module,
Colin Crossdc35e212019-06-06 16:13:11 -07001538 bp: blueprintCtx,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001539 baseModuleContext: m.baseModuleContextFactory(blueprintCtx),
1540 installDeps: m.computeInstallDeps(blueprintCtx),
1541 installFiles: m.installFiles,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001542 variables: make(map[string]string),
Colin Cross3f40fa42015-01-30 17:27:36 -08001543 }
1544
Colin Cross6c4f21f2019-06-06 15:41:36 -07001545 // Temporarily continue to call blueprintCtx.GetMissingDependencies() to maintain the previous behavior of never
1546 // reporting missing dependency errors in Blueprint when AllowMissingDependencies == true.
1547 // TODO: This will be removed once defaults modules handle missing dependency errors
1548 blueprintCtx.GetMissingDependencies()
1549
Colin Crossdc35e212019-06-06 16:13:11 -07001550 // For the final GenerateAndroidBuildActions pass, require that all visited dependencies Soong modules and
Paul Duffin1356d8c2020-02-25 19:26:33 +00001551 // are enabled. Unless the module is a CommonOS variant which may have dependencies on disabled variants
1552 // (because the dependencies are added before the modules are disabled). The
1553 // GetOsSpecificVariantsOfCommonOSVariant(...) method will ensure that the disabled variants are
1554 // ignored.
1555 ctx.baseModuleContext.strictVisitDeps = !m.IsCommonOSVariant()
Colin Crossdc35e212019-06-06 16:13:11 -07001556
Colin Cross4c83e5c2019-02-25 14:54:28 -08001557 if ctx.config.captureBuild {
1558 ctx.ruleParams = make(map[blueprint.Rule]blueprint.RuleParams)
1559 }
1560
Colin Cross67a5c132017-05-09 13:45:28 -07001561 desc := "//" + ctx.ModuleDir() + ":" + ctx.ModuleName() + " "
1562 var suffix []string
Colin Cross0875c522017-11-28 17:34:01 -08001563 if ctx.Os().Class != Device && ctx.Os().Class != Generic {
1564 suffix = append(suffix, ctx.Os().String())
Colin Cross67a5c132017-05-09 13:45:28 -07001565 }
Colin Cross0875c522017-11-28 17:34:01 -08001566 if !ctx.PrimaryArch() {
1567 suffix = append(suffix, ctx.Arch().ArchType.String())
Colin Cross67a5c132017-05-09 13:45:28 -07001568 }
Colin Cross56a83212020-09-15 18:30:11 -07001569 if apexInfo := ctx.Provider(ApexInfoProvider).(ApexInfo); !apexInfo.IsForPlatform() {
1570 suffix = append(suffix, apexInfo.ApexVariationName)
Dan Willemsenb13a9482020-02-14 11:25:54 -08001571 }
Colin Cross67a5c132017-05-09 13:45:28 -07001572
1573 ctx.Variable(pctx, "moduleDesc", desc)
1574
1575 s := ""
1576 if len(suffix) > 0 {
1577 s = " [" + strings.Join(suffix, " ") + "]"
1578 }
1579 ctx.Variable(pctx, "moduleDescSuffix", s)
1580
Dan Willemsen569edc52018-11-19 09:33:29 -08001581 // Some common property checks for properties that will be used later in androidmk.go
Paul Duffined875132020-09-02 13:08:57 +01001582 if m.distProperties.Dist.Dest != nil {
1583 _, err := validateSafePath(*m.distProperties.Dist.Dest)
Dan Willemsen569edc52018-11-19 09:33:29 -08001584 if err != nil {
1585 ctx.PropertyErrorf("dist.dest", "%s", err.Error())
1586 }
1587 }
Paul Duffined875132020-09-02 13:08:57 +01001588 if m.distProperties.Dist.Dir != nil {
1589 _, err := validateSafePath(*m.distProperties.Dist.Dir)
Dan Willemsen569edc52018-11-19 09:33:29 -08001590 if err != nil {
1591 ctx.PropertyErrorf("dist.dir", "%s", err.Error())
1592 }
1593 }
Paul Duffined875132020-09-02 13:08:57 +01001594 if m.distProperties.Dist.Suffix != nil {
1595 if strings.Contains(*m.distProperties.Dist.Suffix, "/") {
Dan Willemsen569edc52018-11-19 09:33:29 -08001596 ctx.PropertyErrorf("dist.suffix", "Suffix may not contain a '/' character.")
1597 }
1598 }
1599
Colin Cross4157e882019-06-06 16:57:04 -07001600 if m.Enabled() {
Jooyung Hand48f3c32019-08-23 11:18:57 +09001601 // ensure all direct android.Module deps are enabled
1602 ctx.VisitDirectDepsBlueprint(func(bm blueprint.Module) {
1603 if _, ok := bm.(Module); ok {
1604 ctx.validateAndroidModule(bm, ctx.baseModuleContext.strictVisitDeps)
1605 }
1606 })
1607
Bob Badoura75b0572020-02-18 20:21:55 -08001608 m.noticeFiles = make([]Path, 0)
1609 optPath := OptionalPath{}
1610 notice := proptools.StringDefault(m.commonProperties.Notice, "")
Colin Cross4157e882019-06-06 16:57:04 -07001611 if module := SrcIsModule(notice); module != "" {
Bob Badoura75b0572020-02-18 20:21:55 -08001612 optPath = ctx.ExpandOptionalSource(&notice, "notice")
1613 } else if notice != "" {
Jiyong Park52818fc2019-03-18 12:01:38 +09001614 noticePath := filepath.Join(ctx.ModuleDir(), notice)
Bob Badoura75b0572020-02-18 20:21:55 -08001615 optPath = ExistentPathForSource(ctx, noticePath)
1616 }
1617 if optPath.Valid() {
1618 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1619 } else {
1620 for _, notice = range []string{"LICENSE", "LICENCE", "NOTICE"} {
1621 noticePath := filepath.Join(ctx.ModuleDir(), notice)
1622 optPath = ExistentPathForSource(ctx, noticePath)
1623 if optPath.Valid() {
1624 m.noticeFiles = append(m.noticeFiles, optPath.Path())
1625 }
1626 }
Jaewoong Jung62707f72018-11-16 13:26:43 -08001627 }
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001628
1629 m.module.GenerateAndroidBuildActions(ctx)
1630 if ctx.Failed() {
1631 return
1632 }
1633
1634 m.installFiles = append(m.installFiles, ctx.installFiles...)
1635 m.checkbuildFiles = append(m.checkbuildFiles, ctx.checkbuildFiles...)
Jiyong Park073ea552020-11-09 14:08:34 +09001636 m.packagingSpecs = append(m.packagingSpecs, ctx.packagingSpecs...)
Inseob Kim8471cda2019-11-15 09:59:12 +09001637 m.initRcPaths = PathsForModuleSrc(ctx, m.commonProperties.Init_rc)
1638 m.vintfFragmentsPaths = PathsForModuleSrc(ctx, m.commonProperties.Vintf_fragments)
Colin Crossc3d87d32020-06-04 13:25:17 -07001639 for k, v := range ctx.phonies {
1640 m.phonies[k] = append(m.phonies[k], v...)
1641 }
Colin Crossdc35e212019-06-06 16:13:11 -07001642 } else if ctx.Config().AllowMissingDependencies() {
1643 // If the module is not enabled it will not create any build rules, nothing will call
1644 // ctx.GetMissingDependencies(), and blueprint will consider the missing dependencies to be unhandled
1645 // and report them as an error even when AllowMissingDependencies = true. Call
1646 // ctx.GetMissingDependencies() here to tell blueprint not to handle them.
1647 ctx.GetMissingDependencies()
Colin Cross3f40fa42015-01-30 17:27:36 -08001648 }
1649
Colin Cross4157e882019-06-06 16:57:04 -07001650 if m == ctx.FinalModule().(Module).base() {
1651 m.generateModuleTarget(ctx)
Colin Cross9b1d13d2016-09-19 15:18:11 -07001652 if ctx.Failed() {
1653 return
1654 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001655 }
Colin Crosscec81712017-07-13 14:43:27 -07001656
Colin Cross4157e882019-06-06 16:57:04 -07001657 m.buildParams = ctx.buildParams
1658 m.ruleParams = ctx.ruleParams
1659 m.variables = ctx.variables
Colin Cross3f40fa42015-01-30 17:27:36 -08001660}
1661
Colin Cross1184b642019-12-30 18:43:07 -08001662type earlyModuleContext struct {
Colin Crossc34d2322020-01-03 15:23:27 -08001663 blueprint.EarlyModuleContext
Colin Cross1184b642019-12-30 18:43:07 -08001664
1665 kind moduleKind
1666 config Config
1667}
1668
1669func (e *earlyModuleContext) Glob(globPattern string, excludes []string) Paths {
1670 ret, err := e.GlobWithDeps(globPattern, excludes)
1671 if err != nil {
1672 e.ModuleErrorf("glob: %s", err.Error())
1673 }
1674 return pathsForModuleSrcFromFullPath(e, ret, true)
1675}
1676
1677func (e *earlyModuleContext) GlobFiles(globPattern string, excludes []string) Paths {
1678 ret, err := e.GlobWithDeps(globPattern, excludes)
1679 if err != nil {
1680 e.ModuleErrorf("glob: %s", err.Error())
1681 }
1682 return pathsForModuleSrcFromFullPath(e, ret, false)
1683}
1684
Colin Cross988414c2020-01-11 01:11:46 +00001685func (b *earlyModuleContext) IsSymlink(path Path) bool {
1686 fileInfo, err := b.config.fs.Lstat(path.String())
1687 if err != nil {
1688 b.ModuleErrorf("os.Lstat(%q) failed: %s", path.String(), err)
1689 }
1690 return fileInfo.Mode()&os.ModeSymlink == os.ModeSymlink
1691}
1692
1693func (b *earlyModuleContext) Readlink(path Path) string {
1694 dest, err := b.config.fs.Readlink(path.String())
1695 if err != nil {
1696 b.ModuleErrorf("os.Readlink(%q) failed: %s", path.String(), err)
1697 }
1698 return dest
1699}
1700
Colin Cross1184b642019-12-30 18:43:07 -08001701func (e *earlyModuleContext) Module() Module {
Colin Crossc34d2322020-01-03 15:23:27 -08001702 module, _ := e.EarlyModuleContext.Module().(Module)
Colin Cross1184b642019-12-30 18:43:07 -08001703 return module
1704}
1705
1706func (e *earlyModuleContext) Config() Config {
Colin Crossc34d2322020-01-03 15:23:27 -08001707 return e.EarlyModuleContext.Config().(Config)
Colin Cross1184b642019-12-30 18:43:07 -08001708}
1709
1710func (e *earlyModuleContext) AConfig() Config {
1711 return e.config
1712}
1713
1714func (e *earlyModuleContext) DeviceConfig() DeviceConfig {
1715 return DeviceConfig{e.config.deviceConfig}
1716}
1717
1718func (e *earlyModuleContext) Platform() bool {
1719 return e.kind == platformModule
1720}
1721
1722func (e *earlyModuleContext) DeviceSpecific() bool {
1723 return e.kind == deviceSpecificModule
1724}
1725
1726func (e *earlyModuleContext) SocSpecific() bool {
1727 return e.kind == socSpecificModule
1728}
1729
1730func (e *earlyModuleContext) ProductSpecific() bool {
1731 return e.kind == productSpecificModule
1732}
1733
1734func (e *earlyModuleContext) SystemExtSpecific() bool {
1735 return e.kind == systemExtSpecificModule
1736}
1737
Colin Cross133ebef2020-08-14 17:38:45 -07001738func (e *earlyModuleContext) Namespace() *Namespace {
1739 return e.EarlyModuleContext.Namespace().(*Namespace)
1740}
1741
Colin Cross1184b642019-12-30 18:43:07 -08001742type baseModuleContext struct {
1743 bp blueprint.BaseModuleContext
1744 earlyModuleContext
Colin Crossfb0c16e2019-11-20 17:12:35 -08001745 os OsType
Colin Cross8b74d172016-09-13 09:59:14 -07001746 target Target
Colin Crossee0bc3b2018-10-02 22:01:37 -07001747 multiTargets []Target
Colin Cross8b74d172016-09-13 09:59:14 -07001748 targetPrimary bool
1749 debug bool
Colin Crossdc35e212019-06-06 16:13:11 -07001750
1751 walkPath []Module
Paul Duffinc5192442020-03-31 11:31:36 +01001752 tagPath []blueprint.DependencyTag
Colin Crossdc35e212019-06-06 16:13:11 -07001753
1754 strictVisitDeps bool // If true, enforce that all dependencies are enabled
Colin Crossf6566ed2015-03-24 11:13:38 -07001755}
1756
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001757func (b *baseModuleContext) OtherModuleName(m blueprint.Module) string {
1758 return b.bp.OtherModuleName(m)
1759}
1760func (b *baseModuleContext) OtherModuleDir(m blueprint.Module) string { return b.bp.OtherModuleDir(m) }
Colin Cross1184b642019-12-30 18:43:07 -08001761func (b *baseModuleContext) OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{}) {
Jooyung Hancd87c692020-02-26 02:05:18 +09001762 b.bp.OtherModuleErrorf(m, fmt, args...)
Colin Cross1184b642019-12-30 18:43:07 -08001763}
1764func (b *baseModuleContext) OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag {
1765 return b.bp.OtherModuleDependencyTag(m)
1766}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001767func (b *baseModuleContext) OtherModuleExists(name string) bool { return b.bp.OtherModuleExists(name) }
Martin Stjernholm009a9dc2020-03-05 17:34:13 +00001768func (b *baseModuleContext) OtherModuleDependencyVariantExists(variations []blueprint.Variation, name string) bool {
1769 return b.bp.OtherModuleDependencyVariantExists(variations, name)
1770}
1771func (b *baseModuleContext) OtherModuleReverseDependencyVariantExists(name string) bool {
1772 return b.bp.OtherModuleReverseDependencyVariantExists(name)
1773}
Paul Duffinca7f0ef2020-02-25 15:50:49 +00001774func (b *baseModuleContext) OtherModuleType(m blueprint.Module) string {
1775 return b.bp.OtherModuleType(m)
1776}
Colin Crossd27e7b82020-07-02 11:38:17 -07001777func (b *baseModuleContext) OtherModuleProvider(m blueprint.Module, provider blueprint.ProviderKey) interface{} {
1778 return b.bp.OtherModuleProvider(m, provider)
1779}
1780func (b *baseModuleContext) OtherModuleHasProvider(m blueprint.Module, provider blueprint.ProviderKey) bool {
1781 return b.bp.OtherModuleHasProvider(m, provider)
1782}
1783func (b *baseModuleContext) Provider(provider blueprint.ProviderKey) interface{} {
1784 return b.bp.Provider(provider)
1785}
1786func (b *baseModuleContext) HasProvider(provider blueprint.ProviderKey) bool {
1787 return b.bp.HasProvider(provider)
1788}
1789func (b *baseModuleContext) SetProvider(provider blueprint.ProviderKey, value interface{}) {
1790 b.bp.SetProvider(provider, value)
1791}
Colin Cross1184b642019-12-30 18:43:07 -08001792
1793func (b *baseModuleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1794 return b.bp.GetDirectDepWithTag(name, tag)
1795}
1796
Paul Duffinf88d8e02020-05-07 20:21:34 +01001797func (b *baseModuleContext) blueprintBaseModuleContext() blueprint.BaseModuleContext {
1798 return b.bp
1799}
1800
Colin Cross25de6c32019-06-06 14:29:25 -07001801type moduleContext struct {
Colin Crossdc35e212019-06-06 16:13:11 -07001802 bp blueprint.ModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -07001803 baseModuleContext
Jiyong Park073ea552020-11-09 14:08:34 +09001804 packagingSpecs []PackagingSpec
Colin Cross897266e2020-02-13 13:22:08 -08001805 installDeps InstallPaths
1806 installFiles InstallPaths
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001807 checkbuildFiles Paths
Colin Cross8d8f8e22016-08-03 11:57:50 -07001808 module Module
Colin Crossc3d87d32020-06-04 13:25:17 -07001809 phonies map[string]Paths
Colin Crosscec81712017-07-13 14:43:27 -07001810
1811 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001812 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001813 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001814 variables map[string]string
Colin Cross6ff51382015-12-17 16:39:19 -08001815}
1816
Colin Crossb88b3c52019-06-10 15:15:17 -07001817func (m *moduleContext) ninjaError(params BuildParams, err error) (PackageContext, BuildParams) {
1818 return pctx, BuildParams{
Colin Cross4b69c492019-06-07 13:06:06 -07001819 Rule: ErrorRule,
1820 Description: params.Description,
1821 Output: params.Output,
1822 Outputs: params.Outputs,
1823 ImplicitOutput: params.ImplicitOutput,
1824 ImplicitOutputs: params.ImplicitOutputs,
Colin Cross6ff51382015-12-17 16:39:19 -08001825 Args: map[string]string{
1826 "error": err.Error(),
1827 },
Colin Crossb88b3c52019-06-10 15:15:17 -07001828 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001829}
1830
Colin Cross25de6c32019-06-06 14:29:25 -07001831func (m *moduleContext) ModuleBuild(pctx PackageContext, params ModuleBuildParams) {
1832 m.Build(pctx, BuildParams(params))
Colin Cross3f40fa42015-01-30 17:27:36 -08001833}
1834
Jingwen Chence679d22020-09-23 04:30:02 +00001835func validateBuildParams(params blueprint.BuildParams) error {
1836 // Validate that the symlink outputs are declared outputs or implicit outputs
1837 allOutputs := map[string]bool{}
1838 for _, output := range params.Outputs {
1839 allOutputs[output] = true
1840 }
1841 for _, output := range params.ImplicitOutputs {
1842 allOutputs[output] = true
1843 }
1844 for _, symlinkOutput := range params.SymlinkOutputs {
1845 if !allOutputs[symlinkOutput] {
1846 return fmt.Errorf(
1847 "Symlink output %s is not a declared output or implicit output",
1848 symlinkOutput)
1849 }
1850 }
1851 return nil
1852}
1853
1854// Convert build parameters from their concrete Android types into their string representations,
1855// and combine the singular and plural fields of the same type (e.g. Output and Outputs).
Colin Cross0875c522017-11-28 17:34:01 -08001856func convertBuildParams(params BuildParams) blueprint.BuildParams {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001857 bparams := blueprint.BuildParams{
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001858 Rule: params.Rule,
Colin Cross0875c522017-11-28 17:34:01 -08001859 Description: params.Description,
Colin Cross33bfb0a2016-11-21 17:23:08 -08001860 Deps: params.Deps,
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001861 Outputs: params.Outputs.Strings(),
1862 ImplicitOutputs: params.ImplicitOutputs.Strings(),
Jingwen Chence679d22020-09-23 04:30:02 +00001863 SymlinkOutputs: params.SymlinkOutputs.Strings(),
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001864 Inputs: params.Inputs.Strings(),
1865 Implicits: params.Implicits.Strings(),
1866 OrderOnly: params.OrderOnly.Strings(),
Colin Cross824f1162020-07-16 13:07:51 -07001867 Validations: params.Validations.Strings(),
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001868 Args: params.Args,
1869 Optional: !params.Default,
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001870 }
1871
Colin Cross33bfb0a2016-11-21 17:23:08 -08001872 if params.Depfile != nil {
1873 bparams.Depfile = params.Depfile.String()
1874 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001875 if params.Output != nil {
1876 bparams.Outputs = append(bparams.Outputs, params.Output.String())
1877 }
Jingwen Chence679d22020-09-23 04:30:02 +00001878 if params.SymlinkOutput != nil {
1879 bparams.SymlinkOutputs = append(bparams.SymlinkOutputs, params.SymlinkOutput.String())
1880 }
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001881 if params.ImplicitOutput != nil {
1882 bparams.ImplicitOutputs = append(bparams.ImplicitOutputs, params.ImplicitOutput.String())
1883 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001884 if params.Input != nil {
1885 bparams.Inputs = append(bparams.Inputs, params.Input.String())
1886 }
1887 if params.Implicit != nil {
1888 bparams.Implicits = append(bparams.Implicits, params.Implicit.String())
1889 }
Colin Cross824f1162020-07-16 13:07:51 -07001890 if params.Validation != nil {
1891 bparams.Validations = append(bparams.Validations, params.Validation.String())
1892 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001893
Colin Cross0b9f31f2019-02-28 11:00:01 -08001894 bparams.Outputs = proptools.NinjaEscapeList(bparams.Outputs)
1895 bparams.ImplicitOutputs = proptools.NinjaEscapeList(bparams.ImplicitOutputs)
Jingwen Chence679d22020-09-23 04:30:02 +00001896 bparams.SymlinkOutputs = proptools.NinjaEscapeList(bparams.SymlinkOutputs)
Colin Cross0b9f31f2019-02-28 11:00:01 -08001897 bparams.Inputs = proptools.NinjaEscapeList(bparams.Inputs)
1898 bparams.Implicits = proptools.NinjaEscapeList(bparams.Implicits)
1899 bparams.OrderOnly = proptools.NinjaEscapeList(bparams.OrderOnly)
Colin Cross824f1162020-07-16 13:07:51 -07001900 bparams.Validations = proptools.NinjaEscapeList(bparams.Validations)
1901 bparams.Depfile = proptools.NinjaEscape(bparams.Depfile)
Colin Crossfe4bc362018-09-12 10:02:13 -07001902
Colin Cross0875c522017-11-28 17:34:01 -08001903 return bparams
1904}
1905
Colin Cross25de6c32019-06-06 14:29:25 -07001906func (m *moduleContext) Variable(pctx PackageContext, name, value string) {
1907 if m.config.captureBuild {
1908 m.variables[name] = value
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001909 }
1910
Colin Crossdc35e212019-06-06 16:13:11 -07001911 m.bp.Variable(pctx.PackageContext, name, value)
Colin Cross0875c522017-11-28 17:34:01 -08001912}
1913
Colin Cross25de6c32019-06-06 14:29:25 -07001914func (m *moduleContext) Rule(pctx PackageContext, name string, params blueprint.RuleParams,
Colin Cross0875c522017-11-28 17:34:01 -08001915 argNames ...string) blueprint.Rule {
1916
Ramy Medhat944839a2020-03-31 22:14:52 -04001917 if m.config.UseRemoteBuild() {
1918 if params.Pool == nil {
1919 // When USE_GOMA=true or USE_RBE=true are set and the rule is not supported by goma/RBE, restrict
1920 // jobs to the local parallelism value
1921 params.Pool = localPool
1922 } else if params.Pool == remotePool {
1923 // remotePool is a fake pool used to identify rule that are supported for remoting. If the rule's
1924 // pool is the remotePool, replace with nil so that ninja runs it at NINJA_REMOTE_NUM_JOBS
1925 // parallelism.
1926 params.Pool = nil
1927 }
Colin Cross2e2dbc22019-09-25 13:31:46 -07001928 }
1929
Colin Crossdc35e212019-06-06 16:13:11 -07001930 rule := m.bp.Rule(pctx.PackageContext, name, params, argNames...)
Colin Cross4c83e5c2019-02-25 14:54:28 -08001931
Colin Cross25de6c32019-06-06 14:29:25 -07001932 if m.config.captureBuild {
1933 m.ruleParams[rule] = params
Colin Cross4c83e5c2019-02-25 14:54:28 -08001934 }
1935
1936 return rule
Colin Cross0875c522017-11-28 17:34:01 -08001937}
1938
Colin Cross25de6c32019-06-06 14:29:25 -07001939func (m *moduleContext) Build(pctx PackageContext, params BuildParams) {
Colin Crossb88b3c52019-06-10 15:15:17 -07001940 if params.Description != "" {
1941 params.Description = "${moduleDesc}" + params.Description + "${moduleDescSuffix}"
1942 }
1943
1944 if missingDeps := m.GetMissingDependencies(); len(missingDeps) > 0 {
1945 pctx, params = m.ninjaError(params, fmt.Errorf("module %s missing dependencies: %s\n",
1946 m.ModuleName(), strings.Join(missingDeps, ", ")))
1947 }
1948
Colin Cross25de6c32019-06-06 14:29:25 -07001949 if m.config.captureBuild {
1950 m.buildParams = append(m.buildParams, params)
Colin Cross0875c522017-11-28 17:34:01 -08001951 }
1952
Jingwen Chence679d22020-09-23 04:30:02 +00001953 bparams := convertBuildParams(params)
1954 err := validateBuildParams(bparams)
1955 if err != nil {
1956 m.ModuleErrorf(
1957 "%s: build parameter validation failed: %s",
1958 m.ModuleName(),
1959 err.Error())
1960 }
1961 m.bp.Build(pctx.PackageContext, bparams)
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001962}
Colin Crossc3d87d32020-06-04 13:25:17 -07001963
1964func (m *moduleContext) Phony(name string, deps ...Path) {
1965 addPhony(m.config, name, deps...)
1966}
1967
Colin Cross25de6c32019-06-06 14:29:25 -07001968func (m *moduleContext) GetMissingDependencies() []string {
Colin Cross6c4f21f2019-06-06 15:41:36 -07001969 var missingDeps []string
1970 missingDeps = append(missingDeps, m.Module().base().commonProperties.MissingDeps...)
Colin Crossdc35e212019-06-06 16:13:11 -07001971 missingDeps = append(missingDeps, m.bp.GetMissingDependencies()...)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001972 missingDeps = FirstUniqueStrings(missingDeps)
1973 return missingDeps
Colin Cross6ff51382015-12-17 16:39:19 -08001974}
1975
Colin Crossdc35e212019-06-06 16:13:11 -07001976func (b *baseModuleContext) AddMissingDependencies(deps []string) {
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001977 if deps != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001978 missingDeps := &b.Module().base().commonProperties.MissingDeps
Colin Cross6c4f21f2019-06-06 15:41:36 -07001979 *missingDeps = append(*missingDeps, deps...)
1980 *missingDeps = FirstUniqueStrings(*missingDeps)
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001981 }
1982}
1983
Colin Crossdc35e212019-06-06 16:13:11 -07001984func (b *baseModuleContext) validateAndroidModule(module blueprint.Module, strict bool) Module {
Colin Crossd11fcda2017-10-23 17:59:01 -07001985 aModule, _ := module.(Module)
Colin Crossdc35e212019-06-06 16:13:11 -07001986
1987 if !strict {
1988 return aModule
1989 }
1990
Colin Cross380c69a2019-06-10 17:49:58 +00001991 if aModule == nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001992 b.ModuleErrorf("module %q not an android module", b.OtherModuleName(module))
Colin Cross380c69a2019-06-10 17:49:58 +00001993 return nil
1994 }
1995
1996 if !aModule.Enabled() {
Colin Crossdc35e212019-06-06 16:13:11 -07001997 if b.Config().AllowMissingDependencies() {
1998 b.AddMissingDependencies([]string{b.OtherModuleName(aModule)})
Colin Cross380c69a2019-06-10 17:49:58 +00001999 } else {
Colin Crossdc35e212019-06-06 16:13:11 -07002000 b.ModuleErrorf("depends on disabled module %q", b.OtherModuleName(aModule))
Colin Cross380c69a2019-06-10 17:49:58 +00002001 }
2002 return nil
2003 }
Colin Crossd11fcda2017-10-23 17:59:01 -07002004 return aModule
2005}
2006
Colin Crossdc35e212019-06-06 16:13:11 -07002007func (b *baseModuleContext) getDirectDepInternal(name string, tag blueprint.DependencyTag) (blueprint.Module, blueprint.DependencyTag) {
Jiyong Parkf2976302019-04-17 21:47:37 +09002008 type dep struct {
2009 mod blueprint.Module
2010 tag blueprint.DependencyTag
2011 }
2012 var deps []dep
Colin Crossdc35e212019-06-06 16:13:11 -07002013 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07002014 if aModule, _ := module.(Module); aModule != nil && aModule.base().BaseModuleName() == name {
Colin Cross1184b642019-12-30 18:43:07 -08002015 returnedTag := b.bp.OtherModuleDependencyTag(aModule)
Jiyong Parkf2976302019-04-17 21:47:37 +09002016 if tag == nil || returnedTag == tag {
2017 deps = append(deps, dep{aModule, returnedTag})
2018 }
2019 }
2020 })
2021 if len(deps) == 1 {
2022 return deps[0].mod, deps[0].tag
2023 } else if len(deps) >= 2 {
2024 panic(fmt.Errorf("Multiple dependencies having same BaseModuleName() %q found from %q",
Colin Crossdc35e212019-06-06 16:13:11 -07002025 name, b.ModuleName()))
Jiyong Parkf2976302019-04-17 21:47:37 +09002026 } else {
2027 return nil, nil
2028 }
2029}
2030
Colin Crossdc35e212019-06-06 16:13:11 -07002031func (b *baseModuleContext) GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module {
Colin Cross0ef08162019-05-01 15:50:51 -07002032 var deps []Module
Colin Crossdc35e212019-06-06 16:13:11 -07002033 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07002034 if aModule, _ := module.(Module); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08002035 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Cross0ef08162019-05-01 15:50:51 -07002036 deps = append(deps, aModule)
2037 }
2038 }
2039 })
2040 return deps
2041}
2042
Colin Cross25de6c32019-06-06 14:29:25 -07002043func (m *moduleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
2044 module, _ := m.getDirectDepInternal(name, tag)
2045 return module
Jiyong Parkf2976302019-04-17 21:47:37 +09002046}
2047
Colin Crossdc35e212019-06-06 16:13:11 -07002048func (b *baseModuleContext) GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag) {
2049 return b.getDirectDepInternal(name, nil)
Jiyong Parkf2976302019-04-17 21:47:37 +09002050}
2051
Colin Crossdc35e212019-06-06 16:13:11 -07002052func (b *baseModuleContext) VisitDirectDepsBlueprint(visit func(blueprint.Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002053 b.bp.VisitDirectDeps(visit)
Colin Cross35143d02017-11-16 00:11:20 -08002054}
2055
Colin Crossdc35e212019-06-06 16:13:11 -07002056func (b *baseModuleContext) VisitDirectDeps(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002057 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07002058 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07002059 visit(aModule)
2060 }
2061 })
2062}
2063
Colin Crossdc35e212019-06-06 16:13:11 -07002064func (b *baseModuleContext) VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002065 b.bp.VisitDirectDeps(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07002066 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Cross1184b642019-12-30 18:43:07 -08002067 if b.bp.OtherModuleDependencyTag(aModule) == tag {
Colin Crossee6143c2017-12-30 17:54:27 -08002068 visit(aModule)
2069 }
2070 }
2071 })
2072}
2073
Colin Crossdc35e212019-06-06 16:13:11 -07002074func (b *baseModuleContext) VisitDirectDepsIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002075 b.bp.VisitDirectDepsIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07002076 // pred
2077 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07002078 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07002079 return pred(aModule)
2080 } else {
2081 return false
2082 }
2083 },
2084 // visit
2085 func(module blueprint.Module) {
2086 visit(module.(Module))
2087 })
2088}
2089
Colin Crossdc35e212019-06-06 16:13:11 -07002090func (b *baseModuleContext) VisitDepsDepthFirst(visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002091 b.bp.VisitDepsDepthFirst(func(module blueprint.Module) {
Colin Crossdc35e212019-06-06 16:13:11 -07002092 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07002093 visit(aModule)
2094 }
2095 })
2096}
2097
Colin Crossdc35e212019-06-06 16:13:11 -07002098func (b *baseModuleContext) VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module)) {
Colin Cross1184b642019-12-30 18:43:07 -08002099 b.bp.VisitDepsDepthFirstIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07002100 // pred
2101 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07002102 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07002103 return pred(aModule)
2104 } else {
2105 return false
2106 }
2107 },
2108 // visit
2109 func(module blueprint.Module) {
2110 visit(module.(Module))
2111 })
2112}
2113
Colin Crossdc35e212019-06-06 16:13:11 -07002114func (b *baseModuleContext) WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool) {
Colin Cross1184b642019-12-30 18:43:07 -08002115 b.bp.WalkDeps(visit)
Alex Light778127a2019-02-27 14:19:50 -08002116}
2117
Colin Crossdc35e212019-06-06 16:13:11 -07002118func (b *baseModuleContext) WalkDeps(visit func(Module, Module) bool) {
2119 b.walkPath = []Module{b.Module()}
Paul Duffinc5192442020-03-31 11:31:36 +01002120 b.tagPath = []blueprint.DependencyTag{}
Colin Cross1184b642019-12-30 18:43:07 -08002121 b.bp.WalkDeps(func(child, parent blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07002122 childAndroidModule, _ := child.(Module)
2123 parentAndroidModule, _ := parent.(Module)
Colin Crossd11fcda2017-10-23 17:59:01 -07002124 if childAndroidModule != nil && parentAndroidModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07002125 // record walkPath before visit
2126 for b.walkPath[len(b.walkPath)-1] != parentAndroidModule {
2127 b.walkPath = b.walkPath[0 : len(b.walkPath)-1]
Paul Duffinc5192442020-03-31 11:31:36 +01002128 b.tagPath = b.tagPath[0 : len(b.tagPath)-1]
Colin Crossdc35e212019-06-06 16:13:11 -07002129 }
2130 b.walkPath = append(b.walkPath, childAndroidModule)
Paul Duffinc5192442020-03-31 11:31:36 +01002131 b.tagPath = append(b.tagPath, b.OtherModuleDependencyTag(childAndroidModule))
Colin Crossd11fcda2017-10-23 17:59:01 -07002132 return visit(childAndroidModule, parentAndroidModule)
2133 } else {
2134 return false
2135 }
2136 })
2137}
2138
Colin Crossdc35e212019-06-06 16:13:11 -07002139func (b *baseModuleContext) GetWalkPath() []Module {
2140 return b.walkPath
2141}
2142
Paul Duffinc5192442020-03-31 11:31:36 +01002143func (b *baseModuleContext) GetTagPath() []blueprint.DependencyTag {
2144 return b.tagPath
2145}
2146
Colin Cross4dfacf92020-09-16 19:22:27 -07002147func (b *baseModuleContext) VisitAllModuleVariants(visit func(Module)) {
2148 b.bp.VisitAllModuleVariants(func(module blueprint.Module) {
2149 visit(module.(Module))
2150 })
2151}
2152
2153func (b *baseModuleContext) PrimaryModule() Module {
2154 return b.bp.PrimaryModule().(Module)
2155}
2156
2157func (b *baseModuleContext) FinalModule() Module {
2158 return b.bp.FinalModule().(Module)
2159}
2160
Jiyong Park1c7e9622020-05-07 16:12:13 +09002161// A regexp for removing boilerplate from BaseDependencyTag from the string representation of
2162// a dependency tag.
Colin Cross6e511a92020-07-27 21:26:48 -07002163var tagCleaner = regexp.MustCompile(`\QBaseDependencyTag:{}\E(, )?`)
Jiyong Park1c7e9622020-05-07 16:12:13 +09002164
2165// PrettyPrintTag returns string representation of the tag, but prefers
2166// custom String() method if available.
2167func PrettyPrintTag(tag blueprint.DependencyTag) string {
2168 // Use tag's custom String() method if available.
2169 if stringer, ok := tag.(fmt.Stringer); ok {
2170 return stringer.String()
2171 }
2172
2173 // Otherwise, get a default string representation of the tag's struct.
Colin Cross6e511a92020-07-27 21:26:48 -07002174 tagString := fmt.Sprintf("%T: %+v", tag, tag)
Jiyong Park1c7e9622020-05-07 16:12:13 +09002175
2176 // Remove the boilerplate from BaseDependencyTag as it adds no value.
2177 tagString = tagCleaner.ReplaceAllString(tagString, "")
2178 return tagString
2179}
2180
2181func (b *baseModuleContext) GetPathString(skipFirst bool) string {
2182 sb := strings.Builder{}
2183 tagPath := b.GetTagPath()
2184 walkPath := b.GetWalkPath()
2185 if !skipFirst {
2186 sb.WriteString(walkPath[0].String())
2187 }
2188 for i, m := range walkPath[1:] {
2189 sb.WriteString("\n")
2190 sb.WriteString(fmt.Sprintf(" via tag %s\n", PrettyPrintTag(tagPath[i])))
2191 sb.WriteString(fmt.Sprintf(" -> %s", m.String()))
2192 }
2193 return sb.String()
2194}
2195
Colin Crossdc35e212019-06-06 16:13:11 -07002196func (m *moduleContext) ModuleSubDir() string {
2197 return m.bp.ModuleSubDir()
Colin Cross0875c522017-11-28 17:34:01 -08002198}
2199
Colin Cross0ea8ba82019-06-06 14:33:29 -07002200func (b *baseModuleContext) Target() Target {
Colin Cross25de6c32019-06-06 14:29:25 -07002201 return b.target
Colin Crossa1ad8d12016-06-01 17:09:44 -07002202}
2203
Colin Cross0ea8ba82019-06-06 14:33:29 -07002204func (b *baseModuleContext) TargetPrimary() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002205 return b.targetPrimary
Colin Cross8b74d172016-09-13 09:59:14 -07002206}
2207
Colin Cross0ea8ba82019-06-06 14:33:29 -07002208func (b *baseModuleContext) MultiTargets() []Target {
Colin Cross25de6c32019-06-06 14:29:25 -07002209 return b.multiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07002210}
2211
Colin Cross0ea8ba82019-06-06 14:33:29 -07002212func (b *baseModuleContext) Arch() Arch {
Colin Cross25de6c32019-06-06 14:29:25 -07002213 return b.target.Arch
Colin Cross3f40fa42015-01-30 17:27:36 -08002214}
2215
Colin Cross0ea8ba82019-06-06 14:33:29 -07002216func (b *baseModuleContext) Os() OsType {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002217 return b.os
Dan Willemsen490fd492015-11-24 17:53:15 -08002218}
2219
Colin Cross0ea8ba82019-06-06 14:33:29 -07002220func (b *baseModuleContext) Host() bool {
Jiyong Park1613e552020-09-14 19:43:17 +09002221 return b.os.Class == Host
Colin Crossf6566ed2015-03-24 11:13:38 -07002222}
2223
Colin Cross0ea8ba82019-06-06 14:33:29 -07002224func (b *baseModuleContext) Device() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002225 return b.os.Class == Device
Colin Crossf6566ed2015-03-24 11:13:38 -07002226}
2227
Colin Cross0ea8ba82019-06-06 14:33:29 -07002228func (b *baseModuleContext) Darwin() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002229 return b.os == Darwin
Colin Cross0af4b842015-04-30 16:36:18 -07002230}
2231
Colin Cross0ea8ba82019-06-06 14:33:29 -07002232func (b *baseModuleContext) Fuchsia() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002233 return b.os == Fuchsia
Doug Horn21b94272019-01-16 12:06:11 -08002234}
2235
Colin Cross0ea8ba82019-06-06 14:33:29 -07002236func (b *baseModuleContext) Windows() bool {
Colin Crossfb0c16e2019-11-20 17:12:35 -08002237 return b.os == Windows
Colin Cross3edeee12017-04-04 12:59:48 -07002238}
2239
Colin Cross0ea8ba82019-06-06 14:33:29 -07002240func (b *baseModuleContext) Debug() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002241 return b.debug
Colin Crossf6566ed2015-03-24 11:13:38 -07002242}
2243
Colin Cross0ea8ba82019-06-06 14:33:29 -07002244func (b *baseModuleContext) PrimaryArch() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002245 if len(b.config.Targets[b.target.Os]) <= 1 {
Colin Cross67a5c132017-05-09 13:45:28 -07002246 return true
2247 }
Colin Cross25de6c32019-06-06 14:29:25 -07002248 return b.target.Arch.ArchType == b.config.Targets[b.target.Os][0].Arch.ArchType
Colin Cross1e7d3702016-08-24 15:25:47 -07002249}
2250
Jiyong Park5baac542018-08-28 09:55:37 +09002251// Makes this module a platform module, i.e. not specific to soc, device,
Justin Yund5f6c822019-06-25 16:47:17 +09002252// product, or system_ext.
Colin Cross4157e882019-06-06 16:57:04 -07002253func (m *ModuleBase) MakeAsPlatform() {
2254 m.commonProperties.Vendor = boolPtr(false)
2255 m.commonProperties.Proprietary = boolPtr(false)
2256 m.commonProperties.Soc_specific = boolPtr(false)
2257 m.commonProperties.Product_specific = boolPtr(false)
Justin Yund5f6c822019-06-25 16:47:17 +09002258 m.commonProperties.System_ext_specific = boolPtr(false)
Jiyong Park5baac542018-08-28 09:55:37 +09002259}
2260
Colin Cross4157e882019-06-06 16:57:04 -07002261func (m *ModuleBase) EnableNativeBridgeSupportByDefault() {
2262 m.commonProperties.Native_bridge_supported = boolPtr(true)
dimitry03dc3f62019-05-09 14:07:34 +02002263}
2264
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09002265func (m *ModuleBase) MakeAsSystemExt() {
Jooyung Han91df2082019-11-20 01:49:42 +09002266 m.commonProperties.Vendor = boolPtr(false)
2267 m.commonProperties.Proprietary = boolPtr(false)
2268 m.commonProperties.Soc_specific = boolPtr(false)
2269 m.commonProperties.Product_specific = boolPtr(false)
2270 m.commonProperties.System_ext_specific = boolPtr(true)
Sundong Ahnd95aa2d2019-10-08 19:34:03 +09002271}
2272
Jooyung Han344d5432019-08-23 11:17:39 +09002273// IsNativeBridgeSupported returns true if "native_bridge_supported" is explicitly set as "true"
2274func (m *ModuleBase) IsNativeBridgeSupported() bool {
2275 return proptools.Bool(m.commonProperties.Native_bridge_supported)
2276}
2277
Colin Cross25de6c32019-06-06 14:29:25 -07002278func (m *moduleContext) InstallInData() bool {
2279 return m.module.InstallInData()
Dan Willemsen782a2d12015-12-21 14:55:28 -08002280}
2281
Jaewoong Jung0949f312019-09-11 10:25:18 -07002282func (m *moduleContext) InstallInTestcases() bool {
2283 return m.module.InstallInTestcases()
2284}
2285
Colin Cross25de6c32019-06-06 14:29:25 -07002286func (m *moduleContext) InstallInSanitizerDir() bool {
2287 return m.module.InstallInSanitizerDir()
Vishwath Mohan1dd88392017-03-29 22:00:18 -07002288}
2289
Yifan Hong1b3348d2020-01-21 15:53:22 -08002290func (m *moduleContext) InstallInRamdisk() bool {
2291 return m.module.InstallInRamdisk()
2292}
2293
Yifan Hong60e0cfb2020-10-21 15:17:56 -07002294func (m *moduleContext) InstallInVendorRamdisk() bool {
2295 return m.module.InstallInVendorRamdisk()
2296}
2297
Colin Cross25de6c32019-06-06 14:29:25 -07002298func (m *moduleContext) InstallInRecovery() bool {
2299 return m.module.InstallInRecovery()
Jiyong Parkf9332f12018-02-01 00:54:12 +09002300}
2301
Colin Cross90ba5f42019-10-02 11:10:58 -07002302func (m *moduleContext) InstallInRoot() bool {
2303 return m.module.InstallInRoot()
2304}
2305
Colin Cross607d8582019-07-29 16:44:46 -07002306func (m *moduleContext) InstallBypassMake() bool {
2307 return m.module.InstallBypassMake()
2308}
2309
Jiyong Park87788b52020-09-01 12:37:45 +09002310func (m *moduleContext) InstallForceOS() (*OsType, *ArchType) {
Colin Cross6e359402020-02-10 15:29:54 -08002311 return m.module.InstallForceOS()
2312}
2313
Colin Cross70dda7e2019-10-01 22:05:35 -07002314func (m *moduleContext) skipInstall(fullInstallPath InstallPath) bool {
Colin Cross25de6c32019-06-06 14:29:25 -07002315 if m.module.base().commonProperties.SkipInstall {
Colin Cross893d8162017-04-26 17:34:03 -07002316 return true
2317 }
2318
Colin Cross3607f212018-05-07 15:28:05 -07002319 // We'll need a solution for choosing which of modules with the same name in different
2320 // namespaces to install. For now, reuse the list of namespaces exported to Make as the
2321 // list of namespaces to install in a Soong-only build.
Colin Cross25de6c32019-06-06 14:29:25 -07002322 if !m.module.base().commonProperties.NamespaceExportedToMake {
Colin Cross3607f212018-05-07 15:28:05 -07002323 return true
2324 }
2325
Colin Cross25de6c32019-06-06 14:29:25 -07002326 if m.Device() {
Colin Cross607d8582019-07-29 16:44:46 -07002327 if m.Config().EmbeddedInMake() && !m.InstallBypassMake() {
Colin Cross893d8162017-04-26 17:34:03 -07002328 return true
2329 }
2330
Colin Cross25de6c32019-06-06 14:29:25 -07002331 if m.Config().SkipMegaDeviceInstall(fullInstallPath.String()) {
Colin Cross893d8162017-04-26 17:34:03 -07002332 return true
2333 }
2334 }
2335
2336 return false
2337}
2338
Colin Cross70dda7e2019-10-01 22:05:35 -07002339func (m *moduleContext) InstallFile(installPath InstallPath, name string, srcPath Path,
2340 deps ...Path) InstallPath {
Jiyong Park073ea552020-11-09 14:08:34 +09002341 return m.installFile(installPath, name, srcPath, deps, false)
Colin Cross5c517922017-08-31 12:29:17 -07002342}
2343
Colin Cross70dda7e2019-10-01 22:05:35 -07002344func (m *moduleContext) InstallExecutable(installPath InstallPath, name string, srcPath Path,
2345 deps ...Path) InstallPath {
Jiyong Park073ea552020-11-09 14:08:34 +09002346 return m.installFile(installPath, name, srcPath, deps, true)
Colin Cross5c517922017-08-31 12:29:17 -07002347}
2348
Jiyong Park073ea552020-11-09 14:08:34 +09002349func (m *moduleContext) installFile(installPath InstallPath, name string, srcPath Path, deps []Path, executable bool) InstallPath {
Colin Cross35cec122015-04-02 14:37:16 -07002350
Colin Cross25de6c32019-06-06 14:29:25 -07002351 fullInstallPath := installPath.Join(m, name)
David Srbecky07656412020-06-04 01:26:16 +01002352 m.module.base().hooks.runInstallHooks(m, srcPath, fullInstallPath, false)
Colin Cross3f40fa42015-01-30 17:27:36 -08002353
Colin Cross25de6c32019-06-06 14:29:25 -07002354 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07002355
Colin Cross897266e2020-02-13 13:22:08 -08002356 deps = append(deps, m.installDeps.Paths()...)
Colin Cross35cec122015-04-02 14:37:16 -07002357
Colin Cross89562dc2016-10-03 17:47:19 -07002358 var implicitDeps, orderOnlyDeps Paths
2359
Colin Cross25de6c32019-06-06 14:29:25 -07002360 if m.Host() {
Colin Cross89562dc2016-10-03 17:47:19 -07002361 // Installed host modules might be used during the build, depend directly on their
2362 // dependencies so their timestamp is updated whenever their dependency is updated
2363 implicitDeps = deps
2364 } else {
2365 orderOnlyDeps = deps
2366 }
2367
Jiyong Park073ea552020-11-09 14:08:34 +09002368 rule := Cp
2369 if executable {
2370 rule = CpExecutable
2371 }
2372
Colin Cross25de6c32019-06-06 14:29:25 -07002373 m.Build(pctx, BuildParams{
Colin Cross5c517922017-08-31 12:29:17 -07002374 Rule: rule,
Colin Cross67a5c132017-05-09 13:45:28 -07002375 Description: "install " + fullInstallPath.Base(),
2376 Output: fullInstallPath,
2377 Input: srcPath,
2378 Implicits: implicitDeps,
2379 OrderOnly: orderOnlyDeps,
Colin Cross25de6c32019-06-06 14:29:25 -07002380 Default: !m.Config().EmbeddedInMake(),
Dan Willemsen322acaf2016-01-12 23:07:05 -08002381 })
Colin Cross3f40fa42015-01-30 17:27:36 -08002382
Colin Cross25de6c32019-06-06 14:29:25 -07002383 m.installFiles = append(m.installFiles, fullInstallPath)
Dan Willemsen322acaf2016-01-12 23:07:05 -08002384 }
Jiyong Park073ea552020-11-09 14:08:34 +09002385
2386 m.packagingSpecs = append(m.packagingSpecs, PackagingSpec{
2387 relPathInPackage: Rel(m, fullInstallPath.PartitionDir(), fullInstallPath.String()),
2388 srcPath: srcPath,
2389 symlinkTarget: "",
2390 executable: executable,
2391 })
2392
Colin Cross25de6c32019-06-06 14:29:25 -07002393 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross35cec122015-04-02 14:37:16 -07002394 return fullInstallPath
2395}
2396
Colin Cross70dda7e2019-10-01 22:05:35 -07002397func (m *moduleContext) InstallSymlink(installPath InstallPath, name string, srcPath InstallPath) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002398 fullInstallPath := installPath.Join(m, name)
David Srbecky07656412020-06-04 01:26:16 +01002399 m.module.base().hooks.runInstallHooks(m, srcPath, fullInstallPath, true)
Colin Cross3854a602016-01-11 12:49:11 -08002400
Jiyong Park073ea552020-11-09 14:08:34 +09002401 relPath, err := filepath.Rel(path.Dir(fullInstallPath.String()), srcPath.String())
2402 if err != nil {
2403 panic(fmt.Sprintf("Unable to generate symlink between %q and %q: %s", fullInstallPath.Base(), srcPath.Base(), err))
2404 }
Colin Cross25de6c32019-06-06 14:29:25 -07002405 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07002406
Colin Cross25de6c32019-06-06 14:29:25 -07002407 m.Build(pctx, BuildParams{
Colin Cross67a5c132017-05-09 13:45:28 -07002408 Rule: Symlink,
2409 Description: "install symlink " + fullInstallPath.Base(),
2410 Output: fullInstallPath,
Dan Willemsen40efa1c2020-01-14 15:19:52 -08002411 Input: srcPath,
Colin Cross25de6c32019-06-06 14:29:25 -07002412 Default: !m.Config().EmbeddedInMake(),
Colin Cross12fc4972016-01-11 12:49:11 -08002413 Args: map[string]string{
Alex Lightfb4353d2019-01-17 13:57:45 -08002414 "fromPath": relPath,
Colin Cross12fc4972016-01-11 12:49:11 -08002415 },
2416 })
Colin Cross3854a602016-01-11 12:49:11 -08002417
Colin Cross25de6c32019-06-06 14:29:25 -07002418 m.installFiles = append(m.installFiles, fullInstallPath)
2419 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross12fc4972016-01-11 12:49:11 -08002420 }
Jiyong Park073ea552020-11-09 14:08:34 +09002421
2422 m.packagingSpecs = append(m.packagingSpecs, PackagingSpec{
2423 relPathInPackage: Rel(m, fullInstallPath.PartitionDir(), fullInstallPath.String()),
2424 srcPath: nil,
2425 symlinkTarget: relPath,
2426 executable: false,
2427 })
2428
Colin Cross3854a602016-01-11 12:49:11 -08002429 return fullInstallPath
2430}
2431
Jiyong Parkf1194352019-02-25 11:05:47 +09002432// installPath/name -> absPath where absPath might be a path that is available only at runtime
2433// (e.g. /apex/...)
Colin Cross70dda7e2019-10-01 22:05:35 -07002434func (m *moduleContext) InstallAbsoluteSymlink(installPath InstallPath, name string, absPath string) InstallPath {
Colin Cross25de6c32019-06-06 14:29:25 -07002435 fullInstallPath := installPath.Join(m, name)
David Srbecky07656412020-06-04 01:26:16 +01002436 m.module.base().hooks.runInstallHooks(m, nil, fullInstallPath, true)
Jiyong Parkf1194352019-02-25 11:05:47 +09002437
Colin Cross25de6c32019-06-06 14:29:25 -07002438 if !m.skipInstall(fullInstallPath) {
2439 m.Build(pctx, BuildParams{
Jiyong Parkf1194352019-02-25 11:05:47 +09002440 Rule: Symlink,
2441 Description: "install symlink " + fullInstallPath.Base() + " -> " + absPath,
2442 Output: fullInstallPath,
Colin Cross25de6c32019-06-06 14:29:25 -07002443 Default: !m.Config().EmbeddedInMake(),
Jiyong Parkf1194352019-02-25 11:05:47 +09002444 Args: map[string]string{
2445 "fromPath": absPath,
2446 },
2447 })
2448
Colin Cross25de6c32019-06-06 14:29:25 -07002449 m.installFiles = append(m.installFiles, fullInstallPath)
Jiyong Parkf1194352019-02-25 11:05:47 +09002450 }
Jiyong Park073ea552020-11-09 14:08:34 +09002451
2452 m.packagingSpecs = append(m.packagingSpecs, PackagingSpec{
2453 relPathInPackage: Rel(m, fullInstallPath.PartitionDir(), fullInstallPath.String()),
2454 srcPath: nil,
2455 symlinkTarget: absPath,
2456 executable: false,
2457 })
2458
Jiyong Parkf1194352019-02-25 11:05:47 +09002459 return fullInstallPath
2460}
2461
Colin Cross25de6c32019-06-06 14:29:25 -07002462func (m *moduleContext) CheckbuildFile(srcPath Path) {
2463 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross3f40fa42015-01-30 17:27:36 -08002464}
2465
Colin Cross41955e82019-05-29 14:40:35 -07002466// SrcIsModule decodes module references in the format ":name" into the module name, or empty string if the input
2467// was not a module reference.
2468func SrcIsModule(s string) (module string) {
Colin Cross068e0fe2016-12-13 15:23:47 -08002469 if len(s) > 1 && s[0] == ':' {
2470 return s[1:]
2471 }
2472 return ""
2473}
2474
Colin Cross41955e82019-05-29 14:40:35 -07002475// SrcIsModule decodes module references in the format ":name{.tag}" into the module name and tag, ":name" into the
2476// module name and an empty string for the tag, or empty strings if the input was not a module reference.
2477func SrcIsModuleWithTag(s string) (module, tag string) {
2478 if len(s) > 1 && s[0] == ':' {
2479 module = s[1:]
2480 if tagStart := strings.IndexByte(module, '{'); tagStart > 0 {
2481 if module[len(module)-1] == '}' {
2482 tag = module[tagStart+1 : len(module)-1]
2483 module = module[:tagStart]
2484 return module, tag
2485 }
2486 }
2487 return module, ""
2488 }
2489 return "", ""
Colin Cross068e0fe2016-12-13 15:23:47 -08002490}
2491
Colin Cross41955e82019-05-29 14:40:35 -07002492type sourceOrOutputDependencyTag struct {
2493 blueprint.BaseDependencyTag
2494 tag string
2495}
2496
2497func sourceOrOutputDepTag(tag string) blueprint.DependencyTag {
2498 return sourceOrOutputDependencyTag{tag: tag}
2499}
2500
2501var SourceDepTag = sourceOrOutputDepTag("")
Colin Cross068e0fe2016-12-13 15:23:47 -08002502
Colin Cross366938f2017-12-11 16:29:02 -08002503// Adds necessary dependencies to satisfy filegroup or generated sources modules listed in srcFiles
2504// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002505//
2506// Deprecated: tag the property with `android:"path"` instead.
Colin Cross068e0fe2016-12-13 15:23:47 -08002507func ExtractSourcesDeps(ctx BottomUpMutatorContext, srcFiles []string) {
Nan Zhang2439eb72017-04-10 11:27:50 -07002508 set := make(map[string]bool)
2509
Colin Cross068e0fe2016-12-13 15:23:47 -08002510 for _, s := range srcFiles {
Colin Cross41955e82019-05-29 14:40:35 -07002511 if m, t := SrcIsModuleWithTag(s); m != "" {
2512 if _, found := set[s]; found {
2513 ctx.ModuleErrorf("found source dependency duplicate: %q!", s)
Nan Zhang2439eb72017-04-10 11:27:50 -07002514 } else {
Colin Cross41955e82019-05-29 14:40:35 -07002515 set[s] = true
2516 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Nan Zhang2439eb72017-04-10 11:27:50 -07002517 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002518 }
2519 }
Colin Cross068e0fe2016-12-13 15:23:47 -08002520}
2521
Colin Cross366938f2017-12-11 16:29:02 -08002522// Adds necessary dependencies to satisfy filegroup or generated sources modules specified in s
2523// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08002524//
2525// Deprecated: tag the property with `android:"path"` instead.
Colin Cross366938f2017-12-11 16:29:02 -08002526func ExtractSourceDeps(ctx BottomUpMutatorContext, s *string) {
2527 if s != nil {
Colin Cross41955e82019-05-29 14:40:35 -07002528 if m, t := SrcIsModuleWithTag(*s); m != "" {
2529 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Colin Cross366938f2017-12-11 16:29:02 -08002530 }
2531 }
2532}
2533
Colin Cross41955e82019-05-29 14:40:35 -07002534// A module that implements SourceFileProducer can be referenced from any property that is tagged with `android:"path"`
2535// 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 -08002536type SourceFileProducer interface {
2537 Srcs() Paths
2538}
2539
Colin Cross41955e82019-05-29 14:40:35 -07002540// A module that implements OutputFileProducer can be referenced from any property that is tagged with `android:"path"`
Roland Levillain97c1f342019-11-22 14:20:54 +00002541// 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 -07002542// listed in the property.
2543type OutputFileProducer interface {
2544 OutputFiles(tag string) (Paths, error)
2545}
2546
Colin Cross5e708052019-08-06 13:59:50 -07002547// OutputFilesForModule returns the paths from an OutputFileProducer with the given tag. On error, including if the
2548// module produced zero paths, it reports errors to the ctx and returns nil.
2549func OutputFilesForModule(ctx PathContext, module blueprint.Module, tag string) Paths {
2550 paths, err := outputFilesForModule(ctx, module, tag)
2551 if err != nil {
2552 reportPathError(ctx, err)
2553 return nil
2554 }
2555 return paths
2556}
2557
2558// OutputFileForModule returns the path from an OutputFileProducer with the given tag. On error, including if the
2559// module produced zero or multiple paths, it reports errors to the ctx and returns nil.
2560func OutputFileForModule(ctx PathContext, module blueprint.Module, tag string) Path {
2561 paths, err := outputFilesForModule(ctx, module, tag)
2562 if err != nil {
2563 reportPathError(ctx, err)
2564 return nil
2565 }
2566 if len(paths) > 1 {
Ulya Trafimovich5ab276a2020-08-25 12:45:15 +01002567 ReportPathErrorf(ctx, "got multiple output files from module %q, expected exactly one",
Colin Cross5e708052019-08-06 13:59:50 -07002568 pathContextName(ctx, module))
2569 return nil
2570 }
2571 return paths[0]
2572}
2573
2574func outputFilesForModule(ctx PathContext, module blueprint.Module, tag string) (Paths, error) {
2575 if outputFileProducer, ok := module.(OutputFileProducer); ok {
2576 paths, err := outputFileProducer.OutputFiles(tag)
2577 if err != nil {
2578 return nil, fmt.Errorf("failed to get output file from module %q: %s",
2579 pathContextName(ctx, module), err.Error())
2580 }
2581 if len(paths) == 0 {
2582 return nil, fmt.Errorf("failed to get output files from module %q", pathContextName(ctx, module))
2583 }
2584 return paths, nil
2585 } else {
2586 return nil, fmt.Errorf("module %q is not an OutputFileProducer", pathContextName(ctx, module))
2587 }
2588}
2589
Colin Crossfe17f6f2019-03-28 19:30:56 -07002590type HostToolProvider interface {
2591 HostToolPath() OptionalPath
2592}
2593
Colin Cross27b922f2019-03-04 22:35:41 -08002594// Returns a list of paths expanded from globs and modules referenced using ":module" syntax. The property must
2595// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002596//
2597// Deprecated: use PathsForModuleSrc or PathsForModuleSrcExcludes instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002598func (m *moduleContext) ExpandSources(srcFiles, excludes []string) Paths {
2599 return PathsForModuleSrcExcludes(m, srcFiles, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07002600}
2601
Colin Cross2fafa3e2019-03-05 12:39:51 -08002602// Returns a single path expanded from globs and modules referenced using ":module" syntax. The property must
2603// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08002604//
2605// Deprecated: use PathForModuleSrc instead.
Colin Cross25de6c32019-06-06 14:29:25 -07002606func (m *moduleContext) ExpandSource(srcFile, prop string) Path {
2607 return PathForModuleSrc(m, srcFile)
Colin Cross2fafa3e2019-03-05 12:39:51 -08002608}
2609
2610// Returns an optional single path expanded from globs and modules referenced using ":module" syntax if
2611// the srcFile is non-nil. The property must be tagged with `android:"path" to support automatic source module
2612// dependency resolution.
Colin Cross25de6c32019-06-06 14:29:25 -07002613func (m *moduleContext) ExpandOptionalSource(srcFile *string, prop string) OptionalPath {
Colin Cross2fafa3e2019-03-05 12:39:51 -08002614 if srcFile != nil {
Colin Cross25de6c32019-06-06 14:29:25 -07002615 return OptionalPathForPath(PathForModuleSrc(m, *srcFile))
Colin Cross2fafa3e2019-03-05 12:39:51 -08002616 }
2617 return OptionalPath{}
2618}
2619
Colin Cross25de6c32019-06-06 14:29:25 -07002620func (m *moduleContext) RequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002621 return m.module.RequiredModuleNames()
Nan Zhang6d34b302017-02-04 17:47:46 -08002622}
2623
Colin Cross25de6c32019-06-06 14:29:25 -07002624func (m *moduleContext) HostRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002625 return m.module.HostRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002626}
2627
Colin Cross25de6c32019-06-06 14:29:25 -07002628func (m *moduleContext) TargetRequiredModuleNames() []string {
Jiyong Park6a8cf5f2019-12-30 16:31:09 +09002629 return m.module.TargetRequiredModuleNames()
Sasha Smundakb6d23052019-04-01 18:37:36 -07002630}
2631
Colin Cross463a90e2015-06-17 14:20:06 -07002632func init() {
Colin Cross798bfce2016-10-12 14:28:16 -07002633 RegisterSingletonType("buildtarget", BuildTargetSingleton)
Colin Cross463a90e2015-06-17 14:20:06 -07002634}
2635
Colin Cross0875c522017-11-28 17:34:01 -08002636func BuildTargetSingleton() Singleton {
Colin Cross1f8c52b2015-06-16 16:38:17 -07002637 return &buildTargetSingleton{}
2638}
2639
Colin Cross87d8b562017-04-25 10:01:55 -07002640func parentDir(dir string) string {
2641 dir, _ = filepath.Split(dir)
2642 return filepath.Clean(dir)
2643}
2644
Colin Cross1f8c52b2015-06-16 16:38:17 -07002645type buildTargetSingleton struct{}
2646
Colin Cross0875c522017-11-28 17:34:01 -08002647func (c *buildTargetSingleton) GenerateBuildActions(ctx SingletonContext) {
2648 var checkbuildDeps Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07002649
Colin Crossc3d87d32020-06-04 13:25:17 -07002650 mmTarget := func(dir string) string {
2651 return "MODULES-IN-" + strings.Replace(filepath.Clean(dir), "/", "-", -1)
Colin Cross87d8b562017-04-25 10:01:55 -07002652 }
2653
Colin Cross0875c522017-11-28 17:34:01 -08002654 modulesInDir := make(map[string]Paths)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002655
Colin Cross0875c522017-11-28 17:34:01 -08002656 ctx.VisitAllModules(func(module Module) {
2657 blueprintDir := module.base().blueprintDir
2658 installTarget := module.base().installTarget
2659 checkbuildTarget := module.base().checkbuildTarget
Colin Cross1f8c52b2015-06-16 16:38:17 -07002660
Colin Cross0875c522017-11-28 17:34:01 -08002661 if checkbuildTarget != nil {
2662 checkbuildDeps = append(checkbuildDeps, checkbuildTarget)
2663 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], checkbuildTarget)
2664 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002665
Colin Cross0875c522017-11-28 17:34:01 -08002666 if installTarget != nil {
2667 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], installTarget)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002668 }
2669 })
2670
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002671 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08002672 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08002673 suffix = "-soong"
2674 }
2675
Colin Cross1f8c52b2015-06-16 16:38:17 -07002676 // Create a top-level checkbuild target that depends on all modules
Colin Crossc3d87d32020-06-04 13:25:17 -07002677 ctx.Phony("checkbuild"+suffix, checkbuildDeps...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002678
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002679 // Make will generate the MODULES-IN-* targets
Colin Crossaabf6792017-11-29 00:27:14 -08002680 if ctx.Config().EmbeddedInMake() {
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002681 return
2682 }
2683
Colin Cross87d8b562017-04-25 10:01:55 -07002684 // Ensure ancestor directories are in modulesInDir
Inseob Kim1a365c62019-06-08 15:47:51 +09002685 dirs := SortedStringKeys(modulesInDir)
Colin Cross87d8b562017-04-25 10:01:55 -07002686 for _, dir := range dirs {
2687 dir := parentDir(dir)
2688 for dir != "." && dir != "/" {
2689 if _, exists := modulesInDir[dir]; exists {
2690 break
2691 }
2692 modulesInDir[dir] = nil
2693 dir = parentDir(dir)
2694 }
2695 }
2696
2697 // Make directories build their direct subdirectories
Colin Cross87d8b562017-04-25 10:01:55 -07002698 for _, dir := range dirs {
2699 p := parentDir(dir)
2700 if p != "." && p != "/" {
Colin Crossc3d87d32020-06-04 13:25:17 -07002701 modulesInDir[p] = append(modulesInDir[p], PathForPhony(ctx, mmTarget(dir)))
Colin Cross87d8b562017-04-25 10:01:55 -07002702 }
2703 }
2704
Dan Willemsend2e95fb2017-09-20 14:30:50 -07002705 // Create a MODULES-IN-<directory> target that depends on all modules in a directory, and
2706 // depends on the MODULES-IN-* targets of all of its subdirectories that contain Android.bp
2707 // files.
Colin Cross1f8c52b2015-06-16 16:38:17 -07002708 for _, dir := range dirs {
Colin Crossc3d87d32020-06-04 13:25:17 -07002709 ctx.Phony(mmTarget(dir), modulesInDir[dir]...)
Colin Cross1f8c52b2015-06-16 16:38:17 -07002710 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002711
2712 // Create (host|host-cross|target)-<OS> phony rules to build a reduced checkbuild.
Jiyong Park1613e552020-09-14 19:43:17 +09002713 type osAndCross struct {
2714 os OsType
2715 hostCross bool
2716 }
2717 osDeps := map[osAndCross]Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08002718 ctx.VisitAllModules(func(module Module) {
2719 if module.Enabled() {
Jiyong Park1613e552020-09-14 19:43:17 +09002720 key := osAndCross{os: module.Target().Os, hostCross: module.Target().HostCross}
2721 osDeps[key] = append(osDeps[key], module.base().checkbuildFiles...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002722 }
2723 })
2724
Colin Cross0875c522017-11-28 17:34:01 -08002725 osClass := make(map[string]Paths)
Jiyong Park1613e552020-09-14 19:43:17 +09002726 for key, deps := range osDeps {
Dan Willemsen61d88b82017-09-20 17:29:08 -07002727 var className string
2728
Jiyong Park1613e552020-09-14 19:43:17 +09002729 switch key.os.Class {
Dan Willemsen61d88b82017-09-20 17:29:08 -07002730 case Host:
Jiyong Park1613e552020-09-14 19:43:17 +09002731 if key.hostCross {
2732 className = "host-cross"
2733 } else {
2734 className = "host"
2735 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07002736 case Device:
2737 className = "target"
2738 default:
2739 continue
2740 }
2741
Jiyong Park1613e552020-09-14 19:43:17 +09002742 name := className + "-" + key.os.Name
Colin Crossc3d87d32020-06-04 13:25:17 -07002743 osClass[className] = append(osClass[className], PathForPhony(ctx, name))
Dan Willemsen61d88b82017-09-20 17:29:08 -07002744
Colin Crossc3d87d32020-06-04 13:25:17 -07002745 ctx.Phony(name, deps...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002746 }
2747
2748 // Wrap those into host|host-cross|target phony rules
Inseob Kim1a365c62019-06-08 15:47:51 +09002749 for _, class := range SortedStringKeys(osClass) {
Colin Crossc3d87d32020-06-04 13:25:17 -07002750 ctx.Phony(class, osClass[class]...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07002751 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07002752}
Colin Crossd779da42015-12-17 18:00:23 -08002753
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002754// Collect information for opening IDE project files in java/jdeps.go.
2755type IDEInfo interface {
2756 IDEInfo(ideInfo *IdeInfo)
2757 BaseModuleName() string
2758}
2759
2760// Extract the base module name from the Import name.
2761// Often the Import name has a prefix "prebuilt_".
2762// Remove the prefix explicitly if needed
2763// until we find a better solution to get the Import name.
2764type IDECustomizedModuleName interface {
2765 IDECustomizedModuleName() string
2766}
2767
2768type IdeInfo struct {
2769 Deps []string `json:"dependencies,omitempty"`
2770 Srcs []string `json:"srcs,omitempty"`
2771 Aidl_include_dirs []string `json:"aidl_include_dirs,omitempty"`
2772 Jarjar_rules []string `json:"jarjar_rules,omitempty"`
2773 Jars []string `json:"jars,omitempty"`
2774 Classes []string `json:"class,omitempty"`
2775 Installed_paths []string `json:"installed,omitempty"`
patricktu18c82ff2019-05-10 15:48:50 +08002776 SrcJars []string `json:"srcjars,omitempty"`
bralee1fbf4402020-05-21 10:11:59 +08002777 Paths []string `json:"path,omitempty"`
Brandon Lee5d45c6f2018-08-15 15:35:38 -07002778}
Paul Duffinf88d8e02020-05-07 20:21:34 +01002779
2780func CheckBlueprintSyntax(ctx BaseModuleContext, filename string, contents string) []error {
2781 bpctx := ctx.blueprintBaseModuleContext()
2782 return blueprint.CheckBlueprintSyntax(bpctx.ModuleFactories(), filename, contents)
2783}