diff options
| author | Steven Fackler <sfackler@gmail.com> | 2014-09-24 00:35:42 -0700 |
|---|---|---|
| committer | Steven Fackler <sfackler@gmail.com> | 2014-09-24 00:35:42 -0700 |
| commit | dcdbdc10036b444ef39c329e9440d4acc6975fda (patch) | |
| tree | 85fc7725a6f5503d20b29cb532bc5683b2a907e5 /src/libsyntax | |
| parent | 65cca7c8b14e9c5673af4921a57c2ccbac3fc2cb (diff) | |
| download | rust-dcdbdc10036b444ef39c329e9440d4acc6975fda.tar.gz rust-dcdbdc10036b444ef39c329e9440d4acc6975fda.zip | |
Fix rebase fallout
Diffstat (limited to 'src/libsyntax')
| -rw-r--r-- | src/libsyntax/ext/base.rs | 2 | ||||
| -rw-r--r-- | src/libsyntax/ext/cfg_attr.rs | 22 | ||||
| -rw-r--r-- | src/libsyntax/test.rs | 2 |
3 files changed, 12 insertions, 14 deletions
diff --git a/src/libsyntax/ext/base.rs b/src/libsyntax/ext/base.rs index 79dc623f507..8bf13e20fed 100644 --- a/src/libsyntax/ext/base.rs +++ b/src/libsyntax/ext/base.rs @@ -440,7 +440,7 @@ fn initial_syntax_expander_table() -> SyntaxEnv { builtin_normal_expander( ext::cfg::expand_cfg)); syntax_expanders.insert(intern("cfg_attr"), - ItemModifier(ext::cfg_attr::expand)); + Modifier(box ext::cfg_attr::expand)); syntax_expanders.insert(intern("trace_macros"), builtin_normal_expander( ext::trace_macros::expand_trace_macros)); diff --git a/src/libsyntax/ext/cfg_attr.rs b/src/libsyntax/ext/cfg_attr.rs index 5df94ac526d..ad02b50f248 100644 --- a/src/libsyntax/ext/cfg_attr.rs +++ b/src/libsyntax/ext/cfg_attr.rs @@ -8,18 +8,16 @@ // option. This file may not be copied, modified, or distributed // except according to those terms. -use std::gc::{Gc, GC}; - use ast; use attr; use codemap::Span; use ext::base::ExtCtxt; use ext::build::AstBuilder; +use ptr::P; -pub fn expand(cx: &mut ExtCtxt, sp: Span, mi: Gc<ast::MetaItem>, it: Gc<ast::Item>) - -> Gc<ast::Item> { +pub fn expand(cx: &mut ExtCtxt, sp: Span, mi: &ast::MetaItem, it: P<ast::Item>) -> P<ast::Item> { let (cfg, attr) = match mi.node { - ast::MetaList(_, ref mis) if mis.len() == 2 => (mis[0], mis[1]), + ast::MetaList(_, ref mis) if mis.len() == 2 => (&mis[0], &mis[1]), _ => { cx.span_err(sp, "expected `#[cfg_attr(<cfg pattern>, <attr>)]`"); return it; @@ -27,26 +25,26 @@ pub fn expand(cx: &mut ExtCtxt, sp: Span, mi: Gc<ast::MetaItem>, it: Gc<ast::Ite }; let mut out = (*it).clone(); - if cfg_matches(cx, cfg) { - out.attrs.push(cx.attribute(attr.span, attr)); + if cfg_matches(cx, &**cfg) { + out.attrs.push(cx.attribute(attr.span, attr.clone())); } - box(GC) out + P(out) } -fn cfg_matches(cx: &mut ExtCtxt, cfg: Gc<ast::MetaItem>) -> bool { +fn cfg_matches(cx: &mut ExtCtxt, cfg: &ast::MetaItem) -> bool { match cfg.node { ast::MetaList(ref pred, ref mis) if pred.get() == "any" => - mis.iter().any(|mi| cfg_matches(cx, *mi)), + mis.iter().any(|mi| cfg_matches(cx, &**mi)), ast::MetaList(ref pred, ref mis) if pred.get() == "all" => - mis.iter().all(|mi| cfg_matches(cx, *mi)), + mis.iter().all(|mi| cfg_matches(cx, &**mi)), ast::MetaList(ref pred, ref mis) if pred.get() == "not" => { if mis.len() != 1 { cx.span_err(cfg.span, format!("expected 1 value, got {}", mis.len()).as_slice()); return false; } - !cfg_matches(cx, mis[0]) + !cfg_matches(cx, &*mis[0]) } ast::MetaList(ref pred, _) => { cx.span_err(cfg.span, diff --git a/src/libsyntax/test.rs b/src/libsyntax/test.rs index b6e3023d2ae..091b0ce8ed9 100644 --- a/src/libsyntax/test.rs +++ b/src/libsyntax/test.rs @@ -340,7 +340,7 @@ fn is_ignored(cx: &TestCtxt, i: &ast::Item) -> bool { attr.check_name("ignore") && match attr.meta_item_list() { Some(ref cfgs) => { if cfgs.iter().any(|cfg| cfg.check_name("cfg")) { - cx.sess.span_warn(attr.span, + cx.span_diagnostic.span_warn(attr.span, "The use of cfg filters in #[ignore] is \ deprecated. Use #[cfg_attr(<cfg pattern>, \ ignore)] instead."); |
