blob: bb0aada9f3d7023405f1577e9e97ef50c23968db [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
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700157 InstallInSanitizerDir() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900158 InstallInRecovery() bool
Colin Cross607d8582019-07-29 16:44:46 -0700159 InstallBypassMake() bool
Nan Zhang6d34b302017-02-04 17:47:46 -0800160
161 RequiredModuleNames() []string
Sasha Smundakb6d23052019-04-01 18:37:36 -0700162 HostRequiredModuleNames() []string
163 TargetRequiredModuleNames() []string
Colin Cross3f68a132017-10-23 17:10:29 -0700164
Colin Cross3f68a132017-10-23 17:10:29 -0700165 ModuleSubDir() string
166
Colin Cross0875c522017-11-28 17:34:01 -0800167 Variable(pctx PackageContext, name, value string)
168 Rule(pctx PackageContext, name string, params blueprint.RuleParams, argNames ...string) blueprint.Rule
Colin Crossae887032017-10-23 17:16:14 -0700169 // Similar to blueprint.ModuleContext.Build, but takes Paths instead of []string,
170 // and performs more verification.
Colin Cross0875c522017-11-28 17:34:01 -0800171 Build(pctx PackageContext, params BuildParams)
Colin Cross3f68a132017-10-23 17:10:29 -0700172
Colin Cross0875c522017-11-28 17:34:01 -0800173 PrimaryModule() Module
174 FinalModule() Module
175 VisitAllModuleVariants(visit func(Module))
Colin Cross3f68a132017-10-23 17:10:29 -0700176
177 GetMissingDependencies() []string
Jeff Gaston088e29e2017-11-29 16:47:17 -0800178 Namespace() blueprint.Namespace
Colin Cross3f40fa42015-01-30 17:27:36 -0800179}
180
Colin Cross635c3b02016-05-18 15:37:25 -0700181type Module interface {
Colin Cross3f40fa42015-01-30 17:27:36 -0800182 blueprint.Module
183
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700184 // GenerateAndroidBuildActions is analogous to Blueprints' GenerateBuildActions,
185 // but GenerateAndroidBuildActions also has access to Android-specific information.
186 // For more information, see Module.GenerateBuildActions within Blueprint's module_ctx.go
Colin Cross635c3b02016-05-18 15:37:25 -0700187 GenerateAndroidBuildActions(ModuleContext)
Jeff Gastonaf3cc2d2017-09-27 17:01:44 -0700188
Colin Cross1e676be2016-10-12 14:38:15 -0700189 DepsMutator(BottomUpMutatorContext)
Colin Cross3f40fa42015-01-30 17:27:36 -0800190
Colin Cross635c3b02016-05-18 15:37:25 -0700191 base() *ModuleBase
Dan Willemsen0effe062015-11-30 16:06:01 -0800192 Enabled() bool
Colin Crossa1ad8d12016-06-01 17:09:44 -0700193 Target() Target
Dan Willemsen782a2d12015-12-21 14:55:28 -0800194 InstallInData() bool
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700195 InstallInSanitizerDir() bool
Jiyong Parkf9332f12018-02-01 00:54:12 +0900196 InstallInRecovery() bool
Colin Cross607d8582019-07-29 16:44:46 -0700197 InstallBypassMake() bool
Colin Crossa2f296f2016-11-29 15:16:18 -0800198 SkipInstall()
Jiyong Park374510b2018-03-19 18:23:01 +0900199 ExportedToMake() bool
Jiyong Park52818fc2019-03-18 12:01:38 +0900200 NoticeFile() OptionalPath
Colin Cross36242852017-06-23 15:06:31 -0700201
202 AddProperties(props ...interface{})
203 GetProperties() []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700204
Colin Crossae887032017-10-23 17:16:14 -0700205 BuildParamsForTests() []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800206 RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800207 VariablesForTests() map[string]string
Paul Duffine2453c72019-05-31 14:00:04 +0100208
Colin Cross9a362232019-07-01 15:32:45 -0700209 // String returns a string that includes the module name and variants for printing during debugging.
210 String() string
211
Paul Duffine2453c72019-05-31 14:00:04 +0100212 // Get the qualified module id for this module.
213 qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName
214
215 // Get information about the properties that can contain visibility rules.
216 visibilityProperties() []visibilityProperty
Paul Duffin63c6e182019-07-24 14:24:38 +0100217
218 // Get the visibility rules that control the visibility of this module.
219 visibility() []string
Paul Duffine2453c72019-05-31 14:00:04 +0100220}
221
222// Qualified id for a module
223type qualifiedModuleName struct {
224 // The package (i.e. directory) in which the module is defined, without trailing /
225 pkg string
226
227 // The name of the module, empty string if package.
228 name string
229}
230
231func (q qualifiedModuleName) String() string {
232 if q.name == "" {
233 return "//" + q.pkg
234 }
235 return "//" + q.pkg + ":" + q.name
236}
237
Paul Duffine484f472019-06-20 16:38:08 +0100238func (q qualifiedModuleName) isRootPackage() bool {
239 return q.pkg == "" && q.name == ""
240}
241
Paul Duffine2453c72019-05-31 14:00:04 +0100242// Get the id for the package containing this module.
243func (q qualifiedModuleName) getContainingPackageId() qualifiedModuleName {
244 pkg := q.pkg
245 if q.name == "" {
Paul Duffine484f472019-06-20 16:38:08 +0100246 if pkg == "" {
247 panic(fmt.Errorf("Cannot get containing package id of root package"))
248 }
249
250 index := strings.LastIndex(pkg, "/")
251 if index == -1 {
252 pkg = ""
253 } else {
254 pkg = pkg[:index]
255 }
Paul Duffine2453c72019-05-31 14:00:04 +0100256 }
257 return newPackageId(pkg)
258}
259
260func newPackageId(pkg string) qualifiedModuleName {
261 // A qualified id for a package module has no name.
262 return qualifiedModuleName{pkg: pkg, name: ""}
Colin Cross3f40fa42015-01-30 17:27:36 -0800263}
264
Colin Crossfc754582016-05-17 16:34:16 -0700265type nameProperties struct {
266 // The name of the module. Must be unique across all modules.
Nan Zhang0007d812017-11-07 10:57:05 -0800267 Name *string
Colin Crossfc754582016-05-17 16:34:16 -0700268}
269
270type commonProperties struct {
Dan Willemsen0effe062015-11-30 16:06:01 -0800271 // emit build rules for this module
272 Enabled *bool `android:"arch_variant"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800273
Paul Duffin2e61fa62019-03-28 14:10:57 +0000274 // Controls the visibility of this module to other modules. Allowable values are one or more of
275 // these formats:
276 //
277 // ["//visibility:public"]: Anyone can use this module.
278 // ["//visibility:private"]: Only rules in the module's package (not its subpackages) can use
279 // this module.
280 // ["//some/package:__pkg__", "//other/package:__pkg__"]: Only modules in some/package and
281 // other/package (defined in some/package/*.bp and other/package/*.bp) have access to
282 // this module. Note that sub-packages do not have access to the rule; for example,
283 // //some/package/foo:bar or //other/package/testing:bla wouldn't have access. __pkg__
284 // is a special module and must be used verbatim. It represents all of the modules in the
285 // package.
286 // ["//project:__subpackages__", "//other:__subpackages__"]: Only modules in packages project
287 // or other or in one of their sub-packages have access to this module. For example,
288 // //project:rule, //project/library:lib or //other/testing/internal:munge are allowed
289 // to depend on this rule (but not //independent:evil)
290 // ["//project"]: This is shorthand for ["//project:__pkg__"]
291 // [":__subpackages__"]: This is shorthand for ["//project:__subpackages__"] where
292 // //project is the module's package. e.g. using [":__subpackages__"] in
293 // packages/apps/Settings/Android.bp is equivalent to
294 // //packages/apps/Settings:__subpackages__.
295 // ["//visibility:legacy_public"]: The default visibility, behaves as //visibility:public
296 // for now. It is an error if it is used in a module.
Paul Duffine2453c72019-05-31 14:00:04 +0100297 //
298 // If a module does not specify the `visibility` property then it uses the
299 // `default_visibility` property of the `package` module in the module's package.
300 //
Paul Duffine484f472019-06-20 16:38:08 +0100301 // If a module does not specify the `visibility` property then it uses the
302 // `default_visibility` property of the `package` module in the module's package.
303 //
Paul Duffine2453c72019-05-31 14:00:04 +0100304 // If the `default_visibility` property is not set for the module's package then
Paul Duffine484f472019-06-20 16:38:08 +0100305 // it will use the `default_visibility` of its closest ancestor package for which
306 // a `default_visibility` property is specified.
307 //
308 // If no `default_visibility` property can be found then the module uses the
309 // global default of `//visibility:legacy_public`.
Paul Duffine2453c72019-05-31 14:00:04 +0100310 //
Paul Duffin95d53b52019-07-24 13:45:05 +0100311 // The `visibility` property has no effect on a defaults module although it does
312 // apply to any non-defaults module that uses it. To set the visibility of a
313 // defaults module, use the `defaults_visibility` property on the defaults module;
314 // not to be confused with the `default_visibility` property on the package module.
315 //
Paul Duffin2e61fa62019-03-28 14:10:57 +0000316 // See https://android.googlesource.com/platform/build/soong/+/master/README.md#visibility for
317 // more details.
318 Visibility []string
319
Colin Cross7d5136f2015-05-11 13:39:40 -0700320 // control whether this module compiles for 32-bit, 64-bit, or both. Possible values
Colin Cross3f40fa42015-01-30 17:27:36 -0800321 // are "32" (compile for 32-bit only), "64" (compile for 64-bit only), "both" (compile for both
322 // architectures), or "first" (compile for 64-bit on a 64-bit platform, and 32-bit on a 32-bit
323 // platform
Colin Cross7d716ba2017-11-01 10:38:29 -0700324 Compile_multilib *string `android:"arch_variant"`
Colin Cross69617d32016-09-06 10:39:07 -0700325
326 Target struct {
327 Host struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700328 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700329 }
330 Android struct {
Colin Cross7d716ba2017-11-01 10:38:29 -0700331 Compile_multilib *string
Colin Cross69617d32016-09-06 10:39:07 -0700332 }
333 }
334
Colin Crossee0bc3b2018-10-02 22:01:37 -0700335 UseTargetVariants bool `blueprint:"mutated"`
336 Default_multilib string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800337
Dan Willemsen782a2d12015-12-21 14:55:28 -0800338 // whether this is a proprietary vendor module, and should be installed into /vendor
Colin Cross7d716ba2017-11-01 10:38:29 -0700339 Proprietary *bool
Dan Willemsen782a2d12015-12-21 14:55:28 -0800340
Colin Cross55708f32017-03-20 13:23:34 -0700341 // vendor who owns this module
Dan Willemsenefac4a82017-07-18 19:42:09 -0700342 Owner *string
Colin Cross55708f32017-03-20 13:23:34 -0700343
Jiyong Park2db76922017-11-08 16:03:48 +0900344 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
345 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
346 // Use `soc_specific` instead for better meaning.
Colin Cross7d716ba2017-11-01 10:38:29 -0700347 Vendor *bool
Dan Willemsenaa118f92017-04-06 12:49:58 -0700348
Jiyong Park2db76922017-11-08 16:03:48 +0900349 // whether this module is specific to an SoC (System-On-a-Chip). When set to true,
350 // it is installed into /vendor (or /system/vendor if vendor partition does not exist).
351 Soc_specific *bool
352
353 // whether this module is specific to a device, not only for SoC, but also for off-chip
354 // peripherals. When set to true, it is installed into /odm (or /vendor/odm if odm partition
355 // does not exist, or /system/vendor/odm if both odm and vendor partitions do not exist).
356 // This implies `soc_specific:true`.
357 Device_specific *bool
358
359 // whether this module is specific to a software configuration of a product (e.g. country,
Jaekyun Seok5cfbfbb2018-01-10 19:00:15 +0900360 // network operator, etc). When set to true, it is installed into /product (or
361 // /system/product if product partition does not exist).
Jiyong Park2db76922017-11-08 16:03:48 +0900362 Product_specific *bool
363
Justin Yund5f6c822019-06-25 16:47:17 +0900364 // TODO(b/135957588) Product_services_specific will be removed once we clear all Android.bp
365 // files that have 'product_services_specific: true'. This will be converted to
366 // Product_speicific as a workaround.
Dario Freni95cf7672018-08-17 00:57:57 +0100367 Product_services_specific *bool
Dario Frenifd05a742018-05-29 13:28:54 +0100368
Justin Yund5f6c822019-06-25 16:47:17 +0900369 // whether this module extends system. When set to true, it is installed into /system_ext
370 // (or /system/system_ext if system_ext partition does not exist).
371 System_ext_specific *bool
372
Jiyong Parkf9332f12018-02-01 00:54:12 +0900373 // Whether this module is installed to recovery partition
374 Recovery *bool
375
dimitry1f33e402019-03-26 12:39:31 +0100376 // Whether this module is built for non-native architecures (also known as native bridge binary)
377 Native_bridge_supported *bool `android:"arch_variant"`
378
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700379 // init.rc files to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800380 Init_rc []string `android:"path"`
Dan Willemsen2277bcb2016-07-25 20:27:39 -0700381
Steven Moreland57a23d22018-04-04 15:42:19 -0700382 // VINTF manifest fragments to be installed if this module is installed
Colin Cross27b922f2019-03-04 22:35:41 -0800383 Vintf_fragments []string `android:"path"`
Steven Moreland57a23d22018-04-04 15:42:19 -0700384
Chris Wolfe998306e2016-08-15 14:47:23 -0400385 // names of other modules to install if this module is installed
Colin Crossc602b7d2017-05-05 13:36:36 -0700386 Required []string `android:"arch_variant"`
Chris Wolfe998306e2016-08-15 14:47:23 -0400387
Sasha Smundakb6d23052019-04-01 18:37:36 -0700388 // names of other modules to install on host if this module is installed
389 Host_required []string `android:"arch_variant"`
390
391 // names of other modules to install on target if this module is installed
392 Target_required []string `android:"arch_variant"`
393
Colin Cross5aac3622017-08-31 15:07:09 -0700394 // relative path to a file to include in the list of notices for the device
Colin Cross27b922f2019-03-04 22:35:41 -0800395 Notice *string `android:"path"`
Colin Cross5aac3622017-08-31 15:07:09 -0700396
Dan Willemsen569edc52018-11-19 09:33:29 -0800397 Dist struct {
398 // copy the output of this module to the $DIST_DIR when `dist` is specified on the
399 // command line and any of these targets are also on the command line, or otherwise
400 // built
401 Targets []string `android:"arch_variant"`
402
403 // The name of the output artifact. This defaults to the basename of the output of
404 // the module.
405 Dest *string `android:"arch_variant"`
406
407 // The directory within the dist directory to store the artifact. Defaults to the
408 // top level directory ("").
409 Dir *string `android:"arch_variant"`
410
411 // A suffix to add to the artifact file name (before any extension).
412 Suffix *string `android:"arch_variant"`
413 } `android:"arch_variant"`
414
Colin Crossa1ad8d12016-06-01 17:09:44 -0700415 // Set by TargetMutator
Colin Crossee0bc3b2018-10-02 22:01:37 -0700416 CompileTarget Target `blueprint:"mutated"`
417 CompileMultiTargets []Target `blueprint:"mutated"`
418 CompilePrimary bool `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800419
420 // Set by InitAndroidModule
421 HostOrDeviceSupported HostOrDeviceSupported `blueprint:"mutated"`
Dan Willemsen0b24c742016-10-04 15:13:37 -0700422 ArchSpecific bool `blueprint:"mutated"`
Colin Crossce75d2c2016-10-06 16:12:58 -0700423
424 SkipInstall bool `blueprint:"mutated"`
Jeff Gaston088e29e2017-11-29 16:47:17 -0800425
426 NamespaceExportedToMake bool `blueprint:"mutated"`
Colin Cross6c4f21f2019-06-06 15:41:36 -0700427
428 MissingDeps []string `blueprint:"mutated"`
Colin Cross9a362232019-07-01 15:32:45 -0700429
430 // Name and variant strings stored by mutators to enable Module.String()
431 DebugName string `blueprint:"mutated"`
432 DebugMutators []string `blueprint:"mutated"`
433 DebugVariations []string `blueprint:"mutated"`
Colin Cross3f40fa42015-01-30 17:27:36 -0800434}
435
436type hostAndDeviceProperties struct {
Colin Cross4e81d702018-11-09 10:36:55 -0800437 // If set to true, build a variant of the module for the host. Defaults to false.
438 Host_supported *bool
439
440 // If set to true, build a variant of the module for the device. Defaults to true.
Colin Crossa4190c12016-07-12 13:11:25 -0700441 Device_supported *bool
Colin Cross3f40fa42015-01-30 17:27:36 -0800442}
443
Colin Crossc472d572015-03-17 15:06:21 -0700444type Multilib string
445
446const (
Colin Cross6b4a32d2017-12-05 13:42:45 -0800447 MultilibBoth Multilib = "both"
448 MultilibFirst Multilib = "first"
449 MultilibCommon Multilib = "common"
450 MultilibCommonFirst Multilib = "common_first"
451 MultilibDefault Multilib = ""
Colin Crossc472d572015-03-17 15:06:21 -0700452)
453
Colin Crossa1ad8d12016-06-01 17:09:44 -0700454type HostOrDeviceSupported int
455
456const (
457 _ HostOrDeviceSupported = iota
Dan Albert0981b5c2018-08-02 13:46:35 -0700458
459 // Host and HostCross are built by default. Device is not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700460 HostSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700461
462 // Host is built by default. HostCross and Device are not supported.
Dan Albertc6345fb2016-10-20 01:36:11 -0700463 HostSupportedNoCross
Dan Albert0981b5c2018-08-02 13:46:35 -0700464
465 // Device is built by default. Host and HostCross are not supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700466 DeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700467
468 // Device is built by default. Host and HostCross are supported.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700469 HostAndDeviceSupported
Dan Albert0981b5c2018-08-02 13:46:35 -0700470
471 // Host, HostCross, and Device are built by default.
Colin Crossa1ad8d12016-06-01 17:09:44 -0700472 HostAndDeviceDefault
Dan Albert0981b5c2018-08-02 13:46:35 -0700473
474 // Nothing is supported. This is not exposed to the user, but used to mark a
475 // host only module as unsupported when the module type is not supported on
476 // the host OS. E.g. benchmarks are supported on Linux but not Darwin.
Dan Willemsen0b24c742016-10-04 15:13:37 -0700477 NeitherHostNorDeviceSupported
Colin Crossa1ad8d12016-06-01 17:09:44 -0700478)
479
Jiyong Park2db76922017-11-08 16:03:48 +0900480type moduleKind int
481
482const (
483 platformModule moduleKind = iota
484 deviceSpecificModule
485 socSpecificModule
486 productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900487 systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900488)
489
490func (k moduleKind) String() string {
491 switch k {
492 case platformModule:
493 return "platform"
494 case deviceSpecificModule:
495 return "device-specific"
496 case socSpecificModule:
497 return "soc-specific"
498 case productSpecificModule:
499 return "product-specific"
Justin Yund5f6c822019-06-25 16:47:17 +0900500 case systemExtSpecificModule:
501 return "systemext-specific"
Jiyong Park2db76922017-11-08 16:03:48 +0900502 default:
503 panic(fmt.Errorf("unknown module kind %d", k))
504 }
505}
506
Colin Cross36242852017-06-23 15:06:31 -0700507func InitAndroidModule(m Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800508 base := m.base()
509 base.module = m
Colin Cross5049f022015-03-18 13:28:46 -0700510
Colin Cross36242852017-06-23 15:06:31 -0700511 m.AddProperties(
Colin Crossfc754582016-05-17 16:34:16 -0700512 &base.nameProperties,
Colin Cross18c46802019-09-24 22:19:02 -0700513 &base.commonProperties)
514
515 // Allow tests to override the default product variables
516 if base.variableProperties == nil {
517 base.variableProperties = zeroProductVariables
518 }
519
520 // Filter the product variables properties to the ones that exist on this module
521 base.variableProperties = createVariableProperties(m.GetProperties(), base.variableProperties)
522 if base.variableProperties != nil {
523 m.AddProperties(base.variableProperties)
524 }
525
Colin Crossa3a97412019-03-18 12:24:29 -0700526 base.generalProperties = m.GetProperties()
Pirama Arumuga Nainar955dc492018-04-17 14:58:42 -0700527 base.customizableProperties = m.GetProperties()
Paul Duffin63c6e182019-07-24 14:24:38 +0100528
529 // The default_visibility property needs to be checked and parsed by the visibility module during
530 // its checking and parsing phases.
531 base.primaryVisibilityProperty =
532 newVisibilityProperty("visibility", &base.commonProperties.Visibility)
533 base.visibilityPropertyInfo = []visibilityProperty{base.primaryVisibilityProperty}
Colin Cross5049f022015-03-18 13:28:46 -0700534}
535
Colin Cross36242852017-06-23 15:06:31 -0700536func InitAndroidArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
537 InitAndroidModule(m)
Colin Cross5049f022015-03-18 13:28:46 -0700538
539 base := m.base()
Colin Cross3f40fa42015-01-30 17:27:36 -0800540 base.commonProperties.HostOrDeviceSupported = hod
Colin Cross69617d32016-09-06 10:39:07 -0700541 base.commonProperties.Default_multilib = string(defaultMultilib)
Dan Willemsen0b24c742016-10-04 15:13:37 -0700542 base.commonProperties.ArchSpecific = true
Colin Crossee0bc3b2018-10-02 22:01:37 -0700543 base.commonProperties.UseTargetVariants = true
Colin Cross3f40fa42015-01-30 17:27:36 -0800544
Dan Willemsen218f6562015-07-08 18:13:11 -0700545 switch hod {
Nan Zhang1a0f09b2017-07-05 10:35:11 -0700546 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Cross36242852017-06-23 15:06:31 -0700547 m.AddProperties(&base.hostAndDeviceProperties)
Colin Cross3f40fa42015-01-30 17:27:36 -0800548 }
549
Colin Cross36242852017-06-23 15:06:31 -0700550 InitArchModule(m)
Colin Cross3f40fa42015-01-30 17:27:36 -0800551}
552
Colin Crossee0bc3b2018-10-02 22:01:37 -0700553func InitAndroidMultiTargetsArchModule(m Module, hod HostOrDeviceSupported, defaultMultilib Multilib) {
554 InitAndroidArchModule(m, hod, defaultMultilib)
555 m.base().commonProperties.UseTargetVariants = false
556}
557
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800558// A ModuleBase object contains the properties that are common to all Android
Colin Cross3f40fa42015-01-30 17:27:36 -0800559// modules. It should be included as an anonymous field in every module
560// struct definition. InitAndroidModule should then be called from the module's
561// factory function, and the return values from InitAndroidModule should be
562// returned from the factory function.
563//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800564// The ModuleBase type is responsible for implementing the GenerateBuildActions
565// method to support the blueprint.Module interface. This method will then call
566// the module's GenerateAndroidBuildActions method once for each build variant
Colin Cross25de6c32019-06-06 14:29:25 -0700567// that is to be built. GenerateAndroidBuildActions is passed a ModuleContext
568// rather than the usual blueprint.ModuleContext.
569// ModuleContext exposes extra functionality specific to the Android build
Colin Cross3f40fa42015-01-30 17:27:36 -0800570// system including details about the particular build variant that is to be
571// generated.
572//
573// For example:
574//
575// import (
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800576// "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -0800577// )
578//
579// type myModule struct {
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800580// android.ModuleBase
Colin Cross3f40fa42015-01-30 17:27:36 -0800581// properties struct {
582// MyProperty string
583// }
584// }
585//
Colin Cross36242852017-06-23 15:06:31 -0700586// func NewMyModule() android.Module) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800587// m := &myModule{}
Colin Cross36242852017-06-23 15:06:31 -0700588// m.AddProperties(&m.properties)
589// android.InitAndroidModule(m)
590// return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800591// }
592//
Nan Zhangb9eeb1d2017-02-02 10:46:07 -0800593// func (m *myModule) GenerateAndroidBuildActions(ctx android.ModuleContext) {
Colin Cross3f40fa42015-01-30 17:27:36 -0800594// // Get the CPU architecture for the current build variant.
595// variantArch := ctx.Arch()
596//
597// // ...
598// }
Colin Cross635c3b02016-05-18 15:37:25 -0700599type ModuleBase struct {
Colin Cross3f40fa42015-01-30 17:27:36 -0800600 // Putting the curiously recurring thing pointing to the thing that contains
601 // the thing pattern to good use.
Colin Cross36242852017-06-23 15:06:31 -0700602 // TODO: remove this
Colin Cross635c3b02016-05-18 15:37:25 -0700603 module Module
Colin Cross3f40fa42015-01-30 17:27:36 -0800604
Colin Crossfc754582016-05-17 16:34:16 -0700605 nameProperties nameProperties
Colin Cross3f40fa42015-01-30 17:27:36 -0800606 commonProperties commonProperties
Colin Cross18c46802019-09-24 22:19:02 -0700607 variableProperties interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800608 hostAndDeviceProperties hostAndDeviceProperties
609 generalProperties []interface{}
Colin Crossc17727d2018-10-24 12:42:09 -0700610 archProperties [][]interface{}
Colin Crossa120ec12016-08-19 16:07:38 -0700611 customizableProperties []interface{}
Colin Cross3f40fa42015-01-30 17:27:36 -0800612
Paul Duffin63c6e182019-07-24 14:24:38 +0100613 // Information about all the properties on the module that contains visibility rules that need
614 // checking.
615 visibilityPropertyInfo []visibilityProperty
616
617 // The primary visibility property, may be nil, that controls access to the module.
618 primaryVisibilityProperty visibilityProperty
619
Colin Cross3f40fa42015-01-30 17:27:36 -0800620 noAddressSanitizer bool
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700621 installFiles Paths
622 checkbuildFiles Paths
Jiyong Park52818fc2019-03-18 12:01:38 +0900623 noticeFile OptionalPath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700624
625 // Used by buildTargetSingleton to create checkbuild and per-directory build targets
626 // Only set on the final variant of each module
Colin Cross0875c522017-11-28 17:34:01 -0800627 installTarget WritablePath
628 checkbuildTarget WritablePath
Colin Cross1f8c52b2015-06-16 16:38:17 -0700629 blueprintDir string
Colin Crossa120ec12016-08-19 16:07:38 -0700630
Colin Cross178a5092016-09-13 13:42:32 -0700631 hooks hooks
Colin Cross36242852017-06-23 15:06:31 -0700632
633 registerProps []interface{}
Colin Crosscec81712017-07-13 14:43:27 -0700634
635 // For tests
Colin Crossae887032017-10-23 17:16:14 -0700636 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800637 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800638 variables map[string]string
Colin Crossa9d8bee2018-10-02 13:59:46 -0700639
640 prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool
Colin Cross36242852017-06-23 15:06:31 -0700641}
642
Colin Cross4157e882019-06-06 16:57:04 -0700643func (m *ModuleBase) DepsMutator(BottomUpMutatorContext) {}
Colin Cross5f692ec2019-02-01 16:53:07 -0800644
Colin Cross4157e882019-06-06 16:57:04 -0700645func (m *ModuleBase) AddProperties(props ...interface{}) {
646 m.registerProps = append(m.registerProps, props...)
Colin Cross36242852017-06-23 15:06:31 -0700647}
648
Colin Cross4157e882019-06-06 16:57:04 -0700649func (m *ModuleBase) GetProperties() []interface{} {
650 return m.registerProps
Colin Cross3f40fa42015-01-30 17:27:36 -0800651}
652
Colin Cross4157e882019-06-06 16:57:04 -0700653func (m *ModuleBase) BuildParamsForTests() []BuildParams {
654 return m.buildParams
Colin Crosscec81712017-07-13 14:43:27 -0700655}
656
Colin Cross4157e882019-06-06 16:57:04 -0700657func (m *ModuleBase) RuleParamsForTests() map[blueprint.Rule]blueprint.RuleParams {
658 return m.ruleParams
Colin Cross4c83e5c2019-02-25 14:54:28 -0800659}
660
Colin Cross4157e882019-06-06 16:57:04 -0700661func (m *ModuleBase) VariablesForTests() map[string]string {
662 return m.variables
Jaewoong Jung38e4fb22018-12-12 09:01:34 -0800663}
664
Colin Cross4157e882019-06-06 16:57:04 -0700665func (m *ModuleBase) Prefer32(prefer32 func(ctx BaseModuleContext, base *ModuleBase, class OsClass) bool) {
666 m.prefer32 = prefer32
Colin Crossa9d8bee2018-10-02 13:59:46 -0700667}
668
Colin Crossce75d2c2016-10-06 16:12:58 -0700669// Name returns the name of the module. It may be overridden by individual module types, for
670// example prebuilts will prepend prebuilt_ to the name.
Colin Cross4157e882019-06-06 16:57:04 -0700671func (m *ModuleBase) Name() string {
672 return String(m.nameProperties.Name)
Colin Crossfc754582016-05-17 16:34:16 -0700673}
674
Colin Cross9a362232019-07-01 15:32:45 -0700675// String returns a string that includes the module name and variants for printing during debugging.
676func (m *ModuleBase) String() string {
677 sb := strings.Builder{}
678 sb.WriteString(m.commonProperties.DebugName)
679 sb.WriteString("{")
680 for i := range m.commonProperties.DebugMutators {
681 if i != 0 {
682 sb.WriteString(",")
683 }
684 sb.WriteString(m.commonProperties.DebugMutators[i])
685 sb.WriteString(":")
686 sb.WriteString(m.commonProperties.DebugVariations[i])
687 }
688 sb.WriteString("}")
689 return sb.String()
690}
691
Colin Crossce75d2c2016-10-06 16:12:58 -0700692// BaseModuleName returns the name of the module as specified in the blueprints file.
Colin Cross4157e882019-06-06 16:57:04 -0700693func (m *ModuleBase) BaseModuleName() string {
694 return String(m.nameProperties.Name)
Colin Crossce75d2c2016-10-06 16:12:58 -0700695}
696
Colin Cross4157e882019-06-06 16:57:04 -0700697func (m *ModuleBase) base() *ModuleBase {
698 return m
Colin Cross3f40fa42015-01-30 17:27:36 -0800699}
700
Paul Duffine2453c72019-05-31 14:00:04 +0100701func (m *ModuleBase) qualifiedModuleId(ctx BaseModuleContext) qualifiedModuleName {
702 return qualifiedModuleName{pkg: ctx.ModuleDir(), name: ctx.ModuleName()}
703}
704
705func (m *ModuleBase) visibilityProperties() []visibilityProperty {
Paul Duffin63c6e182019-07-24 14:24:38 +0100706 return m.visibilityPropertyInfo
707}
708
709func (m *ModuleBase) visibility() []string {
710 // The soong_namespace module does not initialize the primaryVisibilityProperty.
711 if m.primaryVisibilityProperty != nil {
712 return m.primaryVisibilityProperty.getStrings()
713 } else {
714 return nil
Paul Duffine2453c72019-05-31 14:00:04 +0100715 }
716}
717
Colin Cross4157e882019-06-06 16:57:04 -0700718func (m *ModuleBase) SetTarget(target Target, multiTargets []Target, primary bool) {
719 m.commonProperties.CompileTarget = target
720 m.commonProperties.CompileMultiTargets = multiTargets
721 m.commonProperties.CompilePrimary = primary
Colin Crossd3ba0392015-05-07 14:11:29 -0700722}
723
Colin Cross4157e882019-06-06 16:57:04 -0700724func (m *ModuleBase) Target() Target {
725 return m.commonProperties.CompileTarget
Dan Willemsen490fd492015-11-24 17:53:15 -0800726}
727
Colin Cross4157e882019-06-06 16:57:04 -0700728func (m *ModuleBase) TargetPrimary() bool {
729 return m.commonProperties.CompilePrimary
Colin Cross8b74d172016-09-13 09:59:14 -0700730}
731
Colin Cross4157e882019-06-06 16:57:04 -0700732func (m *ModuleBase) MultiTargets() []Target {
733 return m.commonProperties.CompileMultiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -0700734}
735
Colin Cross4157e882019-06-06 16:57:04 -0700736func (m *ModuleBase) Os() OsType {
737 return m.Target().Os
Dan Willemsen490fd492015-11-24 17:53:15 -0800738}
739
Colin Cross4157e882019-06-06 16:57:04 -0700740func (m *ModuleBase) Host() bool {
741 return m.Os().Class == Host || m.Os().Class == HostCross
Dan Willemsen97750522016-02-09 17:43:51 -0800742}
743
Colin Cross4157e882019-06-06 16:57:04 -0700744func (m *ModuleBase) Arch() Arch {
745 return m.Target().Arch
Dan Willemsen97750522016-02-09 17:43:51 -0800746}
747
Colin Cross4157e882019-06-06 16:57:04 -0700748func (m *ModuleBase) ArchSpecific() bool {
749 return m.commonProperties.ArchSpecific
Dan Willemsen0b24c742016-10-04 15:13:37 -0700750}
751
Colin Cross4157e882019-06-06 16:57:04 -0700752func (m *ModuleBase) OsClassSupported() []OsClass {
753 switch m.commonProperties.HostOrDeviceSupported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700754 case HostSupported:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700755 return []OsClass{Host, HostCross}
Dan Albertc6345fb2016-10-20 01:36:11 -0700756 case HostSupportedNoCross:
757 return []OsClass{Host}
Colin Crossa1ad8d12016-06-01 17:09:44 -0700758 case DeviceSupported:
759 return []OsClass{Device}
Dan Albert0981b5c2018-08-02 13:46:35 -0700760 case HostAndDeviceSupported, HostAndDeviceDefault:
Colin Crossa1ad8d12016-06-01 17:09:44 -0700761 var supported []OsClass
Colin Cross4157e882019-06-06 16:57:04 -0700762 if Bool(m.hostAndDeviceProperties.Host_supported) ||
763 (m.commonProperties.HostOrDeviceSupported == HostAndDeviceDefault &&
764 m.hostAndDeviceProperties.Host_supported == nil) {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700765 supported = append(supported, Host, HostCross)
766 }
Colin Cross4157e882019-06-06 16:57:04 -0700767 if m.hostAndDeviceProperties.Device_supported == nil ||
768 *m.hostAndDeviceProperties.Device_supported {
Colin Crossa1ad8d12016-06-01 17:09:44 -0700769 supported = append(supported, Device)
770 }
771 return supported
772 default:
773 return nil
774 }
Colin Cross3f40fa42015-01-30 17:27:36 -0800775}
776
Colin Cross4157e882019-06-06 16:57:04 -0700777func (m *ModuleBase) DeviceSupported() bool {
778 return m.commonProperties.HostOrDeviceSupported == DeviceSupported ||
779 m.commonProperties.HostOrDeviceSupported == HostAndDeviceSupported &&
780 (m.hostAndDeviceProperties.Device_supported == nil ||
781 *m.hostAndDeviceProperties.Device_supported)
Colin Cross3f40fa42015-01-30 17:27:36 -0800782}
783
Colin Cross4157e882019-06-06 16:57:04 -0700784func (m *ModuleBase) Platform() bool {
Justin Yund5f6c822019-06-25 16:47:17 +0900785 return !m.DeviceSpecific() && !m.SocSpecific() && !m.ProductSpecific() && !m.SystemExtSpecific()
Jiyong Parkc678ad32018-04-10 13:07:10 +0900786}
787
Colin Cross4157e882019-06-06 16:57:04 -0700788func (m *ModuleBase) DeviceSpecific() bool {
789 return Bool(m.commonProperties.Device_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900790}
791
Colin Cross4157e882019-06-06 16:57:04 -0700792func (m *ModuleBase) SocSpecific() bool {
793 return Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900794}
795
Colin Cross4157e882019-06-06 16:57:04 -0700796func (m *ModuleBase) ProductSpecific() bool {
797 return Bool(m.commonProperties.Product_specific)
Jiyong Parkc678ad32018-04-10 13:07:10 +0900798}
799
Justin Yund5f6c822019-06-25 16:47:17 +0900800func (m *ModuleBase) SystemExtSpecific() bool {
801 return Bool(m.commonProperties.System_ext_specific)
Dario Frenifd05a742018-05-29 13:28:54 +0100802}
803
Colin Cross4157e882019-06-06 16:57:04 -0700804func (m *ModuleBase) Enabled() bool {
805 if m.commonProperties.Enabled == nil {
806 return !m.Os().DefaultDisabled
Dan Willemsen490fd492015-11-24 17:53:15 -0800807 }
Colin Cross4157e882019-06-06 16:57:04 -0700808 return *m.commonProperties.Enabled
Colin Cross3f40fa42015-01-30 17:27:36 -0800809}
810
Colin Cross4157e882019-06-06 16:57:04 -0700811func (m *ModuleBase) SkipInstall() {
812 m.commonProperties.SkipInstall = true
Colin Crossce75d2c2016-10-06 16:12:58 -0700813}
814
Colin Cross4157e882019-06-06 16:57:04 -0700815func (m *ModuleBase) ExportedToMake() bool {
816 return m.commonProperties.NamespaceExportedToMake
Jiyong Park374510b2018-03-19 18:23:01 +0900817}
818
Colin Cross4157e882019-06-06 16:57:04 -0700819func (m *ModuleBase) computeInstallDeps(
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700820 ctx blueprint.ModuleContext) Paths {
Colin Cross3f40fa42015-01-30 17:27:36 -0800821
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700822 result := Paths{}
Colin Cross6b753602018-06-21 13:03:07 -0700823 // TODO(ccross): we need to use WalkDeps and have some way to know which dependencies require installation
Colin Cross3f40fa42015-01-30 17:27:36 -0800824 ctx.VisitDepsDepthFirstIf(isFileInstaller,
825 func(m blueprint.Module) {
826 fileInstaller := m.(fileInstaller)
827 files := fileInstaller.filesToInstall()
828 result = append(result, files...)
829 })
830
831 return result
832}
833
Colin Cross4157e882019-06-06 16:57:04 -0700834func (m *ModuleBase) filesToInstall() Paths {
835 return m.installFiles
Colin Cross3f40fa42015-01-30 17:27:36 -0800836}
837
Colin Cross4157e882019-06-06 16:57:04 -0700838func (m *ModuleBase) NoAddressSanitizer() bool {
839 return m.noAddressSanitizer
Colin Cross3f40fa42015-01-30 17:27:36 -0800840}
841
Colin Cross4157e882019-06-06 16:57:04 -0700842func (m *ModuleBase) InstallInData() bool {
Dan Willemsen782a2d12015-12-21 14:55:28 -0800843 return false
844}
845
Colin Cross4157e882019-06-06 16:57:04 -0700846func (m *ModuleBase) InstallInSanitizerDir() bool {
Vishwath Mohan1dd88392017-03-29 22:00:18 -0700847 return false
848}
849
Colin Cross4157e882019-06-06 16:57:04 -0700850func (m *ModuleBase) InstallInRecovery() bool {
851 return Bool(m.commonProperties.Recovery)
Jiyong Parkf9332f12018-02-01 00:54:12 +0900852}
853
Colin Cross607d8582019-07-29 16:44:46 -0700854func (m *ModuleBase) InstallBypassMake() bool {
855 return false
856}
857
Colin Cross4157e882019-06-06 16:57:04 -0700858func (m *ModuleBase) Owner() string {
859 return String(m.commonProperties.Owner)
Sundong Ahn4fd04bb2018-08-31 18:01:37 +0900860}
861
Colin Cross4157e882019-06-06 16:57:04 -0700862func (m *ModuleBase) NoticeFile() OptionalPath {
863 return m.noticeFile
Jiyong Park52818fc2019-03-18 12:01:38 +0900864}
865
Colin Cross4157e882019-06-06 16:57:04 -0700866func (m *ModuleBase) generateModuleTarget(ctx ModuleContext) {
Dan Willemsen34cc69e2015-09-23 15:26:20 -0700867 allInstalledFiles := Paths{}
868 allCheckbuildFiles := Paths{}
Colin Cross0875c522017-11-28 17:34:01 -0800869 ctx.VisitAllModuleVariants(func(module Module) {
870 a := module.base()
Colin Crossc9404352015-03-26 16:10:12 -0700871 allInstalledFiles = append(allInstalledFiles, a.installFiles...)
872 allCheckbuildFiles = append(allCheckbuildFiles, a.checkbuildFiles...)
Colin Cross3f40fa42015-01-30 17:27:36 -0800873 })
874
Colin Cross0875c522017-11-28 17:34:01 -0800875 var deps Paths
Colin Cross9454bfa2015-03-17 13:24:18 -0700876
Jeff Gaston088e29e2017-11-29 16:47:17 -0800877 namespacePrefix := ctx.Namespace().(*Namespace).id
878 if namespacePrefix != "" {
879 namespacePrefix = namespacePrefix + "-"
880 }
881
Colin Cross3f40fa42015-01-30 17:27:36 -0800882 if len(allInstalledFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -0800883 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-install")
Colin Cross0875c522017-11-28 17:34:01 -0800884 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -0700885 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -0800886 Output: name,
887 Implicits: allInstalledFiles,
Colin Crossaabf6792017-11-29 00:27:14 -0800888 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross9454bfa2015-03-17 13:24:18 -0700889 })
890 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -0700891 m.installTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -0700892 }
893
894 if len(allCheckbuildFiles) > 0 {
Jeff Gaston088e29e2017-11-29 16:47:17 -0800895 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+"-checkbuild")
Colin Cross0875c522017-11-28 17:34:01 -0800896 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -0700897 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -0800898 Output: name,
899 Implicits: allCheckbuildFiles,
Colin Cross9454bfa2015-03-17 13:24:18 -0700900 })
901 deps = append(deps, name)
Colin Cross4157e882019-06-06 16:57:04 -0700902 m.checkbuildTarget = name
Colin Cross9454bfa2015-03-17 13:24:18 -0700903 }
904
905 if len(deps) > 0 {
Dan Willemsen5ba07e82015-12-11 13:51:06 -0800906 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -0800907 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -0800908 suffix = "-soong"
909 }
910
Jeff Gaston088e29e2017-11-29 16:47:17 -0800911 name := PathForPhony(ctx, namespacePrefix+ctx.ModuleName()+suffix)
Colin Cross0875c522017-11-28 17:34:01 -0800912 ctx.Build(pctx, BuildParams{
Colin Cross9454bfa2015-03-17 13:24:18 -0700913 Rule: blueprint.Phony,
Jeff Gaston088e29e2017-11-29 16:47:17 -0800914 Outputs: []WritablePath{name},
Colin Cross9454bfa2015-03-17 13:24:18 -0700915 Implicits: deps,
Colin Cross3f40fa42015-01-30 17:27:36 -0800916 })
Colin Cross1f8c52b2015-06-16 16:38:17 -0700917
Colin Cross4157e882019-06-06 16:57:04 -0700918 m.blueprintDir = ctx.ModuleDir()
Colin Cross3f40fa42015-01-30 17:27:36 -0800919 }
920}
921
Colin Cross4157e882019-06-06 16:57:04 -0700922func determineModuleKind(m *ModuleBase, ctx blueprint.BaseModuleContext) moduleKind {
923 var socSpecific = Bool(m.commonProperties.Vendor) || Bool(m.commonProperties.Proprietary) || Bool(m.commonProperties.Soc_specific)
924 var deviceSpecific = Bool(m.commonProperties.Device_specific)
925 var productSpecific = Bool(m.commonProperties.Product_specific)
Justin Yund5f6c822019-06-25 16:47:17 +0900926 var systemExtSpecific = Bool(m.commonProperties.System_ext_specific)
Jiyong Park2db76922017-11-08 16:03:48 +0900927
Dario Frenifd05a742018-05-29 13:28:54 +0100928 msg := "conflicting value set here"
929 if socSpecific && deviceSpecific {
930 ctx.PropertyErrorf("device_specific", "a module cannot be specific to SoC and device at the same time.")
Colin Cross4157e882019-06-06 16:57:04 -0700931 if Bool(m.commonProperties.Vendor) {
Jiyong Park2db76922017-11-08 16:03:48 +0900932 ctx.PropertyErrorf("vendor", msg)
933 }
Colin Cross4157e882019-06-06 16:57:04 -0700934 if Bool(m.commonProperties.Proprietary) {
Jiyong Park2db76922017-11-08 16:03:48 +0900935 ctx.PropertyErrorf("proprietary", msg)
936 }
Colin Cross4157e882019-06-06 16:57:04 -0700937 if Bool(m.commonProperties.Soc_specific) {
Jiyong Park2db76922017-11-08 16:03:48 +0900938 ctx.PropertyErrorf("soc_specific", msg)
939 }
940 }
941
Justin Yund5f6c822019-06-25 16:47:17 +0900942 if productSpecific && systemExtSpecific {
943 ctx.PropertyErrorf("product_specific", "a module cannot be specific to product and system_ext at the same time.")
944 ctx.PropertyErrorf("system_ext_specific", msg)
Dario Frenifd05a742018-05-29 13:28:54 +0100945 }
946
Justin Yund5f6c822019-06-25 16:47:17 +0900947 if (socSpecific || deviceSpecific) && (productSpecific || systemExtSpecific) {
Dario Frenifd05a742018-05-29 13:28:54 +0100948 if productSpecific {
949 ctx.PropertyErrorf("product_specific", "a module cannot be specific to SoC or device and product at the same time.")
950 } else {
Justin Yund5f6c822019-06-25 16:47:17 +0900951 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 +0100952 }
953 if deviceSpecific {
954 ctx.PropertyErrorf("device_specific", msg)
955 } else {
Colin Cross4157e882019-06-06 16:57:04 -0700956 if Bool(m.commonProperties.Vendor) {
Dario Frenifd05a742018-05-29 13:28:54 +0100957 ctx.PropertyErrorf("vendor", msg)
958 }
Colin Cross4157e882019-06-06 16:57:04 -0700959 if Bool(m.commonProperties.Proprietary) {
Dario Frenifd05a742018-05-29 13:28:54 +0100960 ctx.PropertyErrorf("proprietary", msg)
961 }
Colin Cross4157e882019-06-06 16:57:04 -0700962 if Bool(m.commonProperties.Soc_specific) {
Dario Frenifd05a742018-05-29 13:28:54 +0100963 ctx.PropertyErrorf("soc_specific", msg)
964 }
965 }
966 }
967
Jiyong Park2db76922017-11-08 16:03:48 +0900968 if productSpecific {
969 return productSpecificModule
Justin Yund5f6c822019-06-25 16:47:17 +0900970 } else if systemExtSpecific {
971 return systemExtSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +0900972 } else if deviceSpecific {
973 return deviceSpecificModule
974 } else if socSpecific {
975 return socSpecificModule
976 } else {
977 return platformModule
978 }
979}
980
Colin Cross0ea8ba82019-06-06 14:33:29 -0700981func (m *ModuleBase) baseModuleContextFactory(ctx blueprint.BaseModuleContext) baseModuleContext {
982 return baseModuleContext{
983 BaseModuleContext: ctx,
984 target: m.commonProperties.CompileTarget,
985 targetPrimary: m.commonProperties.CompilePrimary,
986 multiTargets: m.commonProperties.CompileMultiTargets,
987 kind: determineModuleKind(m, ctx),
988 config: ctx.Config().(Config),
Colin Cross3f40fa42015-01-30 17:27:36 -0800989 }
Colin Cross3f40fa42015-01-30 17:27:36 -0800990}
991
Colin Cross4157e882019-06-06 16:57:04 -0700992func (m *ModuleBase) GenerateBuildActions(blueprintCtx blueprint.ModuleContext) {
Colin Cross25de6c32019-06-06 14:29:25 -0700993 ctx := &moduleContext{
Colin Cross0ea8ba82019-06-06 14:33:29 -0700994 module: m.module,
Colin Crossdc35e212019-06-06 16:13:11 -0700995 bp: blueprintCtx,
Colin Cross0ea8ba82019-06-06 14:33:29 -0700996 baseModuleContext: m.baseModuleContextFactory(blueprintCtx),
997 installDeps: m.computeInstallDeps(blueprintCtx),
998 installFiles: m.installFiles,
Colin Cross0ea8ba82019-06-06 14:33:29 -0700999 variables: make(map[string]string),
Colin Cross3f40fa42015-01-30 17:27:36 -08001000 }
1001
Colin Cross6c4f21f2019-06-06 15:41:36 -07001002 // Temporarily continue to call blueprintCtx.GetMissingDependencies() to maintain the previous behavior of never
1003 // reporting missing dependency errors in Blueprint when AllowMissingDependencies == true.
1004 // TODO: This will be removed once defaults modules handle missing dependency errors
1005 blueprintCtx.GetMissingDependencies()
1006
Colin Crossdc35e212019-06-06 16:13:11 -07001007 // For the final GenerateAndroidBuildActions pass, require that all visited dependencies Soong modules and
1008 // are enabled.
1009 ctx.baseModuleContext.strictVisitDeps = true
1010
Colin Cross4c83e5c2019-02-25 14:54:28 -08001011 if ctx.config.captureBuild {
1012 ctx.ruleParams = make(map[blueprint.Rule]blueprint.RuleParams)
1013 }
1014
Colin Cross67a5c132017-05-09 13:45:28 -07001015 desc := "//" + ctx.ModuleDir() + ":" + ctx.ModuleName() + " "
1016 var suffix []string
Colin Cross0875c522017-11-28 17:34:01 -08001017 if ctx.Os().Class != Device && ctx.Os().Class != Generic {
1018 suffix = append(suffix, ctx.Os().String())
Colin Cross67a5c132017-05-09 13:45:28 -07001019 }
Colin Cross0875c522017-11-28 17:34:01 -08001020 if !ctx.PrimaryArch() {
1021 suffix = append(suffix, ctx.Arch().ArchType.String())
Colin Cross67a5c132017-05-09 13:45:28 -07001022 }
1023
1024 ctx.Variable(pctx, "moduleDesc", desc)
1025
1026 s := ""
1027 if len(suffix) > 0 {
1028 s = " [" + strings.Join(suffix, " ") + "]"
1029 }
1030 ctx.Variable(pctx, "moduleDescSuffix", s)
1031
Dan Willemsen569edc52018-11-19 09:33:29 -08001032 // Some common property checks for properties that will be used later in androidmk.go
Colin Cross4157e882019-06-06 16:57:04 -07001033 if m.commonProperties.Dist.Dest != nil {
1034 _, err := validateSafePath(*m.commonProperties.Dist.Dest)
Dan Willemsen569edc52018-11-19 09:33:29 -08001035 if err != nil {
1036 ctx.PropertyErrorf("dist.dest", "%s", err.Error())
1037 }
1038 }
Colin Cross4157e882019-06-06 16:57:04 -07001039 if m.commonProperties.Dist.Dir != nil {
1040 _, err := validateSafePath(*m.commonProperties.Dist.Dir)
Dan Willemsen569edc52018-11-19 09:33:29 -08001041 if err != nil {
1042 ctx.PropertyErrorf("dist.dir", "%s", err.Error())
1043 }
1044 }
Colin Cross4157e882019-06-06 16:57:04 -07001045 if m.commonProperties.Dist.Suffix != nil {
1046 if strings.Contains(*m.commonProperties.Dist.Suffix, "/") {
Dan Willemsen569edc52018-11-19 09:33:29 -08001047 ctx.PropertyErrorf("dist.suffix", "Suffix may not contain a '/' character.")
1048 }
1049 }
1050
Colin Cross4157e882019-06-06 16:57:04 -07001051 if m.Enabled() {
Jooyung Hand48f3c32019-08-23 11:18:57 +09001052 // ensure all direct android.Module deps are enabled
1053 ctx.VisitDirectDepsBlueprint(func(bm blueprint.Module) {
1054 if _, ok := bm.(Module); ok {
1055 ctx.validateAndroidModule(bm, ctx.baseModuleContext.strictVisitDeps)
1056 }
1057 })
1058
Colin Cross4157e882019-06-06 16:57:04 -07001059 notice := proptools.StringDefault(m.commonProperties.Notice, "NOTICE")
1060 if module := SrcIsModule(notice); module != "" {
1061 m.noticeFile = ctx.ExpandOptionalSource(&notice, "notice")
Jiyong Park52818fc2019-03-18 12:01:38 +09001062 } else {
1063 noticePath := filepath.Join(ctx.ModuleDir(), notice)
Colin Cross4157e882019-06-06 16:57:04 -07001064 m.noticeFile = ExistentPathForSource(ctx, noticePath)
Jaewoong Jung62707f72018-11-16 13:26:43 -08001065 }
Jaewoong Jung5b425e22019-06-17 17:40:56 -07001066
1067 m.module.GenerateAndroidBuildActions(ctx)
1068 if ctx.Failed() {
1069 return
1070 }
1071
1072 m.installFiles = append(m.installFiles, ctx.installFiles...)
1073 m.checkbuildFiles = append(m.checkbuildFiles, ctx.checkbuildFiles...)
Colin Crossdc35e212019-06-06 16:13:11 -07001074 } else if ctx.Config().AllowMissingDependencies() {
1075 // If the module is not enabled it will not create any build rules, nothing will call
1076 // ctx.GetMissingDependencies(), and blueprint will consider the missing dependencies to be unhandled
1077 // and report them as an error even when AllowMissingDependencies = true. Call
1078 // ctx.GetMissingDependencies() here to tell blueprint not to handle them.
1079 ctx.GetMissingDependencies()
Colin Cross3f40fa42015-01-30 17:27:36 -08001080 }
1081
Colin Cross4157e882019-06-06 16:57:04 -07001082 if m == ctx.FinalModule().(Module).base() {
1083 m.generateModuleTarget(ctx)
Colin Cross9b1d13d2016-09-19 15:18:11 -07001084 if ctx.Failed() {
1085 return
1086 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001087 }
Colin Crosscec81712017-07-13 14:43:27 -07001088
Colin Cross4157e882019-06-06 16:57:04 -07001089 m.buildParams = ctx.buildParams
1090 m.ruleParams = ctx.ruleParams
1091 m.variables = ctx.variables
Colin Cross3f40fa42015-01-30 17:27:36 -08001092}
1093
Colin Cross0ea8ba82019-06-06 14:33:29 -07001094type baseModuleContext struct {
1095 blueprint.BaseModuleContext
Colin Cross8b74d172016-09-13 09:59:14 -07001096 target Target
Colin Crossee0bc3b2018-10-02 22:01:37 -07001097 multiTargets []Target
Colin Cross8b74d172016-09-13 09:59:14 -07001098 targetPrimary bool
1099 debug bool
Jiyong Park2db76922017-11-08 16:03:48 +09001100 kind moduleKind
Colin Cross8b74d172016-09-13 09:59:14 -07001101 config Config
Colin Crossdc35e212019-06-06 16:13:11 -07001102
1103 walkPath []Module
1104
1105 strictVisitDeps bool // If true, enforce that all dependencies are enabled
Colin Crossf6566ed2015-03-24 11:13:38 -07001106}
1107
Colin Cross25de6c32019-06-06 14:29:25 -07001108type moduleContext struct {
Colin Crossdc35e212019-06-06 16:13:11 -07001109 bp blueprint.ModuleContext
Colin Cross0ea8ba82019-06-06 14:33:29 -07001110 baseModuleContext
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001111 installDeps Paths
1112 installFiles Paths
1113 checkbuildFiles Paths
Colin Cross8d8f8e22016-08-03 11:57:50 -07001114 module Module
Colin Crosscec81712017-07-13 14:43:27 -07001115
1116 // For tests
Colin Crossae887032017-10-23 17:16:14 -07001117 buildParams []BuildParams
Colin Cross4c83e5c2019-02-25 14:54:28 -08001118 ruleParams map[blueprint.Rule]blueprint.RuleParams
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001119 variables map[string]string
Colin Cross6ff51382015-12-17 16:39:19 -08001120}
1121
Colin Crossb88b3c52019-06-10 15:15:17 -07001122func (m *moduleContext) ninjaError(params BuildParams, err error) (PackageContext, BuildParams) {
1123 return pctx, BuildParams{
Colin Cross4b69c492019-06-07 13:06:06 -07001124 Rule: ErrorRule,
1125 Description: params.Description,
1126 Output: params.Output,
1127 Outputs: params.Outputs,
1128 ImplicitOutput: params.ImplicitOutput,
1129 ImplicitOutputs: params.ImplicitOutputs,
Colin Cross6ff51382015-12-17 16:39:19 -08001130 Args: map[string]string{
1131 "error": err.Error(),
1132 },
Colin Crossb88b3c52019-06-10 15:15:17 -07001133 }
Colin Cross3f40fa42015-01-30 17:27:36 -08001134}
1135
Colin Cross25de6c32019-06-06 14:29:25 -07001136func (m *moduleContext) ModuleBuild(pctx PackageContext, params ModuleBuildParams) {
1137 m.Build(pctx, BuildParams(params))
Colin Cross3f40fa42015-01-30 17:27:36 -08001138}
1139
Colin Cross0875c522017-11-28 17:34:01 -08001140func convertBuildParams(params BuildParams) blueprint.BuildParams {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001141 bparams := blueprint.BuildParams{
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001142 Rule: params.Rule,
Colin Cross0875c522017-11-28 17:34:01 -08001143 Description: params.Description,
Colin Cross33bfb0a2016-11-21 17:23:08 -08001144 Deps: params.Deps,
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001145 Outputs: params.Outputs.Strings(),
1146 ImplicitOutputs: params.ImplicitOutputs.Strings(),
1147 Inputs: params.Inputs.Strings(),
1148 Implicits: params.Implicits.Strings(),
1149 OrderOnly: params.OrderOnly.Strings(),
1150 Args: params.Args,
1151 Optional: !params.Default,
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001152 }
1153
Colin Cross33bfb0a2016-11-21 17:23:08 -08001154 if params.Depfile != nil {
1155 bparams.Depfile = params.Depfile.String()
1156 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001157 if params.Output != nil {
1158 bparams.Outputs = append(bparams.Outputs, params.Output.String())
1159 }
Dan Willemsen9f3c5742016-11-03 14:28:31 -07001160 if params.ImplicitOutput != nil {
1161 bparams.ImplicitOutputs = append(bparams.ImplicitOutputs, params.ImplicitOutput.String())
1162 }
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001163 if params.Input != nil {
1164 bparams.Inputs = append(bparams.Inputs, params.Input.String())
1165 }
1166 if params.Implicit != nil {
1167 bparams.Implicits = append(bparams.Implicits, params.Implicit.String())
1168 }
1169
Colin Cross0b9f31f2019-02-28 11:00:01 -08001170 bparams.Outputs = proptools.NinjaEscapeList(bparams.Outputs)
1171 bparams.ImplicitOutputs = proptools.NinjaEscapeList(bparams.ImplicitOutputs)
1172 bparams.Inputs = proptools.NinjaEscapeList(bparams.Inputs)
1173 bparams.Implicits = proptools.NinjaEscapeList(bparams.Implicits)
1174 bparams.OrderOnly = proptools.NinjaEscapeList(bparams.OrderOnly)
1175 bparams.Depfile = proptools.NinjaEscapeList([]string{bparams.Depfile})[0]
Colin Crossfe4bc362018-09-12 10:02:13 -07001176
Colin Cross0875c522017-11-28 17:34:01 -08001177 return bparams
1178}
1179
Colin Cross25de6c32019-06-06 14:29:25 -07001180func (m *moduleContext) Variable(pctx PackageContext, name, value string) {
1181 if m.config.captureBuild {
1182 m.variables[name] = value
Jaewoong Jung38e4fb22018-12-12 09:01:34 -08001183 }
1184
Colin Crossdc35e212019-06-06 16:13:11 -07001185 m.bp.Variable(pctx.PackageContext, name, value)
Colin Cross0875c522017-11-28 17:34:01 -08001186}
1187
Colin Cross25de6c32019-06-06 14:29:25 -07001188func (m *moduleContext) Rule(pctx PackageContext, name string, params blueprint.RuleParams,
Colin Cross0875c522017-11-28 17:34:01 -08001189 argNames ...string) blueprint.Rule {
1190
Colin Crossdc35e212019-06-06 16:13:11 -07001191 rule := m.bp.Rule(pctx.PackageContext, name, params, argNames...)
Colin Cross4c83e5c2019-02-25 14:54:28 -08001192
Colin Cross25de6c32019-06-06 14:29:25 -07001193 if m.config.captureBuild {
1194 m.ruleParams[rule] = params
Colin Cross4c83e5c2019-02-25 14:54:28 -08001195 }
1196
1197 return rule
Colin Cross0875c522017-11-28 17:34:01 -08001198}
1199
Colin Cross25de6c32019-06-06 14:29:25 -07001200func (m *moduleContext) Build(pctx PackageContext, params BuildParams) {
Colin Crossb88b3c52019-06-10 15:15:17 -07001201 if params.Description != "" {
1202 params.Description = "${moduleDesc}" + params.Description + "${moduleDescSuffix}"
1203 }
1204
1205 if missingDeps := m.GetMissingDependencies(); len(missingDeps) > 0 {
1206 pctx, params = m.ninjaError(params, fmt.Errorf("module %s missing dependencies: %s\n",
1207 m.ModuleName(), strings.Join(missingDeps, ", ")))
1208 }
1209
Colin Cross25de6c32019-06-06 14:29:25 -07001210 if m.config.captureBuild {
1211 m.buildParams = append(m.buildParams, params)
Colin Cross0875c522017-11-28 17:34:01 -08001212 }
1213
Colin Crossdc35e212019-06-06 16:13:11 -07001214 m.bp.Build(pctx.PackageContext, convertBuildParams(params))
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001215}
1216
Colin Crossdc35e212019-06-06 16:13:11 -07001217func (b *baseModuleContext) Module() Module {
1218 module, _ := b.BaseModuleContext.Module().(Module)
1219 return module
1220}
1221
1222func (b *baseModuleContext) Config() Config {
1223 return b.BaseModuleContext.Config().(Config)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001224}
1225
Colin Cross25de6c32019-06-06 14:29:25 -07001226func (m *moduleContext) GetMissingDependencies() []string {
Colin Cross6c4f21f2019-06-06 15:41:36 -07001227 var missingDeps []string
1228 missingDeps = append(missingDeps, m.Module().base().commonProperties.MissingDeps...)
Colin Crossdc35e212019-06-06 16:13:11 -07001229 missingDeps = append(missingDeps, m.bp.GetMissingDependencies()...)
Colin Cross6c4f21f2019-06-06 15:41:36 -07001230 missingDeps = FirstUniqueStrings(missingDeps)
1231 return missingDeps
Colin Cross6ff51382015-12-17 16:39:19 -08001232}
1233
Colin Crossdc35e212019-06-06 16:13:11 -07001234func (b *baseModuleContext) AddMissingDependencies(deps []string) {
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001235 if deps != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001236 missingDeps := &b.Module().base().commonProperties.MissingDeps
Colin Cross6c4f21f2019-06-06 15:41:36 -07001237 *missingDeps = append(*missingDeps, deps...)
1238 *missingDeps = FirstUniqueStrings(*missingDeps)
Dan Willemsen6553f5e2016-03-10 18:14:25 -08001239 }
1240}
1241
Colin Crossdc35e212019-06-06 16:13:11 -07001242func (b *baseModuleContext) validateAndroidModule(module blueprint.Module, strict bool) Module {
Colin Crossd11fcda2017-10-23 17:59:01 -07001243 aModule, _ := module.(Module)
Colin Crossdc35e212019-06-06 16:13:11 -07001244
1245 if !strict {
1246 return aModule
1247 }
1248
Colin Cross380c69a2019-06-10 17:49:58 +00001249 if aModule == nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001250 b.ModuleErrorf("module %q not an android module", b.OtherModuleName(module))
Colin Cross380c69a2019-06-10 17:49:58 +00001251 return nil
1252 }
1253
1254 if !aModule.Enabled() {
Colin Crossdc35e212019-06-06 16:13:11 -07001255 if b.Config().AllowMissingDependencies() {
1256 b.AddMissingDependencies([]string{b.OtherModuleName(aModule)})
Colin Cross380c69a2019-06-10 17:49:58 +00001257 } else {
Colin Crossdc35e212019-06-06 16:13:11 -07001258 b.ModuleErrorf("depends on disabled module %q", b.OtherModuleName(aModule))
Colin Cross380c69a2019-06-10 17:49:58 +00001259 }
1260 return nil
1261 }
Colin Crossd11fcda2017-10-23 17:59:01 -07001262 return aModule
1263}
1264
Colin Crossdc35e212019-06-06 16:13:11 -07001265func (b *baseModuleContext) getDirectDepInternal(name string, tag blueprint.DependencyTag) (blueprint.Module, blueprint.DependencyTag) {
Jiyong Parkf2976302019-04-17 21:47:37 +09001266 type dep struct {
1267 mod blueprint.Module
1268 tag blueprint.DependencyTag
1269 }
1270 var deps []dep
Colin Crossdc35e212019-06-06 16:13:11 -07001271 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001272 if aModule, _ := module.(Module); aModule != nil && aModule.base().BaseModuleName() == name {
Colin Crossdc35e212019-06-06 16:13:11 -07001273 returnedTag := b.BaseModuleContext.OtherModuleDependencyTag(aModule)
Jiyong Parkf2976302019-04-17 21:47:37 +09001274 if tag == nil || returnedTag == tag {
1275 deps = append(deps, dep{aModule, returnedTag})
1276 }
1277 }
1278 })
1279 if len(deps) == 1 {
1280 return deps[0].mod, deps[0].tag
1281 } else if len(deps) >= 2 {
1282 panic(fmt.Errorf("Multiple dependencies having same BaseModuleName() %q found from %q",
Colin Crossdc35e212019-06-06 16:13:11 -07001283 name, b.ModuleName()))
Jiyong Parkf2976302019-04-17 21:47:37 +09001284 } else {
1285 return nil, nil
1286 }
1287}
1288
Colin Crossdc35e212019-06-06 16:13:11 -07001289func (b *baseModuleContext) GetDirectDepsWithTag(tag blueprint.DependencyTag) []Module {
Colin Cross0ef08162019-05-01 15:50:51 -07001290 var deps []Module
Colin Crossdc35e212019-06-06 16:13:11 -07001291 b.VisitDirectDepsBlueprint(func(module blueprint.Module) {
Colin Cross25de6c32019-06-06 14:29:25 -07001292 if aModule, _ := module.(Module); aModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001293 if b.BaseModuleContext.OtherModuleDependencyTag(aModule) == tag {
Colin Cross0ef08162019-05-01 15:50:51 -07001294 deps = append(deps, aModule)
1295 }
1296 }
1297 })
1298 return deps
1299}
1300
Colin Cross25de6c32019-06-06 14:29:25 -07001301func (m *moduleContext) GetDirectDepWithTag(name string, tag blueprint.DependencyTag) blueprint.Module {
1302 module, _ := m.getDirectDepInternal(name, tag)
1303 return module
Jiyong Parkf2976302019-04-17 21:47:37 +09001304}
1305
Colin Crossdc35e212019-06-06 16:13:11 -07001306func (b *baseModuleContext) GetDirectDep(name string) (blueprint.Module, blueprint.DependencyTag) {
1307 return b.getDirectDepInternal(name, nil)
Jiyong Parkf2976302019-04-17 21:47:37 +09001308}
1309
Colin Crossdc35e212019-06-06 16:13:11 -07001310func (b *baseModuleContext) VisitDirectDepsBlueprint(visit func(blueprint.Module)) {
1311 b.BaseModuleContext.VisitDirectDeps(visit)
Colin Cross35143d02017-11-16 00:11:20 -08001312}
1313
Colin Crossdc35e212019-06-06 16:13:11 -07001314func (b *baseModuleContext) VisitDirectDeps(visit func(Module)) {
1315 b.BaseModuleContext.VisitDirectDeps(func(module blueprint.Module) {
1316 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001317 visit(aModule)
1318 }
1319 })
1320}
1321
Colin Crossdc35e212019-06-06 16:13:11 -07001322func (b *baseModuleContext) VisitDirectDepsWithTag(tag blueprint.DependencyTag, visit func(Module)) {
1323 b.BaseModuleContext.VisitDirectDeps(func(module blueprint.Module) {
1324 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
1325 if b.BaseModuleContext.OtherModuleDependencyTag(aModule) == tag {
Colin Crossee6143c2017-12-30 17:54:27 -08001326 visit(aModule)
1327 }
1328 }
1329 })
1330}
1331
Colin Crossdc35e212019-06-06 16:13:11 -07001332func (b *baseModuleContext) VisitDirectDepsIf(pred func(Module) bool, visit func(Module)) {
1333 b.BaseModuleContext.VisitDirectDepsIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001334 // pred
1335 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001336 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001337 return pred(aModule)
1338 } else {
1339 return false
1340 }
1341 },
1342 // visit
1343 func(module blueprint.Module) {
1344 visit(module.(Module))
1345 })
1346}
1347
Colin Crossdc35e212019-06-06 16:13:11 -07001348func (b *baseModuleContext) VisitDepsDepthFirst(visit func(Module)) {
1349 b.BaseModuleContext.VisitDepsDepthFirst(func(module blueprint.Module) {
1350 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001351 visit(aModule)
1352 }
1353 })
1354}
1355
Colin Crossdc35e212019-06-06 16:13:11 -07001356func (b *baseModuleContext) VisitDepsDepthFirstIf(pred func(Module) bool, visit func(Module)) {
1357 b.BaseModuleContext.VisitDepsDepthFirstIf(
Colin Crossd11fcda2017-10-23 17:59:01 -07001358 // pred
1359 func(module blueprint.Module) bool {
Colin Crossdc35e212019-06-06 16:13:11 -07001360 if aModule := b.validateAndroidModule(module, b.strictVisitDeps); aModule != nil {
Colin Crossd11fcda2017-10-23 17:59:01 -07001361 return pred(aModule)
1362 } else {
1363 return false
1364 }
1365 },
1366 // visit
1367 func(module blueprint.Module) {
1368 visit(module.(Module))
1369 })
1370}
1371
Colin Crossdc35e212019-06-06 16:13:11 -07001372func (b *baseModuleContext) WalkDepsBlueprint(visit func(blueprint.Module, blueprint.Module) bool) {
1373 b.BaseModuleContext.WalkDeps(visit)
Alex Light778127a2019-02-27 14:19:50 -08001374}
1375
Colin Crossdc35e212019-06-06 16:13:11 -07001376func (b *baseModuleContext) WalkDeps(visit func(Module, Module) bool) {
1377 b.walkPath = []Module{b.Module()}
1378 b.BaseModuleContext.WalkDeps(func(child, parent blueprint.Module) bool {
1379 childAndroidModule, _ := child.(Module)
1380 parentAndroidModule, _ := parent.(Module)
Colin Crossd11fcda2017-10-23 17:59:01 -07001381 if childAndroidModule != nil && parentAndroidModule != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001382 // record walkPath before visit
1383 for b.walkPath[len(b.walkPath)-1] != parentAndroidModule {
1384 b.walkPath = b.walkPath[0 : len(b.walkPath)-1]
1385 }
1386 b.walkPath = append(b.walkPath, childAndroidModule)
Colin Crossd11fcda2017-10-23 17:59:01 -07001387 return visit(childAndroidModule, parentAndroidModule)
1388 } else {
1389 return false
1390 }
1391 })
1392}
1393
Colin Crossdc35e212019-06-06 16:13:11 -07001394func (b *baseModuleContext) GetWalkPath() []Module {
1395 return b.walkPath
1396}
1397
Colin Cross25de6c32019-06-06 14:29:25 -07001398func (m *moduleContext) VisitAllModuleVariants(visit func(Module)) {
Colin Crossdc35e212019-06-06 16:13:11 -07001399 m.bp.VisitAllModuleVariants(func(module blueprint.Module) {
Colin Cross0875c522017-11-28 17:34:01 -08001400 visit(module.(Module))
1401 })
1402}
1403
Colin Cross25de6c32019-06-06 14:29:25 -07001404func (m *moduleContext) PrimaryModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001405 return m.bp.PrimaryModule().(Module)
Colin Cross0875c522017-11-28 17:34:01 -08001406}
1407
Colin Cross25de6c32019-06-06 14:29:25 -07001408func (m *moduleContext) FinalModule() Module {
Colin Crossdc35e212019-06-06 16:13:11 -07001409 return m.bp.FinalModule().(Module)
1410}
1411
1412func (m *moduleContext) ModuleSubDir() string {
1413 return m.bp.ModuleSubDir()
Colin Cross0875c522017-11-28 17:34:01 -08001414}
1415
Colin Cross0ea8ba82019-06-06 14:33:29 -07001416func (b *baseModuleContext) Target() Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001417 return b.target
Colin Crossa1ad8d12016-06-01 17:09:44 -07001418}
1419
Colin Cross0ea8ba82019-06-06 14:33:29 -07001420func (b *baseModuleContext) TargetPrimary() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001421 return b.targetPrimary
Colin Cross8b74d172016-09-13 09:59:14 -07001422}
1423
Colin Cross0ea8ba82019-06-06 14:33:29 -07001424func (b *baseModuleContext) MultiTargets() []Target {
Colin Cross25de6c32019-06-06 14:29:25 -07001425 return b.multiTargets
Colin Crossee0bc3b2018-10-02 22:01:37 -07001426}
1427
Colin Cross0ea8ba82019-06-06 14:33:29 -07001428func (b *baseModuleContext) Arch() Arch {
Colin Cross25de6c32019-06-06 14:29:25 -07001429 return b.target.Arch
Colin Cross3f40fa42015-01-30 17:27:36 -08001430}
1431
Colin Cross0ea8ba82019-06-06 14:33:29 -07001432func (b *baseModuleContext) Os() OsType {
Colin Cross25de6c32019-06-06 14:29:25 -07001433 return b.target.Os
Dan Willemsen490fd492015-11-24 17:53:15 -08001434}
1435
Colin Cross0ea8ba82019-06-06 14:33:29 -07001436func (b *baseModuleContext) Host() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001437 return b.target.Os.Class == Host || b.target.Os.Class == HostCross
Colin Crossf6566ed2015-03-24 11:13:38 -07001438}
1439
Colin Cross0ea8ba82019-06-06 14:33:29 -07001440func (b *baseModuleContext) Device() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001441 return b.target.Os.Class == Device
Colin Crossf6566ed2015-03-24 11:13:38 -07001442}
1443
Colin Cross0ea8ba82019-06-06 14:33:29 -07001444func (b *baseModuleContext) Darwin() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001445 return b.target.Os == Darwin
Colin Cross0af4b842015-04-30 16:36:18 -07001446}
1447
Colin Cross0ea8ba82019-06-06 14:33:29 -07001448func (b *baseModuleContext) Fuchsia() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001449 return b.target.Os == Fuchsia
Doug Horn21b94272019-01-16 12:06:11 -08001450}
1451
Colin Cross0ea8ba82019-06-06 14:33:29 -07001452func (b *baseModuleContext) Windows() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001453 return b.target.Os == Windows
Colin Cross3edeee12017-04-04 12:59:48 -07001454}
1455
Colin Cross0ea8ba82019-06-06 14:33:29 -07001456func (b *baseModuleContext) Debug() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001457 return b.debug
Colin Crossf6566ed2015-03-24 11:13:38 -07001458}
1459
Colin Cross0ea8ba82019-06-06 14:33:29 -07001460func (b *baseModuleContext) PrimaryArch() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001461 if len(b.config.Targets[b.target.Os]) <= 1 {
Colin Cross67a5c132017-05-09 13:45:28 -07001462 return true
1463 }
Colin Cross25de6c32019-06-06 14:29:25 -07001464 return b.target.Arch.ArchType == b.config.Targets[b.target.Os][0].Arch.ArchType
Colin Cross1e7d3702016-08-24 15:25:47 -07001465}
1466
Colin Cross0ea8ba82019-06-06 14:33:29 -07001467func (b *baseModuleContext) AConfig() Config {
Colin Cross25de6c32019-06-06 14:29:25 -07001468 return b.config
Colin Cross1332b002015-04-07 17:11:30 -07001469}
1470
Colin Cross0ea8ba82019-06-06 14:33:29 -07001471func (b *baseModuleContext) DeviceConfig() DeviceConfig {
Colin Cross25de6c32019-06-06 14:29:25 -07001472 return DeviceConfig{b.config.deviceConfig}
Colin Cross9272ade2016-08-17 15:24:12 -07001473}
1474
Colin Cross0ea8ba82019-06-06 14:33:29 -07001475func (b *baseModuleContext) Platform() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001476 return b.kind == platformModule
Jiyong Park2db76922017-11-08 16:03:48 +09001477}
1478
Colin Cross0ea8ba82019-06-06 14:33:29 -07001479func (b *baseModuleContext) DeviceSpecific() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001480 return b.kind == deviceSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001481}
1482
Colin Cross0ea8ba82019-06-06 14:33:29 -07001483func (b *baseModuleContext) SocSpecific() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001484 return b.kind == socSpecificModule
Jiyong Park2db76922017-11-08 16:03:48 +09001485}
1486
Colin Cross0ea8ba82019-06-06 14:33:29 -07001487func (b *baseModuleContext) ProductSpecific() bool {
Colin Cross25de6c32019-06-06 14:29:25 -07001488 return b.kind == productSpecificModule
Dan Willemsen782a2d12015-12-21 14:55:28 -08001489}
1490
Justin Yund5f6c822019-06-25 16:47:17 +09001491func (b *baseModuleContext) SystemExtSpecific() bool {
1492 return b.kind == systemExtSpecificModule
Dario Frenifd05a742018-05-29 13:28:54 +01001493}
1494
Jiyong Park5baac542018-08-28 09:55:37 +09001495// Makes this module a platform module, i.e. not specific to soc, device,
Justin Yund5f6c822019-06-25 16:47:17 +09001496// product, or system_ext.
Colin Cross4157e882019-06-06 16:57:04 -07001497func (m *ModuleBase) MakeAsPlatform() {
1498 m.commonProperties.Vendor = boolPtr(false)
1499 m.commonProperties.Proprietary = boolPtr(false)
1500 m.commonProperties.Soc_specific = boolPtr(false)
1501 m.commonProperties.Product_specific = boolPtr(false)
Justin Yund5f6c822019-06-25 16:47:17 +09001502 m.commonProperties.System_ext_specific = boolPtr(false)
Jiyong Park5baac542018-08-28 09:55:37 +09001503}
1504
Colin Cross4157e882019-06-06 16:57:04 -07001505func (m *ModuleBase) EnableNativeBridgeSupportByDefault() {
1506 m.commonProperties.Native_bridge_supported = boolPtr(true)
dimitry03dc3f62019-05-09 14:07:34 +02001507}
1508
Jooyung Han344d5432019-08-23 11:17:39 +09001509// IsNativeBridgeSupported returns true if "native_bridge_supported" is explicitly set as "true"
1510func (m *ModuleBase) IsNativeBridgeSupported() bool {
1511 return proptools.Bool(m.commonProperties.Native_bridge_supported)
1512}
1513
Colin Cross25de6c32019-06-06 14:29:25 -07001514func (m *moduleContext) InstallInData() bool {
1515 return m.module.InstallInData()
Dan Willemsen782a2d12015-12-21 14:55:28 -08001516}
1517
Colin Cross25de6c32019-06-06 14:29:25 -07001518func (m *moduleContext) InstallInSanitizerDir() bool {
1519 return m.module.InstallInSanitizerDir()
Vishwath Mohan1dd88392017-03-29 22:00:18 -07001520}
1521
Colin Cross25de6c32019-06-06 14:29:25 -07001522func (m *moduleContext) InstallInRecovery() bool {
1523 return m.module.InstallInRecovery()
Jiyong Parkf9332f12018-02-01 00:54:12 +09001524}
1525
Colin Cross607d8582019-07-29 16:44:46 -07001526func (m *moduleContext) InstallBypassMake() bool {
1527 return m.module.InstallBypassMake()
1528}
1529
Colin Cross25de6c32019-06-06 14:29:25 -07001530func (m *moduleContext) skipInstall(fullInstallPath OutputPath) bool {
1531 if m.module.base().commonProperties.SkipInstall {
Colin Cross893d8162017-04-26 17:34:03 -07001532 return true
1533 }
1534
Colin Cross3607f212018-05-07 15:28:05 -07001535 // We'll need a solution for choosing which of modules with the same name in different
1536 // namespaces to install. For now, reuse the list of namespaces exported to Make as the
1537 // list of namespaces to install in a Soong-only build.
Colin Cross25de6c32019-06-06 14:29:25 -07001538 if !m.module.base().commonProperties.NamespaceExportedToMake {
Colin Cross3607f212018-05-07 15:28:05 -07001539 return true
1540 }
1541
Colin Cross25de6c32019-06-06 14:29:25 -07001542 if m.Device() {
Colin Cross607d8582019-07-29 16:44:46 -07001543 if m.Config().EmbeddedInMake() && !m.InstallBypassMake() {
Colin Cross893d8162017-04-26 17:34:03 -07001544 return true
1545 }
1546
Colin Cross25de6c32019-06-06 14:29:25 -07001547 if m.Config().SkipMegaDeviceInstall(fullInstallPath.String()) {
Colin Cross893d8162017-04-26 17:34:03 -07001548 return true
1549 }
1550 }
1551
1552 return false
1553}
1554
Colin Cross25de6c32019-06-06 14:29:25 -07001555func (m *moduleContext) InstallFile(installPath OutputPath, name string, srcPath Path,
Colin Crossa2344662016-03-24 13:14:12 -07001556 deps ...Path) OutputPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001557 return m.installFile(installPath, name, srcPath, Cp, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001558}
1559
Colin Cross25de6c32019-06-06 14:29:25 -07001560func (m *moduleContext) InstallExecutable(installPath OutputPath, name string, srcPath Path,
Colin Cross5c517922017-08-31 12:29:17 -07001561 deps ...Path) OutputPath {
Colin Cross25de6c32019-06-06 14:29:25 -07001562 return m.installFile(installPath, name, srcPath, CpExecutable, deps)
Colin Cross5c517922017-08-31 12:29:17 -07001563}
1564
Colin Cross25de6c32019-06-06 14:29:25 -07001565func (m *moduleContext) installFile(installPath OutputPath, name string, srcPath Path,
Colin Cross5c517922017-08-31 12:29:17 -07001566 rule blueprint.Rule, deps []Path) OutputPath {
Colin Cross35cec122015-04-02 14:37:16 -07001567
Colin Cross25de6c32019-06-06 14:29:25 -07001568 fullInstallPath := installPath.Join(m, name)
1569 m.module.base().hooks.runInstallHooks(m, fullInstallPath, false)
Colin Cross3f40fa42015-01-30 17:27:36 -08001570
Colin Cross25de6c32019-06-06 14:29:25 -07001571 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001572
Colin Cross25de6c32019-06-06 14:29:25 -07001573 deps = append(deps, m.installDeps...)
Colin Cross35cec122015-04-02 14:37:16 -07001574
Colin Cross89562dc2016-10-03 17:47:19 -07001575 var implicitDeps, orderOnlyDeps Paths
1576
Colin Cross25de6c32019-06-06 14:29:25 -07001577 if m.Host() {
Colin Cross89562dc2016-10-03 17:47:19 -07001578 // Installed host modules might be used during the build, depend directly on their
1579 // dependencies so their timestamp is updated whenever their dependency is updated
1580 implicitDeps = deps
1581 } else {
1582 orderOnlyDeps = deps
1583 }
1584
Colin Cross25de6c32019-06-06 14:29:25 -07001585 m.Build(pctx, BuildParams{
Colin Cross5c517922017-08-31 12:29:17 -07001586 Rule: rule,
Colin Cross67a5c132017-05-09 13:45:28 -07001587 Description: "install " + fullInstallPath.Base(),
1588 Output: fullInstallPath,
1589 Input: srcPath,
1590 Implicits: implicitDeps,
1591 OrderOnly: orderOnlyDeps,
Colin Cross25de6c32019-06-06 14:29:25 -07001592 Default: !m.Config().EmbeddedInMake(),
Dan Willemsen322acaf2016-01-12 23:07:05 -08001593 })
Colin Cross3f40fa42015-01-30 17:27:36 -08001594
Colin Cross25de6c32019-06-06 14:29:25 -07001595 m.installFiles = append(m.installFiles, fullInstallPath)
Dan Willemsen322acaf2016-01-12 23:07:05 -08001596 }
Colin Cross25de6c32019-06-06 14:29:25 -07001597 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross35cec122015-04-02 14:37:16 -07001598 return fullInstallPath
1599}
1600
Colin Cross25de6c32019-06-06 14:29:25 -07001601func (m *moduleContext) InstallSymlink(installPath OutputPath, name string, srcPath OutputPath) OutputPath {
1602 fullInstallPath := installPath.Join(m, name)
1603 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Colin Cross3854a602016-01-11 12:49:11 -08001604
Colin Cross25de6c32019-06-06 14:29:25 -07001605 if !m.skipInstall(fullInstallPath) {
Colin Crossce75d2c2016-10-06 16:12:58 -07001606
Alex Lightfb4353d2019-01-17 13:57:45 -08001607 relPath, err := filepath.Rel(path.Dir(fullInstallPath.String()), srcPath.String())
1608 if err != nil {
1609 panic(fmt.Sprintf("Unable to generate symlink between %q and %q: %s", fullInstallPath.Base(), srcPath.Base(), err))
1610 }
Colin Cross25de6c32019-06-06 14:29:25 -07001611 m.Build(pctx, BuildParams{
Colin Cross67a5c132017-05-09 13:45:28 -07001612 Rule: Symlink,
1613 Description: "install symlink " + fullInstallPath.Base(),
1614 Output: fullInstallPath,
1615 OrderOnly: Paths{srcPath},
Colin Cross25de6c32019-06-06 14:29:25 -07001616 Default: !m.Config().EmbeddedInMake(),
Colin Cross12fc4972016-01-11 12:49:11 -08001617 Args: map[string]string{
Alex Lightfb4353d2019-01-17 13:57:45 -08001618 "fromPath": relPath,
Colin Cross12fc4972016-01-11 12:49:11 -08001619 },
1620 })
Colin Cross3854a602016-01-11 12:49:11 -08001621
Colin Cross25de6c32019-06-06 14:29:25 -07001622 m.installFiles = append(m.installFiles, fullInstallPath)
1623 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross12fc4972016-01-11 12:49:11 -08001624 }
Colin Cross3854a602016-01-11 12:49:11 -08001625 return fullInstallPath
1626}
1627
Jiyong Parkf1194352019-02-25 11:05:47 +09001628// installPath/name -> absPath where absPath might be a path that is available only at runtime
1629// (e.g. /apex/...)
Colin Cross25de6c32019-06-06 14:29:25 -07001630func (m *moduleContext) InstallAbsoluteSymlink(installPath OutputPath, name string, absPath string) OutputPath {
1631 fullInstallPath := installPath.Join(m, name)
1632 m.module.base().hooks.runInstallHooks(m, fullInstallPath, true)
Jiyong Parkf1194352019-02-25 11:05:47 +09001633
Colin Cross25de6c32019-06-06 14:29:25 -07001634 if !m.skipInstall(fullInstallPath) {
1635 m.Build(pctx, BuildParams{
Jiyong Parkf1194352019-02-25 11:05:47 +09001636 Rule: Symlink,
1637 Description: "install symlink " + fullInstallPath.Base() + " -> " + absPath,
1638 Output: fullInstallPath,
Colin Cross25de6c32019-06-06 14:29:25 -07001639 Default: !m.Config().EmbeddedInMake(),
Jiyong Parkf1194352019-02-25 11:05:47 +09001640 Args: map[string]string{
1641 "fromPath": absPath,
1642 },
1643 })
1644
Colin Cross25de6c32019-06-06 14:29:25 -07001645 m.installFiles = append(m.installFiles, fullInstallPath)
Jiyong Parkf1194352019-02-25 11:05:47 +09001646 }
1647 return fullInstallPath
1648}
1649
Colin Cross25de6c32019-06-06 14:29:25 -07001650func (m *moduleContext) CheckbuildFile(srcPath Path) {
1651 m.checkbuildFiles = append(m.checkbuildFiles, srcPath)
Colin Cross3f40fa42015-01-30 17:27:36 -08001652}
1653
Colin Cross3f40fa42015-01-30 17:27:36 -08001654type fileInstaller interface {
Dan Willemsen34cc69e2015-09-23 15:26:20 -07001655 filesToInstall() Paths
Colin Cross3f40fa42015-01-30 17:27:36 -08001656}
1657
1658func isFileInstaller(m blueprint.Module) bool {
1659 _, ok := m.(fileInstaller)
1660 return ok
1661}
1662
1663func isAndroidModule(m blueprint.Module) bool {
Colin Cross635c3b02016-05-18 15:37:25 -07001664 _, ok := m.(Module)
Colin Cross3f40fa42015-01-30 17:27:36 -08001665 return ok
1666}
Colin Crossfce53272015-04-08 11:21:40 -07001667
Dan Willemsen2ef08f42015-06-30 18:15:24 -07001668func findStringInSlice(str string, slice []string) int {
1669 for i, s := range slice {
1670 if s == str {
1671 return i
Colin Crossfce53272015-04-08 11:21:40 -07001672 }
1673 }
Dan Willemsen2ef08f42015-06-30 18:15:24 -07001674 return -1
1675}
1676
Colin Cross41955e82019-05-29 14:40:35 -07001677// SrcIsModule decodes module references in the format ":name" into the module name, or empty string if the input
1678// was not a module reference.
1679func SrcIsModule(s string) (module string) {
Colin Cross068e0fe2016-12-13 15:23:47 -08001680 if len(s) > 1 && s[0] == ':' {
1681 return s[1:]
1682 }
1683 return ""
1684}
1685
Colin Cross41955e82019-05-29 14:40:35 -07001686// SrcIsModule decodes module references in the format ":name{.tag}" into the module name and tag, ":name" into the
1687// module name and an empty string for the tag, or empty strings if the input was not a module reference.
1688func SrcIsModuleWithTag(s string) (module, tag string) {
1689 if len(s) > 1 && s[0] == ':' {
1690 module = s[1:]
1691 if tagStart := strings.IndexByte(module, '{'); tagStart > 0 {
1692 if module[len(module)-1] == '}' {
1693 tag = module[tagStart+1 : len(module)-1]
1694 module = module[:tagStart]
1695 return module, tag
1696 }
1697 }
1698 return module, ""
1699 }
1700 return "", ""
Colin Cross068e0fe2016-12-13 15:23:47 -08001701}
1702
Colin Cross41955e82019-05-29 14:40:35 -07001703type sourceOrOutputDependencyTag struct {
1704 blueprint.BaseDependencyTag
1705 tag string
1706}
1707
1708func sourceOrOutputDepTag(tag string) blueprint.DependencyTag {
1709 return sourceOrOutputDependencyTag{tag: tag}
1710}
1711
1712var SourceDepTag = sourceOrOutputDepTag("")
Colin Cross068e0fe2016-12-13 15:23:47 -08001713
Colin Cross366938f2017-12-11 16:29:02 -08001714// Adds necessary dependencies to satisfy filegroup or generated sources modules listed in srcFiles
1715// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08001716//
1717// Deprecated: tag the property with `android:"path"` instead.
Colin Cross068e0fe2016-12-13 15:23:47 -08001718func ExtractSourcesDeps(ctx BottomUpMutatorContext, srcFiles []string) {
Nan Zhang2439eb72017-04-10 11:27:50 -07001719 set := make(map[string]bool)
1720
Colin Cross068e0fe2016-12-13 15:23:47 -08001721 for _, s := range srcFiles {
Colin Cross41955e82019-05-29 14:40:35 -07001722 if m, t := SrcIsModuleWithTag(s); m != "" {
1723 if _, found := set[s]; found {
1724 ctx.ModuleErrorf("found source dependency duplicate: %q!", s)
Nan Zhang2439eb72017-04-10 11:27:50 -07001725 } else {
Colin Cross41955e82019-05-29 14:40:35 -07001726 set[s] = true
1727 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Nan Zhang2439eb72017-04-10 11:27:50 -07001728 }
Colin Cross068e0fe2016-12-13 15:23:47 -08001729 }
1730 }
Colin Cross068e0fe2016-12-13 15:23:47 -08001731}
1732
Colin Cross366938f2017-12-11 16:29:02 -08001733// Adds necessary dependencies to satisfy filegroup or generated sources modules specified in s
1734// using ":module" syntax, if any.
Colin Cross27b922f2019-03-04 22:35:41 -08001735//
1736// Deprecated: tag the property with `android:"path"` instead.
Colin Cross366938f2017-12-11 16:29:02 -08001737func ExtractSourceDeps(ctx BottomUpMutatorContext, s *string) {
1738 if s != nil {
Colin Cross41955e82019-05-29 14:40:35 -07001739 if m, t := SrcIsModuleWithTag(*s); m != "" {
1740 ctx.AddDependency(ctx.Module(), sourceOrOutputDepTag(t), m)
Colin Cross366938f2017-12-11 16:29:02 -08001741 }
1742 }
1743}
1744
Colin Cross41955e82019-05-29 14:40:35 -07001745// A module that implements SourceFileProducer can be referenced from any property that is tagged with `android:"path"`
1746// 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 -08001747type SourceFileProducer interface {
1748 Srcs() Paths
1749}
1750
Colin Cross41955e82019-05-29 14:40:35 -07001751// A module that implements OutputFileProducer can be referenced from any property that is tagged with `android:"path"`
1752// using the ":module" syntax or ":module{.tag}" syntax and provides a list of otuput files to be used as if they were
1753// listed in the property.
1754type OutputFileProducer interface {
1755 OutputFiles(tag string) (Paths, error)
1756}
1757
Colin Crossfe17f6f2019-03-28 19:30:56 -07001758type HostToolProvider interface {
1759 HostToolPath() OptionalPath
1760}
1761
Colin Cross27b922f2019-03-04 22:35:41 -08001762// Returns a list of paths expanded from globs and modules referenced using ":module" syntax. The property must
1763// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08001764//
1765// Deprecated: use PathsForModuleSrc or PathsForModuleSrcExcludes instead.
Colin Cross25de6c32019-06-06 14:29:25 -07001766func (m *moduleContext) ExpandSources(srcFiles, excludes []string) Paths {
1767 return PathsForModuleSrcExcludes(m, srcFiles, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07001768}
1769
Colin Cross2fafa3e2019-03-05 12:39:51 -08001770// Returns a single path expanded from globs and modules referenced using ":module" syntax. The property must
1771// be tagged with `android:"path" to support automatic source module dependency resolution.
Colin Cross8a497952019-03-05 22:25:09 -08001772//
1773// Deprecated: use PathForModuleSrc instead.
Colin Cross25de6c32019-06-06 14:29:25 -07001774func (m *moduleContext) ExpandSource(srcFile, prop string) Path {
1775 return PathForModuleSrc(m, srcFile)
Colin Cross2fafa3e2019-03-05 12:39:51 -08001776}
1777
1778// Returns an optional single path expanded from globs and modules referenced using ":module" syntax if
1779// the srcFile is non-nil. The property must be tagged with `android:"path" to support automatic source module
1780// dependency resolution.
Colin Cross25de6c32019-06-06 14:29:25 -07001781func (m *moduleContext) ExpandOptionalSource(srcFile *string, prop string) OptionalPath {
Colin Cross2fafa3e2019-03-05 12:39:51 -08001782 if srcFile != nil {
Colin Cross25de6c32019-06-06 14:29:25 -07001783 return OptionalPathForPath(PathForModuleSrc(m, *srcFile))
Colin Cross2fafa3e2019-03-05 12:39:51 -08001784 }
1785 return OptionalPath{}
1786}
1787
Colin Cross25de6c32019-06-06 14:29:25 -07001788func (m *moduleContext) RequiredModuleNames() []string {
1789 return m.module.base().commonProperties.Required
Nan Zhang6d34b302017-02-04 17:47:46 -08001790}
1791
Colin Cross25de6c32019-06-06 14:29:25 -07001792func (m *moduleContext) HostRequiredModuleNames() []string {
1793 return m.module.base().commonProperties.Host_required
Sasha Smundakb6d23052019-04-01 18:37:36 -07001794}
1795
Colin Cross25de6c32019-06-06 14:29:25 -07001796func (m *moduleContext) TargetRequiredModuleNames() []string {
1797 return m.module.base().commonProperties.Target_required
Sasha Smundakb6d23052019-04-01 18:37:36 -07001798}
1799
Colin Crossdc35e212019-06-06 16:13:11 -07001800func (b *baseModuleContext) Glob(globPattern string, excludes []string) Paths {
1801 ret, err := b.GlobWithDeps(globPattern, excludes)
Colin Cross8f101b42015-06-17 15:09:06 -07001802 if err != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001803 b.ModuleErrorf("glob: %s", err.Error())
Colin Cross8f101b42015-06-17 15:09:06 -07001804 }
Colin Crossdc35e212019-06-06 16:13:11 -07001805 return pathsForModuleSrcFromFullPath(b, ret, true)
Colin Crossfce53272015-04-08 11:21:40 -07001806}
Colin Cross1f8c52b2015-06-16 16:38:17 -07001807
Colin Crossdc35e212019-06-06 16:13:11 -07001808func (b *baseModuleContext) GlobFiles(globPattern string, excludes []string) Paths {
1809 ret, err := b.GlobWithDeps(globPattern, excludes)
Nan Zhang581fd212018-01-10 16:06:12 -08001810 if err != nil {
Colin Crossdc35e212019-06-06 16:13:11 -07001811 b.ModuleErrorf("glob: %s", err.Error())
Nan Zhang581fd212018-01-10 16:06:12 -08001812 }
Colin Crossdc35e212019-06-06 16:13:11 -07001813 return pathsForModuleSrcFromFullPath(b, ret, false)
Nan Zhang581fd212018-01-10 16:06:12 -08001814}
1815
Colin Cross463a90e2015-06-17 14:20:06 -07001816func init() {
Colin Cross798bfce2016-10-12 14:28:16 -07001817 RegisterSingletonType("buildtarget", BuildTargetSingleton)
Colin Cross463a90e2015-06-17 14:20:06 -07001818}
1819
Colin Cross0875c522017-11-28 17:34:01 -08001820func BuildTargetSingleton() Singleton {
Colin Cross1f8c52b2015-06-16 16:38:17 -07001821 return &buildTargetSingleton{}
1822}
1823
Colin Cross87d8b562017-04-25 10:01:55 -07001824func parentDir(dir string) string {
1825 dir, _ = filepath.Split(dir)
1826 return filepath.Clean(dir)
1827}
1828
Colin Cross1f8c52b2015-06-16 16:38:17 -07001829type buildTargetSingleton struct{}
1830
Colin Cross0875c522017-11-28 17:34:01 -08001831func (c *buildTargetSingleton) GenerateBuildActions(ctx SingletonContext) {
1832 var checkbuildDeps Paths
Colin Cross1f8c52b2015-06-16 16:38:17 -07001833
Colin Cross0875c522017-11-28 17:34:01 -08001834 mmTarget := func(dir string) WritablePath {
1835 return PathForPhony(ctx,
1836 "MODULES-IN-"+strings.Replace(filepath.Clean(dir), "/", "-", -1))
Colin Cross87d8b562017-04-25 10:01:55 -07001837 }
1838
Colin Cross0875c522017-11-28 17:34:01 -08001839 modulesInDir := make(map[string]Paths)
Colin Cross1f8c52b2015-06-16 16:38:17 -07001840
Colin Cross0875c522017-11-28 17:34:01 -08001841 ctx.VisitAllModules(func(module Module) {
1842 blueprintDir := module.base().blueprintDir
1843 installTarget := module.base().installTarget
1844 checkbuildTarget := module.base().checkbuildTarget
Colin Cross1f8c52b2015-06-16 16:38:17 -07001845
Colin Cross0875c522017-11-28 17:34:01 -08001846 if checkbuildTarget != nil {
1847 checkbuildDeps = append(checkbuildDeps, checkbuildTarget)
1848 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], checkbuildTarget)
1849 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07001850
Colin Cross0875c522017-11-28 17:34:01 -08001851 if installTarget != nil {
1852 modulesInDir[blueprintDir] = append(modulesInDir[blueprintDir], installTarget)
Colin Cross1f8c52b2015-06-16 16:38:17 -07001853 }
1854 })
1855
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001856 suffix := ""
Colin Crossaabf6792017-11-29 00:27:14 -08001857 if ctx.Config().EmbeddedInMake() {
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001858 suffix = "-soong"
1859 }
1860
Colin Cross1f8c52b2015-06-16 16:38:17 -07001861 // Create a top-level checkbuild target that depends on all modules
Colin Cross0875c522017-11-28 17:34:01 -08001862 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07001863 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001864 Output: PathForPhony(ctx, "checkbuild"+suffix),
Colin Cross1f8c52b2015-06-16 16:38:17 -07001865 Implicits: checkbuildDeps,
Colin Cross1f8c52b2015-06-16 16:38:17 -07001866 })
1867
Dan Willemsend2e95fb2017-09-20 14:30:50 -07001868 // Make will generate the MODULES-IN-* targets
Colin Crossaabf6792017-11-29 00:27:14 -08001869 if ctx.Config().EmbeddedInMake() {
Dan Willemsend2e95fb2017-09-20 14:30:50 -07001870 return
1871 }
1872
Colin Cross87d8b562017-04-25 10:01:55 -07001873 // Ensure ancestor directories are in modulesInDir
Inseob Kim1a365c62019-06-08 15:47:51 +09001874 dirs := SortedStringKeys(modulesInDir)
Colin Cross87d8b562017-04-25 10:01:55 -07001875 for _, dir := range dirs {
1876 dir := parentDir(dir)
1877 for dir != "." && dir != "/" {
1878 if _, exists := modulesInDir[dir]; exists {
1879 break
1880 }
1881 modulesInDir[dir] = nil
1882 dir = parentDir(dir)
1883 }
1884 }
1885
1886 // Make directories build their direct subdirectories
Colin Cross87d8b562017-04-25 10:01:55 -07001887 for _, dir := range dirs {
1888 p := parentDir(dir)
1889 if p != "." && p != "/" {
1890 modulesInDir[p] = append(modulesInDir[p], mmTarget(dir))
1891 }
1892 }
1893
Dan Willemsend2e95fb2017-09-20 14:30:50 -07001894 // Create a MODULES-IN-<directory> target that depends on all modules in a directory, and
1895 // depends on the MODULES-IN-* targets of all of its subdirectories that contain Android.bp
1896 // files.
Colin Cross1f8c52b2015-06-16 16:38:17 -07001897 for _, dir := range dirs {
Colin Cross0875c522017-11-28 17:34:01 -08001898 ctx.Build(pctx, BuildParams{
Colin Cross1f8c52b2015-06-16 16:38:17 -07001899 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001900 Output: mmTarget(dir),
Colin Cross87d8b562017-04-25 10:01:55 -07001901 Implicits: modulesInDir[dir],
Dan Willemsen5ba07e82015-12-11 13:51:06 -08001902 // HACK: checkbuild should be an optional build, but force it
1903 // enabled for now in standalone builds
Colin Crossaabf6792017-11-29 00:27:14 -08001904 Default: !ctx.Config().EmbeddedInMake(),
Colin Cross1f8c52b2015-06-16 16:38:17 -07001905 })
1906 }
Dan Willemsen61d88b82017-09-20 17:29:08 -07001907
1908 // Create (host|host-cross|target)-<OS> phony rules to build a reduced checkbuild.
1909 osDeps := map[OsType]Paths{}
Colin Cross0875c522017-11-28 17:34:01 -08001910 ctx.VisitAllModules(func(module Module) {
1911 if module.Enabled() {
1912 os := module.Target().Os
1913 osDeps[os] = append(osDeps[os], module.base().checkbuildFiles...)
Dan Willemsen61d88b82017-09-20 17:29:08 -07001914 }
1915 })
1916
Colin Cross0875c522017-11-28 17:34:01 -08001917 osClass := make(map[string]Paths)
Dan Willemsen61d88b82017-09-20 17:29:08 -07001918 for os, deps := range osDeps {
1919 var className string
1920
1921 switch os.Class {
1922 case Host:
1923 className = "host"
1924 case HostCross:
1925 className = "host-cross"
1926 case Device:
1927 className = "target"
1928 default:
1929 continue
1930 }
1931
Colin Cross0875c522017-11-28 17:34:01 -08001932 name := PathForPhony(ctx, className+"-"+os.Name)
Dan Willemsen61d88b82017-09-20 17:29:08 -07001933 osClass[className] = append(osClass[className], name)
1934
Colin Cross0875c522017-11-28 17:34:01 -08001935 ctx.Build(pctx, BuildParams{
Dan Willemsen61d88b82017-09-20 17:29:08 -07001936 Rule: blueprint.Phony,
Colin Cross0875c522017-11-28 17:34:01 -08001937 Output: name,
1938 Implicits: deps,
Dan Willemsen61d88b82017-09-20 17:29:08 -07001939 })
1940 }
1941
1942 // Wrap those into host|host-cross|target phony rules
Inseob Kim1a365c62019-06-08 15:47:51 +09001943 for _, class := range SortedStringKeys(osClass) {
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: PathForPhony(ctx, class),
Dan Willemsen61d88b82017-09-20 17:29:08 -07001947 Implicits: osClass[class],
Dan Willemsen61d88b82017-09-20 17:29:08 -07001948 })
1949 }
Colin Cross1f8c52b2015-06-16 16:38:17 -07001950}
Colin Crossd779da42015-12-17 18:00:23 -08001951
Brandon Lee5d45c6f2018-08-15 15:35:38 -07001952// Collect information for opening IDE project files in java/jdeps.go.
1953type IDEInfo interface {
1954 IDEInfo(ideInfo *IdeInfo)
1955 BaseModuleName() string
1956}
1957
1958// Extract the base module name from the Import name.
1959// Often the Import name has a prefix "prebuilt_".
1960// Remove the prefix explicitly if needed
1961// until we find a better solution to get the Import name.
1962type IDECustomizedModuleName interface {
1963 IDECustomizedModuleName() string
1964}
1965
1966type IdeInfo struct {
1967 Deps []string `json:"dependencies,omitempty"`
1968 Srcs []string `json:"srcs,omitempty"`
1969 Aidl_include_dirs []string `json:"aidl_include_dirs,omitempty"`
1970 Jarjar_rules []string `json:"jarjar_rules,omitempty"`
1971 Jars []string `json:"jars,omitempty"`
1972 Classes []string `json:"class,omitempty"`
1973 Installed_paths []string `json:"installed,omitempty"`
patricktu18c82ff2019-05-10 15:48:50 +08001974 SrcJars []string `json:"srcjars,omitempty"`
Brandon Lee5d45c6f2018-08-15 15:35:38 -07001975}