Allow concat_idents! in type positions as well as in expression positions

This commit is contained in:
Jeffrey Seyfried 2016-05-19 05:22:42 +00:00
parent 088d417852
commit e992794282
2 changed files with 38 additions and 21 deletions

View file

@ -52,22 +52,36 @@ pub fn expand_syntax_ext<'cx>(cx: &mut ExtCtxt, sp: Span, tts: &[TokenTree])
}
let res = str_to_ident(&res_str);
let e = P(ast::Expr {
id: ast::DUMMY_NODE_ID,
node: ast::ExprKind::Path(None,
ast::Path {
span: sp,
global: false,
segments: vec!(
ast::PathSegment {
identifier: res,
parameters: ast::PathParameters::none(),
}
)
}
),
span: sp,
attrs: None,
});
MacEager::expr(e)
struct Result { ident: ast::Ident, span: Span };
impl Result {
fn path(&self) -> ast::Path {
let segment = ast::PathSegment {
identifier: self.ident,
parameters: ast::PathParameters::none()
};
ast::Path { span: self.span, global: false, segments: vec![segment] }
}
}
impl base::MacResult for Result {
fn make_expr(self: Box<Self>) -> Option<P<ast::Expr>> {
Some(P(ast::Expr {
id: ast::DUMMY_NODE_ID,
node: ast::ExprKind::Path(None, self.path()),
span: self.span,
attrs: None,
}))
}
fn make_ty(self: Box<Self>) -> Option<P<ast::Ty>> {
Some(P(ast::Ty {
id: ast::DUMMY_NODE_ID,
node: ast::TyKind::Path(None, self.path()),
span: self.span,
}))
}
}
Box::new(Result { ident: res, span: sp })
}

View file

@ -8,12 +8,15 @@
// option. This file may not be copied, modified, or distributed
// except according to those terms.
// this now fails (correctly, I claim) because hygiene prevents
// the assembled identifier from being a reference to the binding.
#![feature(concat_idents)]
#![feature(concat_idents, type_macros)]
pub fn main() {
struct Foo;
let _: concat_idents!(F, oo) = Foo; // Test that `concat_idents!` can be used in type positions
let asdf_fdsa = "<.<".to_string();
// this now fails (correctly, I claim) because hygiene prevents
// the assembled identifier from being a reference to the binding.
assert!(concat_idents!(asd, f_f, dsa) == "<.<".to_string());
//~^ ERROR: unresolved name `asdf_fdsa`