Add clippy and fix commands to x.py
This commit is contained in:
parent
315ab95a9c
commit
2f3533b758
|
@ -318,6 +318,8 @@ impl<'a> ShouldRun<'a> {
|
||||||
pub enum Kind {
|
pub enum Kind {
|
||||||
Build,
|
Build,
|
||||||
Check,
|
Check,
|
||||||
|
Clippy,
|
||||||
|
Fix,
|
||||||
Test,
|
Test,
|
||||||
Bench,
|
Bench,
|
||||||
Dist,
|
Dist,
|
||||||
|
@ -359,7 +361,7 @@ impl<'a> Builder<'a> {
|
||||||
tool::Miri,
|
tool::Miri,
|
||||||
native::Lld
|
native::Lld
|
||||||
),
|
),
|
||||||
Kind::Check => describe!(
|
Kind::Check | Kind::Clippy | Kind::Fix => describe!(
|
||||||
check::Std,
|
check::Std,
|
||||||
check::Test,
|
check::Test,
|
||||||
check::Rustc,
|
check::Rustc,
|
||||||
|
@ -520,6 +522,8 @@ impl<'a> Builder<'a> {
|
||||||
let (kind, paths) = match build.config.cmd {
|
let (kind, paths) = match build.config.cmd {
|
||||||
Subcommand::Build { ref paths } => (Kind::Build, &paths[..]),
|
Subcommand::Build { ref paths } => (Kind::Build, &paths[..]),
|
||||||
Subcommand::Check { ref paths } => (Kind::Check, &paths[..]),
|
Subcommand::Check { ref paths } => (Kind::Check, &paths[..]),
|
||||||
|
Subcommand::Clippy { ref paths } => (Kind::Clippy, &paths[..]),
|
||||||
|
Subcommand::Fix { ref paths } => (Kind::Fix, &paths[..]),
|
||||||
Subcommand::Doc { ref paths } => (Kind::Doc, &paths[..]),
|
Subcommand::Doc { ref paths } => (Kind::Doc, &paths[..]),
|
||||||
Subcommand::Test { ref paths, .. } => (Kind::Test, &paths[..]),
|
Subcommand::Test { ref paths, .. } => (Kind::Test, &paths[..]),
|
||||||
Subcommand::Bench { ref paths, .. } => (Kind::Bench, &paths[..]),
|
Subcommand::Bench { ref paths, .. } => (Kind::Bench, &paths[..]),
|
||||||
|
@ -757,17 +761,17 @@ impl<'a> Builder<'a> {
|
||||||
};
|
};
|
||||||
|
|
||||||
let libstd_stamp = match cmd {
|
let libstd_stamp = match cmd {
|
||||||
"check" => check::libstd_stamp(self, cmp, target),
|
"check" | "clippy" | "fix" => check::libstd_stamp(self, cmp, target),
|
||||||
_ => compile::libstd_stamp(self, cmp, target),
|
_ => compile::libstd_stamp(self, cmp, target),
|
||||||
};
|
};
|
||||||
|
|
||||||
let libtest_stamp = match cmd {
|
let libtest_stamp = match cmd {
|
||||||
"check" => check::libtest_stamp(self, cmp, target),
|
"check" | "clippy" | "fix" => check::libtest_stamp(self, cmp, target),
|
||||||
_ => compile::libstd_stamp(self, cmp, target),
|
_ => compile::libstd_stamp(self, cmp, target),
|
||||||
};
|
};
|
||||||
|
|
||||||
let librustc_stamp = match cmd {
|
let librustc_stamp = match cmd {
|
||||||
"check" => check::librustc_stamp(self, cmp, target),
|
"check" | "clippy" | "fix" => check::librustc_stamp(self, cmp, target),
|
||||||
_ => compile::librustc_stamp(self, cmp, target),
|
_ => compile::librustc_stamp(self, cmp, target),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -831,9 +835,9 @@ impl<'a> Builder<'a> {
|
||||||
assert_eq!(target, compiler.host);
|
assert_eq!(target, compiler.host);
|
||||||
}
|
}
|
||||||
|
|
||||||
// Set a flag for `check` so that certain build scripts can do less work
|
// Set a flag for `check`/`clippy`/`fix`, so that certain build
|
||||||
// (e.g., not building/requiring LLVM).
|
// scripts can do less work (e.g. not building/requiring LLVM).
|
||||||
if cmd == "check" {
|
if cmd == "check" || cmd == "clippy" || cmd == "fix" {
|
||||||
cargo.env("RUST_CHECK", "1");
|
cargo.env("RUST_CHECK", "1");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -898,6 +902,11 @@ impl<'a> Builder<'a> {
|
||||||
extra_args.push_str(&s);
|
extra_args.push_str(&s);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if cmd == "clippy" {
|
||||||
|
extra_args.push_str("-Zforce-unstable-if-unmarked -Zunstable-options \
|
||||||
|
--json-rendered=termcolor");
|
||||||
|
}
|
||||||
|
|
||||||
if !extra_args.is_empty() {
|
if !extra_args.is_empty() {
|
||||||
cargo.env(
|
cargo.env(
|
||||||
"RUSTFLAGS",
|
"RUSTFLAGS",
|
||||||
|
@ -966,7 +975,7 @@ impl<'a> Builder<'a> {
|
||||||
if let Some(ref error_format) = self.config.rustc_error_format {
|
if let Some(ref error_format) = self.config.rustc_error_format {
|
||||||
cargo.env("RUSTC_ERROR_FORMAT", error_format);
|
cargo.env("RUSTC_ERROR_FORMAT", error_format);
|
||||||
}
|
}
|
||||||
if cmd != "build" && cmd != "check" && cmd != "rustc" && want_rustdoc {
|
if !(["build", "check", "clippy", "fix", "rustc"].contains(&cmd)) && want_rustdoc {
|
||||||
cargo.env("RUSTDOC_LIBDIR", self.rustc_libdir(compiler));
|
cargo.env("RUSTDOC_LIBDIR", self.rustc_libdir(compiler));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,8 +1,8 @@
|
||||||
//! Implementation of compiling the compiler and standard library, in "check" mode.
|
//! Implementation of compiling the compiler and standard library, in "check"-based modes.
|
||||||
|
|
||||||
use crate::compile::{run_cargo, std_cargo, test_cargo, rustc_cargo, rustc_cargo_env,
|
use crate::compile::{run_cargo, std_cargo, test_cargo, rustc_cargo, rustc_cargo_env,
|
||||||
add_to_sysroot};
|
add_to_sysroot};
|
||||||
use crate::builder::{RunConfig, Builder, ShouldRun, Step};
|
use crate::builder::{RunConfig, Builder, Kind, ShouldRun, Step};
|
||||||
use crate::tool::{prepare_tool_cargo, SourceType};
|
use crate::tool::{prepare_tool_cargo, SourceType};
|
||||||
use crate::{Compiler, Mode};
|
use crate::{Compiler, Mode};
|
||||||
use crate::cache::{INTERNER, Interned};
|
use crate::cache::{INTERNER, Interned};
|
||||||
|
@ -13,6 +13,22 @@ pub struct Std {
|
||||||
pub target: Interned<String>,
|
pub target: Interned<String>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn args(kind: Kind) -> Vec<String> {
|
||||||
|
match kind {
|
||||||
|
Kind::Clippy => vec!["--".to_owned(), "--cap-lints".to_owned(), "warn".to_owned()],
|
||||||
|
_ => Vec::new()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
fn cargo_subcommand(kind: Kind) -> &'static str {
|
||||||
|
match kind {
|
||||||
|
Kind::Check => "check",
|
||||||
|
Kind::Clippy => "clippy",
|
||||||
|
Kind::Fix => "fix",
|
||||||
|
_ => unreachable!()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
impl Step for Std {
|
impl Step for Std {
|
||||||
type Output = ();
|
type Output = ();
|
||||||
const DEFAULT: bool = true;
|
const DEFAULT: bool = true;
|
||||||
|
@ -31,13 +47,14 @@ impl Step for Std {
|
||||||
let target = self.target;
|
let target = self.target;
|
||||||
let compiler = builder.compiler(0, builder.config.build);
|
let compiler = builder.compiler(0, builder.config.build);
|
||||||
|
|
||||||
let mut cargo = builder.cargo(compiler, Mode::Std, target, "check");
|
let mut cargo = builder.cargo(compiler, Mode::Std, target, cargo_subcommand(builder.kind));
|
||||||
std_cargo(builder, &compiler, target, &mut cargo);
|
std_cargo(builder, &compiler, target, &mut cargo);
|
||||||
|
|
||||||
let _folder = builder.fold_output(|| format!("stage{}-std", compiler.stage));
|
let _folder = builder.fold_output(|| format!("stage{}-std", compiler.stage));
|
||||||
builder.info(&format!("Checking std artifacts ({} -> {})", &compiler.host, target));
|
builder.info(&format!("Checking std artifacts ({} -> {})", &compiler.host, target));
|
||||||
run_cargo(builder,
|
run_cargo(builder,
|
||||||
&mut cargo,
|
&mut cargo,
|
||||||
|
args(builder.kind),
|
||||||
&libstd_stamp(builder, compiler, target),
|
&libstd_stamp(builder, compiler, target),
|
||||||
true);
|
true);
|
||||||
|
|
||||||
|
@ -78,13 +95,15 @@ impl Step for Rustc {
|
||||||
|
|
||||||
builder.ensure(Test { target });
|
builder.ensure(Test { target });
|
||||||
|
|
||||||
let mut cargo = builder.cargo(compiler, Mode::Rustc, target, "check");
|
let mut cargo = builder.cargo(compiler, Mode::Rustc, target,
|
||||||
|
cargo_subcommand(builder.kind));
|
||||||
rustc_cargo(builder, &mut cargo);
|
rustc_cargo(builder, &mut cargo);
|
||||||
|
|
||||||
let _folder = builder.fold_output(|| format!("stage{}-rustc", compiler.stage));
|
let _folder = builder.fold_output(|| format!("stage{}-rustc", compiler.stage));
|
||||||
builder.info(&format!("Checking compiler artifacts ({} -> {})", &compiler.host, target));
|
builder.info(&format!("Checking compiler artifacts ({} -> {})", &compiler.host, target));
|
||||||
run_cargo(builder,
|
run_cargo(builder,
|
||||||
&mut cargo,
|
&mut cargo,
|
||||||
|
args(builder.kind),
|
||||||
&librustc_stamp(builder, compiler, target),
|
&librustc_stamp(builder, compiler, target),
|
||||||
true);
|
true);
|
||||||
|
|
||||||
|
@ -127,7 +146,8 @@ impl Step for CodegenBackend {
|
||||||
|
|
||||||
builder.ensure(Rustc { target });
|
builder.ensure(Rustc { target });
|
||||||
|
|
||||||
let mut cargo = builder.cargo(compiler, Mode::Codegen, target, "check");
|
let mut cargo = builder.cargo(compiler, Mode::Codegen, target,
|
||||||
|
cargo_subcommand(builder.kind));
|
||||||
cargo.arg("--manifest-path").arg(builder.src.join("src/librustc_codegen_llvm/Cargo.toml"));
|
cargo.arg("--manifest-path").arg(builder.src.join("src/librustc_codegen_llvm/Cargo.toml"));
|
||||||
rustc_cargo_env(builder, &mut cargo);
|
rustc_cargo_env(builder, &mut cargo);
|
||||||
|
|
||||||
|
@ -136,6 +156,7 @@ impl Step for CodegenBackend {
|
||||||
let _folder = builder.fold_output(|| format!("stage{}-rustc_codegen_llvm", compiler.stage));
|
let _folder = builder.fold_output(|| format!("stage{}-rustc_codegen_llvm", compiler.stage));
|
||||||
run_cargo(builder,
|
run_cargo(builder,
|
||||||
&mut cargo,
|
&mut cargo,
|
||||||
|
args(builder.kind),
|
||||||
&codegen_backend_stamp(builder, compiler, target, backend),
|
&codegen_backend_stamp(builder, compiler, target, backend),
|
||||||
true);
|
true);
|
||||||
}
|
}
|
||||||
|
@ -166,13 +187,14 @@ impl Step for Test {
|
||||||
|
|
||||||
builder.ensure(Std { target });
|
builder.ensure(Std { target });
|
||||||
|
|
||||||
let mut cargo = builder.cargo(compiler, Mode::Test, target, "check");
|
let mut cargo = builder.cargo(compiler, Mode::Test, target, cargo_subcommand(builder.kind));
|
||||||
test_cargo(builder, &compiler, target, &mut cargo);
|
test_cargo(builder, &compiler, target, &mut cargo);
|
||||||
|
|
||||||
let _folder = builder.fold_output(|| format!("stage{}-test", compiler.stage));
|
let _folder = builder.fold_output(|| format!("stage{}-test", compiler.stage));
|
||||||
builder.info(&format!("Checking test artifacts ({} -> {})", &compiler.host, target));
|
builder.info(&format!("Checking test artifacts ({} -> {})", &compiler.host, target));
|
||||||
run_cargo(builder,
|
run_cargo(builder,
|
||||||
&mut cargo,
|
&mut cargo,
|
||||||
|
args(builder.kind),
|
||||||
&libtest_stamp(builder, compiler, target),
|
&libtest_stamp(builder, compiler, target),
|
||||||
true);
|
true);
|
||||||
|
|
||||||
|
@ -212,7 +234,7 @@ impl Step for Rustdoc {
|
||||||
compiler,
|
compiler,
|
||||||
Mode::ToolRustc,
|
Mode::ToolRustc,
|
||||||
target,
|
target,
|
||||||
"check",
|
cargo_subcommand(builder.kind),
|
||||||
"src/tools/rustdoc",
|
"src/tools/rustdoc",
|
||||||
SourceType::InTree,
|
SourceType::InTree,
|
||||||
&[]);
|
&[]);
|
||||||
|
@ -221,6 +243,7 @@ impl Step for Rustdoc {
|
||||||
println!("Checking rustdoc artifacts ({} -> {})", &compiler.host, target);
|
println!("Checking rustdoc artifacts ({} -> {})", &compiler.host, target);
|
||||||
run_cargo(builder,
|
run_cargo(builder,
|
||||||
&mut cargo,
|
&mut cargo,
|
||||||
|
args(builder.kind),
|
||||||
&rustdoc_stamp(builder, compiler, target),
|
&rustdoc_stamp(builder, compiler, target),
|
||||||
true);
|
true);
|
||||||
|
|
||||||
|
|
|
@ -100,6 +100,7 @@ impl Step for Std {
|
||||||
&compiler.host, target));
|
&compiler.host, target));
|
||||||
run_cargo(builder,
|
run_cargo(builder,
|
||||||
&mut cargo,
|
&mut cargo,
|
||||||
|
vec![],
|
||||||
&libstd_stamp(builder, compiler, target),
|
&libstd_stamp(builder, compiler, target),
|
||||||
false);
|
false);
|
||||||
|
|
||||||
|
@ -425,6 +426,7 @@ impl Step for Test {
|
||||||
&compiler.host, target));
|
&compiler.host, target));
|
||||||
run_cargo(builder,
|
run_cargo(builder,
|
||||||
&mut cargo,
|
&mut cargo,
|
||||||
|
vec![],
|
||||||
&libtest_stamp(builder, compiler, target),
|
&libtest_stamp(builder, compiler, target),
|
||||||
false);
|
false);
|
||||||
|
|
||||||
|
@ -556,6 +558,7 @@ impl Step for Rustc {
|
||||||
compiler.stage, &compiler.host, target));
|
compiler.stage, &compiler.host, target));
|
||||||
run_cargo(builder,
|
run_cargo(builder,
|
||||||
&mut cargo,
|
&mut cargo,
|
||||||
|
vec![],
|
||||||
&librustc_stamp(builder, compiler, target),
|
&librustc_stamp(builder, compiler, target),
|
||||||
false);
|
false);
|
||||||
|
|
||||||
|
@ -707,6 +710,7 @@ impl Step for CodegenBackend {
|
||||||
let _folder = builder.fold_output(|| format!("stage{}-rustc_codegen_llvm", compiler.stage));
|
let _folder = builder.fold_output(|| format!("stage{}-rustc_codegen_llvm", compiler.stage));
|
||||||
let files = run_cargo(builder,
|
let files = run_cargo(builder,
|
||||||
cargo.arg("--features").arg(features),
|
cargo.arg("--features").arg(features),
|
||||||
|
vec![],
|
||||||
&tmp_stamp,
|
&tmp_stamp,
|
||||||
false);
|
false);
|
||||||
if builder.config.dry_run {
|
if builder.config.dry_run {
|
||||||
|
@ -1077,6 +1081,7 @@ pub fn add_to_sysroot(
|
||||||
|
|
||||||
pub fn run_cargo(builder: &Builder<'_>,
|
pub fn run_cargo(builder: &Builder<'_>,
|
||||||
cargo: &mut Command,
|
cargo: &mut Command,
|
||||||
|
tail_args: Vec<String>,
|
||||||
stamp: &Path,
|
stamp: &Path,
|
||||||
is_check: bool)
|
is_check: bool)
|
||||||
-> Vec<PathBuf>
|
-> Vec<PathBuf>
|
||||||
|
@ -1099,7 +1104,7 @@ pub fn run_cargo(builder: &Builder<'_>,
|
||||||
// files we need to probe for later.
|
// files we need to probe for later.
|
||||||
let mut deps = Vec::new();
|
let mut deps = Vec::new();
|
||||||
let mut toplevel = Vec::new();
|
let mut toplevel = Vec::new();
|
||||||
let ok = stream_cargo(builder, cargo, &mut |msg| {
|
let ok = stream_cargo(builder, cargo, tail_args, &mut |msg| {
|
||||||
let (filenames, crate_types) = match msg {
|
let (filenames, crate_types) = match msg {
|
||||||
CargoMessage::CompilerArtifact {
|
CargoMessage::CompilerArtifact {
|
||||||
filenames,
|
filenames,
|
||||||
|
@ -1108,6 +1113,10 @@ pub fn run_cargo(builder: &Builder<'_>,
|
||||||
},
|
},
|
||||||
..
|
..
|
||||||
} => (filenames, crate_types),
|
} => (filenames, crate_types),
|
||||||
|
CargoMessage::CompilerMessage { message } => {
|
||||||
|
eprintln!("{}", message.rendered);
|
||||||
|
return;
|
||||||
|
}
|
||||||
_ => return,
|
_ => return,
|
||||||
};
|
};
|
||||||
for filename in filenames {
|
for filename in filenames {
|
||||||
|
@ -1235,6 +1244,7 @@ pub fn run_cargo(builder: &Builder<'_>,
|
||||||
pub fn stream_cargo(
|
pub fn stream_cargo(
|
||||||
builder: &Builder<'_>,
|
builder: &Builder<'_>,
|
||||||
cargo: &mut Command,
|
cargo: &mut Command,
|
||||||
|
tail_args: Vec<String>,
|
||||||
cb: &mut dyn FnMut(CargoMessage<'_>),
|
cb: &mut dyn FnMut(CargoMessage<'_>),
|
||||||
) -> bool {
|
) -> bool {
|
||||||
if builder.config.dry_run {
|
if builder.config.dry_run {
|
||||||
|
@ -1245,6 +1255,10 @@ pub fn stream_cargo(
|
||||||
cargo.arg("--message-format").arg("json")
|
cargo.arg("--message-format").arg("json")
|
||||||
.stdout(Stdio::piped());
|
.stdout(Stdio::piped());
|
||||||
|
|
||||||
|
for arg in tail_args {
|
||||||
|
cargo.arg(arg);
|
||||||
|
}
|
||||||
|
|
||||||
builder.verbose(&format!("running: {:?}", cargo));
|
builder.verbose(&format!("running: {:?}", cargo));
|
||||||
let mut child = match cargo.spawn() {
|
let mut child = match cargo.spawn() {
|
||||||
Ok(child) => child,
|
Ok(child) => child,
|
||||||
|
@ -1291,5 +1305,13 @@ pub enum CargoMessage<'a> {
|
||||||
},
|
},
|
||||||
BuildScriptExecuted {
|
BuildScriptExecuted {
|
||||||
package_id: Cow<'a, str>,
|
package_id: Cow<'a, str>,
|
||||||
|
},
|
||||||
|
CompilerMessage {
|
||||||
|
message: ClippyMessage<'a>
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#[derive(Deserialize)]
|
||||||
|
pub struct ClippyMessage<'a> {
|
||||||
|
rendered: Cow<'a, str>,
|
||||||
|
}
|
||||||
|
|
|
@ -44,6 +44,12 @@ pub enum Subcommand {
|
||||||
Check {
|
Check {
|
||||||
paths: Vec<PathBuf>,
|
paths: Vec<PathBuf>,
|
||||||
},
|
},
|
||||||
|
Clippy {
|
||||||
|
paths: Vec<PathBuf>,
|
||||||
|
},
|
||||||
|
Fix {
|
||||||
|
paths: Vec<PathBuf>,
|
||||||
|
},
|
||||||
Doc {
|
Doc {
|
||||||
paths: Vec<PathBuf>,
|
paths: Vec<PathBuf>,
|
||||||
},
|
},
|
||||||
|
@ -90,6 +96,8 @@ Usage: x.py <subcommand> [options] [<paths>...]
|
||||||
Subcommands:
|
Subcommands:
|
||||||
build Compile either the compiler or libraries
|
build Compile either the compiler or libraries
|
||||||
check Compile either the compiler or libraries, using cargo check
|
check Compile either the compiler or libraries, using cargo check
|
||||||
|
clippy Run clippy
|
||||||
|
fix Run cargo fix
|
||||||
test Build and run some test suites
|
test Build and run some test suites
|
||||||
bench Build and run some benchmarks
|
bench Build and run some benchmarks
|
||||||
doc Build documentation
|
doc Build documentation
|
||||||
|
@ -146,6 +154,8 @@ To learn more about a subcommand, run `./x.py <subcommand> -h`"
|
||||||
let subcommand = args.iter().find(|&s| {
|
let subcommand = args.iter().find(|&s| {
|
||||||
(s == "build")
|
(s == "build")
|
||||||
|| (s == "check")
|
|| (s == "check")
|
||||||
|
|| (s == "clippy")
|
||||||
|
|| (s == "fix")
|
||||||
|| (s == "test")
|
|| (s == "test")
|
||||||
|| (s == "bench")
|
|| (s == "bench")
|
||||||
|| (s == "doc")
|
|| (s == "doc")
|
||||||
|
@ -281,6 +291,28 @@ Arguments:
|
||||||
the compiler.",
|
the compiler.",
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
"clippy" => {
|
||||||
|
subcommand_help.push_str(
|
||||||
|
"\n
|
||||||
|
Arguments:
|
||||||
|
This subcommand accepts a number of paths to directories to the crates
|
||||||
|
and/or artifacts to run clippy against. For example:
|
||||||
|
|
||||||
|
./x.py clippy src/libcore
|
||||||
|
./x.py clippy src/libcore src/libproc_macro",
|
||||||
|
);
|
||||||
|
}
|
||||||
|
"fix" => {
|
||||||
|
subcommand_help.push_str(
|
||||||
|
"\n
|
||||||
|
Arguments:
|
||||||
|
This subcommand accepts a number of paths to directories to the crates
|
||||||
|
and/or artifacts to run `cargo fix` against. For example:
|
||||||
|
|
||||||
|
./x.py fix src/libcore
|
||||||
|
./x.py fix src/libcore src/libproc_macro",
|
||||||
|
);
|
||||||
|
}
|
||||||
"test" => {
|
"test" => {
|
||||||
subcommand_help.push_str(
|
subcommand_help.push_str(
|
||||||
"\n
|
"\n
|
||||||
|
@ -363,6 +395,8 @@ Arguments:
|
||||||
let cmd = match subcommand.as_str() {
|
let cmd = match subcommand.as_str() {
|
||||||
"build" => Subcommand::Build { paths },
|
"build" => Subcommand::Build { paths },
|
||||||
"check" => Subcommand::Check { paths },
|
"check" => Subcommand::Check { paths },
|
||||||
|
"clippy" => Subcommand::Clippy { paths },
|
||||||
|
"fix" => Subcommand::Fix { paths },
|
||||||
"test" => Subcommand::Test {
|
"test" => Subcommand::Test {
|
||||||
paths,
|
paths,
|
||||||
bless: matches.opt_present("bless"),
|
bless: matches.opt_present("bless"),
|
||||||
|
|
|
@ -77,7 +77,7 @@ impl Step for ToolBuild {
|
||||||
let _folder = builder.fold_output(|| format!("stage{}-{}", compiler.stage, tool));
|
let _folder = builder.fold_output(|| format!("stage{}-{}", compiler.stage, tool));
|
||||||
builder.info(&format!("Building stage{} tool {} ({})", compiler.stage, tool, target));
|
builder.info(&format!("Building stage{} tool {} ({})", compiler.stage, tool, target));
|
||||||
let mut duplicates = Vec::new();
|
let mut duplicates = Vec::new();
|
||||||
let is_expected = compile::stream_cargo(builder, &mut cargo, &mut |msg| {
|
let is_expected = compile::stream_cargo(builder, &mut cargo, vec![], &mut |msg| {
|
||||||
// Only care about big things like the RLS/Cargo for now
|
// Only care about big things like the RLS/Cargo for now
|
||||||
match tool {
|
match tool {
|
||||||
| "rls"
|
| "rls"
|
||||||
|
|
Loading…
Reference in New Issue