Skip to content

Commit

Permalink
Move configuration 1 phase before crate metadata collection
Browse files Browse the repository at this point in the history
Stripping unconfigured items prior to collecting crate metadata means we
can say things like `#![cfg_attr(foo, crate_type="lib")]`.

Fixes #25347.
  • Loading branch information
lilyball committed May 14, 2015
1 parent 3ca008d commit 070d6b3
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 11 deletions.
22 changes: 11 additions & 11 deletions src/librustc_driver/driver.rs
Original file line number Diff line number Diff line change
Expand Up @@ -383,17 +383,8 @@ pub fn phase_2_configure_and_expand(sess: &Session,
-> Option<ast::Crate> {
let time_passes = sess.time_passes();

*sess.crate_types.borrow_mut() =
collect_crate_types(sess, &krate.attrs);
*sess.crate_metadata.borrow_mut() =
collect_crate_metadata(sess, &krate.attrs);

time(time_passes, "recursion limit", (), |_| {
middle::recursion_limit::update_recursion_limit(sess, &krate);
});

// strip before expansion to allow macros to depend on
// configuration variables e.g/ in
// strip before anything else because crate metadata may use #[cfg_attr]
// and so macros can depend on configuration variables, such as
//
// #[macro_use] #[cfg(foo)]
// mod bar { macro_rules! baz!(() => {{}}) }
Expand All @@ -403,6 +394,15 @@ pub fn phase_2_configure_and_expand(sess: &Session,
krate = time(time_passes, "configuration 1", krate, |krate|
syntax::config::strip_unconfigured_items(sess.diagnostic(), krate));

*sess.crate_types.borrow_mut() =
collect_crate_types(sess, &krate.attrs);
*sess.crate_metadata.borrow_mut() =
collect_crate_metadata(sess, &krate.attrs);

time(time_passes, "recursion limit", (), |_| {
middle::recursion_limit::update_recursion_limit(sess, &krate);
});

time(time_passes, "gated macro checking", (), |_| {
let features =
syntax::feature_gate::check_crate_macros(sess.codemap(),
Expand Down
5 changes: 5 additions & 0 deletions src/test/run-make/crate-attributes-with-cfg_attr/Makefile
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
-include ../tools.mk

all:
$(RUSTC) --cfg foo lib.rs
# if compilation worked, then it built as a library
13 changes: 13 additions & 0 deletions src/test/run-make/crate-attributes-with-cfg_attr/lib.rs
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
// Copyright 2015 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.

#![cfg_attr(foo, crate_type="lib")]

pub fn foo() {}

0 comments on commit 070d6b3

Please sign in to comment.