about summary refs log tree commit diff
path: root/src/libproc_macro
diff options
context:
space:
mode:
authorbors <bors@rust-lang.org>2017-07-15 08:36:27 +0000
committerbors <bors@rust-lang.org>2017-07-15 08:36:27 +0000
commit70cd955277fdd3a941177f18bedae4223a48df02 (patch)
tree8fa00583a68ea3c817d1776880774cd7e2034903 /src/libproc_macro
parent8658908cf822e9425d0841435c111584750aa236 (diff)
parenta260baae7e77bbae1497f0d37876947b15946553 (diff)
downloadrust-70cd955277fdd3a941177f18bedae4223a48df02.tar.gz
rust-70cd955277fdd3a941177f18bedae4223a48df02.zip
Auto merge of #43179 - oli-obk:mark_all_the_expansions, r=jseyfried
Reintroduce expansion info for proc macros 1.1

r? @jseyfried
Diffstat (limited to 'src/libproc_macro')
-rw-r--r--src/libproc_macro/lib.rs13
1 files changed, 11 insertions, 2 deletions
diff --git a/src/libproc_macro/lib.rs b/src/libproc_macro/lib.rs
index 357e2ab853c..3c5d6aceca9 100644
--- a/src/libproc_macro/lib.rs
+++ b/src/libproc_macro/lib.rs
@@ -57,6 +57,7 @@ use syntax::symbol::Symbol;
 use syntax::tokenstream;
 use syntax_pos::DUMMY_SP;
 use syntax_pos::SyntaxContext;
+use syntax_pos::hygiene::Mark;
 
 /// The main type provided by this crate, representing an abstract stream of
 /// tokens.
@@ -86,8 +87,16 @@ impl FromStr for TokenStream {
         __internal::with_sess(|(sess, mark)| {
             let src = src.to_string();
             let name = "<proc-macro source code>".to_string();
-            let call_site = mark.expn_info().unwrap().call_site;
-            let stream = parse::parse_stream_from_source_str(name, src, sess, Some(call_site));
+            let expn_info = mark.expn_info().unwrap();
+            let call_site = expn_info.call_site;
+            // notify the expansion info that it is unhygienic
+            let mark = Mark::fresh(mark);
+            mark.set_expn_info(expn_info);
+            let span = syntax_pos::Span {
+                ctxt: SyntaxContext::empty().apply_mark(mark),
+                ..call_site
+            };
+            let stream = parse::parse_stream_from_source_str(name, src, sess, Some(span));
             Ok(__internal::token_stream_wrap(stream))
         })
     }