diff options
| author | bors <bors@rust-lang.org> | 2017-07-15 08:36:27 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2017-07-15 08:36:27 +0000 |
| commit | 70cd955277fdd3a941177f18bedae4223a48df02 (patch) | |
| tree | 8fa00583a68ea3c817d1776880774cd7e2034903 /src/libproc_macro | |
| parent | 8658908cf822e9425d0841435c111584750aa236 (diff) | |
| parent | a260baae7e77bbae1497f0d37876947b15946553 (diff) | |
| download | rust-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.rs | 13 |
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)) }) } |
