From 3dccdb1d6c57e983bed7135b4bc9ba7e1ae20fab Mon Sep 17 00:00:00 2001 From: Philip Herron Date: Tue, 2 Nov 2021 17:10:24 +0000 Subject: Desugar AST::TraitObjectTypeOneBound We have two ways to represent TraitObjectType's: - AST::TraitObjectType - AST::TraitObjectTypeOneBound This desugars this within HIR into a single HIR::TraitObjectType which contains a list of bounds. Addresses #786 --- gcc/rust/parse/rust-parse-impl.h | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) (limited to 'gcc/rust/parse/rust-parse-impl.h') diff --git a/gcc/rust/parse/rust-parse-impl.h b/gcc/rust/parse/rust-parse-impl.h index 52aba4f..316933e 100644 --- a/gcc/rust/parse/rust-parse-impl.h +++ b/gcc/rust/parse/rust-parse-impl.h @@ -9061,7 +9061,8 @@ Parser::parse_type () = parse_type_param_bounds (); return std::unique_ptr ( - new AST::TraitObjectType (std::move (bounds), t->get_locus ())); + new AST::TraitObjectType (std::move (bounds), t->get_locus (), + false)); } case IDENTIFIER: case SUPER: @@ -9148,7 +9149,7 @@ Parser::parse_type () } return std::unique_ptr ( - new AST::TraitObjectType (std::move (bounds), locus)); + new AST::TraitObjectType (std::move (bounds), locus, false)); } default: // assume that this is a type path and not an error @@ -9418,7 +9419,8 @@ Parser::parse_paren_prefixed_type () } return std::unique_ptr ( - new AST::TraitObjectType (std::move (bounds), left_delim_locus)); + new AST::TraitObjectType (std::move (bounds), left_delim_locus, + false)); } else { @@ -9528,7 +9530,7 @@ Parser::parse_for_prefixed_type () } return std::unique_ptr ( - new AST::TraitObjectType (std::move (bounds), for_locus)); + new AST::TraitObjectType (std::move (bounds), for_locus, false)); } default: // error -- cgit v1.1