grammar refactoring: base visitor class fixed

This commit is contained in:
ProgramSnail 2023-04-09 14:13:47 +03:00
parent ff893d3ebd
commit 77c7ac0b2f
3 changed files with 112 additions and 155 deletions

View file

@ -6,10 +6,6 @@
#include <optional> #include <optional>
#include <memory> #include <memory>
// for clangd
#include "node.hpp"
namespace interpreter::tokens { namespace interpreter::tokens {
// ----------------- Declarations ----------------- // ----------------- Declarations -----------------
@ -84,66 +80,51 @@ using FlowControl = std::variant<
struct Block; struct Block;
// //
struct NameExpression; struct NameExpression;
struct ScopedStatement; struct ScopedStatement;
using SubExpressionToken = std::variant< using SubExpressionToken = std::variant<
std::unique_ptr<NameExpression>, std::unique_ptr<NameExpression>,
std::unique_ptr<ScopedStatement>>; std::unique_ptr<ScopedStatement>>;
// //
struct FunctionCallExpression; struct FunctionCallExpression;
struct BinaryOperatorExpression; struct BinaryOperatorExpression;
struct ArrayExpression; struct ArrayExpression;
struct ReferenceExpression; struct ReferenceExpression;
using SubExpression = std::variant< using SubExpression = std::variant<
std::unique_ptr<FunctionCallExpression>, std::unique_ptr<FunctionCallExpression>,
std::unique_ptr<BinaryOperatorExpression>, std::unique_ptr<BinaryOperatorExpression>,
std::unique_ptr<SubExpressionToken>, std::unique_ptr<SubExpressionToken>,
std::unique_ptr<ArrayExpression>, std::unique_ptr<ArrayExpression>,
std::unique_ptr<ReferenceExpression>>; std::unique_ptr<ReferenceExpression>>;
// //
enum class LoopControlExpression { enum class LoopControlExpression {
Break, Break,
Continue, Continue,
}; };
//
struct ReturnExpression; struct ReturnExpression;
using PrefixedExpression = std::variant< using PrefixedExpression = std::variant<
std::unique_ptr<ReturnExpression>, std::unique_ptr<ReturnExpression>,
std::unique_ptr<LoopControlExpression>, std::unique_ptr<LoopControlExpression>,
std::unique_ptr<Block>>; std::unique_ptr<Block>>;
// //
struct LambdaFunction; struct LambdaFunction;
struct TypeConstructor; struct TypeConstructor;
struct UnaryOperatorExpression; struct UnaryOperatorExpression;
using Expression = std::variant< using Expression = std::variant<
std::unique_ptr<LambdaFunction>, std::unique_ptr<LambdaFunction>,
std::unique_ptr<TypeConstructor>, std::unique_ptr<TypeConstructor>,
std::unique_ptr<PrefixedExpression>, std::unique_ptr<PrefixedExpression>,
std::unique_ptr<UnaryOperatorExpression>, std::unique_ptr<UnaryOperatorExpression>,
std::unique_ptr<SubExpression>>; std::unique_ptr<SubExpression>>;
// //
struct TupleExpression; struct TupleExpression;
struct VariantExpression; struct VariantExpression;
using SuperExpression = std::variant< using SuperExpression = std::variant<
std::unique_ptr<FlowControl>, std::unique_ptr<FlowControl>,
std::unique_ptr<TupleExpression>, std::unique_ptr<TupleExpression>,
std::unique_ptr<VariantExpression>, std::unique_ptr<VariantExpression>,
std::unique_ptr<Expression>>; std::unique_ptr<Expression>>;
// //
struct ScopedStatement; struct ScopedStatement;
@ -158,15 +139,16 @@ struct ReferenceExpression;
struct FunctionCallExpression; struct FunctionCallExpression;
//
struct TypeExpression; struct TypeExpression;
using FunctionArgument = std::variant< using FunctionArgument = std::variant<
SubExpressionToken, SubExpressionToken,
std::unique_ptr<TypeExpression>>; std::unique_ptr<TypeExpression>>;
//
struct TupleExpression; struct TupleExpression;
struct VariantExpression; struct VariantExpression;
struct ReturnExpression; struct ReturnExpression;
struct TypeConstructor; struct TypeConstructor;
struct LambdaFunction; struct LambdaFunction;
struct ArrayExpression; struct ArrayExpression;
@ -429,7 +411,7 @@ struct UnaryOperatorExpression {
struct ReferenceExpression { struct ReferenceExpression {
std::vector<ReferenceType> references; std::vector<ReferenceType> references;
ScopedStatement expression; ScopedStatement expression;
} };
// Simple Expressions ----------------- // Simple Expressions -----------------
@ -522,7 +504,7 @@ struct TypeExpression {
struct ExtendedScopedAnyType { struct ExtendedScopedAnyType {
std::vector<ReferenceType> references; std::vector<ReferenceType> references;
AnyType type; AnyType type;
} };
// Typeclass ----------------- // Typeclass -----------------

View file

@ -14,8 +14,6 @@ public:
} }
protected: protected:
virtual void Visit(Node* node) {}
// Sources ----------------- // Sources -----------------
virtual void Visit(SourceFile* node) {} virtual void Visit(SourceFile* node) {}
@ -29,28 +27,21 @@ protected:
// Definitions ----------------- // Definitions -----------------
virtual void Visit(ImportStatement* node) {} virtual void Visit(ImportStatement* node) {}
virtual void Visit(UsageDefinition* node) {} virtual void Visit(AliasDefinitionStatement* node) {}
virtual void Visit(AliasDefinition* node) {} virtual void Visit(VariableDefinitionStatement* node) {}
virtual void Visit(VariableDefinition* node) {}
virtual void Visit(FunctionDeclaration* node) {} virtual void Visit(FunctionDeclaration* node) {}
virtual void Visit(FunctionDefinition* node) {} virtual void Visit(FunctionDefinitionStatement* node) {}
virtual void Visit(AliasTypeDefinition* node) {} virtual void Visit(TypeDefinitionStatement* node) {}
virtual void Visit(TypeDefinition* node) {} virtual void Visit(AbstractTypeDefinitionStatement* node) {}
virtual void Visit(TypeclassDefinition* node) {} virtual void Visit(TypeclassDefinitionStatement* node) {}
virtual void Visit(SourceStatement& node); // variant virtual void Visit(SourceStatement& node); // variant
virtual void Visit(ImportSymbol& node); // variant
// Definition parts // Definition parts
virtual void Visit(DefinedName* node) {} virtual void Visit(FunctionDefinition* node) {}
virtual void Visit(DefinedAnnotatedName* node) {} virtual void Visit(TypeDefinition* node) {}
virtual void Visit(DefinedType* node) {}
virtual void Visit(DefinedTypeclass* node) {}
virtual void Visit(DefinitionParameter* node) {} virtual void Visit(DefinitionParameter* node) {}
virtual void Visit(DefinitionArgument* node) {}
virtual void Visit(FunctionDeclarationType& node); // variant
// Flow control ----------------- // Flow control -----------------
@ -66,10 +57,9 @@ protected:
// Statements, expressions, blocks, etc. ----------------- // Statements, expressions, blocks, etc. -----------------
virtual void Visit(Block* node) {} virtual void Visit(BlockStatement& node); // variant
virtual void Visit(ScopedStatement* node) {}
virtual void Visit(LoopControlExpression& node) {} // enum virtual void Visit(Block* node) {}
virtual void Visit(SubExpressionToken& node); // variant virtual void Visit(SubExpressionToken& node); // variant
virtual void Visit(SubExpression& node); // variant virtual void Visit(SubExpression& node); // variant
@ -77,29 +67,31 @@ protected:
virtual void Visit(Expression& node); // variant virtual void Visit(Expression& node); // variant
virtual void Visit(SuperExpression& node); // variant virtual void Visit(SuperExpression& node); // variant
virtual void Visit(BlockStatement& node); // variant virtual void Visit(ScopedStatement* node) {}
// Operators // Operators
virtual void Visit(BinaryOperatorExpression* node) {} virtual void Visit(BinaryOperatorExpression* node) {}
virtual void Visit(UnaryOperatorExpression* node) {} virtual void Visit(UnaryOperatorExpression* node) {}
virtual void Visit(ReferenceExpression* node) {}
// Simple Expressions // Simple Expressions
virtual void Visit(FunctionCallExpression* node) {} virtual void Visit(FunctionCallExpression* node) {}
virtual void Visit(TupleExpression* node) {}
virtual void Visit(VariantExpression* node) {}
virtual void Visit(ReturnExpression* node) {}
virtual void Visit(FunctionArgument& node); // variant virtual void Visit(FunctionArgument& node); // variant
// Lambda virtual void Visit(TupleExpression* node) {}
virtual void Visit(VariantExpression* node) {}
virtual void Visit(ReturnExpression* node) {}
virtual void Visit(TypeConstructor* node) {}
virtual void Visit(LambdaFunction* node) {} virtual void Visit(LambdaFunction* node) {}
virtual void Visit(ArrayExpression* node) {}
virtual void Visit(LoopControlExpression& node) {} // enum
// Name // Name
virtual void Visit(NameSuperExpression* node) {}
virtual void Visit(NameExpression* node) {} virtual void Visit(NameExpression* node) {}
virtual void Visit(TupleName* node) {} virtual void Visit(TupleName* node) {}
virtual void Visit(VariantName* node) {} virtual void Visit(VariantName* node) {}
@ -107,9 +99,11 @@ protected:
virtual void Visit(AnyName& node); // variant virtual void Visit(AnyName& node); // variant
// Type, typeclass, etc. -----------------
// Type // Type
virtual void Visit(TypeConstructor* node) {} virtual void Visit(FunctionType* node) {}
virtual void Visit(TupleType* node) {} virtual void Visit(TupleType* node) {}
virtual void Visit(VariantType* node) {} virtual void Visit(VariantType* node) {}
virtual void Visit(AnnotatedType* node) {} virtual void Visit(AnnotatedType* node) {}
@ -117,16 +111,21 @@ protected:
virtual void Visit(TypeExpression* node) {} virtual void Visit(TypeExpression* node) {}
virtual void Visit(AnyType& node); // variant virtual void Visit(AnyType& node); // variant
virtual void Visit(TypeSubExpression& node); // variant
virtual void Visit(TypeParameter& node); // variant virtual void Visit(ExtendedScopedAnyType* node) {}
// Typeclass // Typeclass
virtual void Visit(AnnotatedTypeclass* node) {}
virtual void Visit(ParametrizedTypeclass* node) {} virtual void Visit(ParametrizedTypeclass* node) {}
virtual void Visit(TypeclassExpression* node) {} virtual void Visit(TypeclassExpression* node) {}
virtual void Visit(TypeclassUsage& node); // variant
// Typeclass & Type
virtual void Visit(TypeParameter& node); // variant
virtual void Visit(TypeSubExpression& node); // variant
// Identifiers, constants, etc. ----------------- // Identifiers, constants, etc. -----------------
virtual void Visit(AnyIdentifier* node) {} // std::string virtual void Visit(AnyIdentifier* node) {} // std::string
@ -138,7 +137,7 @@ protected:
virtual void Visit(Literal& node); // variant virtual void Visit(Literal& node); // variant
virtual void Visit(NameSubSuperExpression& node); // variant virtual void Visit(NameSubExpression& node); // variant
}; };
} // namespace interpreter } // namespace interpreter

