914d142c02
This commit extends the trailing `>` detection to also work for paths such as `Foo::<Bar>>:Baz`. This involves making the existing check take the token that is expected to follow the path being checked as a parameter. Care is taken to ensure that this only happens on the construction of a whole path segment and not a partial path segment (during recursion). Through this enhancement, it was also observed that the ordering of right shift token and greater than tokens was overfitted to the examples being tested. In practice, given a sequence of `>` characters: `>>>>>>>>>` ..then they will be split into `>>` eagerly: `>> >> >> >> >`. ..but when a `<` is prepended, then the first `>>` is split: `<T> > >> >> >> >` ..and then when another `<` is prepended, a right shift is first again: `Vec<<T>> >> >> >> >` In the previous commits, a example that had two `<<` characters was always used and therefore it was incorrectly assumed that `>>` would always be first - but when there is a single `<`, this is not the case.
23 lines
525 B
Rust
23 lines
525 B
Rust
// run-rustfix
|
|
|
|
// This test checks that the following error is emitted and the suggestion works:
|
|
//
|
|
// ```
|
|
// let _ = Vec::<usize>>>::new();
|
|
// ^^ help: remove extra angle brackets
|
|
// ```
|
|
|
|
fn main() {
|
|
let _ = Vec::<usize>>>>>::new();
|
|
//~^ ERROR unmatched angle bracket
|
|
|
|
let _ = Vec::<usize>>>>::new();
|
|
//~^ ERROR unmatched angle bracket
|
|
|
|
let _ = Vec::<usize>>>::new();
|
|
//~^ ERROR unmatched angle bracket
|
|
|
|
let _ = Vec::<usize>>::new();
|
|
//~^ ERROR unmatched angle bracket
|
|
}
|