Detect local-rebuild by just the MAJOR.MINOR version

A new point-release shouldn't change any language semantics, so a local
stage0 that matches MAJOR.MINOR version should still be considered a
local-rebuild as far as `--cfg stageN` features go.

e.g. `1.14.0` should be considered a local-rebuild for any `1.14.X`.

(Bootstrap keys used to be an issue too, until #37265.)
This commit is contained in:
Josh Stone 2016-10-19 08:21:00 -07:00
parent a41505f4f4
commit 81d97957a7
2 changed files with 8 additions and 7 deletions

View File

@ -53,11 +53,12 @@ endif
# versions in the same place # versions in the same place
CFG_FILENAME_EXTRA=$(shell printf '%s' $(CFG_RELEASE)$(CFG_EXTRA_FILENAME) | $(CFG_HASH_COMMAND)) CFG_FILENAME_EXTRA=$(shell printf '%s' $(CFG_RELEASE)$(CFG_EXTRA_FILENAME) | $(CFG_HASH_COMMAND))
# If local-rust is the same as the current version, then force a local-rebuild # If local-rust is the same major.minor as the current version, then force a local-rebuild
ifdef CFG_ENABLE_LOCAL_RUST ifdef CFG_ENABLE_LOCAL_RUST
ifeq ($(CFG_RELEASE),\ SEMVER_PREFIX=$(shell echo $(CFG_RELEASE_NUM) | grep -E -o '^[[:digit:]]+\.[[:digit:]]+')
$(shell $(S)src/etc/local_stage0.sh --print-rustc-release $(CFG_LOCAL_RUST_ROOT))) LOCAL_RELEASE=$(shell $(S)src/etc/local_stage0.sh --print-rustc-release $(CFG_LOCAL_RUST_ROOT))
CFG_INFO := $(info cfg: auto-detected local-rebuild $(CFG_RELEASE)) ifneq (,$(filter $(SEMVER_PREFIX).%,$(LOCAL_RELEASE)))
CFG_INFO := $(info cfg: auto-detected local-rebuild using $(LOCAL_RELEASE))
CFG_ENABLE_LOCAL_REBUILD = 1 CFG_ENABLE_LOCAL_REBUILD = 1
endif endif
endif endif

View File

@ -220,14 +220,14 @@ impl Build {
sanity::check(self); sanity::check(self);
self.verbose("collecting channel variables"); self.verbose("collecting channel variables");
channel::collect(self); channel::collect(self);
// If local-rust is the same as the current version, then force a local-rebuild // If local-rust is the same major.minor as the current version, then force a local-rebuild
let local_version_verbose = output( let local_version_verbose = output(
Command::new(&self.rustc).arg("--version").arg("--verbose")); Command::new(&self.rustc).arg("--version").arg("--verbose"));
let local_release = local_version_verbose let local_release = local_version_verbose
.lines().filter(|x| x.starts_with("release:")) .lines().filter(|x| x.starts_with("release:"))
.next().unwrap().trim_left_matches("release:").trim(); .next().unwrap().trim_left_matches("release:").trim();
if local_release == self.release { if local_release.split('.').take(2).eq(self.release.split('.').take(2)) {
self.verbose(&format!("auto-detected local-rebuild {}", self.release)); self.verbose(&format!("auto-detected local-rebuild {}", local_release));
self.local_rebuild = true; self.local_rebuild = true;
} }
self.verbose("updating submodules"); self.verbose("updating submodules");