forked from rust-lang/rust
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add
-Z span-debug
to allow for easier debugging of proc macros
Currently, the `Debug` impl for `proc_macro::Span` just prints out the byte range. This can make debugging proc macros (either as a crate author or as a compiler developer) very frustrating, since neither the actual filename nor the `SyntaxContext` is displayed. This commit adds a perma-unstable flag `-Z span-debug`. When enabled, the `Debug` impl for `proc_macro::Span` simply forwards directly to `rustc_span::Span`. Once rust-lang#72618 is merged, this will start displaying actual line numbers. While `Debug` impls are not subject to Rust's normal stability guarnatees, we probably shouldn't expose any additional information on stable until `#![feature(proc_macro_span)]` is stabilized. Otherwise, we would be providing a 'backdoor' way to access information that's supposed be behind unstable APIs.
- Loading branch information
Showing
7 changed files
with
220 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,41 @@ | ||
// run-pass | ||
// aux-build:macro-dump-debug.rs | ||
// compile-flags: -Z span-debug | ||
|
||
extern crate macro_dump_debug; | ||
use macro_dump_debug::dump_debug; | ||
|
||
dump_debug! { | ||
ident // ident | ||
r#ident // raw ident | ||
, // alone punct | ||
==> // joint punct | ||
() // empty group | ||
[_] // nonempty group | ||
|
||
// unsuffixed literals | ||
0 | ||
1.0 | ||
"S" | ||
b"B" | ||
r"R" | ||
r##"R"## | ||
br"BR" | ||
br##"BR"## | ||
'C' | ||
b'B' | ||
|
||
// suffixed literals | ||
0q | ||
1.0q | ||
"S"q | ||
b"B"q | ||
r"R"q | ||
r##"R"##q | ||
br"BR"q | ||
br##"BR"##q | ||
'C'q | ||
b'B'q | ||
} | ||
|
||
fn main() {} |
166 changes: 166 additions & 0 deletions
166
src/test/ui/proc-macro/debug/dump-debug-span-debug.stderr
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,166 @@ | ||
TokenStream [Ident { ident: "ident", span: $DIR/dump-debug-span-debug.rs:9:5: 9:10 }, Ident { ident: "r#ident", span: $DIR/dump-debug-span-debug.rs:10:5: 10:12 }, Punct { ch: ',', spacing: Alone, span: $DIR/dump-debug-span-debug.rs:11:5: 11:6 }, Punct { ch: '=', spacing: Joint, span: $DIR/dump-debug-span-debug.rs:12:5: 12:7 }, Punct { ch: '=', spacing: Joint, span: $DIR/dump-debug-span-debug.rs:12:5: 12:7 }, Punct { ch: '>', spacing: Alone, span: $DIR/dump-debug-span-debug.rs:12:7: 12:8 }, Group { delimiter: Parenthesis, stream: TokenStream [], span: $DIR/dump-debug-span-debug.rs:13:5: 13:7 }, Group { delimiter: Bracket, stream: TokenStream [Ident { ident: "_", span: $DIR/dump-debug-span-debug.rs:14:6: 14:7 }], span: $DIR/dump-debug-span-debug.rs:14:5: 14:8 }, Literal { kind: Integer, symbol: "0", suffix: None, span: $DIR/dump-debug-span-debug.rs:17:5: 17:6 }, Literal { kind: Float, symbol: "1.0", suffix: None, span: $DIR/dump-debug-span-debug.rs:18:5: 18:8 }, Literal { kind: Str, symbol: "S", suffix: None, span: $DIR/dump-debug-span-debug.rs:19:5: 19:8 }, Literal { kind: ByteStr, symbol: "B", suffix: None, span: $DIR/dump-debug-span-debug.rs:20:5: 20:9 }, Literal { kind: StrRaw(0), symbol: "R", suffix: None, span: $DIR/dump-debug-span-debug.rs:21:5: 21:9 }, Literal { kind: StrRaw(2), symbol: "R", suffix: None, span: $DIR/dump-debug-span-debug.rs:22:5: 22:13 }, Literal { kind: ByteStrRaw(0), symbol: "BR", suffix: None, span: $DIR/dump-debug-span-debug.rs:23:5: 23:11 }, Literal { kind: ByteStrRaw(2), symbol: "BR", suffix: None, span: $DIR/dump-debug-span-debug.rs:24:5: 24:15 }, Literal { kind: Char, symbol: "C", suffix: None, span: $DIR/dump-debug-span-debug.rs:25:5: 25:8 }, Literal { kind: Byte, symbol: "B", suffix: None, span: $DIR/dump-debug-span-debug.rs:26:5: 26:9 }, Literal { kind: Integer, symbol: "0", suffix: Some("q"), span: $DIR/dump-debug-span-debug.rs:29:5: 29:7 }, Literal { kind: Float, symbol: "1.0", suffix: Some("q"), span: $DIR/dump-debug-span-debug.rs:30:5: 30:9 }, Literal { kind: Str, symbol: "S", suffix: Some("q"), span: $DIR/dump-debug-span-debug.rs:31:5: 31:9 }, Literal { kind: ByteStr, symbol: "B", suffix: Some("q"), span: $DIR/dump-debug-span-debug.rs:32:5: 32:10 }, Literal { kind: StrRaw(0), symbol: "R", suffix: Some("q"), span: $DIR/dump-debug-span-debug.rs:33:5: 33:10 }, Literal { kind: StrRaw(2), symbol: "R", suffix: Some("q"), span: $DIR/dump-debug-span-debug.rs:34:5: 34:14 }, Literal { kind: ByteStrRaw(0), symbol: "BR", suffix: Some("q"), span: $DIR/dump-debug-span-debug.rs:35:5: 35:12 }, Literal { kind: ByteStrRaw(2), symbol: "BR", suffix: Some("q"), span: $DIR/dump-debug-span-debug.rs:36:5: 36:16 }, Literal { kind: Char, symbol: "C", suffix: Some("q"), span: $DIR/dump-debug-span-debug.rs:37:5: 37:9 }, Literal { kind: Byte, symbol: "B", suffix: Some("q"), span: $DIR/dump-debug-span-debug.rs:38:5: 38:10 }] | ||
TokenStream [ | ||
Ident { | ||
ident: "ident", | ||
span: $DIR/dump-debug-span-debug.rs:9:5: 9:10, | ||
}, | ||
Ident { | ||
ident: "r#ident", | ||
span: $DIR/dump-debug-span-debug.rs:10:5: 10:12, | ||
}, | ||
Punct { | ||
ch: ',', | ||
spacing: Alone, | ||
span: $DIR/dump-debug-span-debug.rs:11:5: 11:6, | ||
}, | ||
Punct { | ||
ch: '=', | ||
spacing: Joint, | ||
span: $DIR/dump-debug-span-debug.rs:12:5: 12:7, | ||
}, | ||
Punct { | ||
ch: '=', | ||
spacing: Joint, | ||
span: $DIR/dump-debug-span-debug.rs:12:5: 12:7, | ||
}, | ||
Punct { | ||
ch: '>', | ||
spacing: Alone, | ||
span: $DIR/dump-debug-span-debug.rs:12:7: 12:8, | ||
}, | ||
Group { | ||
delimiter: Parenthesis, | ||
stream: TokenStream [], | ||
span: $DIR/dump-debug-span-debug.rs:13:5: 13:7, | ||
}, | ||
Group { | ||
delimiter: Bracket, | ||
stream: TokenStream [ | ||
Ident { | ||
ident: "_", | ||
span: $DIR/dump-debug-span-debug.rs:14:6: 14:7, | ||
}, | ||
], | ||
span: $DIR/dump-debug-span-debug.rs:14:5: 14:8, | ||
}, | ||
Literal { | ||
kind: Integer, | ||
symbol: "0", | ||
suffix: None, | ||
span: $DIR/dump-debug-span-debug.rs:17:5: 17:6, | ||
}, | ||
Literal { | ||
kind: Float, | ||
symbol: "1.0", | ||
suffix: None, | ||
span: $DIR/dump-debug-span-debug.rs:18:5: 18:8, | ||
}, | ||
Literal { | ||
kind: Str, | ||
symbol: "S", | ||
suffix: None, | ||
span: $DIR/dump-debug-span-debug.rs:19:5: 19:8, | ||
}, | ||
Literal { | ||
kind: ByteStr, | ||
symbol: "B", | ||
suffix: None, | ||
span: $DIR/dump-debug-span-debug.rs:20:5: 20:9, | ||
}, | ||
Literal { | ||
kind: StrRaw(0), | ||
symbol: "R", | ||
suffix: None, | ||
span: $DIR/dump-debug-span-debug.rs:21:5: 21:9, | ||
}, | ||
Literal { | ||
kind: StrRaw(2), | ||
symbol: "R", | ||
suffix: None, | ||
span: $DIR/dump-debug-span-debug.rs:22:5: 22:13, | ||
}, | ||
Literal { | ||
kind: ByteStrRaw(0), | ||
symbol: "BR", | ||
suffix: None, | ||
span: $DIR/dump-debug-span-debug.rs:23:5: 23:11, | ||
}, | ||
Literal { | ||
kind: ByteStrRaw(2), | ||
symbol: "BR", | ||
suffix: None, | ||
span: $DIR/dump-debug-span-debug.rs:24:5: 24:15, | ||
}, | ||
Literal { | ||
kind: Char, | ||
symbol: "C", | ||
suffix: None, | ||
span: $DIR/dump-debug-span-debug.rs:25:5: 25:8, | ||
}, | ||
Literal { | ||
kind: Byte, | ||
symbol: "B", | ||
suffix: None, | ||
span: $DIR/dump-debug-span-debug.rs:26:5: 26:9, | ||
}, | ||
Literal { | ||
kind: Integer, | ||
symbol: "0", | ||
suffix: Some("q"), | ||
span: $DIR/dump-debug-span-debug.rs:29:5: 29:7, | ||
}, | ||
Literal { | ||
kind: Float, | ||
symbol: "1.0", | ||
suffix: Some("q"), | ||
span: $DIR/dump-debug-span-debug.rs:30:5: 30:9, | ||
}, | ||
Literal { | ||
kind: Str, | ||
symbol: "S", | ||
suffix: Some("q"), | ||
span: $DIR/dump-debug-span-debug.rs:31:5: 31:9, | ||
}, | ||
Literal { | ||
kind: ByteStr, | ||
symbol: "B", | ||
suffix: Some("q"), | ||
span: $DIR/dump-debug-span-debug.rs:32:5: 32:10, | ||
}, | ||
Literal { | ||
kind: StrRaw(0), | ||
symbol: "R", | ||
suffix: Some("q"), | ||
span: $DIR/dump-debug-span-debug.rs:33:5: 33:10, | ||
}, | ||
Literal { | ||
kind: StrRaw(2), | ||
symbol: "R", | ||
suffix: Some("q"), | ||
span: $DIR/dump-debug-span-debug.rs:34:5: 34:14, | ||
}, | ||
Literal { | ||
kind: ByteStrRaw(0), | ||
symbol: "BR", | ||
suffix: Some("q"), | ||
span: $DIR/dump-debug-span-debug.rs:35:5: 35:12, | ||
}, | ||
Literal { | ||
kind: ByteStrRaw(2), | ||
symbol: "BR", | ||
suffix: Some("q"), | ||
span: $DIR/dump-debug-span-debug.rs:36:5: 36:16, | ||
}, | ||
Literal { | ||
kind: Char, | ||
symbol: "C", | ||
suffix: Some("q"), | ||
span: $DIR/dump-debug-span-debug.rs:37:5: 37:9, | ||
}, | ||
Literal { | ||
kind: Byte, | ||
symbol: "B", | ||
suffix: Some("q"), | ||
span: $DIR/dump-debug-span-debug.rs:38:5: 38:10, | ||
}, | ||
] |