diff options
| author | bors <bors@rust-lang.org> | 2016-08-02 20:25:50 -0700 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2016-08-02 20:25:50 -0700 |
| commit | f495483f2d44bdf94c9dbd78efa80b02f42b2b23 (patch) | |
| tree | 038768e7b592786e76fe3f849832606a9f57f173 | |
| parent | 379bfd0bc11a5f5a9311d4fb475502bb5120bfe5 (diff) | |
| parent | 44dbc4907d9249349582518109792fd1beb34593 (diff) | |
| download | rust-f495483f2d44bdf94c9dbd78efa80b02f42b2b23.tar.gz rust-f495483f2d44bdf94c9dbd78efa80b02f42b2b23.zip | |
Auto merge of #35159 - michaelwoerister:incr-comp-implies-orbit, r=nikomatsakis
Automatically enable -Zorbit if -Zincremental is specified. Fixes #34973 r? @nikomatsakis
| -rw-r--r-- | src/librustc/session/config.rs | 10 | ||||
| -rw-r--r-- | src/test/compile-fail/enable-orbit-for-incr-comp.rs | 20 |
2 files changed, 29 insertions, 1 deletions
diff --git a/src/librustc/session/config.rs b/src/librustc/session/config.rs index 1d839be9f53..6ed91cdbe18 100644 --- a/src/librustc/session/config.rs +++ b/src/librustc/session/config.rs @@ -1168,7 +1168,15 @@ pub fn build_session_options(matches: &getopts::Matches) -> Options { }) }); - let debugging_opts = build_debugging_options(matches, error_format); + let mut debugging_opts = build_debugging_options(matches, error_format); + + // Incremental compilation only works reliably when translation is done via + // MIR, so let's enable -Z orbit if necessary (see #34973). + if debugging_opts.incremental.is_some() && !debugging_opts.orbit { + early_warn(error_format, "Automatically enabling `-Z orbit` because \ + `-Z incremental` was specified"); + debugging_opts.orbit = true; + } let parse_only = debugging_opts.parse_only; let no_trans = debugging_opts.no_trans; diff --git a/src/test/compile-fail/enable-orbit-for-incr-comp.rs b/src/test/compile-fail/enable-orbit-for-incr-comp.rs new file mode 100644 index 00000000000..eec6bad731e --- /dev/null +++ b/src/test/compile-fail/enable-orbit-for-incr-comp.rs @@ -0,0 +1,20 @@ +// Copyright 2016 The Rust Project Developers. See the COPYRIGHT +// file at the top-level directory of this distribution and at +// http://rust-lang.org/COPYRIGHT. +// +// Licensed under the Apache License, Version 2.0 <LICENSE-APACHE or +// http://www.apache.org/licenses/LICENSE-2.0> or the MIT license +// <LICENSE-MIT or http://opensource.org/licenses/MIT>, at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +// ignore-pretty +// compile-flags:-Zincremental=tmp/cfail-tests/enable-orbit-for-incr-comp -Zorbit=off +// error-pattern:Automatically enabling `-Z orbit` because `-Z incremental` was specified + +#![deny(warnings)] + +fn main() { + FAIL! // We just need some compilation error. What we really care about is + // that the error pattern above is checked. +} |
