]> git.lizzy.rs Git - rust.git/commitdiff
Fix end of TtDelimited span
authorKeegan McAllister <kmcallister@mozilla.com>
Sat, 31 Jan 2015 22:54:43 +0000 (14:54 -0800)
committerKeegan McAllister <kmcallister@mozilla.com>
Sun, 1 Feb 2015 01:41:38 +0000 (17:41 -0800)
src/libsyntax/parse/mod.rs
src/libsyntax/parse/parser.rs

index e7be876edbbecd618ad645ce585c19fe5abf6281..6e368bfa803a6cbafcba805d7be3dcc515a3264f 100644 (file)
@@ -755,6 +755,7 @@ mod test {
     use ast;
     use abi;
     use attr::{first_attr_value_str_by_name, AttrMetaMethods};
+    use parse;
     use parse::parser::Parser;
     use parse::token::{str_to_ident};
     use print::pprust::item_to_string;
@@ -1214,4 +1215,26 @@ fn wb() -> c_int { O_WRONLY as c_int }
         let doc = first_attr_value_str_by_name(item.attrs.as_slice(), "doc").unwrap();
         assert_eq!(doc.get(), "/** doc comment\n *  with CRLF */");
     }
+
+    #[test]
+    fn ttdelim_span() {
+        let sess = parse::new_parse_sess();
+        let expr = parse::parse_expr_from_source_str("foo".to_string(),
+            "foo!( fn main() { body } )".to_string(), vec![], &sess);
+
+        let tts = match expr.node {
+            ast::ExprMac(ref mac) => {
+                let ast::MacInvocTT(_, ref tts, _) = mac.node;
+                tts.clone()
+            }
+            _ => panic!("not a macro"),
+        };
+
+        let span = tts.iter().rev().next().unwrap().get_span();
+
+        match sess.span_diagnostic.cm.span_to_snippet(span) {
+            Some(s) => assert_eq!(&s[], "{ body }"),
+            None => panic!("could not get snippet"),
+        }
+    }
 }
index d99095eeba37799be8df741502767973732cf712..8e88f5a5679856039dc1e70aa3a576cfe7f6914a 100644 (file)
@@ -2735,7 +2735,7 @@ fn parse_non_delim_tt_tok(p: &mut Parser) -> TokenTree {
                 self.open_braces.pop().unwrap();
 
                 // Expand to cover the entire delimited token tree
-                let span = Span { hi: self.span.hi, ..pre_span };
+                let span = Span { hi: close_span.hi, ..pre_span };
 
                 TtDelimited(span, Rc::new(Delimited {
                     delim: delim,