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 90b9529
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 11 deletions.
22 changes: 11 additions & 11 deletions src/librustc_driver/driver.rs
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
16 changes: 16 additions & 0 deletions src/test/auxiliary/crate-attributes-using-cfg_attr.rs
@@ -0,0 +1,16 @@
// 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.

// no-prefer-dynamic
// compile-flags: --cfg foo

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

pub fn foo() {}
15 changes: 15 additions & 0 deletions src/test/run-pass/crate-attributes-using-cfg_attr.rs
@@ -0,0 +1,15 @@
// 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.

// aux-build:crate-attributes-using-cfg_attr.rs

extern crate crate_attributes_using_cfg_attr;

pub fn main() {}

0 comments on commit 90b9529

Please sign in to comment.