rustbuild: Make save-analysis an option

This commit is contained in:
Tatsuyuki Ishi 2017-03-09 17:49:37 +09:00
parent 8c72b7651f
commit e31e264c55
6 changed files with 11 additions and 10 deletions

1
configure vendored
View File

@ -645,6 +645,7 @@ opt dist-host-only 0 "only install bins for the host architecture"
opt inject-std-version 1 "inject the current compiler version of libstd into programs" opt inject-std-version 1 "inject the current compiler version of libstd into programs"
opt llvm-version-check 1 "check if the LLVM version is supported, build anyway" opt llvm-version-check 1 "check if the LLVM version is supported, build anyway"
opt codegen-tests 1 "run the src/test/codegen tests" opt codegen-tests 1 "run the src/test/codegen tests"
opt save-analysis 0 "save API analysis data"
opt option-checking 1 "complain about unrecognized options in this configure script" opt option-checking 1 "complain about unrecognized options in this configure script"
opt ninja 0 "build LLVM using the Ninja generator (for MSVC, requires building in the correct environment)" opt ninja 0 "build LLVM using the Ninja generator (for MSVC, requires building in the correct environment)"
opt locked-deps 0 "force Cargo.lock to be up to date" opt locked-deps 0 "force Cargo.lock to be up to date"

View File

@ -73,6 +73,7 @@ pub struct Config {
pub rustc_default_ar: Option<String>, pub rustc_default_ar: Option<String>,
pub rust_optimize_tests: bool, pub rust_optimize_tests: bool,
pub rust_debuginfo_tests: bool, pub rust_debuginfo_tests: bool,
pub rust_save_analysis: bool,
pub rust_dist_src: bool, pub rust_dist_src: bool,
pub build: String, pub build: String,
@ -223,6 +224,7 @@ struct Rust {
optimize_tests: Option<bool>, optimize_tests: Option<bool>,
debuginfo_tests: Option<bool>, debuginfo_tests: Option<bool>,
codegen_tests: Option<bool>, codegen_tests: Option<bool>,
save_analysis: Option<bool>,
} }
/// TOML representation of how each build target is configured. /// TOML representation of how each build target is configured.
@ -347,6 +349,7 @@ impl Config {
set(&mut config.rust_optimize_tests, rust.optimize_tests); set(&mut config.rust_optimize_tests, rust.optimize_tests);
set(&mut config.rust_debuginfo_tests, rust.debuginfo_tests); set(&mut config.rust_debuginfo_tests, rust.debuginfo_tests);
set(&mut config.codegen_tests, rust.codegen_tests); set(&mut config.codegen_tests, rust.codegen_tests);
set(&mut config.rust_save_analysis, rust.save_analysis);
set(&mut config.rust_rpath, rust.rpath); set(&mut config.rust_rpath, rust.rpath);
set(&mut config.debug_jemalloc, rust.debug_jemalloc); set(&mut config.debug_jemalloc, rust.debug_jemalloc);
set(&mut config.use_jemalloc, rust.use_jemalloc); set(&mut config.use_jemalloc, rust.use_jemalloc);
@ -453,6 +456,7 @@ impl Config {
("LOCAL_REBUILD", self.local_rebuild), ("LOCAL_REBUILD", self.local_rebuild),
("NINJA", self.ninja), ("NINJA", self.ninja),
("CODEGEN_TESTS", self.codegen_tests), ("CODEGEN_TESTS", self.codegen_tests),
("SAVE_ANALYSIS", self.rust_save_analysis),
("LOCKED_DEPS", self.locked_deps), ("LOCKED_DEPS", self.locked_deps),
("VENDOR", self.vendor), ("VENDOR", self.vendor),
("FULL_BOOTSTRAP", self.full_bootstrap), ("FULL_BOOTSTRAP", self.full_bootstrap),

View File

@ -229,6 +229,9 @@
# saying that the FileCheck executable is missing, you may want to disable this. # saying that the FileCheck executable is missing, you may want to disable this.
#codegen-tests = true #codegen-tests = true
# Flag indicating whether the API analysis data should be saved.
#save-analysis = false
# ============================================================================= # =============================================================================
# Options for specific targets # Options for specific targets
# #

View File

@ -313,16 +313,8 @@ pub fn rust_src_location(build: &Build) -> PathBuf {
pub fn analysis(build: &Build, compiler: &Compiler, target: &str) { pub fn analysis(build: &Build, compiler: &Compiler, target: &str) {
println!("Dist analysis"); println!("Dist analysis");
if build.config.channel != "nightly" {
println!("\tskipping - not on nightly channel");
return;
}
if compiler.host != build.config.build { if compiler.host != build.config.build {
println!("\tskipping - not a build host"); println!("\tskipping, not a build host");
return
}
if compiler.stage != 2 {
println!("\tskipping - not stage2");
return return
} }

View File

@ -524,7 +524,7 @@ impl Build {
.env(format!("CFLAGS_{}", target), self.cflags(target).join(" ")); .env(format!("CFLAGS_{}", target), self.cflags(target).join(" "));
} }
if self.config.channel == "nightly" && compiler.is_final_stage(self) { if self.config.rust_save_analysis && compiler.is_final_stage(self) {
cargo.env("RUSTC_SAVE_ANALYSIS", "api".to_string()); cargo.env("RUSTC_SAVE_ANALYSIS", "api".to_string());
} }

View File

@ -42,6 +42,7 @@ fi
if [ "$DEPLOY$DEPLOY_ALT" != "" ]; then if [ "$DEPLOY$DEPLOY_ALT" != "" ]; then
RUST_CONFIGURE_ARGS="$RUST_CONFIGURE_ARGS --release-channel=nightly" RUST_CONFIGURE_ARGS="$RUST_CONFIGURE_ARGS --release-channel=nightly"
RUST_CONFIGURE_ARGS="$RUST_CONFIGURE_ARGS --enable-llvm-static-stdcpp" RUST_CONFIGURE_ARGS="$RUST_CONFIGURE_ARGS --enable-llvm-static-stdcpp"
RUST_CONFIGURE_ARGS="$RUST_CONFIGURE_ARGS --enable-save-analysis"
if [ "$NO_LLVM_ASSERTIONS" = "1" ]; then if [ "$NO_LLVM_ASSERTIONS" = "1" ]; then
RUST_CONFIGURE_ARGS="$RUST_CONFIGURE_ARGS --disable-llvm-assertions" RUST_CONFIGURE_ARGS="$RUST_CONFIGURE_ARGS --disable-llvm-assertions"