From 67d2b1b7fd2d0efed9734bcab0f25528b9e37492 Mon Sep 17 00:00:00 2001 From: Michael Woerister Date: Fri, 10 Nov 2017 17:50:15 +0100 Subject: [PATCH] incr.comp.: Don't crash in DepGraph::try_mark_green() when encountering a removed input node. --- src/librustc/dep_graph/graph.rs | 16 ++++++--- src/librustc/ty/maps/plumbing.rs | 2 +- .../remove_crate/auxiliary/extern_crate.rs | 13 +++++++ src/test/incremental/remove_crate/main.rs | 34 +++++++++++++++++++ 4 files changed, 60 insertions(+), 5 deletions(-) create mode 100644 src/test/incremental/remove_crate/auxiliary/extern_crate.rs create mode 100644 src/test/incremental/remove_crate/main.rs diff --git a/src/librustc/dep_graph/graph.rs b/src/librustc/dep_graph/graph.rs index 1433fa81f333e..97ac1b256124d 100644 --- a/src/librustc/dep_graph/graph.rs +++ b/src/librustc/dep_graph/graph.rs @@ -524,14 +524,22 @@ impl DepGraph { current_deps.push(node_index); continue; } - } else if cfg!(debug_assertions) { + } else { match dep_dep_node.kind { DepKind::Hir | DepKind::HirBody | DepKind::CrateMetadata => { - assert!(dep_dep_node.extract_def_id(tcx).is_none(), - "Input {:?} should have been pre-allocated but wasn't.", - dep_dep_node); + if dep_node.extract_def_id(tcx).is_none() { + // If the node does not exist anymore, we + // just fail to mark green. + return None + } else { + // If the node does exist, it should have + // been pre-allocated. + bug!("DepNode {:?} should have been \ + pre-allocated but wasn't.", + dep_dep_node) + } } _ => { // For other kinds of inputs it's OK to be diff --git a/src/librustc/ty/maps/plumbing.rs b/src/librustc/ty/maps/plumbing.rs index 590d5b8e62f1a..f5e1f384d60ea 100644 --- a/src/librustc/ty/maps/plumbing.rs +++ b/src/librustc/ty/maps/plumbing.rs @@ -723,7 +723,7 @@ pub fn force_from_dep_node<'a, 'gcx, 'lcx>(tcx: TyCtxt<'a, 'gcx, 'lcx>, // This one should never occur in this context DepKind::Null => { - bug!("force_from_dep_node() - Encountered {:?}", dep_node.kind) + bug!("force_from_dep_node() - Encountered {:?}", dep_node) } // These are not queries diff --git a/src/test/incremental/remove_crate/auxiliary/extern_crate.rs b/src/test/incremental/remove_crate/auxiliary/extern_crate.rs new file mode 100644 index 0000000000000..39543cd829d8a --- /dev/null +++ b/src/test/incremental/remove_crate/auxiliary/extern_crate.rs @@ -0,0 +1,13 @@ +// Copyright 2017 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 or the MIT license +// , at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +pub fn foo(_: u8) { + +} diff --git a/src/test/incremental/remove_crate/main.rs b/src/test/incremental/remove_crate/main.rs new file mode 100644 index 0000000000000..fafcb8bb0c83a --- /dev/null +++ b/src/test/incremental/remove_crate/main.rs @@ -0,0 +1,34 @@ +// Copyright 2014 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 or the MIT license +// , at your +// option. This file may not be copied, modified, or distributed +// except according to those terms. + +// Test that removing an upstream crate does not cause any trouble. + +// revisions:rpass1 rpass2 +// aux-build:extern_crate.rs + +#[cfg(rpass1)] +extern crate extern_crate; + +pub fn main() { + #[cfg(rpass1)] + { + extern_crate::foo(1); + } + + #[cfg(rpass2)] + { + foo(1); + } +} + +#[cfg(rpass2)] +pub fn foo(_: u8) { + +}