2023-03-28 12:05:20 +03:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
// for clangd
|
2023-04-25 21:21:36 +03:00
|
|
|
#include "interpreter_tree.hpp"
|
2023-03-28 12:05:20 +03:00
|
|
|
#include "visitor.hpp"
|
|
|
|
|
#include "parse_tree.hpp"
|
|
|
|
|
|
|
|
|
|
namespace interpreter {
|
|
|
|
|
|
|
|
|
|
class BuildVisitor : public Visitor {
|
|
|
|
|
public:
|
2023-04-02 15:10:32 +03:00
|
|
|
explicit BuildVisitor(const parser::ParseTree& parse_tree) : parse_tree_(parse_tree) {}
|
2023-03-28 12:05:20 +03:00
|
|
|
|
|
|
|
|
void VisitSourceFile(SourceFile* source_file) override {
|
|
|
|
|
current_node_ = parse_tree_.GetRoot();
|
|
|
|
|
Visit(source_file);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
private:
|
|
|
|
|
// Sources -----------------
|
|
|
|
|
|
|
|
|
|
void Visit(SourceFile* node) override;
|
|
|
|
|
|
2023-04-02 15:10:32 +03:00
|
|
|
// Namespaces, partitions -----------------
|
2023-03-28 12:05:20 +03:00
|
|
|
|
2023-04-29 13:44:34 +03:00
|
|
|
void Visit(NamespaceSources* node) override;
|
2023-03-28 12:05:20 +03:00
|
|
|
void Visit(Namespace* node) override;
|
|
|
|
|
|
|
|
|
|
// Definitions -----------------
|
|
|
|
|
|
|
|
|
|
void Visit(ImportStatement* node) override;
|
2023-04-09 18:49:52 +03:00
|
|
|
void Visit(AliasDefinitionStatement* node) override;
|
|
|
|
|
void Visit(VariableDefinitionStatement* node) override;
|
2023-03-28 12:05:20 +03:00
|
|
|
void Visit(FunctionDeclaration* node) override;
|
2023-04-09 18:49:52 +03:00
|
|
|
void Visit(FunctionDefinitionStatement* node) override;
|
|
|
|
|
void Visit(TypeDefinitionStatement* node) override;
|
|
|
|
|
void Visit(AbstractTypeDefinitionStatement* node) override;
|
|
|
|
|
void Visit(TypeclassDefinitionStatement* node) override;
|
2023-05-07 22:58:15 +03:00
|
|
|
void Visit(PartitionStatement* node) override;
|
2023-03-28 12:05:20 +03:00
|
|
|
|
2023-04-29 13:44:34 +03:00
|
|
|
void Visit(NamespaceStatement& node) override; // variant
|
2023-03-28 12:05:20 +03:00
|
|
|
void Visit(SourceStatement& node) override; // variant
|
|
|
|
|
|
|
|
|
|
// Definition parts
|
|
|
|
|
|
2023-04-09 18:49:52 +03:00
|
|
|
void Visit(FunctionDefinition* node) override;
|
|
|
|
|
void Visit(TypeDefinition* node) override;
|
2023-04-12 13:31:39 +03:00
|
|
|
void Visit(AnyAnnotatedType* node) override;
|
2023-03-28 12:05:20 +03:00
|
|
|
|
|
|
|
|
// Flow control -----------------
|
|
|
|
|
|
2023-04-25 21:21:36 +03:00
|
|
|
void Visit(TypeConstructorPatternParameter* node) override;
|
|
|
|
|
void Visit(TypeConstructorPattern* node) override;
|
2023-03-29 11:42:00 +03:00
|
|
|
void Visit(MatchCase* node) override;
|
2023-03-28 12:05:20 +03:00
|
|
|
void Visit(Match* node) override;
|
|
|
|
|
void Visit(Condition* node) override;
|
|
|
|
|
void Visit(DoWhileLoop* node) override;
|
|
|
|
|
void Visit(WhileLoop* node) override;
|
|
|
|
|
void Visit(ForLoop* node) override;
|
|
|
|
|
void Visit(LoopLoop* node) override;
|
|
|
|
|
|
2023-04-25 21:21:36 +03:00
|
|
|
void Visit(Pattern& node) override; // variant
|
2023-03-28 12:05:20 +03:00
|
|
|
void Visit(FlowControl& node) override; // variant
|
|
|
|
|
|
|
|
|
|
// Statements, expressions, blocks, etc. -----------------
|
|
|
|
|
|
2023-04-09 18:49:52 +03:00
|
|
|
void Visit(BlockStatement& node) override; // variant
|
2023-03-28 12:05:20 +03:00
|
|
|
|
2023-04-09 18:49:52 +03:00
|
|
|
void Visit(Block* node) override;
|
2023-03-28 12:05:20 +03:00
|
|
|
|
|
|
|
|
void Visit(SubExpressionToken& node) override; // variant
|
|
|
|
|
void Visit(SubExpression& node) override; // variant
|
|
|
|
|
void Visit(PrefixedExpression& node) override; // variant
|
|
|
|
|
void Visit(Expression& node) override; // variant
|
|
|
|
|
void Visit(SuperExpression& node) override; // variant
|
|
|
|
|
|
2023-04-09 18:49:52 +03:00
|
|
|
void Visit(ScopedStatement* node) override;
|
2023-03-28 12:05:20 +03:00
|
|
|
|
|
|
|
|
// Operators
|
|
|
|
|
|
2023-04-09 18:49:52 +03:00
|
|
|
void Visit(ReferenceExpression* node) override;
|
2023-04-21 14:27:55 +03:00
|
|
|
void Visit(AccessExpression* node) override;
|
2023-03-28 12:05:20 +03:00
|
|
|
|
2023-04-10 01:48:07 +03:00
|
|
|
// Other expressions
|
2023-03-28 12:05:20 +03:00
|
|
|
|
|
|
|
|
void Visit(FunctionCallExpression* node) override;
|
|
|
|
|
|
2023-04-09 18:49:52 +03:00
|
|
|
void Visit(TupleExpression* node) override;
|
|
|
|
|
void Visit(VariantExpression* node) override;
|
|
|
|
|
void Visit(ReturnExpression* node) override;
|
2023-04-25 21:21:36 +03:00
|
|
|
void Visit(TypeConstructorParameter* node) override;
|
2023-04-09 18:49:52 +03:00
|
|
|
void Visit(TypeConstructor* node) override;
|
2023-03-28 12:05:20 +03:00
|
|
|
void Visit(LambdaFunction* node) override;
|
2023-04-09 18:49:52 +03:00
|
|
|
void Visit(ArrayExpression* node) override;
|
|
|
|
|
|
|
|
|
|
void Visit(LoopControlExpression& node) override; // enum
|
2023-03-28 12:05:20 +03:00
|
|
|
|
|
|
|
|
// Name
|
|
|
|
|
|
2023-05-07 22:58:15 +03:00
|
|
|
void Visit(PartitionName* node) override;
|
2023-03-28 12:05:20 +03:00
|
|
|
void Visit(NameExpression* node) override;
|
|
|
|
|
void Visit(TupleName* node) override;
|
|
|
|
|
void Visit(VariantName* node) override;
|
|
|
|
|
void Visit(AnnotatedName* node) override;
|
|
|
|
|
|
|
|
|
|
void Visit(AnyName& node) override; // variant
|
|
|
|
|
|
2023-04-09 18:49:52 +03:00
|
|
|
// Type, typeclass, etc. -----------------
|
|
|
|
|
|
2023-03-28 12:05:20 +03:00
|
|
|
// Type
|
|
|
|
|
|
2023-04-09 18:49:52 +03:00
|
|
|
void Visit(FunctionType* node) override;
|
2023-03-28 12:05:20 +03:00
|
|
|
void Visit(TupleType* node) override;
|
|
|
|
|
void Visit(VariantType* node) override;
|
|
|
|
|
void Visit(TypeExpression* node) override;
|
|
|
|
|
|
|
|
|
|
void Visit(AnyType& node) override; // variant
|
|
|
|
|
|
2023-04-09 18:49:52 +03:00
|
|
|
void Visit(ExtendedScopedAnyType* node) override;
|
2023-03-28 12:05:20 +03:00
|
|
|
|
|
|
|
|
// Typeclass
|
|
|
|
|
|
2023-04-25 21:21:36 +03:00
|
|
|
void Visit(ParametrizedTypeclass* node) override;
|
2023-03-28 12:05:20 +03:00
|
|
|
|
2023-04-09 18:49:52 +03:00
|
|
|
// Typeclass & Type
|
|
|
|
|
|
2023-04-25 21:21:36 +03:00
|
|
|
void Visit(ParametrizedType* node) override;
|
|
|
|
|
|
2023-03-28 12:05:20 +03:00
|
|
|
// Identifiers, constants, etc. -----------------
|
|
|
|
|
|
2023-05-05 11:59:02 +03:00
|
|
|
// // void Visit(AnyIdentifier* node) override; // std::string
|
2023-03-28 12:05:20 +03:00
|
|
|
|
|
|
|
|
void Visit(FloatNumberLiteral* node) override;
|
|
|
|
|
void Visit(NumberLiteral* node) override;
|
|
|
|
|
void Visit(StringLiteral* node) override;
|
|
|
|
|
void Visit(CharLiteral* node) override;
|
2023-04-26 01:02:53 +03:00
|
|
|
void Visit(UnitLiteral* node) override;
|
2023-05-08 20:34:36 +03:00
|
|
|
void Visit(BoolLiteral* node) override;
|
2023-03-28 12:05:20 +03:00
|
|
|
|
|
|
|
|
void Visit(Literal& node) override; // variant
|
2023-05-17 15:49:15 +03:00
|
|
|
|
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
void VisitBinaryOperatorExpression(FunctionCallExpression* node);
|
|
|
|
|
|
2023-03-28 12:05:20 +03:00
|
|
|
private:
|
|
|
|
|
const parser::ParseTree& parse_tree_;
|
|
|
|
|
parser::ParseTree::Node current_node_;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
} // namespace interpreter
|