diff options
author | Marc Poulhiès <dkm@kataplop.net> | 2022-01-15 22:43:08 +0100 |
---|---|---|
committer | Marc Poulhiès <dkm@kataplop.net> | 2022-02-25 20:37:37 +0100 |
commit | dffb1adabd3853a8d1100e53d5fa351f8b5f180c (patch) | |
tree | 1daec8a8d99f4936805928920132a2b4be794c88 /gcc/rust/backend/rust-compile-fnparam.h | |
parent | b695eb8f0bae01e00dfb9e9bf2554d1b48b76a9a (diff) | |
download | gcc-dffb1adabd3853a8d1100e53d5fa351f8b5f180c.zip gcc-dffb1adabd3853a8d1100e53d5fa351f8b5f180c.tar.gz gcc-dffb1adabd3853a8d1100e53d5fa351f8b5f180c.tar.bz2 |
HIR Visitor refactoring
This change split the single HIR visitor in smaller abstract ones:
- Stmt
- VisItem
- Pattern
- ExternalItem
- Impl
- Type
- Expression
Instead of providing a Base class with empty visit() methods, they are kept
abstract to avoid the case where a missing visit() is silently ignored:
implementors must explicitely override all visit.
There is also a FullVisitor that covers all HIR nodes and also provides a Base
class with empty behavior.
fixes #825
Signed-off-by: Marc Poulhiès <dkm@kataplop.net>
Diffstat (limited to 'gcc/rust/backend/rust-compile-fnparam.h')
-rw-r--r-- | gcc/rust/backend/rust-compile-fnparam.h | 18 |
1 files changed, 14 insertions, 4 deletions
diff --git a/gcc/rust/backend/rust-compile-fnparam.h b/gcc/rust/backend/rust-compile-fnparam.h index 4ca26ec..74df725 100644 --- a/gcc/rust/backend/rust-compile-fnparam.h +++ b/gcc/rust/backend/rust-compile-fnparam.h @@ -24,10 +24,8 @@ namespace Rust { namespace Compile { -class CompileFnParam : public HIRCompileBase +class CompileFnParam : public HIRCompileBase, public HIR::HIRPatternVisitor { - using Rust::Compile::HIRCompileBase::visit; - public: static Bvariable *compile (Context *ctx, tree fndecl, HIR::FunctionParam *param, tree decl_type, @@ -57,6 +55,18 @@ public: = ctx->get_backend ()->parameter_variable (fndecl, "_", decl_type, locus); } + // Empty visit for unused Pattern HIR nodes. + void visit (HIR::GroupedPattern &) override {} + void visit (HIR::LiteralPattern &) override {} + void visit (HIR::PathInExpression &) override {} + void visit (HIR::QualifiedPathInExpression &) override {} + void visit (HIR::RangePattern &) override {} + void visit (HIR::ReferencePattern &) override {} + void visit (HIR::SlicePattern &) override {} + void visit (HIR::StructPattern &) override {} + void visit (HIR::TuplePattern &) override {} + void visit (HIR::TupleStructPattern &) override {} + private: CompileFnParam (Context *ctx, tree fndecl, tree decl_type, Location locus) : HIRCompileBase (ctx), fndecl (fndecl), decl_type (decl_type), @@ -69,7 +79,7 @@ private: Bvariable *compiled_param; }; -class CompileSelfParam : public HIRCompileBase +class CompileSelfParam : public HIRCompileBase, public HIR::HIRStmtVisitor { public: static Bvariable *compile (Context *ctx, tree fndecl, HIR::SelfParam &self, |