diff --git a/src/librustc_driver/driver.rs b/src/librustc_driver/driver.rs index 46009e5813094..7fd4e3643be57 100644 --- a/src/librustc_driver/driver.rs +++ b/src/librustc_driver/driver.rs @@ -116,34 +116,20 @@ pub fn compile_input(sess: &Session, let outputs = build_output_filenames(input, outdir, output, &krate.attrs, sess); let id = link::find_crate_name(Some(sess), &krate.attrs, input); let ExpansionResult { expanded_crate, defs, analysis, resolutions, mut hir_forest } = { - let make_glob_map = control.make_glob_map; - phase_2_configure_and_expand(sess, &cstore, krate, &id, addl_plugins, make_glob_map)? + phase_2_configure_and_expand( + sess, &cstore, krate, &id, addl_plugins, control.make_glob_map, + |expanded_crate| { + let mut state = CompileState::state_after_expand( + input, sess, outdir, output, &cstore, expanded_crate, &id, + ); + controller_entry_point!(after_expand, sess, state, Ok(())); + Ok(()) + } + )? }; - controller_entry_point!(after_expand, - sess, - CompileState::state_after_expand(input, - sess, - outdir, - output, - &cstore, - &expanded_crate, - &id), - Ok(())); - write_out_deps(sess, &outputs, &id); - controller_entry_point!(after_write_deps, - sess, - CompileState::state_after_write_deps(input, - sess, - outdir, - output, - &cstore, - &expanded_crate, - &id), - Ok(())); - let arenas = ty::CtxtArenas::new(); // Construct the HIR map @@ -285,7 +271,6 @@ pub fn source_name(input: &Input) -> String { pub struct CompileController<'a> { pub after_parse: PhaseController<'a>, pub after_expand: PhaseController<'a>, - pub after_write_deps: PhaseController<'a>, pub after_hir_lowering: PhaseController<'a>, pub after_analysis: PhaseController<'a>, pub after_llvm: PhaseController<'a>, @@ -298,7 +283,6 @@ impl<'a> CompileController<'a> { CompileController { after_parse: PhaseController::basic(), after_expand: PhaseController::basic(), - after_write_deps: PhaseController::basic(), after_hir_lowering: PhaseController::basic(), after_analysis: PhaseController::basic(), after_llvm: PhaseController::basic(), @@ -406,23 +390,6 @@ impl<'a, 'b, 'ast, 'tcx> CompileState<'a, 'b, 'ast, 'tcx> { } } - fn state_after_write_deps(input: &'a Input, - session: &'ast Session, - out_dir: &'a Option, - out_file: &'a Option, - cstore: &'a CStore, - krate: &'a ast::Crate, - crate_name: &'a str) - -> CompileState<'a, 'b, 'ast, 'tcx> { - CompileState { - crate_name: Some(crate_name), - cstore: Some(cstore), - expanded_crate: Some(krate), - out_file: out_file.as_ref().map(|s| &**s), - ..CompileState::empty(input, session, out_dir) - } - } - fn state_after_hir_lowering(input: &'a Input, session: &'ast Session, out_dir: &'a Option, @@ -556,13 +523,16 @@ pub struct ExpansionResult<'a> { /// standard library and prelude, and name resolution. /// /// Returns `None` if we're aborting after handling -W help. -pub fn phase_2_configure_and_expand<'a>(sess: &Session, - cstore: &CStore, - mut krate: ast::Crate, - crate_name: &'a str, - addl_plugins: Option>, - make_glob_map: MakeGlobMap) - -> Result, usize> { +pub fn phase_2_configure_and_expand<'a, F>(sess: &Session, + cstore: &CStore, + mut krate: ast::Crate, + crate_name: &'a str, + addl_plugins: Option>, + make_glob_map: MakeGlobMap, + after_expand: F) + -> Result, usize> + where F: FnOnce(&ast::Crate) -> CompileResult, +{ let time_passes = sess.time_passes(); // strip before anything else because crate metadata may use #[cfg_attr] @@ -745,9 +715,23 @@ pub fn phase_2_configure_and_expand<'a>(sess: &Session, "AST validation", || ast_validation::check_crate(sess, &krate)); - time(sess.time_passes(), "name resolution", || { + time(sess.time_passes(), "name resolution", || -> CompileResult { + // Currently, we ignore the name resolution data structures for the purposes of dependency + // tracking. Instead we will run name resolution and include its output in the hash of each + // item, much like we do for macro expansion. In other words, the hash reflects not just + // its contents but the results of name resolution on those contents. Hopefully we'll push + // this back at some point. + let _ignore = sess.dep_graph.in_ignore(); + resolver.build_reduced_graph(&krate); + resolver.resolve_imports(); + + // Since import resolution will eventually happen in expansion, + // don't perform `after_expand` until after import resolution. + after_expand(&krate)?; + resolver.resolve_crate(&krate); - }); + Ok(()) + })?; // Lower ast -> hir. let hir_forest = time(sess.time_passes(), "lowering ast -> hir", || { diff --git a/src/librustc_driver/lib.rs b/src/librustc_driver/lib.rs index 32eb3fdd71092..c9569a63436f5 100644 --- a/src/librustc_driver/lib.rs +++ b/src/librustc_driver/lib.rs @@ -511,7 +511,7 @@ impl<'a> CompilerCalls<'a> for RustcDefaultCalls { } if sess.opts.no_analysis || sess.opts.debugging_opts.ast_json { - control.after_write_deps.stop = Compilation::Stop; + control.after_hir_lowering.stop = Compilation::Stop; } if !sess.opts.output_types.keys().any(|&i| i == OutputType::Exe) { diff --git a/src/librustc_driver/test.rs b/src/librustc_driver/test.rs index 0f5977cf06618..15a0ab0f284b3 100644 --- a/src/librustc_driver/test.rs +++ b/src/librustc_driver/test.rs @@ -116,9 +116,11 @@ fn test_env(source_string: &str, input: source_string.to_string(), }; let krate = driver::phase_1_parse_input(&sess, krate_config, &input).unwrap(); - let driver::ExpansionResult { defs, resolutions, mut hir_forest, .. } = - driver::phase_2_configure_and_expand(&sess, &cstore, krate, "test", None, MakeGlobMap::No) - .expect("phase 2 aborted"); + let driver::ExpansionResult { defs, resolutions, mut hir_forest, .. } = { + driver::phase_2_configure_and_expand( + &sess, &cstore, krate, "test", None, MakeGlobMap::No, |_| Ok(()), + ).expect("phase 2 aborted") + }; let _ignore = dep_graph.in_ignore(); let arenas = ty::CtxtArenas::new(); diff --git a/src/librustc_resolve/lib.rs b/src/librustc_resolve/lib.rs index ed400af66855a..66b0d663424aa 100644 --- a/src/librustc_resolve/lib.rs +++ b/src/librustc_resolve/lib.rs @@ -1167,18 +1167,6 @@ impl<'a> Resolver<'a> { /// Entry point to crate resolution. pub fn resolve_crate(&mut self, krate: &Crate) { - // Currently, we ignore the name resolution data structures for - // the purposes of dependency tracking. Instead we will run name - // resolution and include its output in the hash of each item, - // much like we do for macro expansion. In other words, the hash - // reflects not just its contents but the results of name - // resolution on those contents. Hopefully we'll push this back at - // some point. - let _ignore = self.session.dep_graph.in_ignore(); - - self.build_reduced_graph(krate); - resolve_imports::resolve_imports(self); - self.current_module = self.graph_root; visit::walk_crate(self, krate); diff --git a/src/librustc_resolve/resolve_imports.rs b/src/librustc_resolve/resolve_imports.rs index cb308f9120404..16a59fbb80002 100644 --- a/src/librustc_resolve/resolve_imports.rs +++ b/src/librustc_resolve/resolve_imports.rs @@ -30,6 +30,12 @@ use syntax_pos::{Span, DUMMY_SP}; use std::cell::{Cell, RefCell}; +impl<'a> Resolver<'a> { + pub fn resolve_imports(&mut self) { + ImportResolver { resolver: self }.resolve_imports(); + } +} + /// Contains data for specific types of import directives. #[derive(Clone, Debug)] pub enum ImportDirectiveSubclass { @@ -722,8 +728,3 @@ fn import_directive_subclass_to_string(subclass: &ImportDirectiveSubclass) -> St GlobImport { .. } => "*".to_string(), } } - -pub fn resolve_imports(resolver: &mut Resolver) { - let mut import_resolver = ImportResolver { resolver: resolver }; - import_resolver.resolve_imports(); -} diff --git a/src/librustdoc/core.rs b/src/librustdoc/core.rs index f4da8167ea286..85ea94e02e8d7 100644 --- a/src/librustdoc/core.rs +++ b/src/librustdoc/core.rs @@ -149,9 +149,9 @@ pub fn run_core(search_paths: SearchPaths, let name = link::find_crate_name(Some(&sess), &krate.attrs, &input); let driver::ExpansionResult { defs, analysis, resolutions, mut hir_forest, .. } = { - let make_glob_map = resolve::MakeGlobMap::No; - driver::phase_2_configure_and_expand(&sess, &cstore, krate, &name, None, make_glob_map) - .expect("phase_2_configure_and_expand aborted in rustdoc!") + driver::phase_2_configure_and_expand( + &sess, &cstore, krate, &name, None, resolve::MakeGlobMap::No, |_| Ok(()), + ).expect("phase_2_configure_and_expand aborted in rustdoc!") }; let arenas = ty::CtxtArenas::new(); diff --git a/src/librustdoc/test.rs b/src/librustdoc/test.rs index 95d02d6ce4bee..e3bc8037d13b6 100644 --- a/src/librustdoc/test.rs +++ b/src/librustdoc/test.rs @@ -95,9 +95,9 @@ pub fn run(input: &str, cfg.extend(config::parse_cfgspecs(cfgs.clone())); let krate = panictry!(driver::phase_1_parse_input(&sess, cfg, &input)); let driver::ExpansionResult { defs, mut hir_forest, .. } = { - let make_glob_map = MakeGlobMap::No; - phase_2_configure_and_expand(&sess, &cstore, krate, "rustdoc-test", None, make_glob_map) - .expect("phase_2_configure_and_expand aborted in rustdoc!") + phase_2_configure_and_expand( + &sess, &cstore, krate, "rustdoc-test", None, MakeGlobMap::No, |_| Ok(()) + ).expect("phase_2_configure_and_expand aborted in rustdoc!") }; let dep_graph = DepGraph::new(false); diff --git a/src/test/run-make/execution-engine/test.rs b/src/test/run-make/execution-engine/test.rs index a94b2a85c7754..21e1463b6ef95 100644 --- a/src/test/run-make/execution-engine/test.rs +++ b/src/test/run-make/execution-engine/test.rs @@ -241,8 +241,9 @@ fn compile_program(input: &str, sysroot: PathBuf) let krate = panictry!(driver::phase_1_parse_input(&sess, cfg, &input)); let driver::ExpansionResult { defs, analysis, resolutions, mut hir_forest, .. } = { - driver::phase_2_configure_and_expand(&sess, &cstore, krate, &id, None, MakeGlobMap::No) - .expect("phase_2 returned `None`") + driver::phase_2_configure_and_expand( + &sess, &cstore, krate, &id, None, MakeGlobMap::No, |_| Ok(()), + ).expect("phase_2 returned `None`") }; let arenas = ty::CtxtArenas::new();