aboutsummaryrefslogtreecommitdiff
path: root/gcc/rust/ast/rust-item.h
diff options
context:
space:
mode:
authorbors[bot] <26634292+bors[bot]@users.noreply.github.com>2022-05-02 14:32:12 +0000
committerGitHub <noreply@github.com>2022-05-02 14:32:12 +0000
commitfb136314f9584744ccc7b09ace3cea99129b7cf4 (patch)
tree49040fe0347cbe57412c4fd79d7e2e55c18abcc0 /gcc/rust/ast/rust-item.h
parent27e562a2c07c9f09c80f905cf7ebc4a5b25672eb (diff)
parent98e1de2d8fdc0f39af161284d2cc74755aa1d260 (diff)
downloadgcc-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.h57
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;