blob: 04fef358034b00fa87da0a1060ae8cba04b70657 [file] [log] [blame]
Ivan Lozanoffee3342019-08-27 12:03:00 -07001// Copyright 2019 The Android Open Source Project
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
15package rust
16
17import (
18 "fmt"
19 "path/filepath"
Ivan Lozano45a9e312021-07-27 12:29:12 -040020 "strings"
Ivan Lozanoffee3342019-08-27 12:03:00 -070021
Ivan Lozanoad8b18b2019-10-31 19:38:29 -070022 "github.com/google/blueprint/proptools"
23
Ivan Lozanoffee3342019-08-27 12:03:00 -070024 "android/soong/android"
25 "android/soong/rust/config"
26)
27
Ivan Lozanodd055472020-09-28 13:22:45 -040028type RustLinkage int
29
30const (
31 DefaultLinkage RustLinkage = iota
32 RlibLinkage
33 DylibLinkage
34)
35
Thiébaud Weksteene81c9242020-08-03 10:46:28 +020036func (compiler *baseCompiler) edition() string {
Chih-Hung Hsieh961a30c2019-10-03 09:47:06 -070037 return proptools.StringDefault(compiler.Properties.Edition, config.DefaultEdition)
38}
39
Matthew Maurer99020b02019-10-31 10:44:40 -070040func (compiler *baseCompiler) setNoStdlibs() {
41 compiler.Properties.No_stdlibs = proptools.BoolPtr(true)
42}
43
Thiébaud Weksteen9e8451e2020-08-13 12:55:59 +020044func (compiler *baseCompiler) disableLints() {
45 compiler.Properties.Lints = proptools.StringPtr("none")
Stephen Craneda931d42020-08-04 13:02:28 -070046}
47
Chih-Hung Hsieh9a4a7ba2019-12-12 19:36:05 -080048func NewBaseCompiler(dir, dir64 string, location installLocation) *baseCompiler {
Ivan Lozanoffee3342019-08-27 12:03:00 -070049 return &baseCompiler{
Chih-Hung Hsieh961a30c2019-10-03 09:47:06 -070050 Properties: BaseCompilerProperties{},
51 dir: dir,
52 dir64: dir64,
Chih-Hung Hsieh9a4a7ba2019-12-12 19:36:05 -080053 location: location,
Ivan Lozanoffee3342019-08-27 12:03:00 -070054 }
55}
56
Chih-Hung Hsieh9a4a7ba2019-12-12 19:36:05 -080057type installLocation int
58
59const (
60 InstallInSystem installLocation = 0
61 InstallInData = iota
Ivan Lozano43845682020-07-09 21:03:28 -040062
63 incorrectSourcesError = "srcs can only contain one path for a rust file and source providers prefixed by \":\""
Thiébaud Weksteenee6a89b2021-02-25 16:30:57 +010064 genSubDir = "out/"
Chih-Hung Hsieh9a4a7ba2019-12-12 19:36:05 -080065)
66
Ivan Lozanoffee3342019-08-27 12:03:00 -070067type BaseCompilerProperties struct {
Ivan Lozanoe4db0032021-08-11 13:39:33 -040068 // path to the source file that is the main entry point of the program (e.g. main.rs or lib.rs).
69 // Only a single source file can be defined. Modules which generate source can be included by prefixing
70 // the module name with ":", for example ":libfoo_bindgen"
71 //
72 // If no source file is defined, a single generated source module can be defined to be used as the main source.
Ivan Lozano8a23fa42020-06-16 10:26:57 -040073 Srcs []string `android:"path,arch_variant"`
74
Thiébaud Weksteen9e8451e2020-08-13 12:55:59 +020075 // name of the lint set that should be used to validate this module.
76 //
77 // Possible values are "default" (for using a sensible set of lints
78 // depending on the module's location), "android" (for the strictest
79 // lint set that applies to all Android platform code), "vendor" (for
80 // a relaxed set) and "none" (for ignoring all lint warnings and
81 // errors). The default value is "default".
82 Lints *string
Chih-Hung Hsiehefdd7ac2019-09-26 18:59:27 -070083
Thiébaud Weksteenc44e7372021-04-07 14:53:06 +020084 // flags to pass to rustc. To enable configuration options or features, use the "cfgs" or "features" properties.
Liz Kammereda93982021-04-20 10:15:41 -040085 Flags []string `android:"arch_variant"`
Ivan Lozanoffee3342019-08-27 12:03:00 -070086
87 // flags to pass to the linker
Liz Kammereda93982021-04-20 10:15:41 -040088 Ld_flags []string `android:"arch_variant"`
Ivan Lozanoffee3342019-08-27 12:03:00 -070089
90 // list of rust rlib crate dependencies
91 Rlibs []string `android:"arch_variant"`
92
93 // list of rust dylib crate dependencies
94 Dylibs []string `android:"arch_variant"`
95
Matthew Maurer0f003b12020-06-29 14:34:06 -070096 // list of rust automatic crate dependencies
97 Rustlibs []string `android:"arch_variant"`
98
Ivan Lozanoffee3342019-08-27 12:03:00 -070099 // list of rust proc_macro crate dependencies
100 Proc_macros []string `android:"arch_variant"`
101
102 // list of C shared library dependencies
103 Shared_libs []string `android:"arch_variant"`
104
Ivan Lozano63bb7682021-03-23 15:53:44 -0400105 // list of C static library dependencies. These dependencies do not normally propagate to dependents
106 // and may need to be redeclared. See whole_static_libs for bundling static dependencies into a library.
Ivan Lozanoffee3342019-08-27 12:03:00 -0700107 Static_libs []string `android:"arch_variant"`
108
Ivan Lozano63bb7682021-03-23 15:53:44 -0400109 // Similar to static_libs, but will bundle the static library dependency into a library. This is helpful
110 // to avoid having to redeclare the dependency for dependents of this library, but in some cases may also
111 // result in bloat if multiple dependencies all include the same static library whole.
112 //
113 // The common use case for this is when the static library is unlikely to be a dependency of other modules to avoid
114 // having to redeclare the static library dependency for every dependent module.
115 // If you are not sure what to, for rust_library modules most static dependencies should go in static_libraries,
116 // and for rust_ffi modules most static dependencies should go into whole_static_libraries.
117 //
118 // For rust_ffi static variants, these libraries will be included in the resulting static library archive.
119 //
120 // For rust_library rlib variants, these libraries will be bundled into the resulting rlib library. This will
121 // include all of the static libraries symbols in any dylibs or binaries which use this rlib as well.
122 Whole_static_libs []string `android:"arch_variant"`
123
Ivan Lozano26ecd6c2020-07-31 13:40:31 -0400124 // crate name, required for modules which produce Rust libraries: rust_library, rust_ffi and SourceProvider
125 // modules which create library variants (rust_bindgen). This must be the expected extern crate name used in
126 // source, and is required to conform to an enforced format matching library output files (if the output file is
127 // lib<someName><suffix>, the crate_name property must be <someName>).
Ivan Lozanoffee3342019-08-27 12:03:00 -0700128 Crate_name string `android:"arch_variant"`
129
130 // list of features to enable for this crate
131 Features []string `android:"arch_variant"`
132
Thiébaud Weksteenc44e7372021-04-07 14:53:06 +0200133 // list of configuration options to enable for this crate. To enable features, use the "features" property.
134 Cfgs []string `android:"arch_variant"`
135
Ivan Lozanoffee3342019-08-27 12:03:00 -0700136 // specific rust edition that should be used if the default version is not desired
137 Edition *string `android:"arch_variant"`
138
139 // sets name of the output
140 Stem *string `android:"arch_variant"`
141
142 // append to name of output
143 Suffix *string `android:"arch_variant"`
144
145 // install to a subdirectory of the default install path for the module
146 Relative_install_path *string `android:"arch_variant"`
Matthew Maurer99020b02019-10-31 10:44:40 -0700147
148 // whether to suppress inclusion of standard crates - defaults to false
149 No_stdlibs *bool
Ivan Lozanoea086132020-12-08 14:43:00 -0500150
151 // Change the rustlibs linkage to select rlib linkage by default for device targets.
152 // Also link libstd as an rlib as well on device targets.
153 // Note: This is the default behavior for host targets.
154 //
155 // This is primarily meant for rust_binary and rust_ffi modules where the default
156 // linkage of libstd might need to be overridden in some use cases. This should
157 // generally be avoided with other module types since it may cause collisions at
158 // linkage if all dependencies of the root binary module do not link against libstd\
159 // the same way.
160 Prefer_rlib *bool `android:"arch_variant"`
Ivan Lozanoffee3342019-08-27 12:03:00 -0700161}
162
163type baseCompiler struct {
Joel Galensonfa049382021-01-14 16:03:18 -0800164 Properties BaseCompilerProperties
Ivan Lozanoffee3342019-08-27 12:03:00 -0700165
166 // Install related
167 dir string
168 dir64 string
169 subDir string
170 relative string
Colin Cross70dda7e2019-10-01 22:05:35 -0700171 path android.InstallPath
Chih-Hung Hsieh9a4a7ba2019-12-12 19:36:05 -0800172 location installLocation
Ivan Lozano6cd99e62020-02-11 08:24:25 -0500173 sanitize *sanitize
Ivan Lozano8a23fa42020-06-16 10:26:57 -0400174
Joel Galensonfa049382021-01-14 16:03:18 -0800175 distFile android.OptionalPath
Thiébaud Weksteenfabaff62020-08-27 13:48:36 +0200176 // Stripped output file. If Valid(), this file will be installed instead of outputFile.
177 strippedOutputFile android.OptionalPath
Thiébaud Weksteenee6a89b2021-02-25 16:30:57 +0100178
179 // If a crate has a source-generated dependency, a copy of the source file
180 // will be available in cargoOutDir (equivalent to Cargo OUT_DIR).
181 cargoOutDir android.ModuleOutPath
Ivan Lozanoffee3342019-08-27 12:03:00 -0700182}
183
Ivan Lozano26ecd6c2020-07-31 13:40:31 -0400184func (compiler *baseCompiler) Disabled() bool {
185 return false
186}
187
188func (compiler *baseCompiler) SetDisabled() {
189 panic("baseCompiler does not implement SetDisabled()")
190}
191
Ivan Lozanoa0cd8f92020-04-09 09:56:02 -0400192func (compiler *baseCompiler) coverageOutputZipPath() android.OptionalPath {
193 panic("baseCompiler does not implement coverageOutputZipPath()")
194}
195
Ivan Lozanoea086132020-12-08 14:43:00 -0500196func (compiler *baseCompiler) preferRlib() bool {
197 return Bool(compiler.Properties.Prefer_rlib)
198}
199
Ivan Lozanodd055472020-09-28 13:22:45 -0400200func (compiler *baseCompiler) stdLinkage(ctx *depsContext) RustLinkage {
Ivan Lozano2b081132020-09-08 12:46:52 -0400201 // For devices, we always link stdlibs in as dylibs by default.
Ivan Lozanoea086132020-12-08 14:43:00 -0500202 if compiler.preferRlib() {
203 return RlibLinkage
204 } else if ctx.Device() {
Ivan Lozanodd055472020-09-28 13:22:45 -0400205 return DylibLinkage
Ivan Lozano2b081132020-09-08 12:46:52 -0400206 } else {
Ivan Lozanodd055472020-09-28 13:22:45 -0400207 return RlibLinkage
Ivan Lozano2b081132020-09-08 12:46:52 -0400208 }
Ivan Lozano042504f2020-08-18 14:31:23 -0400209}
210
Ivan Lozanoffee3342019-08-27 12:03:00 -0700211var _ compiler = (*baseCompiler)(nil)
212
Chih-Hung Hsieh9a4a7ba2019-12-12 19:36:05 -0800213func (compiler *baseCompiler) inData() bool {
214 return compiler.location == InstallInData
215}
216
Ivan Lozanoffee3342019-08-27 12:03:00 -0700217func (compiler *baseCompiler) compilerProps() []interface{} {
218 return []interface{}{&compiler.Properties}
219}
220
Thiébaud Weksteenc44e7372021-04-07 14:53:06 +0200221func (compiler *baseCompiler) cfgsToFlags() []string {
Ivan Lozanoffee3342019-08-27 12:03:00 -0700222 flags := []string{}
Thiébaud Weksteenc44e7372021-04-07 14:53:06 +0200223 for _, cfg := range compiler.Properties.Cfgs {
224 flags = append(flags, "--cfg '"+cfg+"'")
225 }
226 return flags
227}
228
229func (compiler *baseCompiler) featuresToFlags() []string {
230 flags := []string{}
231 for _, feature := range compiler.Properties.Features {
Ivan Lozanoffee3342019-08-27 12:03:00 -0700232 flags = append(flags, "--cfg 'feature=\""+feature+"\"'")
233 }
234 return flags
235}
236
237func (compiler *baseCompiler) compilerFlags(ctx ModuleContext, flags Flags) Flags {
238
Thiébaud Weksteen9e8451e2020-08-13 12:55:59 +0200239 lintFlags, err := config.RustcLintsForDir(ctx.ModuleDir(), compiler.Properties.Lints)
240 if err != nil {
241 ctx.PropertyErrorf("lints", err.Error())
Chih-Hung Hsiehefdd7ac2019-09-26 18:59:27 -0700242 }
Ivan Lozano45a9e312021-07-27 12:29:12 -0400243
244 // linkage-related flags are disallowed.
245 for _, s := range compiler.Properties.Ld_flags {
246 if strings.HasPrefix(s, "-Wl,-l") || strings.HasPrefix(s, "-Wl,-L") {
247 ctx.PropertyErrorf("ld_flags", "'-Wl,-l' and '-Wl,-L' flags cannot be manually specified")
248 }
249 }
250 for _, s := range compiler.Properties.Flags {
251 if strings.HasPrefix(s, "-l") || strings.HasPrefix(s, "-L") {
252 ctx.PropertyErrorf("flags", "'-l' and '-L' flags cannot be manually specified")
253 }
254 if strings.HasPrefix(s, "--extern") {
255 ctx.PropertyErrorf("flags", "'--extern' flag cannot be manually specified")
256 }
257 if strings.HasPrefix(s, "-Clink-args=") || strings.HasPrefix(s, "-C link-args=") {
258 ctx.PropertyErrorf("flags", "'-C link-args' flag cannot be manually specified")
259 }
260 }
261
Thiébaud Weksteen9e8451e2020-08-13 12:55:59 +0200262 flags.RustFlags = append(flags.RustFlags, lintFlags)
Ivan Lozanoffee3342019-08-27 12:03:00 -0700263 flags.RustFlags = append(flags.RustFlags, compiler.Properties.Flags...)
Thiébaud Weksteenc44e7372021-04-07 14:53:06 +0200264 flags.RustFlags = append(flags.RustFlags, compiler.cfgsToFlags()...)
265 flags.RustFlags = append(flags.RustFlags, compiler.featuresToFlags()...)
Dan Albert06feee92021-03-19 15:06:02 -0700266 flags.RustdocFlags = append(flags.RustdocFlags, compiler.cfgsToFlags()...)
267 flags.RustdocFlags = append(flags.RustdocFlags, compiler.featuresToFlags()...)
Thiébaud Weksteene81c9242020-08-03 10:46:28 +0200268 flags.RustFlags = append(flags.RustFlags, "--edition="+compiler.edition())
Dan Albert06feee92021-03-19 15:06:02 -0700269 flags.RustdocFlags = append(flags.RustdocFlags, "--edition="+compiler.edition())
Ivan Lozanoffee3342019-08-27 12:03:00 -0700270 flags.LinkFlags = append(flags.LinkFlags, compiler.Properties.Ld_flags...)
Joel Galenson724286c2019-09-30 13:01:37 -0700271 flags.GlobalRustFlags = append(flags.GlobalRustFlags, config.GlobalRustFlags...)
Ivan Lozanof1c84332019-09-20 11:00:37 -0700272 flags.GlobalRustFlags = append(flags.GlobalRustFlags, ctx.toolchain().ToolchainRustFlags())
273 flags.GlobalLinkFlags = append(flags.GlobalLinkFlags, ctx.toolchain().ToolchainLinkFlags())
Ivan Lozanoffee3342019-08-27 12:03:00 -0700274
275 if ctx.Host() && !ctx.Windows() {
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800276 rpathPrefix := `\$$ORIGIN/`
Ivan Lozanoffee3342019-08-27 12:03:00 -0700277 if ctx.Darwin() {
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800278 rpathPrefix = "@loader_path/"
Ivan Lozanoffee3342019-08-27 12:03:00 -0700279 }
280
281 var rpath string
282 if ctx.toolchain().Is64Bit() {
283 rpath = "lib64"
284 } else {
285 rpath = "lib"
286 }
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800287 flags.LinkFlags = append(flags.LinkFlags, "-Wl,-rpath,"+rpathPrefix+rpath)
288 flags.LinkFlags = append(flags.LinkFlags, "-Wl,-rpath,"+rpathPrefix+"../"+rpath)
Ivan Lozanoffee3342019-08-27 12:03:00 -0700289 }
290
Ivan Lozanof76cdf72021-02-12 09:55:06 -0500291 if ctx.RustModule().UseVndk() {
292 flags.RustFlags = append(flags.RustFlags, "--cfg 'android_vndk'")
293 }
294
Ivan Lozanoffee3342019-08-27 12:03:00 -0700295 return flags
296}
297
298func (compiler *baseCompiler) compile(ctx ModuleContext, flags Flags, deps PathDeps) android.Path {
299 panic(fmt.Errorf("baseCrater doesn't know how to crate things!"))
300}
301
Dan Albert06feee92021-03-19 15:06:02 -0700302func (compiler *baseCompiler) rustdoc(ctx ModuleContext, flags Flags,
303 deps PathDeps) android.OptionalPath {
304
305 return android.OptionalPath{}
306}
307
Thiébaud Weksteenee6a89b2021-02-25 16:30:57 +0100308func (compiler *baseCompiler) initialize(ctx ModuleContext) {
309 compiler.cargoOutDir = android.PathForModuleOut(ctx, genSubDir)
310}
311
312func (compiler *baseCompiler) CargoOutDir() android.OptionalPath {
313 return android.OptionalPathForPath(compiler.cargoOutDir)
314}
315
Jiyong Parke54f07e2021-04-07 15:08:04 +0900316func (compiler *baseCompiler) strippedOutputFilePath() android.OptionalPath {
317 return compiler.strippedOutputFile
318}
319
Ivan Lozanoffee3342019-08-27 12:03:00 -0700320func (compiler *baseCompiler) compilerDeps(ctx DepsContext, deps Deps) Deps {
321 deps.Rlibs = append(deps.Rlibs, compiler.Properties.Rlibs...)
322 deps.Dylibs = append(deps.Dylibs, compiler.Properties.Dylibs...)
Matthew Maurer0f003b12020-06-29 14:34:06 -0700323 deps.Rustlibs = append(deps.Rustlibs, compiler.Properties.Rustlibs...)
Ivan Lozanoffee3342019-08-27 12:03:00 -0700324 deps.ProcMacros = append(deps.ProcMacros, compiler.Properties.Proc_macros...)
325 deps.StaticLibs = append(deps.StaticLibs, compiler.Properties.Static_libs...)
Ivan Lozano63bb7682021-03-23 15:53:44 -0400326 deps.WholeStaticLibs = append(deps.WholeStaticLibs, compiler.Properties.Whole_static_libs...)
Ivan Lozanoffee3342019-08-27 12:03:00 -0700327 deps.SharedLibs = append(deps.SharedLibs, compiler.Properties.Shared_libs...)
328
Matthew Maurer99020b02019-10-31 10:44:40 -0700329 if !Bool(compiler.Properties.No_stdlibs) {
330 for _, stdlib := range config.Stdlibs {
Jiyong Parkb5d2dd22020-08-31 17:22:01 +0900331 // If we're building for the primary arch of the build host, use the compiler's stdlibs
Colin Cross0c66bc62021-07-20 09:47:41 -0700332 if ctx.Target().Os == ctx.Config().BuildOS {
Matthew Maurer99020b02019-10-31 10:44:40 -0700333 stdlib = stdlib + "_" + ctx.toolchain().RustTriple()
334 }
Ivan Lozano2b081132020-09-08 12:46:52 -0400335 deps.Stdlibs = append(deps.Stdlibs, stdlib)
Matthew Maurer99020b02019-10-31 10:44:40 -0700336 }
337 }
Ivan Lozanoffee3342019-08-27 12:03:00 -0700338 return deps
339}
340
Thiébaud Weksteenf1ff54a2021-03-22 14:24:54 +0100341func bionicDeps(ctx DepsContext, deps Deps, static bool) Deps {
Ivan Lozanobf63d002020-10-02 10:03:23 -0400342 bionicLibs := []string{}
343 bionicLibs = append(bionicLibs, "liblog")
344 bionicLibs = append(bionicLibs, "libc")
345 bionicLibs = append(bionicLibs, "libm")
346 bionicLibs = append(bionicLibs, "libdl")
347
348 if static {
349 deps.StaticLibs = append(deps.StaticLibs, bionicLibs...)
350 } else {
351 deps.SharedLibs = append(deps.SharedLibs, bionicLibs...)
352 }
Ivan Lozanof1c84332019-09-20 11:00:37 -0700353
Thiébaud Weksteenf1ff54a2021-03-22 14:24:54 +0100354 if libRuntimeBuiltins := config.BuiltinsRuntimeLibrary(ctx.toolchain()); libRuntimeBuiltins != "" {
355 deps.StaticLibs = append(deps.StaticLibs, libRuntimeBuiltins)
356 }
Ivan Lozanof1c84332019-09-20 11:00:37 -0700357 return deps
358}
359
Ivan Lozanoffee3342019-08-27 12:03:00 -0700360func (compiler *baseCompiler) crateName() string {
361 return compiler.Properties.Crate_name
362}
363
Ivan Lozanod7586b62021-04-01 09:49:36 -0400364func (compiler *baseCompiler) everInstallable() bool {
365 // Most modules are installable, so return true by default.
366 return true
367}
368
Colin Cross70dda7e2019-10-01 22:05:35 -0700369func (compiler *baseCompiler) installDir(ctx ModuleContext) android.InstallPath {
Ivan Lozanoffee3342019-08-27 12:03:00 -0700370 dir := compiler.dir
371 if ctx.toolchain().Is64Bit() && compiler.dir64 != "" {
372 dir = compiler.dir64
373 }
Ivan Lozanod6fdca82020-04-07 12:30:33 -0400374 if ctx.Target().NativeBridge == android.NativeBridgeEnabled {
375 dir = filepath.Join(dir, ctx.Target().NativeBridgeRelativePath)
376 }
377 if !ctx.Host() && ctx.Config().HasMultilibConflict(ctx.Arch().ArchType) {
Ivan Lozanoffee3342019-08-27 12:03:00 -0700378 dir = filepath.Join(dir, ctx.Arch().ArchType.String())
379 }
Ivan Lozanoc08897c2021-04-02 12:41:32 -0400380
381 if compiler.location == InstallInData && ctx.RustModule().UseVndk() {
382 dir = filepath.Join(dir, "vendor")
383 }
Ivan Lozanoffee3342019-08-27 12:03:00 -0700384 return android.PathForModuleInstall(ctx, dir, compiler.subDir,
385 compiler.relativeInstallPath(), compiler.relative)
386}
387
Ivan Lozanoa0cd8f92020-04-09 09:56:02 -0400388func (compiler *baseCompiler) nativeCoverage() bool {
389 return false
390}
391
Thiébaud Weksteenfabaff62020-08-27 13:48:36 +0200392func (compiler *baseCompiler) install(ctx ModuleContext) {
Jiyong Parke54f07e2021-04-07 15:08:04 +0900393 path := ctx.RustModule().OutputFile()
Thiébaud Weksteenfabaff62020-08-27 13:48:36 +0200394 compiler.path = ctx.InstallFile(compiler.installDir(ctx), path.Path().Base(), path.Path())
Ivan Lozanoffee3342019-08-27 12:03:00 -0700395}
396
397func (compiler *baseCompiler) getStem(ctx ModuleContext) string {
398 return compiler.getStemWithoutSuffix(ctx) + String(compiler.Properties.Suffix)
399}
400
401func (compiler *baseCompiler) getStemWithoutSuffix(ctx BaseModuleContext) string {
Thiébaud Weksteen1f7f70f2020-06-24 11:32:48 +0200402 stem := ctx.ModuleName()
Ivan Lozanoffee3342019-08-27 12:03:00 -0700403 if String(compiler.Properties.Stem) != "" {
404 stem = String(compiler.Properties.Stem)
405 }
406
407 return stem
408}
Ivan Lozanoad8b18b2019-10-31 19:38:29 -0700409
Ivan Lozanoffee3342019-08-27 12:03:00 -0700410func (compiler *baseCompiler) relativeInstallPath() string {
411 return String(compiler.Properties.Relative_install_path)
412}
413
Ivan Lozano43845682020-07-09 21:03:28 -0400414// Returns the Path for the main source file along with Paths for generated source files from modules listed in srcs.
Chih-Hung Hsiehbbd25ae2020-05-15 17:36:30 -0700415func srcPathFromModuleSrcs(ctx ModuleContext, srcs []string) (android.Path, android.Paths) {
416 // The srcs can contain strings with prefix ":".
417 // They are dependent modules of this module, with android.SourceDepTag.
418 // They are not the main source file compiled by rustc.
419 numSrcs := 0
420 srcIndex := 0
421 for i, s := range srcs {
422 if android.SrcIsModule(s) == "" {
423 numSrcs++
424 srcIndex = i
425 }
Ivan Lozanoffee3342019-08-27 12:03:00 -0700426 }
Ivan Lozanoe4db0032021-08-11 13:39:33 -0400427 if numSrcs > 1 {
Ivan Lozano43845682020-07-09 21:03:28 -0400428 ctx.PropertyErrorf("srcs", incorrectSourcesError)
Chih-Hung Hsiehbbd25ae2020-05-15 17:36:30 -0700429 }
Ivan Lozanoe4db0032021-08-11 13:39:33 -0400430
431 // If a main source file is not provided we expect only a single SourceProvider module to be defined
432 // within srcs, with the expectation that the first source it provides is the entry point.
Chih-Hung Hsiehbbd25ae2020-05-15 17:36:30 -0700433 if srcIndex != 0 {
434 ctx.PropertyErrorf("srcs", "main source file must be the first in srcs")
Ivan Lozanoe4db0032021-08-11 13:39:33 -0400435 } else if numSrcs > 1 {
436 ctx.PropertyErrorf("srcs", "only a single generated source module can be defined without a main source file.")
Chih-Hung Hsiehbbd25ae2020-05-15 17:36:30 -0700437 }
Ivan Lozanoe4db0032021-08-11 13:39:33 -0400438
Chih-Hung Hsiehbbd25ae2020-05-15 17:36:30 -0700439 paths := android.PathsForModuleSrc(ctx, srcs)
Ivan Lozano43845682020-07-09 21:03:28 -0400440 return paths[srcIndex], paths[1:]
Ivan Lozanoffee3342019-08-27 12:03:00 -0700441}