From ac19420535b41d3b2a0ba68803f9426e3a89abed Mon Sep 17 00:00:00 2001 From: Alex Crichton Date: Tue, 31 May 2016 13:24:28 -0700 Subject: [PATCH] rustbuild: Clean more on `make clean` Be sure to not use the old build cache for the bootstrap build system nor the old caches of the compiler/cargo extractions (in case something went wrong). Closes #33986 --- src/bootstrap/bootstrap.py | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/src/bootstrap/bootstrap.py b/src/bootstrap/bootstrap.py index 0ab5253ee7239..ffb93f2d3ee67 100644 --- a/src/bootstrap/bootstrap.py +++ b/src/bootstrap/bootstrap.py @@ -181,13 +181,13 @@ def cargo_stamp(self): return os.path.join(self.bin_root(), '.cargo-stamp') def rustc_out_of_date(self): - if not os.path.exists(self.rustc_stamp()): + if not os.path.exists(self.rustc_stamp()) or self.clean: return True with open(self.rustc_stamp(), 'r') as f: return self.stage0_rustc_date() != f.read() def cargo_out_of_date(self): - if not os.path.exists(self.cargo_stamp()): + if not os.path.exists(self.cargo_stamp()) or self.clean: return True with open(self.cargo_stamp(), 'r') as f: return self.stage0_cargo_date() != f.read() @@ -234,8 +234,11 @@ def exe_suffix(self): return '' def build_bootstrap(self): + build_dir = os.path.join(self.build_dir, "bootstrap") + if self.clean and os.path.exists(build_dir): + shutil.rmtree(build_dir) env = os.environ.copy() - env["CARGO_TARGET_DIR"] = os.path.join(self.build_dir, "bootstrap") + env["CARGO_TARGET_DIR"] = build_dir env["RUSTC"] = self.rustc() env["LD_LIBRARY_PATH"] = os.path.join(self.bin_root(), "lib") env["DYLD_LIBRARY_PATH"] = os.path.join(self.bin_root(), "lib") @@ -340,6 +343,7 @@ def build_triple(self): def main(): parser = argparse.ArgumentParser(description='Build rust') parser.add_argument('--config') + parser.add_argument('--clean', action='store_true') parser.add_argument('-v', '--verbose', action='store_true') args = [a for a in sys.argv if a != '-h'] @@ -352,6 +356,7 @@ def main(): rb.rust_root = os.path.abspath(os.path.join(__file__, '../../..')) rb.build_dir = os.path.join(os.getcwd(), "build") rb.verbose = args.verbose + rb.clean = args.clean try: with open(args.config or 'config.toml') as config: