lang_2023/src/build_visitor.cpp

1557 lines
46 KiB
C++
Raw Normal View History

2023-03-31 12:10:12 +03:00
#include <iostream>
#include <memory>
2023-04-02 15:10:32 +03:00
// for clangd
2023-03-28 12:05:20 +03:00
#include "../include/build_visitor.hpp"
#include "../include/parse_token_types.hpp"
namespace interpreter {
// Sources -----------------
void BuildVisitor::Visit(SourceFile* node) {
auto parse_node = current_node_;
2023-03-29 11:42:00 +03:00
size_t statement_count = parse_node.NamedChildCount();
2023-03-28 12:05:20 +03:00
2023-03-29 11:42:00 +03:00
node->statements.resize(statement_count);
2023-03-28 12:05:20 +03:00
2023-03-29 11:42:00 +03:00
for (size_t i = 0; i < statement_count; ++i) {
2023-03-28 12:05:20 +03:00
current_node_ = parse_node.NthNamedChild(i);
auto current_node_type = current_node_.GetType();
if (current_node_type == parser::tokens::SourceStatement) {
node->statements[i].emplace<SourceStatement>();
Visit(std::get<SourceStatement>(node->statements[i]));
} else if (current_node_type == parser::tokens::Partition) {
node->statements[i].emplace<Partition>();
Visit(&std::get<Partition>(node->statements[i]));
}
}
2023-03-29 23:19:54 +03:00
2023-03-28 12:05:20 +03:00
current_node_ = parse_node;
}
void BuildVisitor::Visit(Sources* node) {
auto parse_node = current_node_;
2023-03-29 11:42:00 +03:00
size_t statement_count = parse_node.NamedChildCount();
2023-03-28 12:05:20 +03:00
2023-03-29 11:42:00 +03:00
node->statements.resize(statement_count);
2023-03-28 12:05:20 +03:00
2023-03-29 11:42:00 +03:00
for (size_t i = 0; i < statement_count; ++i) {
2023-03-28 12:05:20 +03:00
current_node_ = parse_node.NthNamedChild(i);
Visit(node->statements[i]);
}
2023-03-29 23:19:54 +03:00
2023-03-28 12:05:20 +03:00
current_node_ = parse_node;
}
2023-04-02 15:10:32 +03:00
// Namespaces, partitions -----------------
2023-03-28 12:05:20 +03:00
void BuildVisitor::Visit(Partition* node) {
auto parse_node = current_node_;
2023-03-29 23:19:54 +03:00
std::string name = parse_node.ChildByFieldName("name").GetValue();
2023-03-28 12:05:20 +03:00
if (name == "TEST") {
node->type = Partition::Test;
} else if (name == "INTERFACE") {
node->type = Partition::Interface;
} else if (name == "CORE") {
node->type = Partition::Core;
} else if (name == "LIB") {
node->type = Partition::Lib;
} else if (name == "MODULE") {
node->type = Partition::Module;
} else if (name == "EXE") {
node->type = Partition::Exe;
}
current_node_ = parse_node.ChildByFieldName("scope");
node->scope = std::make_unique<Sources>();
Visit(node->scope.get());
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(Namespace* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
2023-04-02 15:10:32 +03:00
current_node_ = parse_node.ChildByFieldName("name");
2023-03-29 11:42:00 +03:00
auto current_node_type = current_node_.GetType();
2023-03-31 12:10:12 +03:00
2023-03-29 11:42:00 +03:00
if (current_node_type == parser::tokens::DefinedAnnotatedName) {
std::string name_modifier = parse_node.NthChild(1).GetValue(); // TODO
if (name_modifier == "const") {
node->is_const = true;
} else if (name_modifier == "var") {
node->is_const = false;
}
node->name = std::make_unique<DefinedAnnotatedName>();
2023-03-28 12:05:20 +03:00
Visit(std::get<std::unique_ptr<DefinedAnnotatedName>>(node->name).get());
2023-03-29 11:42:00 +03:00
} else if (current_node_type == parser::tokens::DefinedType) {
node->is_const = false; // TODO
node->name = std::make_unique<DefinedType>();
2023-03-28 12:05:20 +03:00
Visit(std::get<std::unique_ptr<DefinedType>>(node->name).get());
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node.ChildByFieldName("scope");
node->scope = std::make_unique<Sources>();
2023-03-28 12:05:20 +03:00
Visit(node->scope.get());
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
// Definitions -----------------
void BuildVisitor::Visit(ImportStatement* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
auto module_name_node = parse_node.ChildByFieldName("module_name");
node->module_name = module_name_node.NthChild(1).GetValue(); // open string literal
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
node->symbols.resize(child_count - 1);
2023-03-29 23:19:54 +03:00
for (size_t i = 0; i < child_count - 1; ++i) {
current_node_ = parse_node.NthNamedChild(i + 1);
2023-03-29 11:42:00 +03:00
Visit(node->symbols[i]);
}
2023-03-28 12:05:20 +03:00
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(UsageDefinition* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
node->name = parse_node.ChildByFieldName("name").GetValue();
current_node_ = parse_node.ChildByFieldName("import_statement");
node->import_statement = std::make_unique<ImportStatement>();
2023-03-28 12:05:20 +03:00
Visit(node->import_statement.get());
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(AliasDefinition* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("type");
node->type = std::make_unique<DefinedType>();
2023-03-28 12:05:20 +03:00
Visit(node->type.get());
2023-03-29 11:42:00 +03:00
current_node_ = parse_node.ChildByFieldName("value");
node->value = std::make_unique<ParametrizedType>();
2023-03-28 12:05:20 +03:00
Visit(node->value.get());
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(VariableDefinition* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
std::string name_modifier = parse_node.NthChild(0).GetValue();
if (name_modifier == "const") {
node->is_const = true;
} else if (name_modifier == "var") {
node->is_const = false;
}
node->name = parse_node.ChildByFieldName("name").GetValue();
current_node_ = parse_node.ChildByFieldName("value");
Visit(node->value);
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(FunctionDeclaration* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
2023-03-29 23:19:54 +03:00
node->name = parse_node.ChildByFieldName("name").GetValue();
2023-03-29 11:42:00 +03:00
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
bool parameters_ended = false;
2023-03-29 23:19:54 +03:00
for (size_t i = 0; i < child_count - 1; ++i) {
current_node_ = parse_node.NthNamedChild(i + 1);
2023-03-29 11:42:00 +03:00
if (current_node_.GetType() != parser::tokens::DefinitionParameter) {
parameters_ended = true;
}
if (!parameters_ended) {
node->parameters.push_back(std::make_unique<DefinitionParameter>());
Visit(node->parameters.back().get());
} else {
node->argument_types.emplace_back();
Visit(node->argument_types.back());
}
}
2023-03-28 12:05:20 +03:00
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(FunctionDefinition* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("name");
node->name = std::make_unique<DefinedName>();
2023-03-28 12:05:20 +03:00
Visit(node->name.get());
2023-03-29 11:42:00 +03:00
current_node_ = parse_node.ChildByFieldName("value");
Visit(node->value);
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(AliasTypeDefinition* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("type");
node->type = std::make_unique<DefinedType>();
Visit(node->type.get());
current_node_ = parse_node.ChildByFieldName("value");
node->value = std::make_unique<ParametrizedType>();
2023-03-28 12:05:20 +03:00
Visit(node->value.get());
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(TypeDefinition* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
std::string type_modifier = parse_node.NthChild(0).GetValue(); // TODO
if (type_modifier == "class") {
node->is_class = true;
} else if (type_modifier == "struct") {
node->is_class = false;
}
current_node_ = parse_node.ChildByFieldName("type");
node->type = std::make_unique<DefinedType>();
Visit(node->type.get());
current_node_ = parse_node.ChildByFieldName("value");
Visit(node->value);
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(TypeclassDefinition* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("typeclass");
node->typeclass = std::make_unique<DefinedTypeclass>();
Visit(node->typeclass.get());
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
2023-03-31 12:10:12 +03:00
node->requirements.resize(child_count - 1);
2023-03-29 11:42:00 +03:00
2023-03-29 23:19:54 +03:00
for (size_t i = 0; i < child_count - 1; ++i) {
current_node_ = parse_node.NthNamedChild(i + 1);
2023-03-31 12:10:12 +03:00
node->requirements[i] = std::make_unique<FunctionDeclaration>();
2023-03-29 11:42:00 +03:00
Visit(node->requirements[i].get());
}
2023-03-28 12:05:20 +03:00
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
}
//
void BuildVisitor::Visit(SourceStatement& node) {
auto parse_node = current_node_;
current_node_ = parse_node.NthNamedChild(0);
std::string current_node_type = current_node_.GetType();
if (current_node_type == parser::tokens::ImportStatement) { // optimize ??
node = std::make_unique<ImportStatement>();
Visit(std::get<std::unique_ptr<ImportStatement>>(node).get());
} else if (current_node_type == parser::tokens::UsageDefinition) {
node = std::make_unique<UsageDefinition>();
Visit(std::get<std::unique_ptr<UsageDefinition>>(node).get());
} else if (current_node_type == parser::tokens::AliasDefinition) {
node = std::make_unique<AliasDefinition>();
Visit(std::get<std::unique_ptr<AliasDefinition>>(node).get());
} else if (current_node_type == parser::tokens::VariableDefinition) {
node = std::make_unique<VariableDefinition>();
Visit(std::get<std::unique_ptr<VariableDefinition>>(node).get());
} else if (current_node_type == parser::tokens::FunctionDeclaration) {
node = std::make_unique<FunctionDeclaration>();
Visit(std::get<std::unique_ptr<FunctionDeclaration>>(node).get());
} else if (current_node_type == parser::tokens::FunctionDefinition) {
node = std::make_unique<FunctionDefinition>();
Visit(std::get<std::unique_ptr<FunctionDefinition>>(node).get());
} else if (current_node_type == parser::tokens::AliasTypeDefinition) {
node = std::make_unique<AliasTypeDefinition>();
Visit(std::get<std::unique_ptr<AliasTypeDefinition>>(node).get());
} else if (current_node_type == parser::tokens::TypeDefinition) {
node = std::make_unique<TypeDefinition>();
Visit(std::get<std::unique_ptr<TypeDefinition>>(node).get());
} else if (current_node_type == parser::tokens::TypeclassDefinition) {
node = std::make_unique<TypeclassDefinition>();
Visit(std::get<std::unique_ptr<TypeclassDefinition>>(node).get());
} else if (current_node_type == parser::tokens::Namespace) {
node = std::make_unique<Namespace>();
Visit(std::get<std::unique_ptr<Namespace>>(node).get());
} else {
// error
2023-03-28 12:05:20 +03:00
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
}
void BuildVisitor::Visit(ImportSymbol& node) {
auto parse_node = current_node_;
current_node_ = parse_node.NthNamedChild(0);
std::string current_node_type = current_node_.GetType();
if (current_node_type == parser::tokens::TypeclassExpression) { // optimize ??
node = std::make_unique<TypeclassExpression>();
Visit(std::get<std::unique_ptr<TypeclassExpression>>(node).get());
} else if (current_node_type == parser::tokens::TypeExpression) {
node = std::make_unique<TypeExpression>();
Visit(std::get<std::unique_ptr<TypeExpression>>(node).get());
} else if (current_node_type == parser::tokens::NameExpression) {
node = std::make_unique<NameExpression>();
Visit(std::get<std::unique_ptr<NameExpression>>(node).get());
} else {
// error
}
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
// Definition parts
void BuildVisitor::Visit(DefinedName* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
2023-03-29 23:19:54 +03:00
node->name = parse_node.ChildByFieldName("name").GetValue();
2023-03-29 11:42:00 +03:00
node->is_operator = (parse_node.NthChild(0).GetValue() == "("); // TODO
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
bool parameters_ended = false;
2023-03-29 23:19:54 +03:00
for (size_t i = 0; i < child_count - 1; ++i) {
current_node_ = parse_node.NthNamedChild(i + 1);
2023-03-29 11:42:00 +03:00
if (current_node_.GetType() != parser::tokens::DefinitionParameter) {
parameters_ended = true;
}
if (!parameters_ended) {
node->parameters.push_back(std::make_unique<DefinitionParameter>());
Visit(node->parameters.back().get());
} else {
node->arguments.push_back(std::make_unique<DefinitionArgument>());
Visit(node->arguments.back().get());
}
}
2023-03-28 12:05:20 +03:00
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(DefinedAnnotatedName* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
2023-03-29 23:19:54 +03:00
node->name = parse_node.ChildByFieldName("name").GetValue();
2023-03-29 11:42:00 +03:00
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
2023-04-02 15:10:32 +03:00
current_node_ = parse_node.NthNamedChild(1);
2023-03-29 11:42:00 +03:00
auto current_node_type = current_node_.GetType();
if (current_node_type == parser::tokens::DefinedType) {
node->type = std::make_unique<DefinedType>();
Visit(std::get<std::unique_ptr<DefinedType>>(node->type).get());
} else if (current_node_type == parser::tokens::DefinedTypeclass) {
node->type = std::make_unique<DefinedTypeclass>();
Visit(std::get<std::unique_ptr<DefinedTypeclass>>(node->type).get());
}
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
}
void BuildVisitor::Visit(DefinedType* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("type");
node->type = std::make_unique<AnnotatedType>();
2023-03-28 12:05:20 +03:00
Visit(node->type.get());
2023-03-29 11:42:00 +03:00
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
bool parameters_ended = false;
2023-03-29 23:19:54 +03:00
for (size_t i = 0; i < child_count - 1; ++i) {
current_node_ = parse_node.NthNamedChild(i + 1);
2023-03-29 11:42:00 +03:00
if (current_node_.GetType() != parser::tokens::DefinitionParameter) {
parameters_ended = true;
}
if (!parameters_ended) {
node->parameters.push_back(std::make_unique<DefinitionParameter>());
Visit(node->parameters.back().get());
} else {
node->arguments.push_back(std::make_unique<DefinitionArgument>());
Visit(node->arguments.back().get());
}
}
2023-03-28 12:05:20 +03:00
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(DefinedTypeclass* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("typeclass");
node->typeclass = std::make_unique<AnnotatedTypeclass>();
2023-03-28 12:05:20 +03:00
Visit(node->typeclass.get());
2023-03-29 11:42:00 +03:00
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
bool parameters_ended = false;
2023-03-29 23:19:54 +03:00
for (size_t i = 0; i < child_count - 1; ++i) {
current_node_ = parse_node.NthNamedChild(i + 1);
2023-03-29 11:42:00 +03:00
if (current_node_.GetType() != parser::tokens::DefinitionParameter) {
parameters_ended = true;
}
if (!parameters_ended) {
node->parameters.push_back(std::make_unique<DefinitionParameter>());
Visit(node->parameters.back().get());
} else {
node->arguments.push_back(std::make_unique<DefinitionArgument>());
Visit(node->arguments.back().get());
}
}
2023-03-28 12:05:20 +03:00
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(DefinitionParameter* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
2023-03-29 23:19:54 +03:00
node->type = parse_node.ChildByFieldName("type").GetValue();
2023-03-29 11:42:00 +03:00
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
2023-03-31 12:10:12 +03:00
node->typeclasses.resize(child_count - 1);
2023-03-29 11:42:00 +03:00
2023-03-29 23:19:54 +03:00
for (size_t i = 0; i < child_count - 1; ++i) {
current_node_ = parse_node.NthNamedChild(i + 1);
2023-03-31 12:10:12 +03:00
std::string current_node_type = current_node_.GetType();
node->typeclasses[i] = std::make_unique<ParametrizedTypeclass>();
if (current_node_type == parser::tokens::TypeclassExpression) { // optimize ??
node->typeclasses[i]->typeclass_expression = std::make_unique<TypeclassExpression>();
Visit(node->typeclasses[i]->typeclass_expression.get());
} else if (current_node_type == parser::tokens::ParametrizedTypeclass) {
Visit(node->typeclasses[i].get());
} else {
// error
}
2023-03-29 11:42:00 +03:00
}
2023-03-28 12:05:20 +03:00
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(DefinitionArgument* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
2023-03-29 23:19:54 +03:00
node->name = parse_node.ChildByFieldName("name").GetValue();
2023-03-29 11:42:00 +03:00
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
2023-03-31 12:10:12 +03:00
node->types.resize(child_count - 1);
2023-03-29 11:42:00 +03:00
2023-03-29 23:19:54 +03:00
for (size_t i = 0; i < child_count - 1; ++i) {
current_node_ = parse_node.NthNamedChild(i + 1);
2023-03-31 12:10:12 +03:00
std::string current_node_type = current_node_.GetType();
node->types[i] = std::make_unique<ParametrizedType>();
if (current_node_type == parser::tokens::TypeExpression) { // optimize ??
node->types[i]->type_expression = std::make_unique<TypeExpression>();
Visit(node->types[i]->type_expression.get());
} else if (current_node_type == parser::tokens::ParametrizedType) {
Visit(node->types[i].get());
} else {
// error
}
2023-03-29 11:42:00 +03:00
}
}
current_node_ = parse_node;
}
void BuildVisitor::Visit(FunctionDeclarationType& node) {
auto parse_node = current_node_;
current_node_ = parse_node.NthNamedChild(0);
std::string current_node_type = current_node_.GetType();
if (current_node_type == parser::tokens::ParametrizedType) { // optimize ??
node = std::make_unique<ParametrizedType>();
Visit(std::get<std::unique_ptr<ParametrizedType>>(node).get());
} else if (current_node_type == parser::tokens::TupleType) {
node = std::make_unique<TupleType>();
Visit(std::get<std::unique_ptr<TupleType>>(node).get());
} else if (current_node_type == parser::tokens::VariantType) {
node = std::make_unique<VariantType>();
Visit(std::get<std::unique_ptr<VariantType>>(node).get());
} else if (current_node_type == parser::tokens::ParametrizedTypeclass) {
node = std::make_unique<ParametrizedTypeclass>();
Visit(std::get<std::unique_ptr<ParametrizedTypeclass>>(node).get());
} else {
// error
2023-03-28 12:05:20 +03:00
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
// Flow control -----------------
2023-03-29 11:42:00 +03:00
void BuildVisitor::Visit(MatchCase* node) {
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("value");
Visit(node->value);
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
2023-04-02 15:10:32 +03:00
std::string prefix = parse_node.NthChild(2).GetValue(); // TODO
2023-03-29 11:42:00 +03:00
if (child_count > 2 || prefix == "?") {
current_node_ = parse_node.ChildByFieldName("condition");
node->condition.emplace();
Visit(node->condition.value());
2023-03-28 12:05:20 +03:00
}
2023-03-29 11:42:00 +03:00
if (child_count > 2 || prefix == "->") {
current_node_ = parse_node.ChildByFieldName("statement");
node->statement.emplace();
Visit(node->statement.value());
2023-03-28 12:05:20 +03:00
}
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
}
void BuildVisitor::Visit(Match* node) {
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("value");
Visit(node->value);
size_t child_count = parse_node.NamedChildCount();
// if (child_count > 1) { // always true (repeat1)
node->matches.resize(child_count - 1);
2023-03-29 23:19:54 +03:00
for (size_t i = 0; i < child_count - 1; ++i) {
current_node_ = parse_node.NthNamedChild(i + 1);
2023-03-29 11:42:00 +03:00
Visit(&node->matches[i]);
}
// }
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(Condition* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
size_t child_count = parse_node.NamedChildCount();
node->conditions.resize(child_count / 2);
node->statements.resize((child_count + 1) / 2);
for (size_t i = 0; i < child_count; ++i) {
current_node_ = parse_node.NthNamedChild(i);
if (i % 2 == 0 && i / 2 < node->conditions.size()) {
Visit(node->conditions[i / 2]);
} else {
Visit(node->statements[i / 2]);
}
2023-03-28 12:05:20 +03:00
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(DoWhileLoop* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("statement");
Visit(node->statement);
current_node_ = parse_node.ChildByFieldName("condition");
Visit(node->condition);
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(WhileLoop* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("condition");
Visit(node->condition);
current_node_ = parse_node.ChildByFieldName("statement");
Visit(node->statement);
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(ForLoop* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("variable");
Visit(node->variable);
current_node_ = parse_node.ChildByFieldName("interval");
Visit(node->interval);
current_node_ = parse_node.ChildByFieldName("statement");
Visit(node->statement);
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(LoopLoop* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("statement");
Visit(node->statement);
current_node_ = parse_node;
}
void BuildVisitor::Visit(FlowControl& node) {
auto parse_node = current_node_;
current_node_ = parse_node.NthNamedChild(0);
std::string current_node_type = current_node_.GetType();
if (current_node_type == parser::tokens::Match) { // optimize ??
node = std::make_unique<Match>();
Visit(std::get<std::unique_ptr<Match>>(node).get());
} else if (current_node_type == parser::tokens::Condition) {
node = std::make_unique<Condition>();
Visit(std::get<std::unique_ptr<Condition>>(node).get());
} else if (current_node_type == parser::tokens::DoWhileLoop) {
node = std::make_unique<DoWhileLoop>();
Visit(std::get<std::unique_ptr<DoWhileLoop>>(node).get());
} else if (current_node_type == parser::tokens::WhileLoop) {
node = std::make_unique<WhileLoop>();
Visit(std::get<std::unique_ptr<WhileLoop>>(node).get());
} else if (current_node_type == parser::tokens::ForLoop) {
node = std::make_unique<ForLoop>();
Visit(std::get<std::unique_ptr<ForLoop>>(node).get());
} else if (current_node_type == parser::tokens::LoopLoop) {
node = std::make_unique<LoopLoop>();
Visit(std::get<std::unique_ptr<LoopLoop>>(node).get());
} else {
// error
}
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
// Statements, expressions, blocks, etc. -----------------
void BuildVisitor::Visit(Block* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
size_t statement_count = parse_node.NamedChildCount();
node->statements.resize(statement_count);
for (size_t i = 0; i < statement_count; ++i) {
current_node_ = parse_node.NthNamedChild(i);
Visit(node->statements[i]);
2023-03-28 12:05:20 +03:00
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(ScopedStatement* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("statement");
Visit(node->statement);
current_node_ = parse_node;
}
void BuildVisitor::Visit(LoopControlExpression& node) {
std::string value = current_node_.NthChild(0).GetValue();
if (value == "break") {
node = LoopControlExpression::Break;
} else if (value == "continue") {
node = LoopControlExpression::Continue;
} else {
// error
}
}
//
void BuildVisitor::Visit(SubExpressionToken& node) {
auto parse_node = current_node_;
current_node_ = parse_node.NthNamedChild(0);
std::string current_node_type = current_node_.GetType();
2023-04-02 15:10:32 +03:00
if (current_node_type == parser::tokens::NameSuperExpression) { // optimize ??
node = std::make_unique<NameSuperExpression>();
Visit(std::get<std::unique_ptr<NameSuperExpression>>(node).get());
2023-03-29 11:42:00 +03:00
} else if (current_node_type == parser::tokens::ScopedStatement) {
node = std::make_unique<ScopedStatement>();
Visit(std::get<std::unique_ptr<ScopedStatement>>(node).get());
} else {
// error
}
current_node_ = parse_node;
}
void BuildVisitor::Visit(SubExpression& node) {
auto parse_node = current_node_;
current_node_ = parse_node.NthNamedChild(0);
std::string current_node_type = current_node_.GetType();
if (current_node_type == parser::tokens::FunctionCallExpression) { // optimize ??
node = std::make_unique<FunctionCallExpression>();
Visit(std::get<std::unique_ptr<FunctionCallExpression>>(node).get());
} else if (current_node_type == parser::tokens::BinaryOperatorExpression) {
node = std::make_unique<BinaryOperatorExpression>();
Visit(std::get<std::unique_ptr<BinaryOperatorExpression>>(node).get());
} else if (current_node_type == parser::tokens::SubExpressionToken) {
node = std::make_unique<SubExpressionToken>();
2023-04-02 15:10:32 +03:00
Visit(*std::get<std::unique_ptr<SubExpressionToken>>(node));
2023-03-29 11:42:00 +03:00
} else {
// error
}
current_node_ = parse_node;
}
void BuildVisitor::Visit(PrefixedExpression& node) {
auto parse_node = current_node_;
current_node_ = parse_node.NthNamedChild(0);
std::string current_node_type = current_node_.GetType();
if (current_node_type == parser::tokens::ReturnExpression) { // optimize ??
node = std::make_unique<ReturnExpression>();
Visit(std::get<std::unique_ptr<ReturnExpression>>(node).get());
} else if (current_node_type == parser::tokens::LoopControlExpression) {
node = std::make_unique<LoopControlExpression>();
2023-04-02 15:10:32 +03:00
Visit(*std::get<std::unique_ptr<LoopControlExpression>>(node));
2023-03-29 11:42:00 +03:00
} else if (current_node_type == parser::tokens::Block) {
node = std::make_unique<Block>();
Visit(std::get<std::unique_ptr<Block>>(node).get());
} else {
// error
}
current_node_ = parse_node;
}
void BuildVisitor::Visit(Expression& node) {
auto parse_node = current_node_;
current_node_ = parse_node.NthNamedChild(0);
std::string current_node_type = current_node_.GetType();
if (current_node_type == parser::tokens::LambdaFunction) { // optimize ??
node = std::make_unique<LambdaFunction>();
Visit(std::get<std::unique_ptr<LambdaFunction>>(node).get());
} else if (current_node_type == parser::tokens::TypeConstructor) {
node = std::make_unique<TypeConstructor>();
Visit(std::get<std::unique_ptr<TypeConstructor>>(node).get());
} else if (current_node_type == parser::tokens::PrefixedExpression) {
node = std::make_unique<PrefixedExpression>();
2023-04-02 15:10:32 +03:00
Visit(*std::get<std::unique_ptr<PrefixedExpression>>(node));
2023-03-29 11:42:00 +03:00
} else if (current_node_type == parser::tokens::UnaryOperatorExpression) {
node = std::make_unique<UnaryOperatorExpression>();
Visit(std::get<std::unique_ptr<UnaryOperatorExpression>>(node).get());
} else if (current_node_type == parser::tokens::SubExpression) {
node = std::make_unique<SubExpression>();
2023-04-02 15:10:32 +03:00
Visit(*std::get<std::unique_ptr<SubExpression>>(node));
2023-03-29 11:42:00 +03:00
} else {
// error
}
current_node_ = parse_node;
}
void BuildVisitor::Visit(SuperExpression& node) {
auto parse_node = current_node_;
current_node_ = parse_node.NthNamedChild(0);
std::string current_node_type = current_node_.GetType();
if (current_node_type == parser::tokens::FlowControl) { // optimize ??
node = std::make_unique<FlowControl>();
2023-04-02 15:10:32 +03:00
Visit(*std::get<std::unique_ptr<FlowControl>>(node));
2023-03-29 11:42:00 +03:00
} else if (current_node_type == parser::tokens::TupleExpression) {
node = std::make_unique<TupleExpression>();
Visit(std::get<std::unique_ptr<TupleExpression>>(node).get());
} else if (current_node_type == parser::tokens::VariantExpression) {
node = std::make_unique<VariantExpression>();
Visit(std::get<std::unique_ptr<VariantExpression>>(node).get());
} else if (current_node_type == parser::tokens::Expression) {
node = std::make_unique<Expression>();
2023-04-02 15:10:32 +03:00
Visit(*std::get<std::unique_ptr<Expression>>(node));
2023-03-29 11:42:00 +03:00
} else {
// error
}
current_node_ = parse_node;
}
void BuildVisitor::Visit(BlockStatement& node) {
auto parse_node = current_node_;
current_node_ = parse_node.NthNamedChild(0);
std::string current_node_type = current_node_.GetType();
if (current_node_type == parser::tokens::Expression) { // optimize ??
node = std::make_unique<Expression>();
2023-04-02 15:10:32 +03:00
Visit(*std::get<std::unique_ptr<Expression>>(node));
2023-03-29 11:42:00 +03:00
} else if (current_node_type == parser::tokens::AliasDefinition) {
node = std::make_unique<AliasDefinition>();
Visit(std::get<std::unique_ptr<AliasDefinition>>(node).get());
} else if (current_node_type == parser::tokens::VariableDefinition) {
node = std::make_unique<VariableDefinition>();
Visit(std::get<std::unique_ptr<VariableDefinition>>(node).get());
} else if (current_node_type == parser::tokens::FlowControl) {
node = std::make_unique<FlowControl>();
2023-04-02 15:10:32 +03:00
Visit(*std::get<std::unique_ptr<FlowControl>>(node));
2023-03-29 11:42:00 +03:00
} else if (current_node_type == parser::tokens::PrefixedExpression) {
node = std::make_unique<PrefixedExpression>();
2023-04-02 15:10:32 +03:00
Visit(*std::get<std::unique_ptr<PrefixedExpression>>(node));
2023-03-29 11:42:00 +03:00
} else {
// error
}
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
// Operators
void BuildVisitor::Visit(BinaryOperatorExpression* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("left_expression");
Visit(node->left_expression);
node->operator_name = parse_node.ChildByFieldName("operator_name").GetValue();
current_node_ = parse_node.ChildByFieldName("right_expression");
Visit(node->right_expression);
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(UnaryOperatorExpression* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
node->operator_name = parse_node.ChildByFieldName("operator_name").GetValue();
current_node_ = parse_node.ChildByFieldName("expression");
Visit(node->expression);
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
// Simple Expressions
void BuildVisitor::Visit(FunctionCallExpression* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("name");
node->name = std::make_unique<NameSuperExpression>();
2023-03-28 12:05:20 +03:00
Visit(node->name.get());
2023-03-29 11:42:00 +03:00
size_t child_count = parse_node.NamedChildCount();
// if (child_count > 1) { // always true (repeat1)
node->arguments.resize(child_count - 1);
2023-03-29 23:19:54 +03:00
for (size_t i = 0; i < child_count - 1; ++i) {
current_node_ = parse_node.NthNamedChild(i + 1);
2023-03-29 11:42:00 +03:00
Visit(node->arguments[i]);
2023-03-28 12:05:20 +03:00
}
2023-03-29 11:42:00 +03:00
// }
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(TupleExpression* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
size_t expressions_count = parse_node.NamedChildCount();
node->expressions.resize(expressions_count);
for (size_t i = 0; i < expressions_count; ++i) {
current_node_ = parse_node.NthNamedChild(i);
Visit(node->expressions[i]);
2023-03-28 12:05:20 +03:00
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(VariantExpression* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
size_t expressions_count = parse_node.NamedChildCount();
node->expressions.resize(expressions_count);
for (size_t i = 0; i < expressions_count; ++i) {
current_node_ = parse_node.NthNamedChild(i);
Visit(node->expressions[i]);
2023-03-28 12:05:20 +03:00
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(ReturnExpression* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("expression");
Visit(node->expression);
current_node_ = parse_node;
}
//
void BuildVisitor::Visit(FunctionArgument& node) {
auto parse_node = current_node_;
current_node_ = parse_node.NthNamedChild(0);
std::string current_node_type = current_node_.GetType();
if (current_node_type == parser::tokens::SubExpressionToken) { // optimize ??
node = std::make_unique<SubExpressionToken>();
2023-04-02 15:10:32 +03:00
Visit(*std::get<std::unique_ptr<SubExpressionToken>>(node));
2023-03-29 11:42:00 +03:00
} else if (current_node_type == parser::tokens::TypeSubExpression) {
node = std::make_unique<TypeSubExpression>();
2023-04-02 15:10:32 +03:00
Visit(*std::get<std::unique_ptr<TypeSubExpression>>(node));
2023-03-29 11:42:00 +03:00
} else {
// error
}
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
// Lambda
void BuildVisitor::Visit(LambdaFunction* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
bool parameters_ended = false;
for (size_t i = 0; i < child_count - 1; ++i) {
current_node_ = parse_node.NthNamedChild(i);
if (current_node_.GetType() != parser::tokens::DefinitionParameter) {
parameters_ended = true;
}
if (!parameters_ended) {
node->parameters.push_back(std::make_unique<DefinitionParameter>());
Visit(node->parameters.back().get());
} else {
node->arguments.push_back(std::make_unique<DefinitionArgument>());
Visit(node->arguments.back().get());
}
}
2023-03-28 12:05:20 +03:00
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node.ChildByFieldName("expression");
Visit(node->expression);
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
// Name
2023-03-29 23:19:54 +03:00
void BuildVisitor::Visit(NameSuperExpression* node) {
auto parse_node = current_node_;
size_t child_count = parse_node.NamedChildCount();
bool namespaces_ended = false;
for (size_t i = 0; i < child_count; ++i) {
current_node_ = parse_node.NthNamedChild(i);
std::string current_node_type = current_node_.GetType();
2023-04-02 15:10:32 +03:00
if (current_node_type != parser::tokens::TypeSubExpression && !namespaces_ended) {
2023-03-29 23:19:54 +03:00
namespaces_ended = true;
if (i + 1 == child_count) {
node->expressions.emplace_back();
if (current_node_type == parser::tokens::NameIdentifier) { // optimize ??
node->expressions.back() = std::make_unique<NameIdentifier>(current_node_.GetValue());
} else if (current_node_type == parser::tokens::Literal) {
node->expressions.back() = std::make_unique<Literal>();
2023-04-02 15:10:32 +03:00
Visit(*std::get<std::unique_ptr<Literal>>(node->expressions.back()));
2023-03-29 23:19:54 +03:00
} else {
// error
}
break;
2023-04-02 15:10:32 +03:00
} else {
// error
2023-03-29 23:19:54 +03:00
}
}
if (!namespaces_ended) {
node->namespaces.emplace_back();
Visit(node->namespaces.back());
} else {
node->expressions.emplace_back();
Visit(node->expressions.back());
}
}
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(NameExpression* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
bool types_ended = false;
for (size_t i = 0; i < child_count - 1; ++i) {
current_node_ = parse_node.NthNamedChild(i);
if (current_node_.GetType() != parser::tokens::TypeSubExpression) {
types_ended = true;
}
if (!types_ended) {
node->namespaces.emplace_back();
Visit(node->namespaces.back());
} else {
node->names.push_back(current_node_.GetValue());
}
2023-03-28 12:05:20 +03:00
}
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(TupleName* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
size_t names_count = parse_node.NamedChildCount();
2023-03-31 12:10:12 +03:00
node->names.resize(names_count);
2023-03-29 11:42:00 +03:00
for (size_t i = 0; i < names_count; ++i) {
current_node_ = parse_node.NthNamedChild(i);
2023-03-31 12:10:12 +03:00
node->names[i] = std::make_unique<AnnotatedName>();
2023-03-29 11:42:00 +03:00
Visit(node->names[i].get());
2023-03-28 12:05:20 +03:00
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(VariantName* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
size_t names_count = parse_node.NamedChildCount();
2023-03-31 12:10:12 +03:00
node->names.resize(names_count);
2023-03-29 11:42:00 +03:00
for (size_t i = 0; i < names_count; ++i) {
current_node_ = parse_node.NthNamedChild(i);
2023-03-31 12:10:12 +03:00
node->names[i] =std::make_unique<AnnotatedName>();
2023-03-29 11:42:00 +03:00
Visit(node->names[i].get());
2023-03-28 12:05:20 +03:00
}
2023-03-29 11:42:00 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(AnnotatedName* node) {
2023-03-29 11:42:00 +03:00
auto parse_node = current_node_;
node->name = parse_node.ChildByFieldName("name").GetValue();
2023-03-31 12:10:12 +03:00
if (parse_node.NamedChildCount() > 1) {
2023-03-29 11:42:00 +03:00
current_node_ = parse_node.ChildByFieldName("type");
node->type = std::make_unique<ParametrizedType>();
Visit(node->type.value().get());
current_node_ = parse_node;
}
}
void BuildVisitor::Visit(AnyName& node) {
auto parse_node = current_node_;
current_node_ = parse_node.NthNamedChild(0);
std::string current_node_type = current_node_.GetType();
if (current_node_type == parser::tokens::AnnotatedName) { // optimize ??
node = std::make_unique<AnnotatedName>();
Visit(std::get<std::unique_ptr<AnnotatedName>>(node).get());
} else if (current_node_type == parser::tokens::TupleName) {
node = std::make_unique<TupleName>();
Visit(std::get<std::unique_ptr<TupleName>>(node).get());
} else if (current_node_type == parser::tokens::VariantName) {
node = std::make_unique<VariantName>();
Visit(std::get<std::unique_ptr<VariantName>>(node).get());
} else {
// error
}
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
// Type
void BuildVisitor::Visit(TypeConstructor* node) {
2023-04-02 15:10:32 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("type");
node->type = std::make_unique<ParametrizedType>();
Visit(node->type.get());
size_t parameter_count = (parse_node.NamedChildCount() - 1) / 2;
node->parameters.resize(parameter_count);
for (size_t i = 0; i < parameter_count * 2; ++i) {
current_node_ = parse_node.NthNamedChild(i + 1);
if (i % 2 == 0) {
node->parameters[i / 2].first = current_node_.GetValue();
} else {
Visit(node->parameters[i / 2].second);
}
}
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(TupleType* node) {
2023-03-29 23:19:54 +03:00
auto parse_node = current_node_;
size_t current_node_n = 0;
current_node_ = parse_node.NthNamedChild(current_node_n);
if (current_node_.GetType() == parser::tokens::TypeIdentifierDefinition) {
node->type = current_node_.GetValue(); // TODO check
++current_node_n;
current_node_ = parse_node.NthNamedChild(current_node_n);
}
while (current_node_n < parse_node.NamedChildCount()) {
node->entities.emplace_back();
if (current_node_.GetType() == parser::tokens::NameIdentifier) {
node->entities.back().first = current_node_.GetValue();
++current_node_n;
current_node_ = parse_node.NthNamedChild(current_node_n);
2023-03-28 12:05:20 +03:00
}
2023-03-29 23:19:54 +03:00
Visit(node->entities.back().second);
++current_node_n;
current_node_ = parse_node.NthNamedChild(current_node_n);
2023-03-28 12:05:20 +03:00
}
2023-03-29 23:19:54 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(VariantType* node) {
2023-03-29 23:19:54 +03:00
auto parse_node = current_node_;
size_t current_node_n = 0;
current_node_ = parse_node.NthNamedChild(current_node_n);
if (current_node_.GetType() == parser::tokens::TypeIdentifierDefinition) {
node->type = current_node_.GetValue(); // TODO check
++current_node_n;
current_node_ = parse_node.NthNamedChild(current_node_n);
2023-03-28 12:05:20 +03:00
}
2023-03-29 23:19:54 +03:00
while (current_node_n < parse_node.NamedChildCount()) {
std::string current_node_type = current_node_.GetType();
node->constructors.emplace_back();
if (current_node_type == parser::tokens::TypeIdentifierDefinition) { // optimize ??
node->constructors.back() = current_node_.GetValue(); // TODO check
} else if (current_node_type == parser::tokens::TupleType) {
node->constructors.back() = std::make_unique<TupleType>();
Visit(std::get<std::unique_ptr<TupleType>>(node->constructors.back()).get());
} else {
// error
}
++current_node_n;
current_node_ = parse_node.NthNamedChild(current_node_n);
}
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(AnnotatedType* node) {
2023-03-29 23:19:54 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("type_expression");
node->type_expression = std::make_unique<TypeExpression>();
2023-03-28 12:05:20 +03:00
Visit(node->type_expression.get());
2023-03-29 23:19:54 +03:00
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
2023-03-31 12:10:12 +03:00
node->annotations.resize(child_count - 1);
2023-03-29 23:19:54 +03:00
for (size_t i = 0; i < child_count - 1; ++i) {
2023-03-31 12:10:12 +03:00
current_node_ = parse_node.NthNamedChild(i + 1);
std::string current_node_type = current_node_.GetType();
node->annotations[i] = std::make_unique<ParametrizedTypeclass>();
if (current_node_type == parser::tokens::TypeclassExpression) { // optimize ??
node->annotations[i]->typeclass_expression = std::make_unique<TypeclassExpression>();
Visit(node->annotations[i]->typeclass_expression.get());
} else if (current_node_type == parser::tokens::ParametrizedTypeclass) {
2023-03-29 23:19:54 +03:00
Visit(node->annotations[i].get());
2023-03-31 12:10:12 +03:00
} else {
// error
}
2023-03-29 23:19:54 +03:00
}
2023-03-28 12:05:20 +03:00
}
2023-03-29 23:19:54 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(ParametrizedType* node) {
2023-03-29 23:19:54 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("type_expression");
node->type_expression = std::make_unique<TypeExpression>();
2023-03-28 12:05:20 +03:00
Visit(node->type_expression.get());
2023-03-29 23:19:54 +03:00
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
node->parameters.resize(child_count - 1);
for (size_t i = 0; i < child_count - 1; ++i) {
current_node_ = parse_node.NthNamedChild(i + 1);
Visit(node->parameters[i]);
}
2023-03-28 12:05:20 +03:00
}
2023-03-29 23:19:54 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(TypeExpression* node) {
2023-03-29 23:19:54 +03:00
auto parse_node = current_node_;
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
node->namespaces.resize(child_count - 1);
for (size_t i = 0; i < child_count - 1; ++i) {
current_node_ = parse_node.NthNamedChild(i);
Visit(node->namespaces[i]);
}
}
node->type = parse_node.ChildByFieldName("type").GetValue();
current_node_ = parse_node;
}
2023-03-31 12:10:12 +03:00
void BuildVisitor::Visit(AnyType& node) { // Or ScopedAnyType
2023-03-29 23:19:54 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.NthNamedChild(0);
std::string current_node_type = current_node_.GetType();
if (current_node_type == parser::tokens::ParametrizedType) { // optimize ??
node = std::make_unique<ParametrizedType>();
Visit(std::get<std::unique_ptr<ParametrizedType>>(node).get());
} else if (current_node_type == parser::tokens::TupleType) {
node = std::make_unique<TupleType>();
Visit(std::get<std::unique_ptr<TupleType>>(node).get());
} else if (current_node_type == parser::tokens::VariantType) {
node = std::make_unique<VariantType>();
Visit(std::get<std::unique_ptr<VariantType>>(node).get());
} else {
// error
}
current_node_ = parse_node;
}
void BuildVisitor::Visit(TypeSubExpression& node) {
auto parse_node = current_node_;
current_node_ = parse_node.NthNamedChild(0);
std::string current_node_type = current_node_.GetType();
if (current_node_type == parser::tokens::TypeIdentifier) { // optimize ??
node = std::make_unique<TypeIdentifier>();
Visit(std::get<std::unique_ptr<TypeIdentifier>>(node).get());
} else if (current_node_type == parser::tokens::AbstractTypeIdentifier) {
node = std::make_unique<AbstractTypeIdentifier>();
Visit(std::get<std::unique_ptr<AbstractTypeIdentifier>>(node).get());
} else if (current_node_type == parser::tokens::ParametrizedType) {
node = std::make_unique<ParametrizedType>();
Visit(std::get<std::unique_ptr<ParametrizedType>>(node).get());
} else {
// error
}
current_node_ = parse_node;
}
void BuildVisitor::Visit(TypeParameter& node) {
auto parse_node = current_node_;
current_node_ = parse_node.NthNamedChild(0);
std::string current_node_type = current_node_.GetType();
2023-03-31 12:10:12 +03:00
if (current_node_type == parser::tokens::TypeExpression) { // optimize ??
node = std::make_unique<TypeExpression>();
Visit(std::get<std::unique_ptr<TypeExpression>>(node).get());
} else if (current_node_type == parser::tokens::ParametrizedType) {
2023-03-29 23:19:54 +03:00
node = std::make_unique<ParametrizedType>();
Visit(std::get<std::unique_ptr<ParametrizedType>>(node).get());
} else if (current_node_type == parser::tokens::Expression) {
node = std::make_unique<Expression>();
2023-04-02 15:10:32 +03:00
Visit(*std::get<std::unique_ptr<Expression>>(node));
2023-03-29 23:19:54 +03:00
} else {
// error
2023-03-28 12:05:20 +03:00
}
2023-03-29 23:19:54 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
// Typeclass
void BuildVisitor::Visit(AnnotatedTypeclass* node) {
2023-03-29 23:19:54 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("typeclass_expression");
node->typeclass_expression = std::make_unique<TypeclassExpression>();
2023-03-28 12:05:20 +03:00
Visit(node->typeclass_expression.get());
2023-03-29 23:19:54 +03:00
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
2023-03-31 12:10:12 +03:00
node->annotations.resize(child_count - 1);
2023-03-29 23:19:54 +03:00
for (size_t i = 0; i < child_count - 1; ++i) {
current_node_ = parse_node.NthNamedChild(i + 1);
2023-03-31 12:10:12 +03:00
std::string current_node_type = current_node_.GetType();
node->annotations[i] = std::make_unique<ParametrizedTypeclass>();
if (current_node_type == parser::tokens::TypeclassExpression) { // optimize ??
node->annotations[i]->typeclass_expression = std::make_unique<TypeclassExpression>();
Visit(node->annotations[i]->typeclass_expression.get());
} else if (current_node_type == parser::tokens::ParametrizedTypeclass) {
Visit(node->annotations[i].get());
} else {
// error
}
2023-03-29 23:19:54 +03:00
}
2023-03-28 12:05:20 +03:00
}
2023-03-29 23:19:54 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(ParametrizedTypeclass* node) {
2023-03-29 23:19:54 +03:00
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("typeclass_expression");
node->typeclass_expression = std::make_unique<TypeclassExpression>();
2023-03-28 12:05:20 +03:00
Visit(node->typeclass_expression.get());
2023-03-29 23:19:54 +03:00
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
node->parameters.resize(child_count - 1);
for (size_t i = 0; i < child_count - 1; ++i) {
current_node_ = parse_node.NthNamedChild(i + 1);
Visit(node->parameters[i]);
}
2023-03-28 12:05:20 +03:00
}
2023-03-29 23:19:54 +03:00
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(TypeclassExpression* node) {
2023-03-29 23:19:54 +03:00
auto parse_node = current_node_;
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
node->namespaces.resize(child_count - 1);
for (size_t i = 0; i < child_count - 1; ++i) {
current_node_ = parse_node.NthNamedChild(i);
Visit(node->namespaces[i]);
}
2023-03-28 12:05:20 +03:00
}
2023-03-29 23:19:54 +03:00
node->typeclass = parse_node.ChildByFieldName("typeclass").GetValue();
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
// Identifiers, constants, etc. -----------------
2023-03-29 23:19:54 +03:00
void BuildVisitor::Visit(AnyIdentifier* node) { // std::string
*node = current_node_.GetValue();
} // TODO use in other places ??
2023-03-28 12:05:20 +03:00
void BuildVisitor::Visit(FloatNumberLiteral* node) {
2023-04-02 15:10:32 +03:00
node->value = std::stod(current_node_.GetValue());
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(NumberLiteral* node) {
2023-04-02 15:10:32 +03:00
node->value = std::stoll(current_node_.GetValue());
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(StringLiteral* node) {
2023-03-29 11:42:00 +03:00
node->value = current_node_.NthChild(1).GetValue();
2023-03-28 12:05:20 +03:00
}
void BuildVisitor::Visit(CharLiteral* node) {
2023-03-29 23:19:54 +03:00
node->value = current_node_.NthChild(1).GetValue()[0];
2023-03-29 11:42:00 +03:00
}
void BuildVisitor::Visit(Literal& node) {
auto parse_node = current_node_;
current_node_ = parse_node.NthNamedChild(0);
std::string current_node_type = current_node_.GetType();
if (current_node_type == parser::tokens::FloatNumberLiteral) { // optimize ??
node = std::make_unique<FloatNumberLiteral>();
Visit(std::get<std::unique_ptr<FloatNumberLiteral>>(node).get());
} else if (current_node_type == parser::tokens::NumberLiteral) {
node = std::make_unique<NumberLiteral>();
Visit(std::get<std::unique_ptr<NumberLiteral>>(node).get());
} else if (current_node_type == parser::tokens::StringLiteral) {
node = std::make_unique<StringLiteral>();
Visit(std::get<std::unique_ptr<StringLiteral>>(node).get());
} else if (current_node_type == parser::tokens::CharLiteral) {
node = std::make_unique<CharLiteral>();
Visit(std::get<std::unique_ptr<CharLiteral>>(node).get());
} else {
// error
}
current_node_ = parse_node;
}
void BuildVisitor::Visit(NameSubSuperExpression& node) {
auto parse_node = current_node_;
current_node_ = parse_node.NthNamedChild(0);
std::string current_node_type = current_node_.GetType();
if (current_node_type == parser::tokens::NameIdentifier) { // optimize ??
2023-04-02 15:10:32 +03:00
// TODO: choose node = std::make_unique<NameIdentifier>(current_node_.GetValue());
2023-03-29 11:42:00 +03:00
Visit(std::get<std::unique_ptr<NameIdentifier>>(node).get());
} else if (current_node_type == parser::tokens::Literal) {
node = std::make_unique<Literal>();
2023-04-02 15:10:32 +03:00
Visit(*std::get<std::unique_ptr<Literal>>(node));
2023-03-29 11:42:00 +03:00
} else if (current_node_type == parser::tokens::SuperExpression) {
node = std::make_unique<SuperExpression>();
2023-04-02 15:10:32 +03:00
Visit(*std::get<std::unique_ptr<SuperExpression>>(node));
2023-03-29 11:42:00 +03:00
} else {
// error
}
current_node_ = parse_node;
2023-03-28 12:05:20 +03:00
}
} // namespace interpreter