diff options
author | bors[bot] <26634292+bors[bot]@users.noreply.github.com> | 2022-05-02 14:32:12 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2022-05-02 14:32:12 +0000 |
commit | fb136314f9584744ccc7b09ace3cea99129b7cf4 (patch) | |
tree | 49040fe0347cbe57412c4fd79d7e2e55c18abcc0 /gcc/rust/ast/rust-item.h | |
parent | 27e562a2c07c9f09c80f905cf7ebc4a5b25672eb (diff) | |
parent | 98e1de2d8fdc0f39af161284d2cc74755aa1d260 (diff) | |
download | gcc-fb136314f9584744ccc7b09ace3cea99129b7cf4.zip gcc-fb136314f9584744ccc7b09ace3cea99129b7cf4.tar.gz gcc-fb136314f9584744ccc7b09ace3cea99129b7cf4.tar.bz2 |
Merge #1191
1191: Resolve simple paths in use items r=CohenArthur a=CohenArthur
In order to resolve `SimplePath`s, we have to expand all paths present
in a `UseDeclaration` and resolve them. For example, we want to resolve
two paths with the following statement `use foo::bar::{baz, bul}`:
`foo::bar::baz` and `foo::bar::bul`
This also removes the prelude inclusion (`use std::prelude::v1::*`)
since we cannot resolve it (yet!)
Needs #1172 to compile
Adresses #1159
Adresses #1187
Co-authored-by: Arthur Cohen <arthur.cohen@embecosm.com>
Diffstat (limited to 'gcc/rust/ast/rust-item.h')
-rw-r--r-- | gcc/rust/ast/rust-item.h | 57 |
1 files changed, 57 insertions, 0 deletions
diff --git a/gcc/rust/ast/rust-item.h b/gcc/rust/ast/rust-item.h index 9dc61a8..4bed5af 100644 --- a/gcc/rust/ast/rust-item.h +++ b/gcc/rust/ast/rust-item.h @@ -1179,8 +1179,29 @@ class UseTree Location locus; public: + enum Kind + { + Glob, + Rebind, + List, + }; + virtual ~UseTree () {} + // Overload assignment operator to clone + UseTree &operator= (UseTree const &other) + { + locus = other.locus; + + return *this; + } + + UseTree (const UseTree &other) = default; + + // move constructors + UseTree (UseTree &&other) = default; + UseTree &operator= (UseTree &&other) = default; + // Unique pointer custom clone function std::unique_ptr<UseTree> clone_use_tree () const { @@ -1188,6 +1209,7 @@ public: } virtual std::string as_string () const = 0; + virtual Kind get_kind () const = 0; Location get_locus () const { return locus; } @@ -1237,6 +1259,14 @@ public: void accept_vis (ASTVisitor &vis) override; + Kind get_kind () const override { return Glob; } + + SimplePath get_path () const + { + rust_assert (has_path ()); + return path; + } + /* TODO: find way to ensure only PATH_PREFIXED glob_type has path - factory * methods? */ protected: @@ -1318,6 +1348,18 @@ public: void accept_vis (ASTVisitor &vis) override; + Kind get_kind () const override { return List; } + SimplePath get_path () const + { + rust_assert (has_path ()); + return path; + } + + const std::vector<std::unique_ptr<UseTree>> &get_trees () const + { + return trees; + } + // TODO: find way to ensure only PATH_PREFIXED path_type has path - factory // methods? protected: @@ -1363,6 +1405,20 @@ public: void accept_vis (ASTVisitor &vis) override; + Kind get_kind () const override { return Rebind; } + + SimplePath get_path () const + { + rust_assert (has_path ()); + return path; + } + + const Identifier &get_identifier () const + { + rust_assert (has_identifier ()); + return identifier; + } + // TODO: find way to ensure only PATH_PREFIXED path_type has path - factory // methods? protected: @@ -1420,6 +1476,7 @@ public: UseDeclaration &operator= (UseDeclaration &&other) = default; Location get_locus () const override final { return locus; } + const std::unique_ptr<UseTree> &get_tree () const { return use_tree; } void accept_vis (ASTVisitor &vis) override; |