From ad5927870cd32c5feb7f42dc4bca4a1b21e61a0e Mon Sep 17 00:00:00 2001 From: Jared Roesch Date: Sat, 25 Jul 2015 21:30:35 -0700 Subject: [PATCH] Add a macro invocation to the type AST Reapplied the changes from https://github.com/freebroccolo/rust/commit/dc64b731d7f66c2b43d5e5e8c721be7bd3b59540 to a clean branch of master --- src/librustc_typeck/astconv.rs | 3 +++ src/librustdoc/clean/mod.rs | 3 +++ src/libsyntax/ast.rs | 2 ++ src/libsyntax/fold.rs | 3 +++ src/libsyntax/print/pprust.rs | 3 +++ src/libsyntax/visit.rs | 3 +++ 6 files changed, 17 insertions(+) diff --git a/src/librustc_typeck/astconv.rs b/src/librustc_typeck/astconv.rs index a2c968a290b..cfd681e51f4 100644 --- a/src/librustc_typeck/astconv.rs +++ b/src/librustc_typeck/astconv.rs @@ -1662,6 +1662,9 @@ pub fn ast_ty_to_ty<'tcx>(this: &AstConv<'tcx>, // handled specially and will not descend into this routine. this.ty_infer(None, None, None, ast_ty.span) } + ast::TyMac(_) => { + tcx.sess.span_bug(m.span, "unexpanded type macro found conversion") + } }; tcx.ast_ty_to_ty_cache.borrow_mut().insert(ast_ty.id, typ); diff --git a/src/librustdoc/clean/mod.rs b/src/librustdoc/clean/mod.rs index 11a0e0eaa49..a79a571f0c7 100644 --- a/src/librustdoc/clean/mod.rs +++ b/src/librustdoc/clean/mod.rs @@ -1611,6 +1611,9 @@ fn clean(&self, cx: &DocContext) -> Type { TyTypeof(..) => { panic!("Unimplemented type {:?}", self.node) }, + TyMac(..) => { + cx.tcx().sess.span_bug(m.span, "unexpanded type macro found during cleaning") + } } } } diff --git a/src/libsyntax/ast.rs b/src/libsyntax/ast.rs index db173d08308..eefd3da9f4a 100644 --- a/src/libsyntax/ast.rs +++ b/src/libsyntax/ast.rs @@ -1471,6 +1471,8 @@ pub enum Ty_ { /// TyInfer means the type should be inferred instead of it having been /// specified. This can appear anywhere in a type. TyInfer, + // A macro in the type position. + TyMac(Mac) } #[derive(Clone, PartialEq, Eq, RustcEncodable, RustcDecodable, Hash, Debug, Copy)] diff --git a/src/libsyntax/fold.rs b/src/libsyntax/fold.rs index dab6d41df30..72fe9a7711d 100644 --- a/src/libsyntax/fold.rs +++ b/src/libsyntax/fold.rs @@ -429,6 +429,9 @@ pub fn noop_fold_ty(t: P, fld: &mut T) -> P { TyPolyTraitRef(bounds) => { TyPolyTraitRef(bounds.move_map(|b| fld.fold_ty_param_bound(b))) } + TyMac(mac) => { + TyMac(fld.fold_mac(mac)) + } }, span: fld.new_span(span) }) diff --git a/src/libsyntax/print/pprust.rs b/src/libsyntax/print/pprust.rs index 6cfe85bc37e..17fa0922da9 100644 --- a/src/libsyntax/print/pprust.rs +++ b/src/libsyntax/print/pprust.rs @@ -734,6 +734,9 @@ pub fn print_type(&mut self, ty: &ast::Ty) -> io::Result<()> { ast::TyInfer => { try!(word(&mut self.s, "_")); } + ast::TyMac(ref m) => { + try!(self.print_mac(m, token::Paren)); + } } self.end() } diff --git a/src/libsyntax/visit.rs b/src/libsyntax/visit.rs index 649052d123c..b32ed15b50f 100644 --- a/src/libsyntax/visit.rs +++ b/src/libsyntax/visit.rs @@ -405,6 +405,9 @@ pub fn walk_ty<'v, V: Visitor<'v>>(visitor: &mut V, typ: &'v Ty) { visitor.visit_expr(&**expression) } TyInfer => {} + TyMac(ref mac) => { + visitor.visit_mac(mac) + } } } -- GitLab