diff options
| author | bors <bors@rust-lang.org> | 2021-11-26 13:42:35 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2021-11-26 13:42:35 +0000 |
| commit | 454cc5fb86be180b3ec1138b6f2b480fbf3f1388 (patch) | |
| tree | 618d3a042df21961cf8987774e019c8f1b3dbbe4 /src | |
| parent | 1e79d79dac11ce121b972fbaa0db9b0d1756b991 (diff) | |
| parent | 6955afe8fd16d51b2c617d69f89a9eac5b7fd150 (diff) | |
| download | rust-454cc5fb86be180b3ec1138b6f2b480fbf3f1388.tar.gz rust-454cc5fb86be180b3ec1138b6f2b480fbf3f1388.zip | |
Auto merge of #91164 - Badel2:usefulness-stack-overflow, r=davidtwco
Fix stack overflow in `usefulness.rs` Fix #88747 Applied the suggestion from `@nbdd0121,` not sure if this has any drawbacks. The first call to `ensure_sufficient_stack` is not needed to fix the test case, but I added it to be safe.
Diffstat (limited to 'src')
| -rw-r--r-- | src/test/ui/pattern/usefulness/issue-88747.rs | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/src/test/ui/pattern/usefulness/issue-88747.rs b/src/test/ui/pattern/usefulness/issue-88747.rs new file mode 100644 index 00000000000..948c99f9ce9 --- /dev/null +++ b/src/test/ui/pattern/usefulness/issue-88747.rs @@ -0,0 +1,14 @@ +// check-pass: this used to be a stack overflow because of recursion in `usefulness.rs` + +macro_rules! long_tuple_arg { + ([$($t:tt)*]#$($h:tt)*) => { + long_tuple_arg!{[$($t)*$($t)*]$($h)*} + }; + ([$([$t:tt $y:tt])*]) => { + pub fn _f(($($t,)*): ($($y,)*)) {} + } +} + +long_tuple_arg!{[[_ u8]]########## ###} + +fn main() {} |
