Added error-format flag to x.py.

This commit is contained in:
penpalperson 2018-02-24 15:56:33 -07:00
parent 6070d3e47e
commit 264a92182e
4 changed files with 13 additions and 0 deletions

View File

@ -61,6 +61,11 @@ fn main() {
args.remove(n); args.remove(n);
} }
if let Some(s) = env::var_os("RUSTC_ERROR_FORMAT") {
args.push("--error-format".into());
args.push(s);
}
// Detect whether or not we're a build script depending on whether --target // Detect whether or not we're a build script depending on whether --target
// is passed (a bit janky...) // is passed (a bit janky...)
let target = args.windows(2) let target = args.windows(2)

View File

@ -598,6 +598,9 @@ impl<'a> Builder<'a> {
if let Some(target_linker) = self.build.linker(target) { if let Some(target_linker) = self.build.linker(target) {
cargo.env("RUSTC_TARGET_LINKER", target_linker); cargo.env("RUSTC_TARGET_LINKER", target_linker);
} }
if let Some(ref error_format) = self.config.rustc_error_format {
cargo.env("RUSTC_ERROR_FORMAT", error_format);
}
if cmd != "build" && cmd != "check" { if cmd != "build" && cmd != "check" {
cargo.env("RUSTDOC_LIBDIR", self.rustc_libdir(self.compiler(2, self.build.build))); cargo.env("RUSTDOC_LIBDIR", self.rustc_libdir(self.compiler(2, self.build.build)));
} }

View File

@ -57,6 +57,7 @@ pub struct Config {
pub profiler: bool, pub profiler: bool,
pub ignore_git: bool, pub ignore_git: bool,
pub exclude: Vec<PathBuf>, pub exclude: Vec<PathBuf>,
pub rustc_error_format: Option<String>,
pub run_host_only: bool, pub run_host_only: bool,
@ -330,6 +331,7 @@ impl Config {
config.test_miri = false; config.test_miri = false;
config.rust_codegen_backends = vec![INTERNER.intern_str("llvm")]; config.rust_codegen_backends = vec![INTERNER.intern_str("llvm")];
config.rustc_error_format = flags.rustc_error_format;
config.on_fail = flags.on_fail; config.on_fail = flags.on_fail;
config.stage = flags.stage; config.stage = flags.stage;
config.src = flags.src; config.src = flags.src;

View File

@ -43,6 +43,7 @@ pub struct Flags {
pub cmd: Subcommand, pub cmd: Subcommand,
pub incremental: bool, pub incremental: bool,
pub exclude: Vec<PathBuf>, pub exclude: Vec<PathBuf>,
pub rustc_error_format: Option<String>,
} }
pub enum Subcommand { pub enum Subcommand {
@ -118,6 +119,7 @@ To learn more about a subcommand, run `./x.py <subcommand> -h`");
opts.optopt("", "src", "path to the root of the rust checkout", "DIR"); opts.optopt("", "src", "path to the root of the rust checkout", "DIR");
opts.optopt("j", "jobs", "number of jobs to run in parallel", "JOBS"); opts.optopt("j", "jobs", "number of jobs to run in parallel", "JOBS");
opts.optflag("h", "help", "print this help message"); opts.optflag("h", "help", "print this help message");
opts.optflag("", "error-format", "rustc error format");
// fn usage() // fn usage()
let usage = |exit_code: i32, opts: &Options, subcommand_help: &str, extra_help: &str| -> ! { let usage = |exit_code: i32, opts: &Options, subcommand_help: &str, extra_help: &str| -> ! {
@ -370,6 +372,7 @@ Arguments:
verbose: matches.opt_count("verbose"), verbose: matches.opt_count("verbose"),
stage, stage,
on_fail: matches.opt_str("on-fail"), on_fail: matches.opt_str("on-fail"),
rustc_error_format: matches.opt_str("error-format"),
keep_stage: matches.opt_str("keep-stage").map(|j| j.parse().unwrap()), keep_stage: matches.opt_str("keep-stage").map(|j| j.parse().unwrap()),
build: matches.opt_str("build").map(|s| INTERNER.intern_string(s)), build: matches.opt_str("build").map(|s| INTERNER.intern_string(s)),
host: split(matches.opt_strs("host")) host: split(matches.opt_strs("host"))