Skip to content

Commit

Permalink
Auto merge of #50205 - topecongiro:include-parens-to-type-parameter, …
Browse files Browse the repository at this point in the history
…r=petrochenkov

Include parens to type parameter

The motivation of this PR is to fix a bug in rustfmt (cc rust-lang/rustfmt#2630).
  • Loading branch information
bors committed Jun 10, 2018
2 parents 684b8d3 + dc87d0d commit 06ab5a6
Show file tree
Hide file tree
Showing 3 changed files with 19 additions and 18 deletions.
17 changes: 9 additions & 8 deletions src/libsyntax/parse/parser.rs
Original file line number Diff line number Diff line change
Expand Up @@ -4746,6 +4746,7 @@ impl<'a> Parser<'a> {
self.check_keyword(keywords::For) ||
self.check(&token::OpenDelim(token::Paren));
if is_bound_start {
let lo = self.span;
let has_parens = self.eat(&token::OpenDelim(token::Paren));
let question = if self.eat(&token::Question) { Some(self.prev_span) } else { None };
if self.token.is_lifetime() {
Expand All @@ -4754,10 +4755,17 @@ impl<'a> Parser<'a> {
"`?` may only modify trait bounds, not lifetime bounds");
}
bounds.push(RegionTyParamBound(self.expect_lifetime()));
if has_parens {
self.expect(&token::CloseDelim(token::Paren))?;
self.span_err(self.prev_span,
"parenthesized lifetime bounds are not supported");
}
} else {
let lo = self.span;
let lifetime_defs = self.parse_late_bound_lifetime_defs()?;
let path = self.parse_path(PathStyle::Type)?;
if has_parens {
self.expect(&token::CloseDelim(token::Paren))?;
}
let poly_trait = PolyTraitRef::new(lifetime_defs, path, lo.to(self.prev_span));
let modifier = if question.is_some() {
TraitBoundModifier::Maybe
Expand All @@ -4766,13 +4774,6 @@ impl<'a> Parser<'a> {
};
bounds.push(TraitTyParamBound(poly_trait, modifier));
}
if has_parens {
self.expect(&token::CloseDelim(token::Paren))?;
if let Some(&RegionTyParamBound(..)) = bounds.last() {
self.span_err(self.prev_span,
"parenthesized lifetime bounds are not supported");
}
}
} else {
break
}
Expand Down
4 changes: 2 additions & 2 deletions src/test/ui/maybe-bounds.rs
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@

trait Tr: ?Sized {} //~ ERROR `?Trait` is not permitted in supertraits

type A1 = Tr + ?Sized; //~ ERROR `?Trait` is not permitted in trait object types
type A2 = for<'a> Tr + ?Sized; //~ ERROR `?Trait` is not permitted in trait object types
type A1 = Tr + (?Sized); //~ ERROR `?Trait` is not permitted in trait object types
type A2 = for<'a> Tr + (?Sized); //~ ERROR `?Trait` is not permitted in trait object types

fn main() {}
16 changes: 8 additions & 8 deletions src/test/ui/maybe-bounds.stderr
Original file line number Diff line number Diff line change
@@ -1,22 +1,22 @@
error: `?Trait` is not permitted in supertraits
--> $DIR/maybe-bounds.rs:11:12
--> $DIR/maybe-bounds.rs:11:11
|
LL | trait Tr: ?Sized {} //~ ERROR `?Trait` is not permitted in supertraits
| ^^^^^
| ^^^^^^
|
= note: traits are `?Sized` by default

error: `?Trait` is not permitted in trait object types
--> $DIR/maybe-bounds.rs:13:17
--> $DIR/maybe-bounds.rs:13:16
|
LL | type A1 = Tr + ?Sized; //~ ERROR `?Trait` is not permitted in trait object types
| ^^^^^
LL | type A1 = Tr + (?Sized); //~ ERROR `?Trait` is not permitted in trait object types
| ^^^^^^^^

error: `?Trait` is not permitted in trait object types
--> $DIR/maybe-bounds.rs:14:25
--> $DIR/maybe-bounds.rs:14:24
|
LL | type A2 = for<'a> Tr + ?Sized; //~ ERROR `?Trait` is not permitted in trait object types
| ^^^^^
LL | type A2 = for<'a> Tr + (?Sized); //~ ERROR `?Trait` is not permitted in trait object types
| ^^^^^^^^

error: aborting due to 3 previous errors

0 comments on commit 06ab5a6

Please sign in to comment.