blob: 2d0c20d8cb23f9819db7f1a31bc23428945962d8 [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"
Alex Lightfb4353d2019-01-17 13:57:45 -080019 "path"
Colin Cross3f40fa42015-01-30 17:27:36 -080020 "path/filepath"
Colin Cross6ff51382015-12-17 16:39:19 -080021 "strings"
Colin Crossaabf6792017-11-29 00:27:14 -080022 "text/scanner"
Colin Crossf6566ed2015-03-24 11:13:38 -070023
24 "github.com/google/blueprint"
Colin Cross7f19f372016-11-01 11:10:25 -070025 "github.com/google/blueprint/pathtools"
Colin Crossfe4bc362018-09-12 10:02:13 -070026 "github.com/google/blueprint/proptools"
Colin Cross3f40fa42015-01-30 17:27:36 -080027)
28
29var (
30 DeviceSharedLibrary = "shared_library"
31 DeviceStaticLibrary = "static_library"
32 DeviceExecutable = "executable"
33 HostSharedLibrary = "host_shared_library"
34 HostStaticLibrary = "host_static_library"
35 HostExecutable = "host_executable"
36)
37
Colin Crossae887032017-10-23 17:16:14 -070038type BuildParams struct {
Dan Willemsen9f3c5742016-11-03 14:28:31 -070039 Rule blueprint.Rule
Colin Cross33bfb0a2016-11-21 17:23:08 -080040 Deps blueprint.Deps
41 Depfile WritablePath
Colin Cross67a5c132017-05-09 13:45:28 -070042 Description string
Dan Willemsen9f3c5742016-11-03 14:28:31 -070043 Output WritablePath
44 Outputs WritablePaths
45 ImplicitOutput WritablePath
46 ImplicitOutputs WritablePaths
47 Input Path
48 Inputs Paths
49 Implicit Path
50 Implicits Paths
51 OrderOnly Paths
52 Default bool
53 Args map[string]string
Dan Willemsen34cc69e2015-09-23 15:26:20 -070054}
55
Colin Crossae887032017-10-23 17:16:14 -070056type ModuleBuildParams BuildParams
57
Colin Cross0ea8ba82019-06-06 14:33:29 -070058// BaseModuleContext is the same as blueprint.BaseModuleContext except that Config() returns
Colin Crossdc35e212019-06-06 16:13:11 -070059// a Config instead of an interface{}, and some methods have been wrapped to use an android.Module
60// instead of a blueprint.Module, plus some extra methods that return Android-specific information
Colin Cross0ea8ba82019-06-06 14:33:29 -070061// about the current module.
62type BaseModuleContext interface {
Colin Crossdc35e212019-06-06 16:13:11 -070063 Module() Module
Colin Cross0ea8ba82019-06-06 14:33:29 -070064 ModuleName() string
65 ModuleDir() string
66 ModuleType() string
67 Config() Config
68
Colin Crossdc35e212019-06-06 16:13:11 -070069 OtherModuleName(m blueprint.Module) string
70 OtherModuleDir(m blueprint.Module) string
71 OtherModuleErrorf(m blueprint.Module, fmt string, args ...interface{})
72 OtherModuleDependencyTag(m blueprint.Module) blueprint.DependencyTag
73 OtherModuleExists(name string) bool
Jiyong Park9e6c2422019-08-09 20:39:45 +090074 OtherModuleType(m blueprint.Module) string
Colin Crossdc35e212019-06-06 16:13:11 -070075
76 GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module
77 GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module
78 GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag)
79
80 VisitDirectDepsBlueprint(visit func(blueprint.Module))
81 VisitDirectDeps(visit func(Module))
82 VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module))
83 VisitDirectDepsIf(pred func(Module) bool, visit func(Module))
84 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
85 VisitDepsDepthFirst(visit func(Module))
86 // Deprecated: use WalkDeps instead to support multiple dependency tags on the same module
87 VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module))
88 WalkDeps(visit func(Module, Module) bool)
89 WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool)
90 // GetWalkPath is supposed to be called in visit function passed in WalkDeps()
91 // and returns a top-down dependency path from a start module to current child module.
92 GetWalkPath() []Module
93
Colin Cross0ea8ba82019-06-06 14:33:29 -070094 ContainsProperty(name string) bool
95 Errorf(pos scanner.Position, fmt string, args ...interface{})
96 ModuleErrorf(fmt string, args ...interface{})
97 PropertyErrorf(property, fmt string, args ...interface{})
98 Failed() bool
99
100 // GlobWithDeps returns a list of files that match the specified pattern but do not match any
101 // of the patterns in excludes. It also adds efficient dependencies to rerun the primary
102 // builder whenever a file matching the pattern as added or removed, without rerunning if a
103 // file that does not match the pattern is added to a searched directory.
104 GlobWithDeps(pattern string, excludes []string) ([]string, error)
105
Colin Crossdc35e212019-06-06 16:13:11 -0700106 Glob(globPattern string, excludes []string) Paths
107 GlobFiles(globPattern string, excludes []string) Paths
108
Colin Cross0ea8ba82019-06-06 14:33:29 -0700109 Fs() pathtools.FileSystem
110 AddNinjaFileDeps(deps ...string)
111
Colin Crossdc35e212019-06-06 16:13:11 -0700112 AddMissingDependencies(missingDeps []string)
113
Colin Crossa1ad8d12016-06-01 17:09:44 -0700114 Target() Target
Colin Cross8b74d172016-09-13 09:59:14 -0700115 TargetPrimary() bool
Colin Crossee0bc3b2018-10-02 22:01:37 -0700116 MultiTargets() []Target
Colin Crossf6566ed2015-03-24 11:13:38 -0700117 Arch() Arch
Colin Crossa1ad8d12016-06-01 17:09:44 -0700118 Os() OsType
Colin Crossf6566ed2015-03-24 11:13:38 -0700119 Host() bool
120 Device() bool
Colin Cross0af4b842015-04-30 16:36:18 -0700121 Darwin() bool
Doug Horn21b94272019-01-16 12:06:11 -0800122 Fuchsia() bool
Colin Cross3edeee12017-04-04 12:59:48 -0700123 Windows() bool
Colin Crossf6566ed2015-03-24 11:13:38 -0700124 Debug() bool
Colin Cross1e7d3702016-08-24 15:25:47 -0700125 PrimaryArch() bool
Jiyong Park2db76922017-11-08 16:03:48 +0900126 Platform() bool
127 DeviceSpecific() bool
128 SocSpecific() bool
129 ProductSpecific() bool
Justin Yund5f6c822019-06-25 16:47:17 +0900130 SystemExtSpecific() bool
Colin Cross1332b002015-04-07 17:11:30 -0700131 AConfig() Config
Colin Cross9272ade2016-08-17 15:24:12 -0700132 DeviceConfig() DeviceConfig
Colin Crossf6566ed2015-03-24 11:13:38 -0700133}
134
Colin Cross0ea8ba82019-06-06 14:33:29 -0700135// Deprecated: use BaseModuleContext instead
Colin Cross635c3b02016-05-18 15:37:25 -0700136type BaseContext interface {
Colin Crossaabf6792017-11-29 00:27:14 -0800137 BaseModuleContext
Colin Crossaabf6792017-11-29 00:27:14 -0800138}
139
Colin Cross635c3b02016-05-18 15:37:25 -0700140type ModuleContext interface {
Colin Crossaabf6792017-11-29 00:27:14 -0800141 BaseModuleContext
Colin Cross3f40fa42015-01-30 17:27:36 -0800142
Colin Crossae887032017-10-23 17:16:14 -0700143 // Deprecated: use ModuleContext.Build instead.
Colin Cross0875c522017-11-28 17:34:01 -0800144 ModuleBuild(pctx PackageContext, params ModuleBuildParams)
Colin Cross8f101b42015-06-17 15:09:06 -0700145
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700146 ExpandSources(srcFiles, excludes []string) Paths
Colin Cross366938f2017-12-11 16:29:02 -0800147 ExpandSource(srcFile, prop string) Path
Colin Cross2383f3b2018-02-06 14:40:13 -0800148 ExpandOptionalSource(srcFile *string, prop string) OptionalPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700149
Colin Cross5c517922017-08-31 12:29:17 -0700150 InstallExecutable(installPath OutputPath, name string, srcPath Path, deps ...Path) OutputPath
151 InstallFile(installPath OutputPath, name string, srcPath Path, deps ...Path) OutputPath
Colin Cross3854a602016-01-11 12:49:11 -0800152 InstallSymlink(installPath OutputPath, name string, srcPath OutputPath) OutputPath
Jiyong Parkf1194352019-02-25 11:05:47 +0900153 InstallAbsoluteSymlink(installPath OutputPath, name string, absPath string) OutputPath
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700154 CheckbuildFile(srcPath Path)
Dan Willemsen6553f5e2016-03-10 18:14:25 -0800155
Colin Cross8d8f8e22016-08-03 11:57:50 -0700156 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700157 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700158 InstallInSanitizerDir() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900159 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700160 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700161 InstallBypassMake() bool
Nan Zhang6d34b302017-02-04 17:47:46 -0800162
163 RequiredModuleNames() []string
Sasha Smundakb6d23052019-04-01 18:37:36 -0700164 HostRequiredModuleNames() []string
165 TargetRequiredModuleNames() []string
Colin Cross3f68a132017-10-23 17:10:29 -0700166
Colin Cross3f68a132017-10-23 17:10:29 -0700167 ModuleSubDir() string
168
Colin Cross0875c522017-11-28 17:34:01 -0800169 Variable(pctx PackageContext, name, value string)
170 Rule(pctx PackageContext, name string, params blueprint.RuleParams, argNames ...string) blueprint.Rule
Colin Crossae887032017-10-23 17:16:14 -0700171 // Similar to blueprint.ModuleContext.Build, but takes Paths instead of []string,
172 // and performs more verification.
Colin Cross0875c522017-11-28 17:34:01 -0800173 Build(pctx PackageContext, params BuildParams)
Colin Cross3f68a132017-10-23 17:10:29 -0700174
Colin Cross0875c522017-11-28 17:34:01 -0800175 PrimaryModule() Module
176 FinalModule() Module
177 VisitAllModuleVariants(visit func(Module))
Colin Cross3f68a132017-10-23 17:10:29 -0700178
179 GetMissingDependencies() []string
Jeff Gaston088e29e2017-11-29 16:47:17 -0800180 Namespace() blueprint.Namespace
Colin Cross3f40fa42015-01-30 17:27:36 -0800181}
182
Colin Cross635c3b02016-05-18 15:37:25 -0700183type Module interface {
Colin Cross3f40fa42015-01-30 17:27:36 -0800184 blueprint.Module
185
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700186 // GenerateAndroidBuildActions is analogous to Blueprints' GenerateBuildActions,
187 // but GenerateAndroidBuildActions also has access to Android-specific information.
188 // For more information, see Module.GenerateBuildActions within Blueprint's module_ctx.go
Colin Cross635c3b02016-05-18 15:37:25 -0700189 GenerateAndroidBuildActions(ModuleContext)
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700190
Colin Cross1e676be2016-10-12 14:38:15 -0700191 DepsMutator(BottomUpMutatorContext)
Colin Cross3f40fa42015-01-30 17:27:36 -0800192
Colin Cross635c3b02016-05-18 15:37:25 -0700193 base() *ModuleBase
Dan Willemsen0effe062015-11-30 16:06:01 -0800194 Enabled() bool
Colin Crossa1ad8d12016-06-01 17:09:44 -0700195 Target() Target
Dan Willemsen782a2d12015-12-21 14:55:28 -0800196 InstallInData() bool
Jaewoong Jung0949f312019-09-11 10:25:18 -0700197 InstallInTestcases() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700198 InstallInSanitizerDir() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900199 InstallInRecovery() bool
Colin Cross90ba5f42019-10-02 11:10:58 -0700200 InstallInRoot() bool
Colin Cross607d8582019-07-29 16:44:46 -0700201 InstallBypassMake() bool
Colin Crossa2f296f2016-11-29 15:16:18 -0800202 SkipInstall()
Jiyong Park374510b2018-03-19 18:23:01 +0900203 ExportedToMake() bool
Jiyong Park52818fc2019-03-18 12:01:38 +0900204 NoticeFile() OptionalPath
Colin Cross36242852017-06-23 15:06:31 -0700205
206 AddProperties(props ...interface{})
207 GetProperties() []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700208
Colin Crossae887032017-10-23 17:16:14 -0700209 BuildParamsForTests() []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800210 RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800211 VariablesForTests() map[string]string
Paul Duffine2453c72019-05-31 14:00:04 +0100212
Colin Cross9a362232019-07-01 15:32:45 -0700213 // String returns a string that includes the module name and variants for printing during debugging.
214 String() string
215
Paul Duffine2453c72019-05-31 14:00:04 +0100216 // Get the qualified module id for this module.
217 qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName
218
219 // Get information about the properties that can contain visibility rules.
220 visibilityProperties() []visibilityProperty
Paul Duffin63c6e182019-07-24 14:24:38 +0100221
222 // Get the visibility rules that control the visibility of this module.
223 visibility() []string
Paul Duffine2453c72019-05-31 14:00:04 +0100224}
225
226// Qualified id for a module
227type qualifiedModuleName struct {
228 // The package (i.e. directory) in which the module is defined, without trailing /
229 pkg string
230
231 // The name of the module, empty string if package.
232 name string
233}
234
235func (q qualifiedModuleName) String() string {
236 if q.name == "" {
237 return "//" + q.pkg
238 }
239 return "//" + q.pkg + ":" + q.name
240}
241
Paul Duffine484f472019-06-20 16:38:08 +0100242func (q qualifiedModuleName) isRootPackage() bool {
243 return q.pkg == "" && q.name == ""
244}
245
Paul Duffine2453c72019-05-31 14:00:04 +0100246// Get the id for the package containing this module.
247func (q qualifiedModuleName) getContainingPackageId() qualifiedModuleName {
248 pkg := q.pkg
249 if q.name == "" {
Paul Duffine484f472019-06-20 16:38:08 +0100250 if pkg == "" {
251 panic(fmt.Errorf("Cannot get containing package id of root package"))
252 }
253
254 index := strings.LastIndex(pkg, "/")
255 if index == -1 {
256 pkg = ""
257 } else {
258 pkg = pkg[:index]
259 }
Paul Duffine2453c72019-05-31 14:00:04 +0100260 }
261 return newPackageId(pkg)
262}
263
264func newPackageId(pkg string) qualifiedModuleName {
265 // A qualified id for a package module has no name.
266 return qualifiedModuleName{pkg: pkg, name: ""}
Colin Cross3f40fa42015-01-30 17:27:36 -0800267}
268
Colin Crossfc754582016-05-17 16:34:16 -0700269type nameProperties struct {
270 // The name of the module. Must be unique across all modules.
Nan Zhang0007d812017-11-07 10:57:05 -0800271 Name *string
Colin Crossfc754582016-05-17 16:34:16 -0700272}
273
274type commonProperties struct {
Dan Willemsen0effe062015-11-30 16:06:01 -0800275 // emit build rules for this module
276 Enabled *bool `android:"arch_variant"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800277
Paul Duffin2e61fa62019-03-28 14:10:57 +0000278 // Controls the visibility of this module to other modules. Allowable values are one or more of
279 // these formats:
280 //
281 // ["//visibility:public"]: Anyone can use this module.
282 // ["//visibility:private"]: Only rules in the module's package (not its subpackages) can use
283 // this module.
284 // ["//some/package:__pkg__", "//other/package:__pkg__"]: Only modules in some/package and
285 // other/package (defined in some/package/*.bp and other/package/*.bp) have access to
286 // this module. Note that sub-packages do not have access to the rule; for example,
287 // //some/package/foo:bar or //other/package/testing:bla wouldn't have access. __pkg__
288 // is a special module and must be used verbatim. It represents all of the modules in the
289 // package.
290 // ["//project:__subpackages__", "//other:__subpackages__"]: Only modules in packages project
291 // or other or in one of their sub-packages have access to this module. For example,
292 // //project:rule, //project/library:lib or //other/testing/internal:munge are allowed
293 // to depend on this rule (but not //independent:evil)
294 // ["//project"]: This is shorthand for ["//project:__pkg__"]
295 // [":__subpackages__"]: This is shorthand for ["//project:__subpackages__"] where
296 // //project is the module's package. e.g. using [":__subpackages__"] in
297 // packages/apps/Settings/Android.bp is equivalent to
298 // //packages/apps/Settings:__subpackages__.
299 // ["//visibility:legacy_public"]: The default visibility, behaves as //visibility:public
300 // for now. It is an error if it is used in a module.
Paul Duffine2453c72019-05-31 14:00:04 +0100301 //
302 // If a module does not specify the `visibility` property then it uses the
303 // `default_visibility` property of the `package` module in the module's package.
304 //
Paul Duffine484f472019-06-20 16:38:08 +0100305 // If a module does not specify the `visibility` property then it uses the
306 // `default_visibility` property of the `package` module in the module's package.
307 //
Paul Duffine2453c72019-05-31 14:00:04 +0100308 // If the `default_visibility` property is not set for the module's package then
Paul Duffine484f472019-06-20 16:38:08 +0100309 // it will use the `default_visibility` of its closest ancestor package for which
310 // a `default_visibility` property is specified.
311 //
312 // If no `default_visibility` property can be found then the module uses the
313 // global default of `//visibility:legacy_public`.
Paul Duffine2453c72019-05-31 14:00:04 +0100314 //
Paul Duffin95d53b52019-07-24 13:45:05 +0100315 // The `visibility` property has no effect on a defaults module although it does
316 // apply to any non-defaults module that uses it. To set the visibility of a
317 // defaults module, use the `defaults_visibility` property on the defaults module;
318 // not to be confused with the `default_visibility` property on the package module.
319 //
Paul Duffin2e61fa62019-03-28 14:10:57 +0000320 // See https://android.googlesource.com/platform/build/soong/+/master/README.md#visibility for
321 // more details.
322 Visibility []string
323
Colin Cross7d5136f2015-05-11 13:39:40 -0700324 // control whether this module compiles for 32-bit, 64-bit, or both. Possible values
Colin Cross3f40fa42015-01-30 17:27:36 -0800325 // are "32" (compile for 32-bit only), "64" (compile for 64-bit only), "both" (compile for both
326 // architectures), or "first" (compile for 64-bit on a 64-bit platform, and 32-bit on a 32-bit
327 // platform
Colin Cross7d716ba2017-11-01 10:38:29 -0700328 Compile_multilib *string `android:"arch_variant"`
Colin Cross69617d32016-09-06 10:39:07 -0700329
330 Target struct {
331 Host struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700332 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700333 }
334 Android struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700335 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700336 }
337 }
338
Colin Crossee0bc3b2018-10-02 22:01:37 -0700339 UseTargetVariants bool `blueprint:"mutated"`
340 Default_multilib string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800341
Dan Willemsen782a2d12015-12-21 14:55:28 -0800342 // whether this is a proprietary vendor module, and should be installed into /vendor
Colin Cross7d716ba2017-11-01 10:38:29 -0700343 Proprietary *bool
Dan Willemsen782a2d12015-12-21 14:55:28 -0800344
Colin Cross55708f32017-03-20 13:23:34 -0700345 // vendor who owns this module
Dan Willemsenefac4a82017-07-18 19:42:09 -0700346 Owner *string
Colin Cross55708f32017-03-20 13:23:34 -0700347
Jiyong Park2db76922017-11-08 16:03:48 +0900348 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
349 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
350 // Use `soc_specific` instead for better meaning.
Colin Cross7d716ba2017-11-01 10:38:29 -0700351 Vendor *bool
Dan Willemsenaa118f92017-04-06 12:49:58 -0700352
Jiyong Park2db76922017-11-08 16:03:48 +0900353 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
354 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
355 Soc_specific *bool
356
357 // whether this module is specific to a device, not only for SoC, but also for off-chip
358 // peripherals. When set to true, it is installed into /odm (or /vendor/odm if odm partition
359 // does not exist, or /system/vendor/odm if both odm and vendor partitions do not exist).
360 // This implies `soc_specific:true`.
361 Device_specific *bool
362
363 // whether this module is specific to a software configuration of a product (e.g. country,
Jaekyun Seok5cfbfbb2018-01-10 19:00:15 +0900364 // network operator, etc). When set to true, it is installed into /product (or
365 // /system/product if product partition does not exist).
Jiyong Park2db76922017-11-08 16:03:48 +0900366 Product_specific *bool
367
Justin Yund5f6c822019-06-25 16:47:17 +0900368 // TODO(b/135957588) Product_services_specific will be removed once we clear all Android.bp
369 // files that have 'product_services_specific: true'. This will be converted to
370 // Product_speicific as a workaround.
Dario Freni95cf7672018-08-17 00:57:57 +0100371 Product_services_specific *bool
Dario Frenifd05a742018-05-29 13:28:54 +0100372
Justin Yund5f6c822019-06-25 16:47:17 +0900373 // whether this module extends system. When set to true, it is installed into /system_ext
374 // (or /system/system_ext if system_ext partition does not exist).
375 System_ext_specific *bool
376
Jiyong Parkf9332f12018-02-01 00:54:12 +0900377 // Whether this module is installed to recovery partition
378 Recovery *bool
379
dimitry1f33e402019-03-26 12:39:31 +0100380 // Whether this module is built for non-native architecures (also known as native bridge binary)
381 Native_bridge_supported *bool `android:"arch_variant"`
382
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700383 // init.rc files to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800384 Init_rc []string `android:"path"`
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700385
Steven Moreland57a23d22018-04-04 15:42:19 -0700386 // VINTF manifest fragments to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800387 Vintf_fragments []string `android:"path"`
Steven Moreland57a23d22018-04-04 15:42:19 -0700388
Chris Wolfe998306e2016-08-15 14:47:23 -0400389 // names of other modules to install if this module is installed
Colin Crossc602b7d2017-05-05 13:36:36 -0700390 Required []string `android:"arch_variant"`
Chris Wolfe998306e2016-08-15 14:47:23 -0400391
Sasha Smundakb6d23052019-04-01 18:37:36 -0700392 // names of other modules to install on host if this module is installed
393 Host_required []string `android:"arch_variant"`
394
395 // names of other modules to install on target if this module is installed
396 Target_required []string `android:"arch_variant"`
397
Colin Cross5aac3622017-08-31 15:07:09 -0700398 // relative path to a file to include in the list of notices for the device
Colin Cross27b922f2019-03-04 22:35:41 -0800399 Notice *string `android:"path"`
Colin Cross5aac3622017-08-31 15:07:09 -0700400
Dan Willemsen569edc52018-11-19 09:33:29 -0800401 Dist struct {
402 // copy the output of this module to the $DIST_DIR when `dist` is specified on the
403 // command line and any of these targets are also on the command line, or otherwise
404 // built
405 Targets []string `android:"arch_variant"`
406
407 // The name of the output artifact. This defaults to the basename of the output of
408 // the module.
409 Dest *string `android:"arch_variant"`
410
411 // The directory within the dist directory to store the artifact. Defaults to the
412 // top level directory ("").
413 Dir *string `android:"arch_variant"`
414
415 // A suffix to add to the artifact file name (before any extension).
416 Suffix *string `android:"arch_variant"`
417 } `android:"arch_variant"`
418
Colin Crossa1ad8d12016-06-01 17:09:44 -0700419 // Set by TargetMutator
Colin Crossee0bc3b2018-10-02 22:01:37 -0700420 CompileTarget Target `blueprint:"mutated"`
421 CompileMultiTargets []Target `blueprint:"mutated"`
422 CompilePrimary bool `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800423
424 // Set by InitAndroidModule
425 HostOrDeviceSupported HostOrDeviceSupported `blueprint:"mutated"`
Dan Willemsen0b24c742016-10-04 15:13:37 -0700426 ArchSpecific bool `blueprint:"mutated"`
Colin Crossce75d2c2016-10-06 16:12:58 -0700427
428 SkipInstall bool `blueprint:"mutated"`
Jeff Gaston088e29e2017-11-29 16:47:17 -0800429
430 NamespaceExportedToMake bool `blueprint:"mutated"`
Colin Cross6c4f21f2019-06-06 15:41:36 -0700431
432 MissingDeps []string `blueprint:"mutated"`
Colin Cross9a362232019-07-01 15:32:45 -0700433
434 // Name and variant strings stored by mutators to enable Module.String()
435 DebugName string `blueprint:"mutated"`
436 DebugMutators []string `blueprint:"mutated"`
437 DebugVariations []string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800438}
439
440type hostAndDeviceProperties struct {
Colin Cross4e81d702018-11-09 10:36:55 -0800441 // If set to true, build a variant of the module for the host. Defaults to false.
442 Host_supported *bool
443
444 // If set to true, build a variant of the module for the device. Defaults to true.
Colin Crossa4190c12016-07-12 13:11:25 -0700445 Device_supported *bool
Colin Cross3f40fa42015-01-30 17:27:36 -0800446}
447
Colin Crossc472d572015-03-17 15:06:21 -0700448type Multilib string
449
450const (
Colin Cross6b4a32d2017-12-05 13:42:45 -0800451 MultilibBoth Multilib = "both"
452 MultilibFirst Multilib = "first"
453 MultilibCommon Multilib = "common"
454 MultilibCommonFirst Multilib = "common_first"
455 MultilibDefault Multilib = ""
Colin Crossc472d572015-03-17 15:06:21 -0700456)
457
Colin Crossa1ad8d12016-06-01 17:09:44 -0700458type HostOrDeviceSupported int
459
460const (
461 _ HostOrDeviceSupported = iota
Dan Albert0981b5c2018-08-02 13:46:35 -0700462
463 // Host and HostCross are built by default. Device is not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700464 HostSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700465
466 // Host is built by default. HostCross and Device are not supported.
Dan Albertc6345fb2016-10-20 01:36:11 -0700467 HostSupportedNoCross
Dan Albert0981b5c2018-08-02 13:46:35 -0700468
469 // Device is built by default. Host and HostCross are not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700470 DeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700471
472 // Device is built by default. Host and HostCross are supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700473 HostAndDeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700474
475 // Host, HostCross, and Device are built by default.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700476 HostAndDeviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700477
478 // Nothing is supported. This is not exposed to the user, but used to mark a
479 // host only module as unsupported when the module type is not supported on
480 // the host OS. E.g. benchmarks are supported on Linux but not Darwin.
Dan Willemsen0b24c742016-10-04 15:13:37 -0700481 NeitherHostNorDeviceSupported
Colin Crossa1ad8d12016-06-01 17:09:44 -0700482)
483
Jiyong Park2db76922017-11-08 16:03:48 +0900484type moduleKind int
485
486const (
487 platformModule moduleKind = iota
488 deviceSpecificModule
489 socSpecificModule
490 productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900491 systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900492)
493
494func (k moduleKind) String() string {
495 switch k {
496 case platformModule:
497 return "platform"
498 case deviceSpecificModule:
499 return "device-specific"
500 case socSpecificModule:
501 return "soc-specific"
502 case productSpecificModule:
503 return "product-specific"
Justin Yund5f6c822019-06-25 16:47:17 +0900504 case systemExtSpecificModule:
505 return "systemext-specific"
Jiyong Park2db76922017-11-08 16:03:48 +0900506 default:
507 panic(fmt.Errorf("unknown module kind %d", k))
508 }
509}
510
Colin Cross36242852017-06-23 15:06:31 -0700511func InitAndroidModule(m Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800512 base := m.base()
513 base.module = m
Colin Cross5049f022015-03-18 13:28:46 -0700514
Colin Cross36242852017-06-23 15:06:31 -0700515 m.AddProperties(
Colin Crossfc754582016-05-17 16:34:16 -0700516 &base.nameProperties,
517 &base.commonProperties,
518 &base.variableProperties)
Colin Crossa3a97412019-03-18 12:24:29 -0700519 base.generalProperties = m.GetProperties()
Pirama Arumuga Nainar955dc492018-04-17 14:58:42 -0700520 base.customizableProperties = m.GetProperties()
Paul Duffin63c6e182019-07-24 14:24:38 +0100521
522 // The default_visibility property needs to be checked and parsed by the visibility module during
523 // its checking and parsing phases.
524 base.primaryVisibilityProperty =
525 newVisibilityProperty("visibility", &base.commonProperties.Visibility)
526 base.visibilityPropertyInfo = []visibilityProperty{base.primaryVisibilityProperty}
Colin Cross5049f022015-03-18 13:28:46 -0700527}
528
Colin Cross36242852017-06-23 15:06:31 -0700529func InitAndroidArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
530 InitAndroidModule(m)
Colin Cross5049f022015-03-18 13:28:46 -0700531
532 base := m.base()
Colin Cross3f40fa42015-01-30 17:27:36 -0800533 base.commonProperties.HostOrDeviceSupported = hod
Colin Cross69617d32016-09-06 10:39:07 -0700534 base.commonProperties.Default_multilib = string(defaultMultilib)
Dan Willemsen0b24c742016-10-04 15:13:37 -0700535 base.commonProperties.ArchSpecific = true
Colin Crossee0bc3b2018-10-02 22:01:37 -0700536 base.commonProperties.UseTargetVariants = true
Colin Cross3f40fa42015-01-30 17:27:36 -0800537
Dan Willemsen218f6562015-07-08 18:13:11 -0700538 switch hod {
Nan Zhang1a0f09b2017-07-05 10:35:11 -0700539 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Cross36242852017-06-23 15:06:31 -0700540 m.AddProperties(&base.hostAndDeviceProperties)
Colin Cross3f40fa42015-01-30 17:27:36 -0800541 }
542
Colin Cross36242852017-06-23 15:06:31 -0700543 InitArchModule(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800544}
545
Colin Crossee0bc3b2018-10-02 22:01:37 -0700546func InitAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
547 InitAndroidArchModule(m, hod, defaultMultilib)
548 m.base().commonProperties.UseTargetVariants = false
549}
550
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800551// A ModuleBase object contains the properties that are common to all Android
Colin Cross3f40fa42015-01-30 17:27:36 -0800552// modules. It should be included as an anonymous field in every module
553// struct definition. InitAndroidModule should then be called from the module's
554// factory function, and the return values from InitAndroidModule should be
555// returned from the factory function.
556//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800557// The ModuleBase type is responsible for implementing the GenerateBuildActions
558// method to support the blueprint.Module interface. This method will then call
559// the module's GenerateAndroidBuildActions method once for each build variant
Colin Cross25de6c32019-06-06 14:29:25 -0700560// that is to be built. GenerateAndroidBuildActions is passed a ModuleContext
561// rather than the usual blueprint.ModuleContext.
562// ModuleContext exposes extra functionality specific to the Android build
Colin Cross3f40fa42015-01-30 17:27:36 -0800563// system including details about the particular build variant that is to be
564// generated.
565//
566// For example:
567//
568// import (
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800569// "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -0800570// )
571//
572// type myModule struct {
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800573// android.ModuleBase
Colin Cross3f40fa42015-01-30 17:27:36 -0800574// properties struct {
575// MyProperty string
576// }
577// }
578//
Colin Cross36242852017-06-23 15:06:31 -0700579// func NewMyModule() android.Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800580// m := &myModule{}
Colin Cross36242852017-06-23 15:06:31 -0700581// m.AddProperties(&m.properties)
582// android.InitAndroidModule(m)
583// return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800584// }
585//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800586// func (m *myModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800587// // Get the CPU architecture for the current build variant.
588// variantArch := ctx.Arch()
589//
590// // ...
591// }
Colin Cross635c3b02016-05-18 15:37:25 -0700592type ModuleBase struct {
Colin Cross3f40fa42015-01-30 17:27:36 -0800593 // Putting the curiously recurring thing pointing to the thing that contains
594 // the thing pattern to good use.
Colin Cross36242852017-06-23 15:06:31 -0700595 // TODO: remove this
Colin Cross635c3b02016-05-18 15:37:25 -0700596 module Module
Colin Cross3f40fa42015-01-30 17:27:36 -0800597
Colin Crossfc754582016-05-17 16:34:16 -0700598 nameProperties nameProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800599 commonProperties commonProperties
Colin Cross7f64b6d2015-07-09 13:57:48 -0700600 variableProperties variableProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800601 hostAndDeviceProperties hostAndDeviceProperties
602 generalProperties []interface{}
Colin Crossc17727d2018-10-24 12:42:09 -0700603 archProperties [][]interface{}
Colin Crossa120ec12016-08-19 16:07:38 -0700604 customizableProperties []interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800605
Paul Duffin63c6e182019-07-24 14:24:38 +0100606 // Information about all the properties on the module that contains visibility rules that need
607 // checking.
608 visibilityPropertyInfo []visibilityProperty
609
610 // The primary visibility property, may be nil, that controls access to the module.
611 primaryVisibilityProperty visibilityProperty
612
Colin Cross3f40fa42015-01-30 17:27:36 -0800613 noAddressSanitizer bool
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700614 installFiles Paths
615 checkbuildFiles Paths
Jiyong Park52818fc2019-03-18 12:01:38 +0900616 noticeFile OptionalPath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700617
618 // Used by buildTargetSingleton to create checkbuild and per-directory build targets
619 // Only set on the final variant of each module
Colin Cross0875c522017-11-28 17:34:01 -0800620 installTarget WritablePath
621 checkbuildTarget WritablePath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700622 blueprintDir string
Colin Crossa120ec12016-08-19 16:07:38 -0700623
Colin Cross178a5092016-09-13 13:42:32 -0700624 hooks hooks
Colin Cross36242852017-06-23 15:06:31 -0700625
626 registerProps []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700627
628 // For tests
Colin Crossae887032017-10-23 17:16:14 -0700629 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800630 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800631 variables map[string]string
Colin Crossa9d8bee2018-10-02 13:59:46 -0700632
633 prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool
Colin Cross36242852017-06-23 15:06:31 -0700634}
635
Colin Cross4157e882019-06-06 16:57:04 -0700636func (m *ModuleBase) DepsMutator(BottomUpMutatorContext) {}
Colin Cross5f692ec2019-02-01 16:53:07 -0800637
Colin Cross4157e882019-06-06 16:57:04 -0700638func (m *ModuleBase) AddProperties(props ...interface{}) {
639 m.registerProps = append(m.registerProps, props...)
Colin Cross36242852017-06-23 15:06:31 -0700640}
641
Colin Cross4157e882019-06-06 16:57:04 -0700642func (m *ModuleBase) GetProperties() []interface{} {
643 return m.registerProps
Colin Cross3f40fa42015-01-30 17:27:36 -0800644}
645
Colin Cross4157e882019-06-06 16:57:04 -0700646func (m *ModuleBase) BuildParamsForTests() []BuildParams {
647 return m.buildParams
Colin Crosscec81712017-07-13 14:43:27 -0700648}
649
Colin Cross4157e882019-06-06 16:57:04 -0700650func (m *ModuleBase) RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams {
651 return m.ruleParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800652}
653
Colin Cross4157e882019-06-06 16:57:04 -0700654func (m *ModuleBase) VariablesForTests() map[string]string {
655 return m.variables
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800656}
657
Colin Cross4157e882019-06-06 16:57:04 -0700658func (m *ModuleBase) Prefer32(prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool) {
659 m.prefer32 = prefer32
Colin Crossa9d8bee2018-10-02 13:59:46 -0700660}
661
Colin Crossce75d2c2016-10-06 16:12:58 -0700662// Name returns the name of the module. It may be overridden by individual module types, for
663// example prebuilts will prepend prebuilt_ to the name.
Colin Cross4157e882019-06-06 16:57:04 -0700664func (m *ModuleBase) Name() string {
665 return String(m.nameProperties.Name)
Colin Crossfc754582016-05-17 16:34:16 -0700666}
667
Colin Cross9a362232019-07-01 15:32:45 -0700668// String returns a string that includes the module name and variants for printing during debugging.
669func (m *ModuleBase) String() string {
670 sb := strings.Builder{}
671 sb.WriteString(m.commonProperties.DebugName)
672 sb.WriteString("{")
673 for i := range m.commonProperties.DebugMutators {
674 if i != 0 {
675 sb.WriteString(",")
676 }
677 sb.WriteString(m.commonProperties.DebugMutators[i])
678 sb.WriteString(":")
679 sb.WriteString(m.commonProperties.DebugVariations[i])
680 }
681 sb.WriteString("}")
682 return sb.String()
683}
684
Colin Crossce75d2c2016-10-06 16:12:58 -0700685// BaseModuleName returns the name of the module as specified in the blueprints file.
Colin Cross4157e882019-06-06 16:57:04 -0700686func (m *ModuleBase) BaseModuleName() string {
687 return String(m.nameProperties.Name)
Colin Crossce75d2c2016-10-06 16:12:58 -0700688}
689
Colin Cross4157e882019-06-06 16:57:04 -0700690func (m *ModuleBase) base() *ModuleBase {
691 return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800692}
693
Paul Duffine2453c72019-05-31 14:00:04 +0100694func (m *ModuleBase) qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName {
695 return qualifiedModuleName{pkg: ctx.ModuleDir(), name: ctx.ModuleName()}
696}
697
698func (m *ModuleBase) visibilityProperties() []visibilityProperty {
Paul Duffin63c6e182019-07-24 14:24:38 +0100699 return m.visibilityPropertyInfo
700}
701
702func (m *ModuleBase) visibility() []string {
703 // The soong_namespace module does not initialize the primaryVisibilityProperty.
704 if m.primaryVisibilityProperty != nil {
705 return m.primaryVisibilityProperty.getStrings()
706 } else {
707 return nil
Paul Duffine2453c72019-05-31 14:00:04 +0100708 }
709}
710
Colin Cross4157e882019-06-06 16:57:04 -0700711func (m *ModuleBase) SetTarget(target Target, multiTargets []Target, primary bool) {
712 m.commonProperties.CompileTarget = target
713 m.commonProperties.CompileMultiTargets = multiTargets
714 m.commonProperties.CompilePrimary = primary
Colin Crossd3ba0392015-05-07 14:11:29 -0700715}
716
Colin Cross4157e882019-06-06 16:57:04 -0700717func (m *ModuleBase) Target() Target {
718 return m.commonProperties.CompileTarget
Dan Willemsen490fd492015-11-24 17:53:15 -0800719}
720
Colin Cross4157e882019-06-06 16:57:04 -0700721func (m *ModuleBase) TargetPrimary() bool {
722 return m.commonProperties.CompilePrimary
Colin Cross8b74d172016-09-13 09:59:14 -0700723}
724
Colin Cross4157e882019-06-06 16:57:04 -0700725func (m *ModuleBase) MultiTargets() []Target {
726 return m.commonProperties.CompileMultiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -0700727}
728
Colin Cross4157e882019-06-06 16:57:04 -0700729func (m *ModuleBase) Os() OsType {
730 return m.Target().Os
Dan Willemsen490fd492015-11-24 17:53:15 -0800731}
732
Colin Cross4157e882019-06-06 16:57:04 -0700733func (m *ModuleBase) Host() bool {
734 return m.Os().Class == Host || m.Os().Class == HostCross
Dan Willemsen97750522016-02-09 17:43:51 -0800735}
736
Colin Cross4157e882019-06-06 16:57:04 -0700737func (m *ModuleBase) Arch() Arch {
738 return m.Target().Arch
Dan Willemsen97750522016-02-09 17:43:51 -0800739}
740
Colin Cross4157e882019-06-06 16:57:04 -0700741func (m *ModuleBase) ArchSpecific() bool {
742 return m.commonProperties.ArchSpecific
Dan Willemsen0b24c742016-10-04 15:13:37 -0700743}
744
Colin Cross4157e882019-06-06 16:57:04 -0700745func (m *ModuleBase) OsClassSupported() []OsClass {
746 switch m.commonProperties.HostOrDeviceSupported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700747 case HostSupported:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700748 return []OsClass{Host, HostCross}
Dan Albertc6345fb2016-10-20 01:36:11 -0700749 case HostSupportedNoCross:
750 return []OsClass{Host}
Colin Crossa1ad8d12016-06-01 17:09:44 -0700751 case DeviceSupported:
752 return []OsClass{Device}
Dan Albert0981b5c2018-08-02 13:46:35 -0700753 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700754 var supported []OsClass
Colin Cross4157e882019-06-06 16:57:04 -0700755 if Bool(m.hostAndDeviceProperties.Host_supported) ||
756 (m.commonProperties.HostOrDeviceSupported == HostAndDeviceDefault &&
757 m.hostAndDeviceProperties.Host_supported == nil) {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700758 supported = append(supported, Host, HostCross)
759 }
Colin Cross4157e882019-06-06 16:57:04 -0700760 if m.hostAndDeviceProperties.Device_supported == nil ||
761 *m.hostAndDeviceProperties.Device_supported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700762 supported = append(supported, Device)
763 }
764 return supported
765 default:
766 return nil
767 }
Colin Cross3f40fa42015-01-30 17:27:36 -0800768}
769
Colin Cross4157e882019-06-06 16:57:04 -0700770func (m *ModuleBase) DeviceSupported() bool {
771 return m.commonProperties.HostOrDeviceSupported == DeviceSupported ||
772 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
773 (m.hostAndDeviceProperties.Device_supported == nil ||
774 *m.hostAndDeviceProperties.Device_supported)
Colin Cross3f40fa42015-01-30 17:27:36 -0800775}
776
Colin Cross4157e882019-06-06 16:57:04 -0700777func (m *ModuleBase) Platform() bool {
Justin Yund5f6c822019-06-25 16:47:17 +0900778 return !m.DeviceSpecific() && !m.SocSpecific() && !m.ProductSpecific() && !m.SystemExtSpecific()
Jiyong Parkc678ad32018-04-10 13:07:10 +0900779}
780
Colin Cross4157e882019-06-06 16:57:04 -0700781func (m *ModuleBase) DeviceSpecific() bool {
782 return Bool(m.commonProperties.Device_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900783}
784
Colin Cross4157e882019-06-06 16:57:04 -0700785func (m *ModuleBase) SocSpecific() bool {
786 return Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900787}
788
Colin Cross4157e882019-06-06 16:57:04 -0700789func (m *ModuleBase) ProductSpecific() bool {
790 return Bool(m.commonProperties.Product_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900791}
792
Justin Yund5f6c822019-06-25 16:47:17 +0900793func (m *ModuleBase) SystemExtSpecific() bool {
794 return Bool(m.commonProperties.System_ext_specific)
Dario Frenifd05a742018-05-29 13:28:54 +0100795}
796
Colin Cross4157e882019-06-06 16:57:04 -0700797func (m *ModuleBase) Enabled() bool {
798 if m.commonProperties.Enabled == nil {
799 return !m.Os().DefaultDisabled
Dan Willemsen490fd492015-11-24 17:53:15 -0800800 }
Colin Cross4157e882019-06-06 16:57:04 -0700801 return *m.commonProperties.Enabled
Colin Cross3f40fa42015-01-30 17:27:36 -0800802}
803
Colin Cross4157e882019-06-06 16:57:04 -0700804func (m *ModuleBase) SkipInstall() {
805 m.commonProperties.SkipInstall = true
Colin Crossce75d2c2016-10-06 16:12:58 -0700806}
807
Colin Cross4157e882019-06-06 16:57:04 -0700808func (m *ModuleBase) ExportedToMake() bool {
809 return m.commonProperties.NamespaceExportedToMake
Jiyong Park374510b2018-03-19 18:23:01 +0900810}
811
Colin Cross4157e882019-06-06 16:57:04 -0700812func (m *ModuleBase) computeInstallDeps(
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700813 ctx blueprint.ModuleContext) Paths {
Colin Cross3f40fa42015-01-30 17:27:36 -0800814
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700815 result := Paths{}
Colin Cross6b753602018-06-21 13:03:07 -0700816 // TODO(ccross): we need to use WalkDeps and have some way to know which dependencies require installation
Colin Cross3f40fa42015-01-30 17:27:36 -0800817 ctx.VisitDepsDepthFirstIf(isFileInstaller,
818 func(m blueprint.Module) {
819 fileInstaller := m.(fileInstaller)
820 files := fileInstaller.filesToInstall()
821 result = append(result, files...)
822 })
823
824 return result
825}
826
Colin Cross4157e882019-06-06 16:57:04 -0700827func (m *ModuleBase) filesToInstall() Paths {
828 return m.installFiles
Colin Cross3f40fa42015-01-30 17:27:36 -0800829}
830
Colin Cross4157e882019-06-06 16:57:04 -0700831func (m *ModuleBase) NoAddressSanitizer() bool {
832 return m.noAddressSanitizer
Colin Cross3f40fa42015-01-30 17:27:36 -0800833}
834
Colin Cross4157e882019-06-06 16:57:04 -0700835func (m *ModuleBase) InstallInData() bool {
Dan Willemsen782a2d12015-12-21 14:55:28 -0800836 return false
837}
838
Jaewoong Jung0949f312019-09-11 10:25:18 -0700839func (m *ModuleBase) InstallInTestcases() bool {
840 return false
841}
842
Colin Cross4157e882019-06-06 16:57:04 -0700843func (m *ModuleBase) InstallInSanitizerDir() bool {
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700844 return false
845}
846
Colin Cross4157e882019-06-06 16:57:04 -0700847func (m *ModuleBase) InstallInRecovery() bool {
848 return Bool(m.commonProperties.Recovery)
Jiyong Parkf9332f12018-02-01 00:54:12 +0900849}
850
Colin Cross90ba5f42019-10-02 11:10:58 -0700851func (m *ModuleBase) InstallInRoot() bool {
852 return false
853}
854
Colin Cross607d8582019-07-29 16:44:46 -0700855func (m *ModuleBase) InstallBypassMake() bool {
856 return false
857}
858
Colin Cross4157e882019-06-06 16:57:04 -0700859func (m *ModuleBase) Owner() string {
860 return String(m.commonProperties.Owner)
Sundong Ahn4fd04bb2018-08-31 18:01:37 +0900861}
862
Colin Cross4157e882019-06-06 16:57:04 -0700863func (m *ModuleBase) NoticeFile() OptionalPath {
864 return m.noticeFile
Jiyong Park52818fc2019-03-18 12:01:38 +0900865}
866
Colin Cross4157e882019-06-06 16:57:04 -0700867func (m *ModuleBase) generateModuleTarget(ctx ModuleContext) {
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700868 allInstalledFiles := Paths{}
869 allCheckbuildFiles := Paths{}
Colin Cross0875c522017-11-28 17:34:01 -0800870 ctx.VisitAllModuleVariants(func(module Module) {
871 a := module.base()
Colin Crossc9404352015-03-26 16:10:12 -0700872 allInstalledFiles = append(allInstalledFiles, a.installFiles...)
873 allCheckbuildFiles = append(allCheckbuildFiles, a.checkbuildFiles...)
Colin Cross3f40fa42015-01-30 17:27:36 -0800874 })
875
Colin Cross0875c522017-11-28 17:34:01 -0800876 var deps Paths
Colin Cross9454bfa2015-03-17 13:24:18 -0700877
Jeff Gaston088e29e2017-11-29 16:47:17 -0800878 namespacePrefix := ctx.Namespace().(*Namespace).id
879 if namespacePrefix != "" {
880 namespacePrefix = namespacePrefix + "-"
881 }
882
Colin Cross3f40fa42015-01-30 17:27:36 -0800883 if len(allInstalledFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -0800884 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-install")
Colin Cross0875c522017-11-28 17:34:01 -0800885 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -0700886 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -0800887 Output: name,
888 Implicits: allInstalledFiles,
Colin Crossaabf6792017-11-29 00:27:14 -0800889 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross9454bfa2015-03-17 13:24:18 -0700890 })
891 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -0700892 m.installTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -0700893 }
894
895 if len(allCheckbuildFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -0800896 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-checkbuild")
Colin Cross0875c522017-11-28 17:34:01 -0800897 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -0700898 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -0800899 Output: name,
900 Implicits: allCheckbuildFiles,
Colin Cross9454bfa2015-03-17 13:24:18 -0700901 })
902 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -0700903 m.checkbuildTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -0700904 }
905
906 if len(deps) > 0 {
Dan Willemsen5ba07e82015-12-11 13:51:06 -0800907 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -0800908 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -0800909 suffix = "-soong"
910 }
911
Jeff Gaston088e29e2017-11-29 16:47:17 -0800912 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+suffix)
Colin Cross0875c522017-11-28 17:34:01 -0800913 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -0700914 Rule: blueprint.Phony,
Jeff Gaston088e29e2017-11-29 16:47:17 -0800915 Outputs: []WritablePath{name},
Colin Cross9454bfa2015-03-17 13:24:18 -0700916 Implicits: deps,
Colin Cross3f40fa42015-01-30 17:27:36 -0800917 })
Colin Cross1f8c52b2015-06-16 16:38:17 -0700918
Colin Cross4157e882019-06-06 16:57:04 -0700919 m.blueprintDir = ctx.ModuleDir()
Colin Cross3f40fa42015-01-30 17:27:36 -0800920 }
921}
922
Colin Cross4157e882019-06-06 16:57:04 -0700923func determineModuleKind(m *ModuleBase, ctx blueprint.BaseModuleContext) moduleKind {
924 var socSpecific = Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
925 var deviceSpecific = Bool(m.commonProperties.Device_specific)
926 var productSpecific = Bool(m.commonProperties.Product_specific)
Justin Yund5f6c822019-06-25 16:47:17 +0900927 var systemExtSpecific = Bool(m.commonProperties.System_ext_specific)
Jiyong Park2db76922017-11-08 16:03:48 +0900928
Dario Frenifd05a742018-05-29 13:28:54 +0100929 msg := "conflicting value set here"
930 if socSpecific && deviceSpecific {
931 ctx.PropertyErrorf("device_specific", "a module cannot be specific to SoC and device at the same time.")
Colin Cross4157e882019-06-06 16:57:04 -0700932 if Bool(m.commonProperties.Vendor) {
Jiyong Park2db76922017-11-08 16:03:48 +0900933 ctx.PropertyErrorf("vendor", msg)
934 }
Colin Cross4157e882019-06-06 16:57:04 -0700935 if Bool(m.commonProperties.Proprietary) {
Jiyong Park2db76922017-11-08 16:03:48 +0900936 ctx.PropertyErrorf("proprietary", msg)
937 }
Colin Cross4157e882019-06-06 16:57:04 -0700938 if Bool(m.commonProperties.Soc_specific) {
Jiyong Park2db76922017-11-08 16:03:48 +0900939 ctx.PropertyErrorf("soc_specific", msg)
940 }
941 }
942
Justin Yund5f6c822019-06-25 16:47:17 +0900943 if productSpecific && systemExtSpecific {
944 ctx.PropertyErrorf("product_specific", "a module cannot be specific to product and system_ext at the same time.")
945 ctx.PropertyErrorf("system_ext_specific", msg)
Dario Frenifd05a742018-05-29 13:28:54 +0100946 }
947
Justin Yund5f6c822019-06-25 16:47:17 +0900948 if (socSpecific || deviceSpecific) && (productSpecific || systemExtSpecific) {
Dario Frenifd05a742018-05-29 13:28:54 +0100949 if productSpecific {
950 ctx.PropertyErrorf("product_specific", "a module cannot be specific to SoC or device and product at the same time.")
951 } else {
Justin Yund5f6c822019-06-25 16:47:17 +0900952 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 +0100953 }
954 if deviceSpecific {
955 ctx.PropertyErrorf("device_specific", msg)
956 } else {
Colin Cross4157e882019-06-06 16:57:04 -0700957 if Bool(m.commonProperties.Vendor) {
Dario Frenifd05a742018-05-29 13:28:54 +0100958 ctx.PropertyErrorf("vendor", msg)
959 }
Colin Cross4157e882019-06-06 16:57:04 -0700960 if Bool(m.commonProperties.Proprietary) {
Dario Frenifd05a742018-05-29 13:28:54 +0100961 ctx.PropertyErrorf("proprietary", msg)
962 }
Colin Cross4157e882019-06-06 16:57:04 -0700963 if Bool(m.commonProperties.Soc_specific) {
Dario Frenifd05a742018-05-29 13:28:54 +0100964 ctx.PropertyErrorf("soc_specific", msg)
965 }
966 }
967 }
968
Jiyong Park2db76922017-11-08 16:03:48 +0900969 if productSpecific {
970 return productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900971 } else if systemExtSpecific {
972 return systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900973 } else if deviceSpecific {
974 return deviceSpecificModule
975 } else if socSpecific {
976 return socSpecificModule
977 } else {
978 return platformModule
979 }
980}
981
Colin Cross0ea8ba82019-06-06 14:33:29 -0700982func (m *ModuleBase) baseModuleContextFactory(ctx blueprint.BaseModuleContext) baseModuleContext {
983 return baseModuleContext{
984 BaseModuleContext: ctx,
985 target: m.commonProperties.CompileTarget,
986 targetPrimary: m.commonProperties.CompilePrimary,
987 multiTargets: m.commonProperties.CompileMultiTargets,
988 kind: determineModuleKind(m, ctx),
989 config: ctx.Config().(Config),
Colin Cross3f40fa42015-01-30 17:27:36 -0800990 }
Colin Cross3f40fa42015-01-30 17:27:36 -0800991}
992
Colin Cross4157e882019-06-06 16:57:04 -0700993func (m *ModuleBase) GenerateBuildActions(blueprintCtx blueprint.ModuleContext) {
Colin Cross25de6c32019-06-06 14:29:25 -0700994 ctx := &moduleContext{
Colin Cross0ea8ba82019-06-06 14:33:29 -0700995 module: m.module,
Colin Crossdc35e212019-06-06 16:13:11 -0700996 bp: blueprintCtx,
Colin Cross0ea8ba82019-06-06 14:33:29 -0700997 baseModuleContext: m.baseModuleContextFactory(blueprintCtx),
998 installDeps: m.computeInstallDeps(blueprintCtx),
999 installFiles: m.installFiles,
Colin Cross0ea8ba82019-06-06 14:33:29 -07001000 variables: make(map[string]string),
Colin Cross3f40fa42015-01-30 17:27:36 -08001001 }
1002
Colin Cross6c4f21f2019-06-06 15:41:36 -07001003 // Temporarily continue to call blueprintCtx.GetMissingDependencies() to maintain the previous behavior of never
1004 // reporting missing dependency errors in Blueprint when AllowMissingDependencies == true.
1005 // TODO: This will be removed once defaults modules handle missing dependency errors
1006 blueprintCtx.GetMissingDependencies()
1007
Colin Crossdc35e212019-06-06 16:13:11 -07001008 // For the final GenerateAndroidBuildActions pass, require that all visited dependencies Soong modules and
1009 // are enabled.
1010 ctx.baseModuleContext.strictVisitDeps = true
1011
Colin Cross4c83e5c2019-02-25 14:54:28 -08001012 if ctx.config.captureBuild {
1013 ctx.ruleParams = make(map[blueprint.Rule]blueprint.RuleParams)
1014 }
1015
Colin Cross67a5c132017-05-09 13:45:28 -07001016 desc := "//" + ctx.ModuleDir() + ":" + ctx.ModuleName() + " "
1017 var suffix []string
Colin Cross0875c522017-11-28 17:34:01 -08001018 if ctx.Os().Class != Device && ctx.Os().Class != Generic {
1019 suffix = append(suffix, ctx.Os().String())
Colin Cross67a5c132017-05-09 13:45:28 -07001020 }
Colin Cross0875c522017-11-28 17:34:01 -08001021 if !ctx.PrimaryArch() {
1022 suffix = append(suffix, ctx.Arch().ArchType.String())
Colin Cross67a5c132017-05-09 13:45:28 -07001023 }
1024
1025 ctx.Variable(pctx, "moduleDesc", desc)
1026
1027 s := ""
1028 if len(suffix) > 0 {
1029 s = " [" + strings.Join(suffix, " ") + "]"
1030 }
1031 ctx.Variable(pctx, "moduleDescSuffix", s)
1032
Dan Willemsen569edc52018-11-19 09:33:29 -08001033 // Some common property checks for properties that will be used later in androidmk.go
Colin Cross4157e882019-06-06 16:57:04 -07001034 if m.commonProperties.Dist.Dest != nil {
1035 _, err := validateSafePath(*m.commonProperties.Dist.Dest)
Dan Willemsen569edc52018-11-19 09:33:29 -08001036 if err != nil {
1037 ctx.PropertyErrorf("dist.dest", "%s", err.Error())
1038 }
1039 }
Colin Cross4157e882019-06-06 16:57:04 -07001040 if m.commonProperties.Dist.Dir != nil {
1041 _, err := validateSafePath(*m.commonProperties.Dist.Dir)
Dan Willemsen569edc52018-11-19 09:33:29 -08001042 if err != nil {
1043 ctx.PropertyErrorf("dist.dir", "%s", err.Error())
1044 }
1045 }
Colin Cross4157e882019-06-06 16:57:04 -07001046 if m.commonProperties.Dist.Suffix != nil {
1047 if strings.Contains(*m.commonProperties.Dist.Suffix, "/") {
Dan Willemsen569edc52018-11-19 09:33:29 -08001048 ctx.PropertyErrorf("dist.suffix", "Suffix may not contain a '/' character.")
1049 }
1050 }
1051
Colin Cross4157e882019-06-06 16:57:04 -07001052 if m.Enabled() {
Jooyung Hand48f3c32019-08-23 11:18:57 +09001053 // ensure all direct android.Module deps are enabled
1054 ctx.VisitDirectDepsBlueprint(func(bm blueprint.Module) {
1055 if _, ok := bm.(Module); ok {
1056 ctx.validateAndroidModule(bm, ctx.baseModuleContext.strictVisitDeps)
1057 }
1058 })
1059
Colin Cross4157e882019-06-06 16:57:04 -07001060 notice := proptools.StringDefault(m.commonProperties.Notice, "NOTICE")
1061 if module := SrcIsModule(notice); module != "" {
1062 m.noticeFile = ctx.ExpandOptionalSource(&notice, "notice")
Jiyong Park52818fc2019-03-18 12:01:38 +09001063 } else {
1064 noticePath := filepath.Join(ctx.ModuleDir(), notice)
Colin Cross4157e882019-06-06 16:57:04 -07001065 m.noticeFile = ExistentPathForSource(ctx, noticePath)
Jaewoong Jung62707f72018-11-16 13:26:43 -08001066 }
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001067
1068 m.module.GenerateAndroidBuildActions(ctx)
1069 if ctx.Failed() {
1070 return
1071 }
1072
1073 m.installFiles = append(m.installFiles, ctx.installFiles...)
1074 m.checkbuildFiles = append(m.checkbuildFiles, ctx.checkbuildFiles...)
Colin Crossdc35e212019-06-06 16:13:11 -07001075 } else if ctx.Config().AllowMissingDependencies() {
1076 // If the module is not enabled it will not create any build rules, nothing will call
1077 // ctx.GetMissingDependencies(), and blueprint will consider the missing dependencies to be unhandled
1078 // and report them as an error even when AllowMissingDependencies = true. Call
1079 // ctx.GetMissingDependencies() here to tell blueprint not to handle them.
1080 ctx.GetMissingDependencies()
Colin Cross3f40fa42015-01-30 17:27:36 -08001081 }
1082
Colin Cross4157e882019-06-06 16:57:04 -07001083 if m == ctx.FinalModule().(Module).base() {
1084 m.generateModuleTarget(ctx)
Colin Cross9b1d13d2016-09-19 15:18:11 -07001085 if ctx.Failed() {
1086 return
1087 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001088 }
Colin Crosscec81712017-07-13 14:43:27 -07001089
Colin Cross4157e882019-06-06 16:57:04 -07001090 m.buildParams = ctx.buildParams
1091 m.ruleParams = ctx.ruleParams
1092 m.variables = ctx.variables
Colin Cross3f40fa42015-01-30 17:27:36 -08001093}
1094
Colin Cross0ea8ba82019-06-06 14:33:29 -07001095type baseModuleContext struct {
1096 blueprint.BaseModuleContext
Colin Cross8b74d172016-09-13 09:59:14 -07001097 target Target
Colin Crossee0bc3b2018-10-02 22:01:37 -07001098 multiTargets []Target
Colin Cross8b74d172016-09-13 09:59:14 -07001099 targetPrimary bool
1100 debug bool
Jiyong Park2db76922017-11-08 16:03:48 +09001101 kind moduleKind
Colin Cross8b74d172016-09-13 09:59:14 -07001102 config Config
Colin Crossdc35e212019-06-06 16:13:11 -07001103
1104 walkPath []Module
1105
1106 strictVisitDeps bool // If true, enforce that all dependencies are enabled
Colin Crossf6566ed2015-03-24 11:13:38 -07001107}
1108
Colin Cross25de6c32019-06-06 14:29:25 -07001109type moduleContext struct {
Colin Crossdc35e212019-06-06 16:13:11 -07001110 bp blueprint.ModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -07001111 baseModuleContext
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001112 installDeps Paths
1113 installFiles Paths
1114 checkbuildFiles Paths
Colin Cross8d8f8e22016-08-03 11:57:50 -07001115 module Module
Colin Crosscec81712017-07-13 14:43:27 -07001116
1117 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001118 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001119 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001120 variables map[string]string
Colin Cross6ff51382015-12-17 16:39:19 -08001121}
1122
Colin Crossb88b3c52019-06-10 15:15:17 -07001123func (m *moduleContext) ninjaError(params BuildParams, err error) (PackageContext, BuildParams) {
1124 return pctx, BuildParams{
Colin Cross4b69c492019-06-07 13:06:06 -07001125 Rule: ErrorRule,
1126 Description: params.Description,
1127 Output: params.Output,
1128 Outputs: params.Outputs,
1129 ImplicitOutput: params.ImplicitOutput,
1130 ImplicitOutputs: params.ImplicitOutputs,
Colin Cross6ff51382015-12-17 16:39:19 -08001131 Args: map[string]string{
1132 "error": err.Error(),
1133 },
Colin Crossb88b3c52019-06-10 15:15:17 -07001134 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001135}
1136
Colin Cross25de6c32019-06-06 14:29:25 -07001137func (m *moduleContext) ModuleBuild(pctx PackageContext, params ModuleBuildParams) {
1138 m.Build(pctx, BuildParams(params))
Colin Cross3f40fa42015-01-30 17:27:36 -08001139}
1140
Colin Cross0875c522017-11-28 17:34:01 -08001141func convertBuildParams(params BuildParams) blueprint.BuildParams {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001142 bparams := blueprint.BuildParams{
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001143 Rule: params.Rule,
Colin Cross0875c522017-11-28 17:34:01 -08001144 Description: params.Description,
Colin Cross33bfb0a2016-11-21 17:23:08 -08001145 Deps: params.Deps,
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001146 Outputs: params.Outputs.Strings(),
1147 ImplicitOutputs: params.ImplicitOutputs.Strings(),
1148 Inputs: params.Inputs.Strings(),
1149 Implicits: params.Implicits.Strings(),
1150 OrderOnly: params.OrderOnly.Strings(),
1151 Args: params.Args,
1152 Optional: !params.Default,
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001153 }
1154
Colin Cross33bfb0a2016-11-21 17:23:08 -08001155 if params.Depfile != nil {
1156 bparams.Depfile = params.Depfile.String()
1157 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001158 if params.Output != nil {
1159 bparams.Outputs = append(bparams.Outputs, params.Output.String())
1160 }
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001161 if params.ImplicitOutput != nil {
1162 bparams.ImplicitOutputs = append(bparams.ImplicitOutputs, params.ImplicitOutput.String())
1163 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001164 if params.Input != nil {
1165 bparams.Inputs = append(bparams.Inputs, params.Input.String())
1166 }
1167 if params.Implicit != nil {
1168 bparams.Implicits = append(bparams.Implicits, params.Implicit.String())
1169 }
1170
Colin Cross0b9f31f2019-02-28 11:00:01 -08001171 bparams.Outputs = proptools.NinjaEscapeList(bparams.Outputs)
1172 bparams.ImplicitOutputs = proptools.NinjaEscapeList(bparams.ImplicitOutputs)
1173 bparams.Inputs = proptools.NinjaEscapeList(bparams.Inputs)
1174 bparams.Implicits = proptools.NinjaEscapeList(bparams.Implicits)
1175 bparams.OrderOnly = proptools.NinjaEscapeList(bparams.OrderOnly)
1176 bparams.Depfile = proptools.NinjaEscapeList([]string{bparams.Depfile})[0]
Colin Crossfe4bc362018-09-12 10:02:13 -07001177
Colin Cross0875c522017-11-28 17:34:01 -08001178 return bparams
1179}
1180
Colin Cross25de6c32019-06-06 14:29:25 -07001181func (m *moduleContext) Variable(pctx PackageContext, name, value string) {
1182 if m.config.captureBuild {
1183 m.variables[name] = value
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001184 }
1185
Colin Crossdc35e212019-06-06 16:13:11 -07001186 m.bp.Variable(pctx.PackageContext, name, value)
Colin Cross0875c522017-11-28 17:34:01 -08001187}
1188
Colin Cross25de6c32019-06-06 14:29:25 -07001189func (m *moduleContext) Rule(pctx PackageContext, name string, params blueprint.RuleParams,
Colin Cross0875c522017-11-28 17:34:01 -08001190 argNames ...string) blueprint.Rule {
1191
Colin Crossdc35e212019-06-06 16:13:11 -07001192 rule := m.bp.Rule(pctx.PackageContext, name, params, argNames...)
Colin Cross4c83e5c2019-02-25 14:54:28 -08001193
Colin Cross25de6c32019-06-06 14:29:25 -07001194 if m.config.captureBuild {
1195 m.ruleParams[rule] = params
Colin Cross4c83e5c2019-02-25 14:54:28 -08001196 }
1197
1198 return rule
Colin Cross0875c522017-11-28 17:34:01 -08001199}
1200
Colin Cross25de6c32019-06-06 14:29:25 -07001201func (m *moduleContext) Build(pctx PackageContext, params BuildParams) {
Colin Crossb88b3c52019-06-10 15:15:17 -07001202 if params.Description != "" {
1203 params.Description = "${moduleDesc}" + params.Description + "${moduleDescSuffix}"
1204 }
1205
1206 if missingDeps := m.GetMissingDependencies(); len(missingDeps) > 0 {
1207 pctx, params = m.ninjaError(params, fmt.Errorf("module %s missing dependencies: %s\n",
1208 m.ModuleName(), strings.Join(missingDeps, ", ")))
1209 }
1210
Colin Cross25de6c32019-06-06 14:29:25 -07001211 if m.config.captureBuild {
1212 m.buildParams = append(m.buildParams, params)
Colin Cross0875c522017-11-28 17:34:01 -08001213 }
1214
Colin Crossdc35e212019-06-06 16:13:11 -07001215 m.bp.Build(pctx.PackageContext, convertBuildParams(params))
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001216}
1217
Colin Crossdc35e212019-06-06 16:13:11 -07001218func (b *baseModuleContext) Module() Module {
1219 module, _ := b.BaseModuleContext.Module().(Module)
1220 return module
1221}
1222
1223func (b *baseModuleContext) Config() Config {
1224 return b.BaseModuleContext.Config().(Config)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001225}
1226
Colin Cross25de6c32019-06-06 14:29:25 -07001227func (m *moduleContext) GetMissingDependencies() []string {
Colin Cross6c4f21f2019-06-06 15:41:36 -07001228 var missingDeps []string
1229 missingDeps = append(missingDeps, m.Module().base().commonProperties.MissingDeps...)
Colin Crossdc35e212019-06-06 16:13:11 -07001230 missingDeps = append(missingDeps, m.bp.GetMissingDependencies()...)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001231 missingDeps = FirstUniqueStrings(missingDeps)
1232 return missingDeps
Colin Cross6ff51382015-12-17 16:39:19 -08001233}
1234
Colin Crossdc35e212019-06-06 16:13:11 -07001235func (b *baseModuleContext) AddMissingDependencies(deps []string) {
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001236 if deps != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001237 missingDeps := &b.Module().base().commonProperties.MissingDeps
Colin Cross6c4f21f2019-06-06 15:41:36 -07001238 *missingDeps = append(*missingDeps, deps...)
1239 *missingDeps = FirstUniqueStrings(*missingDeps)
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001240 }
1241}
1242
Colin Crossdc35e212019-06-06 16:13:11 -07001243func (b *baseModuleContext) validateAndroidModule(module blueprint.Module, strict bool) Module {
Colin Crossd11fcda2017-10-23 17:59:01 -07001244 aModule, _ := module.(Module)
Colin Crossdc35e212019-06-06 16:13:11 -07001245
1246 if !strict {
1247 return aModule
1248 }
1249
Colin Cross380c69a2019-06-10 17:49:58 +00001250 if aModule == nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001251 b.ModuleErrorf("module %q not an android module", b.OtherModuleName(module))
Colin Cross380c69a2019-06-10 17:49:58 +00001252 return nil
1253 }
1254
1255 if !aModule.Enabled() {
Colin Crossdc35e212019-06-06 16:13:11 -07001256 if b.Config().AllowMissingDependencies() {
1257 b.AddMissingDependencies([]string{b.OtherModuleName(aModule)})
Colin Cross380c69a2019-06-10 17:49:58 +00001258 } else {
Colin Crossdc35e212019-06-06 16:13:11 -07001259 b.ModuleErrorf("depends on disabled module %q", b.OtherModuleName(aModule))
Colin Cross380c69a2019-06-10 17:49:58 +00001260 }
1261 return nil
1262 }
Colin Crossd11fcda2017-10-23 17:59:01 -07001263 return aModule
1264}
1265
Colin Crossdc35e212019-06-06 16:13:11 -07001266func (b *baseModuleContext) getDirectDepInternal(name string, tag blueprint.DependencyTag) (blueprint.Module, blueprint.DependencyTag) {
Jiyong Parkf2976302019-04-17 21:47:37 +09001267 type dep struct {
1268 mod blueprint.Module
1269 tag blueprint.DependencyTag
1270 }
1271 var deps []dep
Colin Crossdc35e212019-06-06 16:13:11 -07001272 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001273 if aModule, _ := module.(Module); aModule != nil && aModule.base().BaseModuleName() == name {
Colin Crossdc35e212019-06-06 16:13:11 -07001274 returnedTag := b.BaseModuleContext.OtherModuleDependencyTag(aModule)
Jiyong Parkf2976302019-04-17 21:47:37 +09001275 if tag == nil || returnedTag == tag {
1276 deps = append(deps, dep{aModule, returnedTag})
1277 }
1278 }
1279 })
1280 if len(deps) == 1 {
1281 return deps[0].mod, deps[0].tag
1282 } else if len(deps) >= 2 {
1283 panic(fmt.Errorf("Multiple dependencies having same BaseModuleName() %q found from %q",
Colin Crossdc35e212019-06-06 16:13:11 -07001284 name, b.ModuleName()))
Jiyong Parkf2976302019-04-17 21:47:37 +09001285 } else {
1286 return nil, nil
1287 }
1288}
1289
Colin Crossdc35e212019-06-06 16:13:11 -07001290func (b *baseModuleContext) GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module {
Colin Cross0ef08162019-05-01 15:50:51 -07001291 var deps []Module
Colin Crossdc35e212019-06-06 16:13:11 -07001292 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001293 if aModule, _ := module.(Module); aModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001294 if b.BaseModuleContext.OtherModuleDependencyTag(aModule) == tag {
Colin Cross0ef08162019-05-01 15:50:51 -07001295 deps = append(deps, aModule)
1296 }
1297 }
1298 })
1299 return deps
1300}
1301
Colin Cross25de6c32019-06-06 14:29:25 -07001302func (m *moduleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1303 module, _ := m.getDirectDepInternal(name, tag)
1304 return module
Jiyong Parkf2976302019-04-17 21:47:37 +09001305}
1306
Colin Crossdc35e212019-06-06 16:13:11 -07001307func (b *baseModuleContext) GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag) {
1308 return b.getDirectDepInternal(name, nil)
Jiyong Parkf2976302019-04-17 21:47:37 +09001309}
1310
Colin Crossdc35e212019-06-06 16:13:11 -07001311func (b *baseModuleContext) VisitDirectDepsBlueprint(visit func(blueprint.Module)) {
1312 b.BaseModuleContext.VisitDirectDeps(visit)
Colin Cross35143d02017-11-16 00:11:20 -08001313}
1314
Colin Crossdc35e212019-06-06 16:13:11 -07001315func (b *baseModuleContext) VisitDirectDeps(visit func(Module)) {
1316 b.BaseModuleContext.VisitDirectDeps(func(module blueprint.Module) {
1317 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001318 visit(aModule)
1319 }
1320 })
1321}
1322
Colin Crossdc35e212019-06-06 16:13:11 -07001323func (b *baseModuleContext) VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module)) {
1324 b.BaseModuleContext.VisitDirectDeps(func(module blueprint.Module) {
1325 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
1326 if b.BaseModuleContext.OtherModuleDependencyTag(aModule) == tag {
Colin Crossee6143c2017-12-30 17:54:27 -08001327 visit(aModule)
1328 }
1329 }
1330 })
1331}
1332
Colin Crossdc35e212019-06-06 16:13:11 -07001333func (b *baseModuleContext) VisitDirectDepsIf(pred func(Module) bool, visit func(Module)) {
1334 b.BaseModuleContext.VisitDirectDepsIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001335 // pred
1336 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001337 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001338 return pred(aModule)
1339 } else {
1340 return false
1341 }
1342 },
1343 // visit
1344 func(module blueprint.Module) {
1345 visit(module.(Module))
1346 })
1347}
1348
Colin Crossdc35e212019-06-06 16:13:11 -07001349func (b *baseModuleContext) VisitDepsDepthFirst(visit func(Module)) {
1350 b.BaseModuleContext.VisitDepsDepthFirst(func(module blueprint.Module) {
1351 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001352 visit(aModule)
1353 }
1354 })
1355}
1356
Colin Crossdc35e212019-06-06 16:13:11 -07001357func (b *baseModuleContext) VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module)) {
1358 b.BaseModuleContext.VisitDepsDepthFirstIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001359 // pred
1360 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001361 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001362 return pred(aModule)
1363 } else {
1364 return false
1365 }
1366 },
1367 // visit
1368 func(module blueprint.Module) {
1369 visit(module.(Module))
1370 })
1371}
1372
Colin Crossdc35e212019-06-06 16:13:11 -07001373func (b *baseModuleContext) WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool) {
1374 b.BaseModuleContext.WalkDeps(visit)
Alex Light778127a2019-02-27 14:19:50 -08001375}
1376
Colin Crossdc35e212019-06-06 16:13:11 -07001377func (b *baseModuleContext) WalkDeps(visit func(Module, Module) bool) {
1378 b.walkPath = []Module{b.Module()}
1379 b.BaseModuleContext.WalkDeps(func(child, parent blueprint.Module) bool {
1380 childAndroidModule, _ := child.(Module)
1381 parentAndroidModule, _ := parent.(Module)
Colin Crossd11fcda2017-10-23 17:59:01 -07001382 if childAndroidModule != nil && parentAndroidModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001383 // record walkPath before visit
1384 for b.walkPath[len(b.walkPath)-1] != parentAndroidModule {
1385 b.walkPath = b.walkPath[0 : len(b.walkPath)-1]
1386 }
1387 b.walkPath = append(b.walkPath, childAndroidModule)
Colin Crossd11fcda2017-10-23 17:59:01 -07001388 return visit(childAndroidModule, parentAndroidModule)
1389 } else {
1390 return false
1391 }
1392 })
1393}
1394
Colin Crossdc35e212019-06-06 16:13:11 -07001395func (b *baseModuleContext) GetWalkPath() []Module {
1396 return b.walkPath
1397}
1398
Colin Cross25de6c32019-06-06 14:29:25 -07001399func (m *moduleContext) VisitAllModuleVariants(visit func(Module)) {
Colin Crossdc35e212019-06-06 16:13:11 -07001400 m.bp.VisitAllModuleVariants(func(module blueprint.Module) {
Colin Cross0875c522017-11-28 17:34:01 -08001401 visit(module.(Module))
1402 })
1403}
1404
Colin Cross25de6c32019-06-06 14:29:25 -07001405func (m *moduleContext) PrimaryModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001406 return m.bp.PrimaryModule().(Module)
Colin Cross0875c522017-11-28 17:34:01 -08001407}
1408
Colin Cross25de6c32019-06-06 14:29:25 -07001409func (m *moduleContext) FinalModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001410 return m.bp.FinalModule().(Module)
1411}
1412
1413func (m *moduleContext) ModuleSubDir() string {
1414 return m.bp.ModuleSubDir()
Colin Cross0875c522017-11-28 17:34:01 -08001415}
1416
Colin Cross0ea8ba82019-06-06 14:33:29 -07001417func (b *baseModuleContext) Target() Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001418 return b.target
Colin Crossa1ad8d12016-06-01 17:09:44 -07001419}
1420
Colin Cross0ea8ba82019-06-06 14:33:29 -07001421func (b *baseModuleContext) TargetPrimary() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001422 return b.targetPrimary
Colin Cross8b74d172016-09-13 09:59:14 -07001423}
1424
Colin Cross0ea8ba82019-06-06 14:33:29 -07001425func (b *baseModuleContext) MultiTargets() []Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001426 return b.multiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07001427}
1428
Colin Cross0ea8ba82019-06-06 14:33:29 -07001429func (b *baseModuleContext) Arch() Arch {
Colin Cross25de6c32019-06-06 14:29:25 -07001430 return b.target.Arch
Colin Cross3f40fa42015-01-30 17:27:36 -08001431}
1432
Colin Cross0ea8ba82019-06-06 14:33:29 -07001433func (b *baseModuleContext) Os() OsType {
Colin Cross25de6c32019-06-06 14:29:25 -07001434 return b.target.Os
Dan Willemsen490fd492015-11-24 17:53:15 -08001435}
1436
Colin Cross0ea8ba82019-06-06 14:33:29 -07001437func (b *baseModuleContext) Host() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001438 return b.target.Os.Class == Host || b.target.Os.Class == HostCross
Colin Crossf6566ed2015-03-24 11:13:38 -07001439}
1440
Colin Cross0ea8ba82019-06-06 14:33:29 -07001441func (b *baseModuleContext) Device() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001442 return b.target.Os.Class == Device
Colin Crossf6566ed2015-03-24 11:13:38 -07001443}
1444
Colin Cross0ea8ba82019-06-06 14:33:29 -07001445func (b *baseModuleContext) Darwin() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001446 return b.target.Os == Darwin
Colin Cross0af4b842015-04-30 16:36:18 -07001447}
1448
Colin Cross0ea8ba82019-06-06 14:33:29 -07001449func (b *baseModuleContext) Fuchsia() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001450 return b.target.Os == Fuchsia
Doug Horn21b94272019-01-16 12:06:11 -08001451}
1452
Colin Cross0ea8ba82019-06-06 14:33:29 -07001453func (b *baseModuleContext) Windows() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001454 return b.target.Os == Windows
Colin Cross3edeee12017-04-04 12:59:48 -07001455}
1456
Colin Cross0ea8ba82019-06-06 14:33:29 -07001457func (b *baseModuleContext) Debug() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001458 return b.debug
Colin Crossf6566ed2015-03-24 11:13:38 -07001459}
1460
Colin Cross0ea8ba82019-06-06 14:33:29 -07001461func (b *baseModuleContext) PrimaryArch() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001462 if len(b.config.Targets[b.target.Os]) <= 1 {
Colin Cross67a5c132017-05-09 13:45:28 -07001463 return true
1464 }
Colin Cross25de6c32019-06-06 14:29:25 -07001465 return b.target.Arch.ArchType == b.config.Targets[b.target.Os][0].Arch.ArchType
Colin Cross1e7d3702016-08-24 15:25:47 -07001466}
1467
Colin Cross0ea8ba82019-06-06 14:33:29 -07001468func (b *baseModuleContext) AConfig() Config {
Colin Cross25de6c32019-06-06 14:29:25 -07001469 return b.config
Colin Cross1332b002015-04-07 17:11:30 -07001470}
1471
Colin Cross0ea8ba82019-06-06 14:33:29 -07001472func (b *baseModuleContext) DeviceConfig() DeviceConfig {
Colin Cross25de6c32019-06-06 14:29:25 -07001473 return DeviceConfig{b.config.deviceConfig}
Colin Cross9272ade2016-08-17 15:24:12 -07001474}
1475
Colin Cross0ea8ba82019-06-06 14:33:29 -07001476func (b *baseModuleContext) Platform() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001477 return b.kind == platformModule
Jiyong Park2db76922017-11-08 16:03:48 +09001478}
1479
Colin Cross0ea8ba82019-06-06 14:33:29 -07001480func (b *baseModuleContext) DeviceSpecific() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001481 return b.kind == deviceSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001482}
1483
Colin Cross0ea8ba82019-06-06 14:33:29 -07001484func (b *baseModuleContext) SocSpecific() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001485 return b.kind == socSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001486}
1487
Colin Cross0ea8ba82019-06-06 14:33:29 -07001488func (b *baseModuleContext) ProductSpecific() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001489 return b.kind == productSpecificModule
Dan Willemsen782a2d12015-12-21 14:55:28 -08001490}
1491
Justin Yund5f6c822019-06-25 16:47:17 +09001492func (b *baseModuleContext) SystemExtSpecific() bool {
1493 return b.kind == systemExtSpecificModule
Dario Frenifd05a742018-05-29 13:28:54 +01001494}
1495
Jiyong Park5baac542018-08-28 09:55:37 +09001496// Makes this module a platform module, i.e. not specific to soc, device,
Justin Yund5f6c822019-06-25 16:47:17 +09001497// product, or system_ext.
Colin Cross4157e882019-06-06 16:57:04 -07001498func (m *ModuleBase) MakeAsPlatform() {
1499 m.commonProperties.Vendor = boolPtr(false)
1500 m.commonProperties.Proprietary = boolPtr(false)
1501 m.commonProperties.Soc_specific = boolPtr(false)
1502 m.commonProperties.Product_specific = boolPtr(false)
Justin Yund5f6c822019-06-25 16:47:17 +09001503 m.commonProperties.System_ext_specific = boolPtr(false)
Jiyong Park5baac542018-08-28 09:55:37 +09001504}
1505
Colin Cross4157e882019-06-06 16:57:04 -07001506func (m *ModuleBase) EnableNativeBridgeSupportByDefault() {
1507 m.commonProperties.Native_bridge_supported = boolPtr(true)
dimitry03dc3f62019-05-09 14:07:34 +02001508}
1509
Jooyung Han344d5432019-08-23 11:17:39 +09001510// IsNativeBridgeSupported returns true if "native_bridge_supported" is explicitly set as "true"
1511func (m *ModuleBase) IsNativeBridgeSupported() bool {
1512 return proptools.Bool(m.commonProperties.Native_bridge_supported)
1513}
1514
Colin Cross25de6c32019-06-06 14:29:25 -07001515func (m *moduleContext) InstallInData() bool {
1516 return m.module.InstallInData()
Dan Willemsen782a2d12015-12-21 14:55:28 -08001517}
1518
Jaewoong Jung0949f312019-09-11 10:25:18 -07001519func (m *moduleContext) InstallInTestcases() bool {
1520 return m.module.InstallInTestcases()
1521}
1522
Colin Cross25de6c32019-06-06 14:29:25 -07001523func (m *moduleContext) InstallInSanitizerDir() bool {
1524 return m.module.InstallInSanitizerDir()
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001525}
1526
Colin Cross25de6c32019-06-06 14:29:25 -07001527func (m *moduleContext) InstallInRecovery() bool {
1528 return m.module.InstallInRecovery()
Jiyong Parkf9332f12018-02-01 00:54:12 +09001529}
1530
Colin Cross90ba5f42019-10-02 11:10:58 -07001531func (m *moduleContext) InstallInRoot() bool {
1532 return m.module.InstallInRoot()
1533}
1534
Colin Cross607d8582019-07-29 16:44:46 -07001535func (m *moduleContext) InstallBypassMake() bool {
1536 return m.module.InstallBypassMake()
1537}
1538
Colin Cross25de6c32019-06-06 14:29:25 -07001539func (m *moduleContext) skipInstall(fullInstallPath OutputPath) bool {
1540 if m.module.base().commonProperties.SkipInstall {
Colin Cross893d8162017-04-26 17:34:03 -07001541 return true
1542 }
1543
Colin Cross3607f212018-05-07 15:28:05 -07001544 // We'll need a solution for choosing which of modules with the same name in different
1545 // namespaces to install. For now, reuse the list of namespaces exported to Make as the
1546 // list of namespaces to install in a Soong-only build.
Colin Cross25de6c32019-06-06 14:29:25 -07001547 if !m.module.base().commonProperties.NamespaceExportedToMake {
Colin Cross3607f212018-05-07 15:28:05 -07001548 return true
1549 }
1550
Colin Cross25de6c32019-06-06 14:29:25 -07001551 if m.Device() {
Colin Cross607d8582019-07-29 16:44:46 -07001552 if m.Config().EmbeddedInMake() && !m.InstallBypassMake() {
Colin Cross893d8162017-04-26 17:34:03 -07001553 return true
1554 }
1555
Colin Cross25de6c32019-06-06 14:29:25 -07001556 if m.Config().SkipMegaDeviceInstall(fullInstallPath.String()) {
Colin Cross893d8162017-04-26 17:34:03 -07001557 return true
1558 }
1559 }
1560
1561 return false
1562}
1563
Colin Cross25de6c32019-06-06 14:29:25 -07001564func (m *moduleContext) InstallFile(installPath OutputPath, name string, srcPath Path,
Colin Crossa2344662016-03-24 13:14:12 -07001565 deps ...Path) OutputPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001566 return m.installFile(installPath, name, srcPath, Cp, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001567}
1568
Colin Cross25de6c32019-06-06 14:29:25 -07001569func (m *moduleContext) InstallExecutable(installPath OutputPath, name string, srcPath Path,
Colin Cross5c517922017-08-31 12:29:17 -07001570 deps ...Path) OutputPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001571 return m.installFile(installPath, name, srcPath, CpExecutable, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001572}
1573
Colin Cross25de6c32019-06-06 14:29:25 -07001574func (m *moduleContext) installFile(installPath OutputPath, name string, srcPath Path,
Colin Cross5c517922017-08-31 12:29:17 -07001575 rule blueprint.Rule, deps []Path) OutputPath {
Colin Cross35cec122015-04-02 14:37:16 -07001576
Colin Cross25de6c32019-06-06 14:29:25 -07001577 fullInstallPath := installPath.Join(m, name)
1578 m.module.base().hooks.runInstallHooks(m, fullInstallPath, false)
Colin Cross3f40fa42015-01-30 17:27:36 -08001579
Colin Cross25de6c32019-06-06 14:29:25 -07001580 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001581
Colin Cross25de6c32019-06-06 14:29:25 -07001582 deps = append(deps, m.installDeps...)
Colin Cross35cec122015-04-02 14:37:16 -07001583
Colin Cross89562dc2016-10-03 17:47:19 -07001584 var implicitDeps, orderOnlyDeps Paths
1585
Colin Cross25de6c32019-06-06 14:29:25 -07001586 if m.Host() {
Colin Cross89562dc2016-10-03 17:47:19 -07001587 // Installed host modules might be used during the build, depend directly on their
1588 // dependencies so their timestamp is updated whenever their dependency is updated
1589 implicitDeps = deps
1590 } else {
1591 orderOnlyDeps = deps
1592 }
1593
Colin Cross25de6c32019-06-06 14:29:25 -07001594 m.Build(pctx, BuildParams{
Colin Cross5c517922017-08-31 12:29:17 -07001595 Rule: rule,
Colin Cross67a5c132017-05-09 13:45:28 -07001596 Description: "install " + fullInstallPath.Base(),
1597 Output: fullInstallPath,
1598 Input: srcPath,
1599 Implicits: implicitDeps,
1600 OrderOnly: orderOnlyDeps,
Colin Cross25de6c32019-06-06 14:29:25 -07001601 Default: !m.Config().EmbeddedInMake(),
Dan Willemsen322acaf2016-01-12 23:07:05 -08001602 })
Colin Cross3f40fa42015-01-30 17:27:36 -08001603
Colin Cross25de6c32019-06-06 14:29:25 -07001604 m.installFiles = append(m.installFiles, fullInstallPath)
Dan Willemsen322acaf2016-01-12 23:07:05 -08001605 }
Colin Cross25de6c32019-06-06 14:29:25 -07001606 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross35cec122015-04-02 14:37:16 -07001607 return fullInstallPath
1608}
1609
Colin Cross25de6c32019-06-06 14:29:25 -07001610func (m *moduleContext) InstallSymlink(installPath OutputPath, name string, srcPath OutputPath) OutputPath {
1611 fullInstallPath := installPath.Join(m, name)
1612 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Colin Cross3854a602016-01-11 12:49:11 -08001613
Colin Cross25de6c32019-06-06 14:29:25 -07001614 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001615
Alex Lightfb4353d2019-01-17 13:57:45 -08001616 relPath, err := filepath.Rel(path.Dir(fullInstallPath.String()), srcPath.String())
1617 if err != nil {
1618 panic(fmt.Sprintf("Unable to generate symlink between %q and %q: %s", fullInstallPath.Base(), srcPath.Base(), err))
1619 }
Colin Cross25de6c32019-06-06 14:29:25 -07001620 m.Build(pctx, BuildParams{
Colin Cross67a5c132017-05-09 13:45:28 -07001621 Rule: Symlink,
1622 Description: "install symlink " + fullInstallPath.Base(),
1623 Output: fullInstallPath,
1624 OrderOnly: Paths{srcPath},
Colin Cross25de6c32019-06-06 14:29:25 -07001625 Default: !m.Config().EmbeddedInMake(),
Colin Cross12fc4972016-01-11 12:49:11 -08001626 Args: map[string]string{
Alex Lightfb4353d2019-01-17 13:57:45 -08001627 "fromPath": relPath,
Colin Cross12fc4972016-01-11 12:49:11 -08001628 },
1629 })
Colin Cross3854a602016-01-11 12:49:11 -08001630
Colin Cross25de6c32019-06-06 14:29:25 -07001631 m.installFiles = append(m.installFiles, fullInstallPath)
1632 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross12fc4972016-01-11 12:49:11 -08001633 }
Colin Cross3854a602016-01-11 12:49:11 -08001634 return fullInstallPath
1635}
1636
Jiyong Parkf1194352019-02-25 11:05:47 +09001637// installPath/name -> absPath where absPath might be a path that is available only at runtime
1638// (e.g. /apex/...)
Colin Cross25de6c32019-06-06 14:29:25 -07001639func (m *moduleContext) InstallAbsoluteSymlink(installPath OutputPath, name string, absPath string) OutputPath {
1640 fullInstallPath := installPath.Join(m, name)
1641 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Jiyong Parkf1194352019-02-25 11:05:47 +09001642
Colin Cross25de6c32019-06-06 14:29:25 -07001643 if !m.skipInstall(fullInstallPath) {
1644 m.Build(pctx, BuildParams{
Jiyong Parkf1194352019-02-25 11:05:47 +09001645 Rule: Symlink,
1646 Description: "install symlink " + fullInstallPath.Base() + " -> " + absPath,
1647 Output: fullInstallPath,
Colin Cross25de6c32019-06-06 14:29:25 -07001648 Default: !m.Config().EmbeddedInMake(),
Jiyong Parkf1194352019-02-25 11:05:47 +09001649 Args: map[string]string{
1650 "fromPath": absPath,
1651 },
1652 })
1653
Colin Cross25de6c32019-06-06 14:29:25 -07001654 m.installFiles = append(m.installFiles, fullInstallPath)
Jiyong Parkf1194352019-02-25 11:05:47 +09001655 }
1656 return fullInstallPath
1657}
1658
Colin Cross25de6c32019-06-06 14:29:25 -07001659func (m *moduleContext) CheckbuildFile(srcPath Path) {
1660 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross3f40fa42015-01-30 17:27:36 -08001661}
1662
Colin Cross3f40fa42015-01-30 17:27:36 -08001663type fileInstaller interface {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001664 filesToInstall() Paths
Colin Cross3f40fa42015-01-30 17:27:36 -08001665}
1666
1667func isFileInstaller(m blueprint.Module) bool {
1668 _, ok := m.(fileInstaller)
1669 return ok
1670}
1671
1672func isAndroidModule(m blueprint.Module) bool {
Colin Cross635c3b02016-05-18 15:37:25 -07001673 _, ok := m.(Module)
Colin Cross3f40fa42015-01-30 17:27:36 -08001674 return ok
1675}
Colin Crossfce53272015-04-08 11:21:40 -07001676
Dan Willemsen2ef08f42015-06-30 18:15:24 -07001677func findStringInSlice(str string, slice []string) int {
1678 for i, s := range slice {
1679 if s == str {
1680 return i
Colin Crossfce53272015-04-08 11:21:40 -07001681 }
1682 }
Dan Willemsen2ef08f42015-06-30 18:15:24 -07001683 return -1
1684}
1685
Colin Cross41955e82019-05-29 14:40:35 -07001686// SrcIsModule decodes module references in the format ":name" into the module name, or empty string if the input
1687// was not a module reference.
1688func SrcIsModule(s string) (module string) {
Colin Cross068e0fe2016-12-13 15:23:47 -08001689 if len(s) > 1 && s[0] == ':' {
1690 return s[1:]
1691 }
1692 return ""
1693}
1694
Colin Cross41955e82019-05-29 14:40:35 -07001695// SrcIsModule decodes module references in the format ":name{.tag}" into the module name and tag, ":name" into the
1696// module name and an empty string for the tag, or empty strings if the input was not a module reference.
1697func SrcIsModuleWithTag(s string) (module, tag string) {
1698 if len(s) > 1 && s[0] == ':' {
1699 module = s[1:]
1700 if tagStart := strings.IndexByte(module, '{'); tagStart > 0 {
1701 if module[len(module)-1] == '}' {
1702 tag = module[tagStart+1 : len(module)-1]
1703 module = module[:tagStart]
1704 return module, tag
1705 }
1706 }
1707 return module, ""
1708 }
1709 return "", ""
Colin Cross068e0fe2016-12-13 15:23:47 -08001710}
1711
Colin Cross41955e82019-05-29 14:40:35 -07001712type sourceOrOutputDependencyTag struct {
1713 blueprint.BaseDependencyTag
1714 tag string
1715}
1716
1717func sourceOrOutputDepTag(tag string) blueprint.DependencyTag {
1718 return sourceOrOutputDependencyTag{tag: tag}
1719}
1720
1721var SourceDepTag = sourceOrOutputDepTag("")
Colin Cross068e0fe2016-12-13 15:23:47 -08001722
Colin Cross366938f2017-12-11 16:29:02 -08001723// Adds necessary dependencies to satisfy filegroup or generated sources modules listed in srcFiles
1724// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08001725//
1726// Deprecated: tag the property with `android:"path"` instead.
Colin Cross068e0fe2016-12-13 15:23:47 -08001727func ExtractSourcesDeps(ctx BottomUpMutatorContext, srcFiles []string) {
Nan Zhang2439eb72017-04-10 11:27:50 -07001728 set := make(map[string]bool)
1729
Colin Cross068e0fe2016-12-13 15:23:47 -08001730 for _, s := range srcFiles {
Colin Cross41955e82019-05-29 14:40:35 -07001731 if m, t := SrcIsModuleWithTag(s); m != "" {
1732 if _, found := set[s]; found {
1733 ctx.ModuleErrorf("found source dependency duplicate: %q!", s)
Nan Zhang2439eb72017-04-10 11:27:50 -07001734 } else {
Colin Cross41955e82019-05-29 14:40:35 -07001735 set[s] = true
1736 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Nan Zhang2439eb72017-04-10 11:27:50 -07001737 }
Colin Cross068e0fe2016-12-13 15:23:47 -08001738 }
1739 }
Colin Cross068e0fe2016-12-13 15:23:47 -08001740}
1741
Colin Cross366938f2017-12-11 16:29:02 -08001742// Adds necessary dependencies to satisfy filegroup or generated sources modules specified in s
1743// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08001744//
1745// Deprecated: tag the property with `android:"path"` instead.
Colin Cross366938f2017-12-11 16:29:02 -08001746func ExtractSourceDeps(ctx BottomUpMutatorContext, s *string) {
1747 if s != nil {
Colin Cross41955e82019-05-29 14:40:35 -07001748 if m, t := SrcIsModuleWithTag(*s); m != "" {
1749 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Colin Cross366938f2017-12-11 16:29:02 -08001750 }
1751 }
1752}
1753
Colin Cross41955e82019-05-29 14:40:35 -07001754// A module that implements SourceFileProducer can be referenced from any property that is tagged with `android:"path"`
1755// 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 -08001756type SourceFileProducer interface {
1757 Srcs() Paths
1758}
1759
Colin Cross41955e82019-05-29 14:40:35 -07001760// A module that implements OutputFileProducer can be referenced from any property that is tagged with `android:"path"`
1761// using the ":module" syntax or ":module{.tag}" syntax and provides a list of otuput files to be used as if they were
1762// listed in the property.
1763type OutputFileProducer interface {
1764 OutputFiles(tag string) (Paths, error)
1765}
1766
Colin Crossfe17f6f2019-03-28 19:30:56 -07001767type HostToolProvider interface {
1768 HostToolPath() OptionalPath
1769}
1770
Colin Cross27b922f2019-03-04 22:35:41 -08001771// Returns a list of paths expanded from globs and modules referenced using ":module" syntax. The property must
1772// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08001773//
1774// Deprecated: use PathsForModuleSrc or PathsForModuleSrcExcludes instead.
Colin Cross25de6c32019-06-06 14:29:25 -07001775func (m *moduleContext) ExpandSources(srcFiles, excludes []string) Paths {
1776 return PathsForModuleSrcExcludes(m, srcFiles, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07001777}
1778
Colin Cross2fafa3e2019-03-05 12:39:51 -08001779// Returns a single path expanded from globs and modules referenced using ":module" syntax. The property must
1780// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08001781//
1782// Deprecated: use PathForModuleSrc instead.
Colin Cross25de6c32019-06-06 14:29:25 -07001783func (m *moduleContext) ExpandSource(srcFile, prop string) Path {
1784 return PathForModuleSrc(m, srcFile)
Colin Cross2fafa3e2019-03-05 12:39:51 -08001785}
1786
1787// Returns an optional single path expanded from globs and modules referenced using ":module" syntax if
1788// the srcFile is non-nil. The property must be tagged with `android:"path" to support automatic source module
1789// dependency resolution.
Colin Cross25de6c32019-06-06 14:29:25 -07001790func (m *moduleContext) ExpandOptionalSource(srcFile *string, prop string) OptionalPath {
Colin Cross2fafa3e2019-03-05 12:39:51 -08001791 if srcFile != nil {
Colin Cross25de6c32019-06-06 14:29:25 -07001792 return OptionalPathForPath(PathForModuleSrc(m, *srcFile))
Colin Cross2fafa3e2019-03-05 12:39:51 -08001793 }
1794 return OptionalPath{}
1795}
1796
Colin Cross25de6c32019-06-06 14:29:25 -07001797func (m *moduleContext) RequiredModuleNames() []string {
1798 return m.module.base().commonProperties.Required
Nan Zhang6d34b302017-02-04 17:47:46 -08001799}
1800
Colin Cross25de6c32019-06-06 14:29:25 -07001801func (m *moduleContext) HostRequiredModuleNames() []string {
1802 return m.module.base().commonProperties.Host_required
Sasha Smundakb6d23052019-04-01 18:37:36 -07001803}
1804
Colin Cross25de6c32019-06-06 14:29:25 -07001805func (m *moduleContext) TargetRequiredModuleNames() []string {
1806 return m.module.base().commonProperties.Target_required
Sasha Smundakb6d23052019-04-01 18:37:36 -07001807}
1808
Colin Crossdc35e212019-06-06 16:13:11 -07001809func (b *baseModuleContext) Glob(globPattern string, excludes []string) Paths {
1810 ret, err := b.GlobWithDeps(globPattern, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07001811 if err != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001812 b.ModuleErrorf("glob: %s", err.Error())
Colin Cross8f101b42015-06-17 15:09:06 -07001813 }
Colin Crossdc35e212019-06-06 16:13:11 -07001814 return pathsForModuleSrcFromFullPath(b, ret, true)
Colin Crossfce53272015-04-08 11:21:40 -07001815}
Colin Cross1f8c52b2015-06-16 16:38:17 -07001816
Colin Crossdc35e212019-06-06 16:13:11 -07001817func (b *baseModuleContext) GlobFiles(globPattern string, excludes []string) Paths {
1818 ret, err := b.GlobWithDeps(globPattern, excludes)
Nan Zhang581fd212018-01-10 16:06:12 -08001819 if err != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001820 b.ModuleErrorf("glob: %s", err.Error())
Nan Zhang581fd212018-01-10 16:06:12 -08001821 }
Colin Crossdc35e212019-06-06 16:13:11 -07001822 return pathsForModuleSrcFromFullPath(b, ret, false)
Nan Zhang581fd212018-01-10 16:06:12 -08001823}
1824
Colin Cross463a90e2015-06-17 14:20:06 -07001825func init() {
Colin Cross798bfce2016-10-12 14:28:16 -07001826 RegisterSingletonType("buildtarget", BuildTargetSingleton)
Colin Cross463a90e2015-06-17 14:20:06 -07001827}
1828
Colin Cross0875c522017-11-28 17:34:01 -08001829func BuildTargetSingleton() Singleton {
Colin Cross1f8c52b2015-06-16 16:38:17 -07001830 return &buildTargetSingleton{}
1831}
1832
Colin Cross87d8b562017-04-25 10:01:55 -07001833func parentDir(dir string) string {
1834 dir, _ = filepath.Split(dir)
1835 return filepath.Clean(dir)
1836}
1837
Colin Cross1f8c52b2015-06-16 16:38:17 -07001838type buildTargetSingleton struct{}
1839
Colin Cross0875c522017-11-28 17:34:01 -08001840func (c *buildTargetSingleton) GenerateBuildActions(ctx SingletonContext) {
1841 var checkbuildDeps Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07001842
Colin Cross0875c522017-11-28 17:34:01 -08001843 mmTarget := func(dir string) WritablePath {
1844 return PathForPhony(ctx,
1845 "MODULES-IN-"+strings.Replace(filepath.Clean(dir), "/", "-", -1))
Colin Cross87d8b562017-04-25 10:01:55 -07001846 }
1847
Colin Cross0875c522017-11-28 17:34:01 -08001848 modulesInDir := make(map[string]Paths)
Colin Cross1f8c52b2015-06-16 16:38:17 -07001849
Colin Cross0875c522017-11-28 17:34:01 -08001850 ctx.VisitAllModules(func(module Module) {
1851 blueprintDir := module.base().blueprintDir
1852 installTarget := module.base().installTarget
1853 checkbuildTarget := module.base().checkbuildTarget
Colin Cross1f8c52b2015-06-16 16:38:17 -07001854
Colin Cross0875c522017-11-28 17:34:01 -08001855 if checkbuildTarget != nil {
1856 checkbuildDeps = append(checkbuildDeps, checkbuildTarget)
1857 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], checkbuildTarget)
1858 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07001859
Colin Cross0875c522017-11-28 17:34:01 -08001860 if installTarget != nil {
1861 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], installTarget)
Colin Cross1f8c52b2015-06-16 16:38:17 -07001862 }
1863 })
1864
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001865 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08001866 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001867 suffix = "-soong"
1868 }
1869
Colin Cross1f8c52b2015-06-16 16:38:17 -07001870 // Create a top-level checkbuild target that depends on all modules
Colin Cross0875c522017-11-28 17:34:01 -08001871 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07001872 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001873 Output: PathForPhony(ctx, "checkbuild"+suffix),
Colin Cross1f8c52b2015-06-16 16:38:17 -07001874 Implicits: checkbuildDeps,
Colin Cross1f8c52b2015-06-16 16:38:17 -07001875 })
1876
Dan Willemsend2e95fb2017-09-20 14:30:50 -07001877 // Make will generate the MODULES-IN-* targets
Colin Crossaabf6792017-11-29 00:27:14 -08001878 if ctx.Config().EmbeddedInMake() {
Dan Willemsend2e95fb2017-09-20 14:30:50 -07001879 return
1880 }
1881
Colin Cross87d8b562017-04-25 10:01:55 -07001882 // Ensure ancestor directories are in modulesInDir
Inseob Kim1a365c62019-06-08 15:47:51 +09001883 dirs := SortedStringKeys(modulesInDir)
Colin Cross87d8b562017-04-25 10:01:55 -07001884 for _, dir := range dirs {
1885 dir := parentDir(dir)
1886 for dir != "." && dir != "/" {
1887 if _, exists := modulesInDir[dir]; exists {
1888 break
1889 }
1890 modulesInDir[dir] = nil
1891 dir = parentDir(dir)
1892 }
1893 }
1894
1895 // Make directories build their direct subdirectories
Colin Cross87d8b562017-04-25 10:01:55 -07001896 for _, dir := range dirs {
1897 p := parentDir(dir)
1898 if p != "." && p != "/" {
1899 modulesInDir[p] = append(modulesInDir[p], mmTarget(dir))
1900 }
1901 }
1902
Dan Willemsend2e95fb2017-09-20 14:30:50 -07001903 // Create a MODULES-IN-<directory> target that depends on all modules in a directory, and
1904 // depends on the MODULES-IN-* targets of all of its subdirectories that contain Android.bp
1905 // files.
Colin Cross1f8c52b2015-06-16 16:38:17 -07001906 for _, dir := range dirs {
Colin Cross0875c522017-11-28 17:34:01 -08001907 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07001908 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001909 Output: mmTarget(dir),
Colin Cross87d8b562017-04-25 10:01:55 -07001910 Implicits: modulesInDir[dir],
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001911 // HACK: checkbuild should be an optional build, but force it
1912 // enabled for now in standalone builds
Colin Crossaabf6792017-11-29 00:27:14 -08001913 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross1f8c52b2015-06-16 16:38:17 -07001914 })
1915 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07001916
1917 // Create (host|host-cross|target)-<OS> phony rules to build a reduced checkbuild.
1918 osDeps := map[OsType]Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08001919 ctx.VisitAllModules(func(module Module) {
1920 if module.Enabled() {
1921 os := module.Target().Os
1922 osDeps[os] = append(osDeps[os], module.base().checkbuildFiles...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07001923 }
1924 })
1925
Colin Cross0875c522017-11-28 17:34:01 -08001926 osClass := make(map[string]Paths)
Dan Willemsen61d88b82017-09-20 17:29:08 -07001927 for os, deps := range osDeps {
1928 var className string
1929
1930 switch os.Class {
1931 case Host:
1932 className = "host"
1933 case HostCross:
1934 className = "host-cross"
1935 case Device:
1936 className = "target"
1937 default:
1938 continue
1939 }
1940
Colin Cross0875c522017-11-28 17:34:01 -08001941 name := PathForPhony(ctx, className+"-"+os.Name)
Dan Willemsen61d88b82017-09-20 17:29:08 -07001942 osClass[className] = append(osClass[className], name)
1943
Colin Cross0875c522017-11-28 17:34:01 -08001944 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07001945 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001946 Output: name,
1947 Implicits: deps,
Dan Willemsen61d88b82017-09-20 17:29:08 -07001948 })
1949 }
1950
1951 // Wrap those into host|host-cross|target phony rules
Inseob Kim1a365c62019-06-08 15:47:51 +09001952 for _, class := range SortedStringKeys(osClass) {
Colin Cross0875c522017-11-28 17:34:01 -08001953 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07001954 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001955 Output: PathForPhony(ctx, class),
Dan Willemsen61d88b82017-09-20 17:29:08 -07001956 Implicits: osClass[class],
Dan Willemsen61d88b82017-09-20 17:29:08 -07001957 })
1958 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07001959}
Colin Crossd779da42015-12-17 18:00:23 -08001960
Brandon Lee5d45c6f2018-08-15 15:35:38 -07001961// Collect information for opening IDE project files in java/jdeps.go.
1962type IDEInfo interface {
1963 IDEInfo(ideInfo *IdeInfo)
1964 BaseModuleName() string
1965}
1966
1967// Extract the base module name from the Import name.
1968// Often the Import name has a prefix "prebuilt_".
1969// Remove the prefix explicitly if needed
1970// until we find a better solution to get the Import name.
1971type IDECustomizedModuleName interface {
1972 IDECustomizedModuleName() string
1973}
1974
1975type IdeInfo struct {
1976 Deps []string `json:"dependencies,omitempty"`
1977 Srcs []string `json:"srcs,omitempty"`
1978 Aidl_include_dirs []string `json:"aidl_include_dirs,omitempty"`
1979 Jarjar_rules []string `json:"jarjar_rules,omitempty"`
1980 Jars []string `json:"jars,omitempty"`
1981 Classes []string `json:"class,omitempty"`
1982 Installed_paths []string `json:"installed,omitempty"`
patricktu18c82ff2019-05-10 15:48:50 +08001983 SrcJars []string `json:"srcjars,omitempty"`
Brandon Lee5d45c6f2018-08-15 15:35:38 -07001984}