blob: 60b5926e8d1d05914281997cbc51fea614e83a1b [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 (
Ivan Lozano1776a2a2020-11-11 10:59:52 -050018 "path/filepath"
Ivan Lozanoffee3342019-08-27 12:03:00 -070019 "strings"
20
21 "github.com/google/blueprint"
22
23 "android/soong/android"
Thiébaud Weksteen71512f32020-11-03 15:17:51 +010024 "android/soong/rust/config"
Ivan Lozanoffee3342019-08-27 12:03:00 -070025)
26
27var (
28 _ = pctx.SourcePathVariable("rustcCmd", "${config.RustBin}/rustc")
29 rustc = pctx.AndroidStaticRule("rustc",
30 blueprint.RuleParams{
Ivan Lozano43845682020-07-09 21:03:28 -040031 Command: "$envVars $rustcCmd " +
Ivan Lozanoffee3342019-08-27 12:03:00 -070032 "-C linker=${config.RustLinker} " +
Ivan Lozanof1c84332019-09-20 11:00:37 -070033 "-C link-args=\"${crtBegin} ${config.RustLinkerArgs} ${linkFlags} ${crtEnd}\" " +
Chih-Hung Hsieh29aa9fd2020-08-13 15:46:21 -070034 "--emit link -o $out --emit dep-info=$out.d.raw $in ${libFlags} $rustcFlags" +
35 " && grep \"^$out:\" $out.d.raw > $out.d",
Ivan Lozanoffee3342019-08-27 12:03:00 -070036 CommandDeps: []string{"$rustcCmd"},
Ivan Lozanob2df9f82019-11-05 12:16:46 -080037 // Rustc deps-info writes out make compatible dep files: https://github.com/rust-lang/rust/issues/7633
Chih-Hung Hsieh29aa9fd2020-08-13 15:46:21 -070038 // Rustc emits unneeded dependency lines for the .d and input .rs files.
39 // Those extra lines cause ninja warning:
40 // "warning: depfile has multiple output paths"
41 // For ninja, we keep/grep only the dependency rule for the rust $out file.
Ivan Lozanob2df9f82019-11-05 12:16:46 -080042 Deps: blueprint.DepsGCC,
43 Depfile: "$out.d",
Ivan Lozanoffee3342019-08-27 12:03:00 -070044 },
Ivan Lozano43845682020-07-09 21:03:28 -040045 "rustcFlags", "linkFlags", "libFlags", "crtBegin", "crtEnd", "envVars")
Ivan Lozanoa0cd8f92020-04-09 09:56:02 -040046
Dan Albert06feee92021-03-19 15:06:02 -070047 _ = pctx.SourcePathVariable("rustdocCmd", "${config.RustBin}/rustdoc")
48 rustdoc = pctx.AndroidStaticRule("rustdoc",
49 blueprint.RuleParams{
Dan Albertb433bf72021-04-27 17:12:02 -070050 Command: "$envVars $rustdocCmd $rustdocFlags $in -o $outDir && " +
Dan Albert06feee92021-03-19 15:06:02 -070051 "touch $out",
52 CommandDeps: []string{"$rustdocCmd"},
53 },
54 "rustdocFlags", "outDir", "envVars")
55
Thiébaud Weksteen92f703b2020-06-22 13:28:02 +020056 _ = pctx.SourcePathVariable("clippyCmd", "${config.RustBin}/clippy-driver")
57 clippyDriver = pctx.AndroidStaticRule("clippy",
58 blueprint.RuleParams{
Ivan Lozanobae62be2020-07-21 13:28:27 -040059 Command: "$envVars $clippyCmd " +
Thiébaud Weksteen92f703b2020-06-22 13:28:02 +020060 // Because clippy-driver uses rustc as backend, we need to have some output even during the linting.
61 // Use the metadata output as it has the smallest footprint.
Thiébaud Weksteen94c83252021-04-07 16:00:19 +020062 "--emit metadata -o $out --emit dep-info=$out.d.raw $in ${libFlags} " +
63 "$rustcFlags $clippyFlags" +
64 " && grep \"^$out:\" $out.d.raw > $out.d",
Thiébaud Weksteen92f703b2020-06-22 13:28:02 +020065 CommandDeps: []string{"$clippyCmd"},
Thiébaud Weksteen94c83252021-04-07 16:00:19 +020066 Deps: blueprint.DepsGCC,
67 Depfile: "$out.d",
Thiébaud Weksteen92f703b2020-06-22 13:28:02 +020068 },
Ivan Lozanobae62be2020-07-21 13:28:27 -040069 "rustcFlags", "libFlags", "clippyFlags", "envVars")
Thiébaud Weksteen92f703b2020-06-22 13:28:02 +020070
Ivan Lozanoa0cd8f92020-04-09 09:56:02 -040071 zip = pctx.AndroidStaticRule("zip",
72 blueprint.RuleParams{
73 Command: "cat $out.rsp | tr ' ' '\\n' | tr -d \\' | sort -u > ${out}.tmp && ${SoongZipCmd} -o ${out} -C $$OUT_DIR -l ${out}.tmp",
74 CommandDeps: []string{"${SoongZipCmd}"},
75 Rspfile: "$out.rsp",
76 RspfileContent: "$in",
77 })
Ivan Lozano43845682020-07-09 21:03:28 -040078
79 cp = pctx.AndroidStaticRule("cp",
80 blueprint.RuleParams{
81 Command: "cp `cat $outDir.rsp` $outDir",
82 Rspfile: "${outDir}.rsp",
83 RspfileContent: "$in",
84 },
85 "outDir")
Ivan Lozanoffee3342019-08-27 12:03:00 -070086)
87
Ivan Lozanoa0cd8f92020-04-09 09:56:02 -040088type buildOutput struct {
Joel Galensonfa049382021-01-14 16:03:18 -080089 outputFile android.Path
Ivan Lozanoa0cd8f92020-04-09 09:56:02 -040090}
Ivan Lozanoffee3342019-08-27 12:03:00 -070091
Ivan Lozanoa0cd8f92020-04-09 09:56:02 -040092func init() {
93 pctx.HostBinToolVariable("SoongZipCmd", "soong_zip")
Ivan Lozanoffee3342019-08-27 12:03:00 -070094}
95
Thiébaud Weksteen1f7f70f2020-06-24 11:32:48 +020096func TransformSrcToBinary(ctx ModuleContext, mainSrc android.Path, deps PathDeps, flags Flags,
Dan Albert06feee92021-03-19 15:06:02 -070097 outputFile android.WritablePath) buildOutput {
Pirama Arumuga Nainarf77913f2021-10-25 15:37:43 -070098 flags.GlobalRustFlags = append(flags.GlobalRustFlags, "-C lto=thin")
Ivan Lozano31b095d2019-11-20 10:14:33 -080099
Dan Albert06feee92021-03-19 15:06:02 -0700100 return transformSrctoCrate(ctx, mainSrc, deps, flags, outputFile, "bin")
Ivan Lozanoffee3342019-08-27 12:03:00 -0700101}
102
Thiébaud Weksteen1f7f70f2020-06-24 11:32:48 +0200103func TransformSrctoRlib(ctx ModuleContext, mainSrc android.Path, deps PathDeps, flags Flags,
Dan Albert06feee92021-03-19 15:06:02 -0700104 outputFile android.WritablePath) buildOutput {
105 return transformSrctoCrate(ctx, mainSrc, deps, flags, outputFile, "rlib")
Ivan Lozanoffee3342019-08-27 12:03:00 -0700106}
107
Thiébaud Weksteen1f7f70f2020-06-24 11:32:48 +0200108func TransformSrctoDylib(ctx ModuleContext, mainSrc android.Path, deps PathDeps, flags Flags,
Dan Albert06feee92021-03-19 15:06:02 -0700109 outputFile android.WritablePath) buildOutput {
110 return transformSrctoCrate(ctx, mainSrc, deps, flags, outputFile, "dylib")
Ivan Lozanoffee3342019-08-27 12:03:00 -0700111}
112
Thiébaud Weksteen1f7f70f2020-06-24 11:32:48 +0200113func TransformSrctoStatic(ctx ModuleContext, mainSrc android.Path, deps PathDeps, flags Flags,
Dan Albert06feee92021-03-19 15:06:02 -0700114 outputFile android.WritablePath) buildOutput {
Pirama Arumuga Nainarf77913f2021-10-25 15:37:43 -0700115 flags.GlobalRustFlags = append(flags.GlobalRustFlags, "-C lto=thin")
Dan Albert06feee92021-03-19 15:06:02 -0700116 return transformSrctoCrate(ctx, mainSrc, deps, flags, outputFile, "staticlib")
Ivan Lozano52767be2019-10-18 14:49:46 -0700117}
118
Thiébaud Weksteen1f7f70f2020-06-24 11:32:48 +0200119func TransformSrctoShared(ctx ModuleContext, mainSrc android.Path, deps PathDeps, flags Flags,
Dan Albert06feee92021-03-19 15:06:02 -0700120 outputFile android.WritablePath) buildOutput {
Pirama Arumuga Nainarf77913f2021-10-25 15:37:43 -0700121 flags.GlobalRustFlags = append(flags.GlobalRustFlags, "-C lto=thin")
Dan Albert06feee92021-03-19 15:06:02 -0700122 return transformSrctoCrate(ctx, mainSrc, deps, flags, outputFile, "cdylib")
Ivan Lozano52767be2019-10-18 14:49:46 -0700123}
124
Thiébaud Weksteen1f7f70f2020-06-24 11:32:48 +0200125func TransformSrctoProcMacro(ctx ModuleContext, mainSrc android.Path, deps PathDeps,
Dan Albert06feee92021-03-19 15:06:02 -0700126 flags Flags, outputFile android.WritablePath) buildOutput {
127 return transformSrctoCrate(ctx, mainSrc, deps, flags, outputFile, "proc-macro")
Ivan Lozanoffee3342019-08-27 12:03:00 -0700128}
129
130func rustLibsToPaths(libs RustLibraries) android.Paths {
131 var paths android.Paths
132 for _, lib := range libs {
133 paths = append(paths, lib.Path)
134 }
135 return paths
136}
137
Dan Albert06feee92021-03-19 15:06:02 -0700138func makeLibFlags(deps PathDeps) []string {
139 var libFlags []string
140
141 // Collect library/crate flags
142 for _, lib := range deps.RLibs {
143 libFlags = append(libFlags, "--extern "+lib.CrateName+"="+lib.Path.String())
144 }
145 for _, lib := range deps.DyLibs {
146 libFlags = append(libFlags, "--extern "+lib.CrateName+"="+lib.Path.String())
147 }
148 for _, proc_macro := range deps.ProcMacros {
149 libFlags = append(libFlags, "--extern "+proc_macro.CrateName+"="+proc_macro.Path.String())
150 }
151
152 for _, path := range deps.linkDirs {
153 libFlags = append(libFlags, "-L "+path)
154 }
155
156 return libFlags
157}
158
159func rustEnvVars(ctx ModuleContext, deps PathDeps) []string {
160 var envVars []string
161
162 // libstd requires a specific environment variable to be set. This is
163 // not officially documented and may be removed in the future. See
164 // https://github.com/rust-lang/rust/blob/master/library/std/src/env.rs#L866.
165 if ctx.RustModule().CrateName() == "std" {
166 envVars = append(envVars, "STD_ENV_ARCH="+config.StdEnvArch[ctx.RustModule().Arch().ArchType])
167 }
168
169 if len(deps.SrcDeps) > 0 {
170 moduleGenDir := ctx.RustModule().compiler.CargoOutDir()
171 // We must calculate an absolute path for OUT_DIR since Rust's include! macro (which normally consumes this)
172 // assumes that paths are relative to the source file.
173 var outDirPrefix string
174 if !filepath.IsAbs(moduleGenDir.String()) {
175 // If OUT_DIR is not absolute, we use $$PWD to generate an absolute path (os.Getwd() returns '/')
176 outDirPrefix = "$$PWD/"
177 } else {
178 // If OUT_DIR is absolute, then moduleGenDir will be an absolute path, so we don't need to set this to anything.
179 outDirPrefix = ""
180 }
181 envVars = append(envVars, "OUT_DIR="+filepath.Join(outDirPrefix, moduleGenDir.String()))
182 }
183
184 return envVars
185}
186
Thiébaud Weksteen1f7f70f2020-06-24 11:32:48 +0200187func transformSrctoCrate(ctx ModuleContext, main android.Path, deps PathDeps, flags Flags,
Ivan Lozano7b0781d2021-11-03 15:30:18 -0400188 outputFile android.WritablePath, crateType string) buildOutput {
Ivan Lozanoffee3342019-08-27 12:03:00 -0700189
190 var inputs android.Paths
Ivan Lozanob2df9f82019-11-05 12:16:46 -0800191 var implicits android.Paths
Ivan Lozanoa0cd8f92020-04-09 09:56:02 -0400192 var output buildOutput
Dan Albert06feee92021-03-19 15:06:02 -0700193 var rustcFlags, linkFlags []string
Ivan Lozanoa0cd8f92020-04-09 09:56:02 -0400194 var implicitOutputs android.WritablePaths
195
196 output.outputFile = outputFile
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800197 crateName := ctx.RustModule().CrateName()
Thiébaud Weksteen1f7f70f2020-06-24 11:32:48 +0200198 targetTriple := ctx.toolchain().RustTriple()
Ivan Lozanoffee3342019-08-27 12:03:00 -0700199
Dan Albert06feee92021-03-19 15:06:02 -0700200 envVars := rustEnvVars(ctx, deps)
Thiébaud Weksteen71512f32020-11-03 15:17:51 +0100201
Ivan Lozanoffee3342019-08-27 12:03:00 -0700202 inputs = append(inputs, main)
203
204 // Collect rustc flags
Ivan Lozanof1c84332019-09-20 11:00:37 -0700205 rustcFlags = append(rustcFlags, flags.GlobalRustFlags...)
Ivan Lozanoffee3342019-08-27 12:03:00 -0700206 rustcFlags = append(rustcFlags, flags.RustFlags...)
Ivan Lozano7b0781d2021-11-03 15:30:18 -0400207 rustcFlags = append(rustcFlags, "--crate-type="+crateType)
Jaewoong Jung18aefc12020-12-21 09:11:10 -0800208 if crateName != "" {
209 rustcFlags = append(rustcFlags, "--crate-name="+crateName)
Ivan Lozanoad8b18b2019-10-31 19:38:29 -0700210 }
Ivan Lozanoffee3342019-08-27 12:03:00 -0700211 if targetTriple != "" {
212 rustcFlags = append(rustcFlags, "--target="+targetTriple)
Ivan Lozanof1c84332019-09-20 11:00:37 -0700213 linkFlags = append(linkFlags, "-target "+targetTriple)
Ivan Lozanoffee3342019-08-27 12:03:00 -0700214 }
Matthew Maurerbb3add12020-06-25 09:34:12 -0700215
216 // Suppress an implicit sysroot
217 rustcFlags = append(rustcFlags, "--sysroot=/dev/null")
218
Ivan Lozanof1c84332019-09-20 11:00:37 -0700219 // Collect linker flags
220 linkFlags = append(linkFlags, flags.GlobalLinkFlags...)
221 linkFlags = append(linkFlags, flags.LinkFlags...)
Ivan Lozanoffee3342019-08-27 12:03:00 -0700222
Ivan Lozanoa2268632021-07-22 10:52:06 -0400223 // Check if this module needs to use the bootstrap linker
224 if ctx.RustModule().Bootstrap() && !ctx.RustModule().InRecovery() && !ctx.RustModule().InRamdisk() && !ctx.RustModule().InVendorRamdisk() {
225 dynamicLinker := "-Wl,-dynamic-linker,/system/bin/bootstrap/linker"
226 if ctx.toolchain().Is64Bit() {
227 dynamicLinker += "64"
228 }
229 linkFlags = append(linkFlags, dynamicLinker)
230 }
231
Dan Albert06feee92021-03-19 15:06:02 -0700232 libFlags := makeLibFlags(deps)
Ivan Lozanoffee3342019-08-27 12:03:00 -0700233
234 // Collect dependencies
Ivan Lozanob2df9f82019-11-05 12:16:46 -0800235 implicits = append(implicits, rustLibsToPaths(deps.RLibs)...)
236 implicits = append(implicits, rustLibsToPaths(deps.DyLibs)...)
237 implicits = append(implicits, rustLibsToPaths(deps.ProcMacros)...)
238 implicits = append(implicits, deps.StaticLibs...)
Ivan Lozanoec6e9912021-01-21 15:23:29 -0500239 implicits = append(implicits, deps.SharedLibDeps...)
Ivan Lozano9d74a522020-12-01 09:25:22 -0500240 implicits = append(implicits, deps.srcProviderFiles...)
Ivan Lozano43845682020-07-09 21:03:28 -0400241
Ivan Lozanob2df9f82019-11-05 12:16:46 -0800242 if deps.CrtBegin.Valid() {
243 implicits = append(implicits, deps.CrtBegin.Path(), deps.CrtEnd.Path())
Ivan Lozanof1c84332019-09-20 11:00:37 -0700244 }
Ivan Lozanoffee3342019-08-27 12:03:00 -0700245
Ivan Lozano43845682020-07-09 21:03:28 -0400246 if len(deps.SrcDeps) > 0 {
Thiébaud Weksteenee6a89b2021-02-25 16:30:57 +0100247 moduleGenDir := ctx.RustModule().compiler.CargoOutDir()
Ivan Lozano43845682020-07-09 21:03:28 -0400248 var outputs android.WritablePaths
249
250 for _, genSrc := range deps.SrcDeps {
Ivan Lozano10735d92020-07-22 09:14:47 -0400251 if android.SuffixInList(outputs.Strings(), genSubDir+genSrc.Base()) {
Ivan Lozano43845682020-07-09 21:03:28 -0400252 ctx.PropertyErrorf("srcs",
253 "multiple source providers generate the same filename output: "+genSrc.Base())
254 }
Ivan Lozano10735d92020-07-22 09:14:47 -0400255 outputs = append(outputs, android.PathForModuleOut(ctx, genSubDir+genSrc.Base()))
Ivan Lozano43845682020-07-09 21:03:28 -0400256 }
257
258 ctx.Build(pctx, android.BuildParams{
259 Rule: cp,
Thiébaud Weksteenee6a89b2021-02-25 16:30:57 +0100260 Description: "cp " + moduleGenDir.Path().Rel(),
Ivan Lozano43845682020-07-09 21:03:28 -0400261 Outputs: outputs,
262 Inputs: deps.SrcDeps,
263 Args: map[string]string{
264 "outDir": moduleGenDir.String(),
265 },
266 })
267 implicits = append(implicits, outputs.Paths()...)
Ivan Lozano43845682020-07-09 21:03:28 -0400268 }
269
Thiébaud Weksteen9997ea72021-02-22 10:52:22 +0100270 envVars = append(envVars, "ANDROID_RUST_VERSION="+config.RustDefaultVersion)
271
Ivan Lozanoa9a1fc02021-08-11 15:13:43 -0400272 if ctx.RustModule().compiler.CargoEnvCompat() {
273 if _, ok := ctx.RustModule().compiler.(*binaryDecorator); ok {
274 envVars = append(envVars, "CARGO_BIN_NAME="+strings.TrimSuffix(outputFile.Base(), outputFile.Ext()))
275 }
276 envVars = append(envVars, "CARGO_CRATE_NAME="+ctx.RustModule().CrateName())
277 pkgVersion := ctx.RustModule().compiler.CargoPkgVersion()
278 if pkgVersion != "" {
279 envVars = append(envVars, "CARGO_PKG_VERSION="+pkgVersion)
280 }
281 }
282
Ivan Lozanobae62be2020-07-21 13:28:27 -0400283 if flags.Clippy {
284 clippyFile := android.PathForModuleOut(ctx, outputFile.Base()+".clippy")
285 ctx.Build(pctx, android.BuildParams{
286 Rule: clippyDriver,
287 Description: "clippy " + main.Rel(),
288 Output: clippyFile,
289 ImplicitOutputs: nil,
290 Inputs: inputs,
291 Implicits: implicits,
292 Args: map[string]string{
293 "rustcFlags": strings.Join(rustcFlags, " "),
294 "libFlags": strings.Join(libFlags, " "),
295 "clippyFlags": strings.Join(flags.ClippyFlags, " "),
296 "envVars": strings.Join(envVars, " "),
297 },
298 })
299 // Declare the clippy build as an implicit dependency of the original crate.
300 implicits = append(implicits, clippyFile)
301 }
302
Ivan Lozanoffee3342019-08-27 12:03:00 -0700303 ctx.Build(pctx, android.BuildParams{
Ivan Lozanoa0cd8f92020-04-09 09:56:02 -0400304 Rule: rustc,
305 Description: "rustc " + main.Rel(),
306 Output: outputFile,
307 ImplicitOutputs: implicitOutputs,
308 Inputs: inputs,
309 Implicits: implicits,
Ivan Lozanoffee3342019-08-27 12:03:00 -0700310 Args: map[string]string{
311 "rustcFlags": strings.Join(rustcFlags, " "),
Ivan Lozanof1c84332019-09-20 11:00:37 -0700312 "linkFlags": strings.Join(linkFlags, " "),
Ivan Lozanoffee3342019-08-27 12:03:00 -0700313 "libFlags": strings.Join(libFlags, " "),
Ivan Lozanob2df9f82019-11-05 12:16:46 -0800314 "crtBegin": deps.CrtBegin.String(),
315 "crtEnd": deps.CrtEnd.String(),
Ivan Lozano43845682020-07-09 21:03:28 -0400316 "envVars": strings.Join(envVars, " "),
Ivan Lozanoffee3342019-08-27 12:03:00 -0700317 },
318 })
319
Ivan Lozanoa0cd8f92020-04-09 09:56:02 -0400320 return output
321}
Dan Albert06feee92021-03-19 15:06:02 -0700322
323func Rustdoc(ctx ModuleContext, main android.Path, deps PathDeps,
324 flags Flags) android.ModuleOutPath {
325
326 rustdocFlags := append([]string{}, flags.RustdocFlags...)
327 rustdocFlags = append(rustdocFlags, "--sysroot=/dev/null")
328
Dan Albertb433bf72021-04-27 17:12:02 -0700329 // Build an index for all our crates. -Z unstable options is required to use
330 // this flag.
331 rustdocFlags = append(rustdocFlags, "-Z", "unstable-options", "--enable-index-page")
332
Dan Albert06feee92021-03-19 15:06:02 -0700333 targetTriple := ctx.toolchain().RustTriple()
334
335 // Collect rustc flags
336 if targetTriple != "" {
337 rustdocFlags = append(rustdocFlags, "--target="+targetTriple)
338 }
339
340 crateName := ctx.RustModule().CrateName()
Dan Albertb433bf72021-04-27 17:12:02 -0700341 rustdocFlags = append(rustdocFlags, "--crate-name "+crateName)
Dan Albert06feee92021-03-19 15:06:02 -0700342
343 rustdocFlags = append(rustdocFlags, makeLibFlags(deps)...)
344 docTimestampFile := android.PathForModuleOut(ctx, "rustdoc.timestamp")
Dan Albertb433bf72021-04-27 17:12:02 -0700345
Chris Wailesb2703ad2021-07-30 13:25:42 -0700346 // Silence warnings about renamed lints for third-party crates
347 modulePath := android.PathForModuleSrc(ctx).String()
348 if android.IsThirdPartyPath(modulePath) {
349 rustdocFlags = append(rustdocFlags, " -A renamed_and_removed_lints")
350 }
Chris Wailes9953a192021-07-28 12:07:16 -0700351
Dan Albertb433bf72021-04-27 17:12:02 -0700352 // Yes, the same out directory is used simultaneously by all rustdoc builds.
353 // This is what cargo does. The docs for individual crates get generated to
354 // a subdirectory named for the crate, and rustdoc synchronizes writes to
355 // shared pieces like the index and search data itself.
356 // https://github.com/rust-lang/rust/blob/master/src/librustdoc/html/render/write_shared.rs#L144-L146
357 docDir := android.PathForOutput(ctx, "rustdoc")
Dan Albert06feee92021-03-19 15:06:02 -0700358
359 ctx.Build(pctx, android.BuildParams{
360 Rule: rustdoc,
361 Description: "rustdoc " + main.Rel(),
362 Output: docTimestampFile,
363 Input: main,
Ivan Lozano8d10fc32021-11-05 16:36:47 -0400364 Implicit: ctx.RustModule().UnstrippedOutputFile(),
Dan Albert06feee92021-03-19 15:06:02 -0700365 Args: map[string]string{
366 "rustdocFlags": strings.Join(rustdocFlags, " "),
367 "outDir": docDir.String(),
368 "envVars": strings.Join(rustEnvVars(ctx, deps), " "),
369 },
370 })
371
372 return docTimestampFile
373}