diff options
author | Philip Herron <philip.herron@embecosm.com> | 2021-08-27 18:17:30 +0100 |
---|---|---|
committer | Philip Herron <philip.herron@embecosm.com> | 2021-08-27 18:17:30 +0100 |
commit | 46e8bf357ccd9bb0cf45b1f2f104fb1b72798a1a (patch) | |
tree | 322b247f975308a44e01c688c6b075b1fdb8f2cb /gcc | |
parent | 6b42381685595c34f21d5ce9ef1c31ceac76720d (diff) | |
download | gcc-46e8bf357ccd9bb0cf45b1f2f104fb1b72798a1a.zip gcc-46e8bf357ccd9bb0cf45b1f2f104fb1b72798a1a.tar.gz gcc-46e8bf357ccd9bb0cf45b1f2f104fb1b72798a1a.tar.bz2 |
Qualified paths have a mandatory initial segment
Qualified path in type's initial segment is mandatory (+) any other
segments are optional after the fact. see
https://doc.rust-lang.org/reference/paths.html#qualified-paths
This change makes the AST have a mandatory field for the initial segment
the segment list now only contains the optional remaining segments.
Diffstat (limited to 'gcc')
-rw-r--r-- | gcc/rust/ast/rust-path.h | 14 | ||||
-rw-r--r-- | gcc/rust/parse/rust-parse-impl.h | 7 |
2 files changed, 13 insertions, 8 deletions
diff --git a/gcc/rust/ast/rust-path.h b/gcc/rust/ast/rust-path.h index c042a8f..6ccd3a0 100644 --- a/gcc/rust/ast/rust-path.h +++ b/gcc/rust/ast/rust-path.h @@ -939,6 +939,7 @@ protected: class QualifiedPathInType : public TypeNoBounds { QualifiedPathType path_type; + std::unique_ptr<TypePathSegment> associated_segment; std::vector<std::unique_ptr<TypePathSegment> > segments; Location locus; @@ -953,9 +954,11 @@ protected: public: QualifiedPathInType ( QualifiedPathType qual_path_type, + std::unique_ptr<TypePathSegment> associated_segment, std::vector<std::unique_ptr<TypePathSegment> > path_segments, - Location locus = Location ()) + Location locus) : path_type (std::move (qual_path_type)), + associated_segment (std::move (associated_segment)), segments (std::move (path_segments)), locus (locus) {} @@ -995,8 +998,8 @@ public: static QualifiedPathInType create_error () { return QualifiedPathInType ( - QualifiedPathType::create_error (), - std::vector<std::unique_ptr<TypePathSegment> > ()); + QualifiedPathType::create_error (), nullptr, + std::vector<std::unique_ptr<TypePathSegment> > (), Location ()); } std::string as_string () const override; @@ -1010,6 +1013,11 @@ public: return path_type; } + std::unique_ptr<TypePathSegment> &get_associated_segment () + { + return associated_segment; + } + // TODO: this seems kinda dodgy std::vector<std::unique_ptr<TypePathSegment> > &get_segments () { diff --git a/gcc/rust/parse/rust-parse-impl.h b/gcc/rust/parse/rust-parse-impl.h index 8ee9e42..1c0644d 100644 --- a/gcc/rust/parse/rust-parse-impl.h +++ b/gcc/rust/parse/rust-parse-impl.h @@ -6742,10 +6742,6 @@ Parser<ManagedTokenSource>::parse_qualified_path_in_type () return AST::QualifiedPathInType::create_error (); } - // parse path segments - std::vector<std::unique_ptr<AST::TypePathSegment>> segments; - segments.reserve (1); - // parse initial required segment if (!expect_token (SCOPE_RESOLUTION)) { @@ -6765,9 +6761,9 @@ Parser<ManagedTokenSource>::parse_qualified_path_in_type () return AST::QualifiedPathInType::create_error (); } - segments.push_back (std::move (initial_segment)); // parse optional segments (as long as scope resolution operator exists) + std::vector<std::unique_ptr<AST::TypePathSegment>> segments; const_TokenPtr t = lexer.peek_token (); while (t->get_id () == SCOPE_RESOLUTION) { @@ -6796,6 +6792,7 @@ Parser<ManagedTokenSource>::parse_qualified_path_in_type () segments.shrink_to_fit (); return AST::QualifiedPathInType (std::move (qual_path_type), + std::move (initial_segment), std::move (segments), locus); } |