aboutsummaryrefslogtreecommitdiff
path: root/gcc/rust/hir/tree/rust-hir.h
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/rust/hir/tree/rust-hir.h')
-rw-r--r--gcc/rust/hir/tree/rust-hir.h45
1 files changed, 27 insertions, 18 deletions
diff --git a/gcc/rust/hir/tree/rust-hir.h b/gcc/rust/hir/tree/rust-hir.h
index b4a9616..8b60d10 100644
--- a/gcc/rust/hir/tree/rust-hir.h
+++ b/gcc/rust/hir/tree/rust-hir.h
@@ -65,6 +65,12 @@ public:
: inner_attrs (std::move (inner_attrs)){};
};
+class FullVisitable
+{
+public:
+ virtual void accept_vis (HIRFullVisitor &vis) = 0;
+};
+
// forward decl for use in token tree method
class Token;
@@ -155,9 +161,11 @@ public:
/* Base statement abstract class. Note that most "statements" are not allowed in
* top-level module scope - only a subclass of statements called "items" are. */
-class Stmt : public Node
+class Stmt : public Node, public FullVisitable
{
public:
+ using FullVisitable::accept_vis;
+
// Unique pointer custom clone function
std::unique_ptr<Stmt> clone_stmt () const
{
@@ -170,7 +178,6 @@ public:
virtual std::string as_string () const = 0;
- virtual void accept_vis (HIRFullVisitor &vis) = 0;
virtual void accept_vis (HIRStmtVisitor &vis) = 0;
virtual Location get_locus () const = 0;
@@ -253,8 +260,11 @@ protected:
class ExprWithoutBlock;
// Base expression HIR node - abstract
-class Expr : public Node
+class Expr : public Node, public FullVisitable
{
+public:
+ using FullVisitable::accept_vis;
+
protected:
AST::AttrVec outer_attrs;
Analysis::NodeMapping mappings;
@@ -322,7 +332,6 @@ public:
virtual ExprType get_expression_type () const = 0;
virtual void accept_vis (HIRExpressionVisitor &vis) = 0;
- virtual void accept_vis (HIRFullVisitor &vis) = 0;
protected:
// Constructor
@@ -374,9 +383,11 @@ public:
};
// Pattern base HIR node
-class Pattern : public Node
+class Pattern : public Node, public FullVisitable
{
public:
+ using FullVisitable::accept_vis;
+
enum PatternType
{
PATH,
@@ -407,7 +418,6 @@ public:
virtual std::string as_string () const = 0;
- virtual void accept_vis (HIRFullVisitor &vis) = 0;
virtual void accept_vis (HIRPatternVisitor &vis) = 0;
virtual Analysis::NodeMapping get_pattern_mappings () const = 0;
@@ -425,9 +435,10 @@ protected:
class TraitBound;
// Base class for types as represented in HIR - abstract
-class Type : public Node
+class Type : public Node, public FullVisitable
{
public:
+ using FullVisitable::accept_vis;
// Unique pointer custom clone function
std::unique_ptr<Type> clone_type () const
{
@@ -450,7 +461,6 @@ public:
/* as pointer, shouldn't require definition beforehand, only forward
* declaration. */
- virtual void accept_vis (HIRFullVisitor &vis) = 0;
virtual void accept_vis (HIRTypeVisitor &vis) = 0;
virtual Analysis::NodeMapping get_mappings () const { return mappings; }
@@ -497,9 +507,10 @@ protected:
/* Abstract base class representing a type param bound - Lifetime and TraitBound
* extends it */
-class TypeParamBound
+class TypeParamBound : public FullVisitable
{
public:
+ using FullVisitable::accept_vis;
enum BoundType
{
LIFETIME,
@@ -516,8 +527,6 @@ public:
virtual std::string as_string () const = 0;
- virtual void accept_vis (HIRFullVisitor &vis) = 0;
-
virtual Analysis::NodeMapping get_mappings () const = 0;
virtual Location get_locus () const = 0;
@@ -590,9 +599,11 @@ protected:
/* Base generic parameter in HIR. Abstract - can be represented by a Lifetime or
* Type param */
-class GenericParam
+class GenericParam : public FullVisitable
{
public:
+ using FullVisitable::accept_vis;
+
virtual ~GenericParam () {}
enum class GenericKind
@@ -610,8 +621,6 @@ public:
virtual std::string as_string () const = 0;
- virtual void accept_vis (HIRFullVisitor &vis) = 0;
-
virtual Location get_locus () const = 0;
Analysis::NodeMapping get_mappings () const { return mappings; }
@@ -768,9 +777,10 @@ private:
};
// Item used in trait declarations - abstract base class
-class TraitItem : public Node
+class TraitItem : public Node, public FullVisitable
{
public:
+ using FullVisitable::accept_vis;
enum TraitItemKind
{
FUNC,
@@ -800,7 +810,6 @@ public:
virtual std::string as_string () const = 0;
virtual void accept_vis (HIRTraitItemVisitor &vis) = 0;
- virtual void accept_vis (HIRFullVisitor &vis) = 0;
virtual const std::string trait_identifier () const = 0;
@@ -814,9 +823,10 @@ public:
virtual const AST::AttrVec &get_outer_attrs () const = 0;
};
-class ImplItem : public Node
+class ImplItem : public Node, public FullVisitable
{
public:
+ using FullVisitable::accept_vis;
enum ImplItemType
{
FUNCTION,
@@ -837,7 +847,6 @@ public:
virtual std::string as_string () const = 0;
virtual void accept_vis (HIRImplVisitor &vis) = 0;
- virtual void accept_vis (HIRFullVisitor &vis) = 0;
virtual void accept_vis (HIRStmtVisitor &vis) = 0;
virtual Analysis::NodeMapping get_impl_mappings () const = 0;