View file

@ -11,30 +11,24 @@ void Visitor::Visit(SourceStatement& node) {
Visit(std::get<std::unique_ptr<ImportStatement>>(node).get()); Visit(std::get<std::unique_ptr<ImportStatement>>(node).get());
break; break;
case 1: case 1:
Visit(std::get<std::unique_ptr<UsageDefinition>>(node).get()); Visit(std::get<std::unique_ptr<AliasDefinitionStatement>>(node).get());
break; break;
case 2: case 2:
Visit(std::get<std::unique_ptr<AliasDefinition>>(node).get());
break;
case 3:
Visit(std::get<std::unique_ptr<VariableDefinition>>(node).get());
break;
case 4:
Visit(std::get<std::unique_ptr<FunctionDeclaration>>(node).get()); Visit(std::get<std::unique_ptr<FunctionDeclaration>>(node).get());
break; break;
case 3:
Visit(std::get<std::unique_ptr<FunctionDefinitionStatement>>(node).get());
break;
case 4:
Visit(std::get<std::unique_ptr<TypeDefinitionStatement>>(node).get());
break;
case 5: case 5:
Visit(std::get<std::unique_ptr<FunctionDefinition>>(node).get()); Visit(std::get<std::unique_ptr<AbstractTypeDefinitionStatement>>(node).get());
break; break;
case 6: case 6:
Visit(std::get<std::unique_ptr<AliasTypeDefinition>>(node).get()); Visit(std::get<std::unique_ptr<TypeclassDefinitionStatement>>(node).get());
break; break;
case 7: case 7:
Visit(std::get<std::unique_ptr<TypeDefinition>>(node).get());
break;
case 8:
Visit(std::get<std::unique_ptr<TypeclassDefinition>>(node).get());
break;
case 9:
Visit(std::get<std::unique_ptr<Namespace>>(node).get()); Visit(std::get<std::unique_ptr<Namespace>>(node).get());
break; break;
default: default:
@ -43,45 +37,6 @@ void Visitor::Visit(SourceStatement& node) {
} }
} }
void Visitor::Visit(ImportSymbol& node) {
switch (node.index()) {
case 0:
Visit(std::get<std::unique_ptr<TypeclassExpression>>(node).get());
break;
case 1:
Visit(std::get<std::unique_ptr<TypeExpression>>(node).get());
break;
case 2:
Visit(std::get<std::unique_ptr<NameExpression>>(node).get());
break;
default:
// error
break;
}
}
// Definition parts
void Visitor::Visit(FunctionDeclarationType& node) {
switch (node.index()) {
case 0:
Visit(std::get<std::unique_ptr<ParametrizedType>>(node).get());
break;
case 1:
Visit(std::get<std::unique_ptr<TupleType>>(node).get());
break;
case 2:
Visit(std::get<std::unique_ptr<VariantType>>(node).get());
break;
case 3:
Visit(std::get<std::unique_ptr<ParametrizedTypeclass>>(node).get());
break;
default:
// error
break;
}
}
// Flow control ----------------- // Flow control -----------------
void Visitor::Visit(FlowControl& node) { void Visitor::Visit(FlowControl& node) {
@ -112,10 +67,32 @@ void Visitor::Visit(FlowControl& node) {
// Statements, expressions, blocks, etc. ----------------- // Statements, expressions, blocks, etc. -----------------
void Visitor::Visit(BlockStatement& node) {
switch (node.index()) {
case 0:
Visit(*std::get<std::unique_ptr<Expression>>(node));
break;
case 1:
Visit(std::get<std::unique_ptr<VariableDefinitionStatement>>(node).get());
break;
case 2:
Visit(*std::get<std::unique_ptr<FlowControl>>(node));
break;
case 3:
Visit(*std::get<std::unique_ptr<PrefixedExpression>>(node));
break;
default:
// error
break;
}
}
//
void Visitor::Visit(SubExpressionToken& node) { void Visitor::Visit(SubExpressionToken& node) {
switch (node.index()) { switch (node.index()) {
case 0: case 0:
Visit(std::get<std::unique_ptr<NameSuperExpression>>(node).get()); Visit(std::get<std::unique_ptr<NameExpression>>(node).get());
break; break;
case 1: case 1:
Visit(std::get<std::unique_ptr<ScopedStatement>>(node).get()); Visit(std::get<std::unique_ptr<ScopedStatement>>(node).get());
@ -137,6 +114,12 @@ void Visitor::Visit(SubExpression& node) {
case 2: case 2:
Visit(*std::get<std::unique_ptr<SubExpressionToken>>(node)); Visit(*std::get<std::unique_ptr<SubExpressionToken>>(node));
break; break;
case 3:
Visit(std::get<std::unique_ptr<ArrayExpression>>(node).get());
break;
case 4:
Visit(std::get<std::unique_ptr<ReferenceExpression>>(node).get());
break;
default: default:
// error // error
break; break;
@ -203,31 +186,6 @@ void Visitor::Visit(SuperExpression& node) {
} }
} }
//
void Visitor::Visit(BlockStatement& node) {
switch (node.index()) {
case 0:
Visit(*std::get<std::unique_ptr<Expression>>(node));
break;
case 1:
Visit(std::get<std::unique_ptr<AliasDefinition>>(node).get());
break;
case 2:
Visit(std::get<std::unique_ptr<VariableDefinition>>(node).get());
break;
case 3:
Visit(*std::get<std::unique_ptr<FlowControl>>(node));
break;
case 4:
Visit(*std::get<std::unique_ptr<PrefixedExpression>>(node));
break;
default:
// error
break;
}
}
// Simple Expressions // Simple Expressions
void Visitor::Visit(FunctionArgument& node) { void Visitor::Visit(FunctionArgument& node) {
@ -263,6 +221,8 @@ void Visitor::Visit(AnyName& node) {
} }
} }
// Type, typeclass, etc. -----------------
// Type // Type
void Visitor::Visit(AnyType& node) { // Or ScopedAnyType void Visitor::Visit(AnyType& node) { // Or ScopedAnyType
@ -276,6 +236,41 @@ void Visitor::Visit(AnyType& node) { // Or ScopedAnyType
case 2: case 2:
Visit(std::get<std::unique_ptr<VariantType>>(node).get()); Visit(std::get<std::unique_ptr<VariantType>>(node).get());
break; break;
case 3:
Visit(std::get<std::unique_ptr<FunctionType>>(node).get());
break;
default:
// error
break;
}
}
// Typeclass
void Visitor::Visit(TypeclassUsage& node) {
switch (node.index()) {
case 0:
Visit(std::get<std::unique_ptr<TypeclassExpression>>(node).get());
break;
case 1:
Visit(std::get<std::unique_ptr<ParametrizedTypeclass>>(node).get());
break;
default:
// error
break;
}
}
// Typeclass & Type
void Visitor::Visit(TypeParameter& node) {
switch (node.index()) {
case 0:
Visit(std::get<std::unique_ptr<TypeExpression>>(node).get());
break;
case 1:
Visit(std::get<std::unique_ptr<ParametrizedType>>(node).get());
break;
default: default:
// error // error
break; break;
@ -296,25 +291,6 @@ void Visitor::Visit(TypeSubExpression& node) {
} }
} }
//
void Visitor::Visit(TypeParameter& node) {
switch (node.index()) {
case 0:
Visit(std::get<std::unique_ptr<TypeExpression>>(node).get());
break;
case 1:
Visit(std::get<std::unique_ptr<ParametrizedType>>(node).get());
break;
case 2:
Visit(*std::get<std::unique_ptr<Expression>>(node));
break;
default:
// error
break;
}
}
// Identifiers, constants, etc. ----------------- // Identifiers, constants, etc. -----------------
void Visitor::Visit(Literal& node) { void Visitor::Visit(Literal& node) {
@ -339,7 +315,7 @@ void Visitor::Visit(Literal& node) {
// //
void Visitor::Visit(NameSubSuperExpression& node) { void Visitor::Visit(NameSubExpression& node) {
switch (node.index()) { switch (node.index()) {
case 0: case 0:
Visit(std::get<std::unique_ptr<NameIdentifier>>(node).get()); Visit(std::get<std::unique_ptr<NameIdentifier>>(node).get());