first iteration of find_symbols_visitor

This commit is contained in:
ProgramSnail 2023-04-12 13:31:39 +03:00
parent 87bd815bbb
commit 399631b9ca
13 changed files with 92065 additions and 92399 deletions

View file

@ -200,7 +200,7 @@ void BuildVisitor::Visit(FunctionDeclaration* node) {
for (size_t i = 0; i + 2 < child_count; ++i) {
current_node_ = parse_node.NthNamedChild(i + 1);
node->parameters.push_back(std::make_unique<DefinitionParameter>());
node->parameters.push_back(std::make_unique<AnnotatedAbstractType>());
Visit(node->parameters.back().get());
}
@ -346,12 +346,12 @@ void BuildVisitor::Visit(FunctionDefinition* node) {
for (size_t i = 0; i + 1 < child_count; ++i) {
current_node_ = parse_node.NthNamedChild(i + 1);
if (current_node_.GetType() != parser::tokens::DefinitionParameter) {
if (current_node_.GetType() != parser::tokens::AnnotatedAbstractType) {
parameters_ended = true;
}
if (!parameters_ended) {
node->parameters.push_back(std::make_unique<DefinitionParameter>());
node->parameters.push_back(std::make_unique<AnnotatedAbstractType>());
Visit(node->parameters.back().get());
} else {
node->arguments.emplace_back();
@ -375,7 +375,7 @@ void BuildVisitor::Visit(TypeDefinition* node) {
if (child_count > 1) {
for (size_t i = 0; i + 1 < child_count; ++i) {
current_node_ = parse_node.NthNamedChild(i + 1);
node->parameters.push_back(std::make_unique<DefinitionParameter>());
node->parameters.push_back(std::make_unique<AnnotatedAbstractType>());
Visit(node->parameters.back().get());
}
}
@ -383,7 +383,7 @@ void BuildVisitor::Visit(TypeDefinition* node) {
current_node_ = parse_node;
}
void BuildVisitor::Visit(DefinitionParameter* node) {
void BuildVisitor::Visit(AnyAnnotatedType* node) {
auto parse_node = current_node_;
node->type = parse_node.ChildByFieldName("type").GetValue();
@ -904,12 +904,12 @@ void BuildVisitor::Visit(LambdaFunction* node) {
for (size_t i = 0; i + 1 < child_count; ++i) {
current_node_ = parse_node.NthNamedChild(i);
if (current_node_.GetType() != parser::tokens::DefinitionParameter) {
if (current_node_.GetType() != parser::tokens::AnnotatedAbstractType) {
parameters_ended = true;
}
if (!parameters_ended) {
node->parameters.push_back(std::make_unique<DefinitionParameter>());
node->parameters.push_back(std::make_unique<AnnotatedAbstractType>());
Visit(node->parameters.back().get());
} else {
node->arguments.emplace_back();
@ -1155,27 +1155,6 @@ void BuildVisitor::Visit(VariantType* node) {
current_node_ = parse_node;
}
void BuildVisitor::Visit(AnnotatedType* node) {
auto parse_node = current_node_;
current_node_ = parse_node.ChildByFieldName("type_expression");
node->type_expression = std::make_unique<TypeExpression>();
Visit(node->type_expression.get());
size_t child_count = parse_node.NamedChildCount();
if (child_count > 1) {
node->annotations.resize(child_count - 1);
for (size_t i = 0; i + 1 < child_count; ++i) {
current_node_ = parse_node.NthNamedChild(i + 1);
Visit(node->annotations[i]);
}
}
current_node_ = parse_node;
}
void BuildVisitor::Visit(ParametrizedType* node) {
auto parse_node = current_node_;

View file

@ -30,19 +30,24 @@ void FindSymbolsVisitor::Visit(Partition* node) {
}
void FindSymbolsVisitor::Visit(Namespace* node) {
if (std::holds_alternative<std::unique_ptr<DefinedAnnotatedName>>(node->name)) {
Visit(std::get<std::unique_ptr<DefinedAnnotatedName>>(node->name).get());
auto info = std::move(std::any_cast<std::pair<std::string, std::string>>(current_info_));
global_info_.AddEnterNamespace(info.first, info.second);
current_info_.reset();
} else if (std::holds_alternative<std::unique_ptr<DefinedType>>(node->name)) {
Visit(std::get<std::unique_ptr<DefinedType>>(node->name).get());
auto info = std::move(std::any_cast<std::string>(current_info_));
global_info_.AddEnterNamespace(std::nullopt, info);
current_info_.reset();
} else {
// error
std::optional<info::NamespaceInfo::Modifier> modifier;
if (node->modifier.has_value()) {
switch (node->modifier.value()) {
case interpreter::Namespace::Var:
modifier = info::NamespaceInfo::Var;
break;
case interpreter::Namespace::Const:
modifier = info::NamespaceInfo::Const;
break;
}
}
std::optional<std::string> name;
if (node->name.has_value()) {
name = node->name.value().name;
}
global_info_.AddEnterNamespace(node->type, modifier, name);
Visit(node->scope.get());
global_info_.ExitNamespace();
}
@ -50,408 +55,197 @@ void FindSymbolsVisitor::Visit(Namespace* node) {
// Definitions -----------------
void FindSymbolsVisitor::Visit(ImportStatement* node) {
is_in_statement = true;
info::ImportInfo info;
info.module_name = node->module_name;
for (auto& symbol : node->symbols) {
Visitor::Visit(symbol);
info.symbols.push_back(std::move(std::any_cast<std::string>(current_info_))); // TODO: expressions
}
global_info_.AddImport(std::move(info));
// TODO: what if inside usage definition, global_info_.AddImport(std::move(info));
}
info.symbols = node->symbols;
global_info_.AddImport(std::move(info), node->name);
void FindSymbolsVisitor::Visit(UsageDefinition* node) {
global_info_.AddUsageForNextImport(node->name);
Visit(node->import_statement.get());
is_in_statement = false;
}
// <-- current position
void FindSymbolsVisitor::Visit(AliasDefinition* node) {
void FindSymbolsVisitor::Visit(AliasDefinitionStatement* node) {
is_in_statement = true;
info::TypeInfo info;
Visit(node->type.get());
auto type_info = std::move(
std::any_cast<std::pair<std::string, std::vector<std::string>>>(current_info_));
current_info_.reset();
Visit(node->value.get());
auto value_info = std::move(std::any_cast<info::TypeUsageInfo>(current_info_));
current_info_.reset();
info::AliasTypeInfo alias_info;
alias_info.isAnotherType = false;
alias_info.params = std::move(type_info.second);
alias_info.value = std::move(value_info);
switch (node->modifier) {
case interpreter::AliasDefinitionStatement::Alias:
alias_info.modifier = info::AliasTypeInfo::Alias;
break;
case interpreter::AliasDefinitionStatement::Type:
alias_info.modifier = info::AliasTypeInfo::Type;
break;
case interpreter::AliasDefinitionStatement::Let:
alias_info.modifier = info::AliasTypeInfo::Let;
break;
}
alias_info.parameters = node->parameters;
alias_info.value.node = node->value.get();
info.type = std::move(alias_info);
global_info_.AddType(type_info.first, info);
}
global_info_.AddType(node->type, std::move(info));
// void FindSymbolsVisitor::Visit(VariableDefinition* node) { // TODO: decide
// out_ << "(Variable " << (node->is_const ? "const" : "var") << ' ';
// Visit(&node->name);
// out_ << " = ";
// Visitor::Visit(node->value);
// out_ << ")\n";
// }
is_in_statement = false;
}
void FindSymbolsVisitor::Visit(FunctionDeclaration* node) {
bool was_in_statement = is_in_statement;
is_in_statement = true;
info::FunctionDeclarationInfo info;
for (auto& parameter : node->parameters) {
Visit(parameter.get());
auto param_info = std::move(std::any_cast<info::ParameterInfo>(current_info_));
info.parameters.resize(node->parameters.size());
for (size_t i = 0; i < node->parameters.size(); ++i) {
Visit(node->parameters[i].get());
info.parameters[i] = std::move(std::any_cast<info::ParameterInfo>(current_info_));
current_info_.reset();
info.params.push_back(std::move(param_info));
}
for (auto& argument_type : node->argument_types) {
Visitor::Visit(argument_type);
auto type_info = std::move(std::any_cast<info::TypeUsageInfo>(current_info_));
current_info_.reset();
info.arg_types.push_back(std::move(type_info));
info.argument_types.resize(node->type->types.size());
for (size_t i = 0; i < node->type->types.size(); ++i) {
info.argument_type_nodes[i] = &node->type->types[i];
}
if (was_in_statement) {
current_info_ = std::move(info);
} else {
global_info_.AddFunctionDeclaration(node->name, std::move(info));
is_in_statement = false;
}
global_info_.AddFunctionDeclaration(node->name, std::move(info));
}
void FindSymbolsVisitor::Visit(FunctionDefinition* node) {
void FindSymbolsVisitor::Visit(FunctionDefinitionStatement* node) {
is_in_statement = true;
info::FunctionDefinitionInfo info;
Visit(node->name.get());
auto name_info = std::move(
std::any_cast<info::SymbolDefinitionInfo>(current_info_));
current_info_.reset();
auto definition = node->definition.get();
info.parameters.resize(definition->parameters.size());
for (size_t i = 0; i < definition->parameters.size(); ++i) {
Visit(definition->parameters[i].get());
info.parameters[i] = std::move(std::any_cast<info::ParameterInfo>(current_info_));
current_info_.reset();
}
info.argument_names.resize(definition->arguments.size());
for (size_t i = 0; i < definition->arguments.size(); ++i) {
info.argument_names[i] = definition->arguments[i].name;
}
info.params = std::move(name_info.params);
info.arg_names = std::move(name_info.arg_names);
info.expression = &node->value;
global_info_.AddFunctionDefinition(name_info.name, std::move(info));
global_info_.AddFunctionDefinition(definition->name, std::move(info));
is_in_statement = false;
}
void FindSymbolsVisitor::Visit(AliasTypeDefinition* node) { // TODO: unite with AliasDefinition
void FindSymbolsVisitor::Visit(TypeDefinitionStatement* node) {
is_in_statement = true;
info::TypeInfo info;
Visit(node->type.get());
auto type_info = std::move(
std::any_cast<std::pair<std::string, std::vector<std::string>>>(current_info_));
current_info_.reset();
Visit(node->value.get());
auto value_info = std::move(std::any_cast<info::TypeUsageInfo>(current_info_));
current_info_.reset();
info::AliasTypeInfo alias_info;
alias_info.isAnotherType = true;
alias_info.params = std::move(type_info.second);
alias_info.value = std::move(value_info);
info.type = std::move(alias_info);
global_info_.AddType(type_info.first, std::move(info));
}
void FindSymbolsVisitor::Visit(TypeDefinition* node) {
info::TypeInfo info;
Visit(node->type.get());
auto type_info = std::move(
std::any_cast<info::SymbolDefinitionInfo>(current_info_));
current_info_.reset();
Visitor::Visit(node->value);
auto value_info = std::move(std::any_cast<info::AnyTypeVariant>(current_info_));
current_info_.reset();
auto definition = node->definition.get();
info::AnyTypeInfo any_type_info;
any_type_info.params = std::move(type_info.params);
any_type_info.arg_names = std::move(type_info.arg_names);
switch (value_info.index()) {
case 0:
any_type_info.info =
std::make_unique<info::VariantTypeInfo>(
std::move(std::get<info::VariantTypeInfo>(value_info)));
break;
case 1:
any_type_info.info =
std::make_unique<info::TupleTypeInfo>(
std::move(std::get<info::TupleTypeInfo>(value_info)));
break;
case 2:
any_type_info.info =
std::make_unique<info::BuiltInTypeInfo>(
std::move(std::get<info::BuiltInTypeInfo>(value_info)));
break;
default:
// error
break;
Visit(definition->type.get());
any_type_info.type = std::move(std::any_cast<info::ParameterInfo>(current_info_));
current_info_.reset();
any_type_info.parameters.resize(definition->parameters.size());
for (size_t i = 0; i < definition->parameters.size(); ++i) {
Visit(definition->parameters[i].get());
any_type_info.parameters[i] = std::move(std::any_cast<info::ParameterInfo>(current_info_));
current_info_.reset();
}
any_type_info.value = &node->value;
std::string type = any_type_info.type.type;
info.type = std::move(any_type_info);
global_info_.AddType(type_info.name, std::move(info));
global_info_.AddType(type, std::move(info));
is_in_statement = false;
}
void FindSymbolsVisitor::Visit(TypeclassDefinition* node) {
info::TypeclassInfo info;
void FindSymbolsVisitor::Visit(AbstractTypeDefinitionStatement* node) {
is_in_statement = true;
Visit(node->typeclass.get());
auto typeclass_info = std::move(
std::any_cast<info::SymbolDefinitionInfo>(current_info_));
info::TypeInfo info;
info::AbstractTypeInfo abstract_type_info;
Visit(node->type.get());
abstract_type_info.type = std::move(std::any_cast<info::ParameterInfo>(current_info_));
current_info_.reset();
info.params = std::move(typeclass_info.params);
info.arg_names = std::move(typeclass_info.arg_names);
for (auto& requirement : node->requirements) {
Visit(requirement.get());
auto requrement_info = std::move(std::any_cast<info::FunctionDeclarationInfo>(current_info_));
current_info_.reset();
info.requirements.push_back(std::move(requrement_info));
switch (node->modifier) {
case interpreter::AbstractTypeDefinitionStatement::Basic:
abstract_type_info.modifier = info::AbstractTypeInfo::Basic;
break;
case interpreter::AbstractTypeDefinitionStatement::Abstract:
abstract_type_info.modifier = info::AbstractTypeInfo::Abstract;
break;
}
global_info_.AddTypeclass(typeclass_info.name, std::move(info));
std::string type = abstract_type_info.type.type;
info.type = std::move(abstract_type_info);
global_info_.AddType(type, std::move(info));
is_in_statement = false;
}
void FindSymbolsVisitor::Visit(TypeclassDefinitionStatement* node) {
is_in_statement = true;
info::TypeclassInfo info;
auto definition = node->definition.get();
info.parameters.resize(definition->parameters.size());
for (size_t i = 0; i < definition->parameters.size(); ++i) {
Visit(definition->parameters[i].get());
info.parameters[i] = std::move(std::any_cast<info::ParameterInfo>(current_info_));
current_info_.reset();
}
info.requirements.reserve(node->requirements.size());
for (size_t i = 0; i < node->requirements.size(); ++i) {
Visit(node->requirements[i].get());
info.requirements[i] = std::move(std::any_cast<info::FunctionDeclarationInfo>(current_info_));
current_info_.reset();
}
global_info_.AddTypeclass(definition->type.get()->type, std::move(info));
is_in_statement = false;
}
// Definition parts
void FindSymbolsVisitor::Visit(DefinedName* node) {
info::SymbolDefinitionInfo info;
info.name = node->name;
for (auto& parameter : node->parameters) {
Visit(parameter.get());
auto param_info = std::move(std::any_cast<info::ParameterInfo>(current_info_));
current_info_.reset();
info.params.push_back(std::move(param_info));
}
for (auto& argument : node->arguments) {
Visit(argument.get());
auto argument_info = std::move(std::any_cast<std::string>(current_info_));
current_info_.reset();
info.arg_names.push_back(std::move(argument_info));
}
current_info_ = std::move(info);
}
void FindSymbolsVisitor::Visit(DefinedAnnotatedName* node) { // TODO: remove
// Visit(&node->name);
if (std::holds_alternative<std::unique_ptr<DefinedType>>(node->type)) {
Visit(std::get<std::unique_ptr<DefinedType>>(node->type).get());
} else if (std::holds_alternative<std::unique_ptr<DefinedTypeclass>>(node->type)) {
Visit(std::get<std::unique_ptr<DefinedTypeclass>>(node->type).get());
} else {
// no annotation
}
}
void FindSymbolsVisitor::Visit(DefinedType* node) {
info::SymbolDefinitionInfo info;
Visit(node->type.get());
info.name = /*...*/; // TODO
for (auto& parameter : node->parameters) {
Visit(parameter.get());
auto param_info = std::move(std::any_cast<info::ParameterInfo>(current_info_));
current_info_.reset();
info.params.push_back(std::move(param_info));
}
for (auto& argument : node->arguments) {
Visit(argument.get());
auto argument_info = std::move(std::any_cast<std::string>(current_info_));
current_info_.reset();
info.arg_names.push_back(std::move(argument_info));
}
current_info_ = std::move(info);
}
void FindSymbolsVisitor::Visit(DefinedTypeclass* node) {
info::SymbolDefinitionInfo info;
Visit(node->typeclass.get());
info.name = /*...*/; // TODO
for (auto& parameter : node->parameters) {
Visit(parameter.get());
auto param_info = std::move(std::any_cast<info::ParameterInfo>(current_info_));
current_info_.reset();
info.params.push_back(std::move(param_info));
}
for (auto& argument : node->arguments) {
Visit(argument.get());
auto argument_info = std::move(std::any_cast<std::string>(current_info_));
current_info_.reset();
info.arg_names.push_back(std::move(argument_info));
}
current_info_ = std::move(info);
}
void FindSymbolsVisitor::Visit(DefinitionParameter* node) {
void FindSymbolsVisitor::Visit(AnyAnnotatedType* node) {
info::ParameterInfo info;
info.name = node->type;
for (auto& typeclass : node->typeclasses) {
Visit(typeclass.get());
auto typeclass_info = std::move(std::any_cast</*...*/>(current_info_));
current_info_.reset();
info.param_names.push_back(std::move(typeclass_info));
info.type = node->type;
info.typeclass_nodes.resize(node->typeclasses.size());
for (size_t i = 0; i < node->typeclasses.size(); ++i) {
info.typeclass_nodes[i] = &node->typeclasses[i];
}
current_info_ = std::move(info);
}
void FindSymbolsVisitor::Visit(DefinitionArgument* node) {
std::string info; // TODO: add type
info = node->name;
// for (auto& type : node->types) {
// Visit(type.get());
// auto argument_info = std::move(std::any_cast<std::string>(current_info_));
// current_info_.reset();
// info.types.push_back(std::move(argument_info));
// }
current_info_ = std::move(info);
}
// Statements, expressions, blocks, etc. -----------------
// Name
// void FindSymbolsVisitor::Visit(NameSuperExpression* node) {
// for (auto& variable_namespace : node->namespaces) {
// Visitor::Visit(variable_namespace);
// }
// for (size_t i = 0; i < node->expressions.size(); ++i) {
// Visitor::Visit(node->expressions[i]);
// if (i + 1 < node->expressions.size()) {
// }
// }
// }
//
// void FindSymbolsVisitor::Visit(NameExpression* node) {
// for (auto& variable_namespace : node->namespaces) {
// Visitor::Visit(variable_namespace);
// }
// for (size_t i = 0; i < node->names.size(); ++i) {
// Visit(&node->names[i]);
// if (i + 1 < node->names.size()) {
// }
// }
// }
//
// void FindSymbolsVisitor::Visit(TupleName* node) {
// for (auto& name : node->names) {
// Visit(name.get());
// }
// }
//
// void FindSymbolsVisitor::Visit(VariantName* node) {
// for (auto& name : node->names) {
// Visit(name.get());
// }
// }
//
// void FindSymbolsVisitor::Visit(AnnotatedName* node) {
// Visit(&node->name);
// if (node->type.has_value()) {
// Visit(node->type.value().get());
// }
// }
// Type
void FindSymbolsVisitor::Visit(TupleType* node) {
info::TupleTypeInfo info;
if (node->type.has_value()) {
info.name = node->type.value();
}
for (auto& entity : node->entities) {
info.fields.emplace_back();
if (entity.first.has_value()) {
info.fields.back().first = entity.first.value();
}
Visitor::Visit(entity.second);
auto entity_type_info = std::move(std::any_cast<info::AnyTypeInfo>(current_info_));
current_info_.reset();
info.fields.back().second = std::move(entity_type_info);
}
current_info_ = info::AnyTypeVariant(std::move(info));
}
void FindSymbolsVisitor::Visit(VariantType* node) {
info::VariantTypeInfo info;
if (node->type.has_value()) {
info.name = node->type.value();ParametrizedType
}
for (auto& constructor : node->constructors) {
if (std::holds_alternative<TypeIdentifierDefinition>(constructor)) {
info.constructors.push_back(std::get<TypeIdentifierDefinition>(constructor));
} else if (std::holds_alternative<std::unique_ptr<TupleType>>(constructor)) {
Visit(std::get<std::unique_ptr<TupleType>>(constructor).get());
auto constructor_tuple_info = std::move(std::any_cast<info::TupleTypeInfo>(current_info_));
current_info_.reset();
info.constructors.push_back(std::move(constructor_tuple_info));
} else {
// error
}
}
current_info_ = info::AnyTypeVariant(std::move(info));
}
void FindSymbolsVisitor::Visit(AnnotatedType* node) {
Visit(node->type_expression.get());
if (!node->annotations.empty()) {
}
for (auto& annotation : node->annotations) {
Visit(annotation.get());
}
}
void FindSymbolsVisitor::Visit(ParametrizedType* node) {
Visit(node->type_expression.get());
for (auto& parameter : node->parameters) {
Visitor::Visit(parameter);
}
}
void FindSymbolsVisitor::Visit(TypeExpression* node) {
for (auto& type_namespace : node->namespaces) {
Visitor::Visit(type_namespace);
}
Visit(&node->type);
}
// Typeclass
void FindSymbolsVisitor::Visit(AnnotatedTypeclass* node) {
Visit(node->typeclass_expression.get());
if (!node->annotations.empty()) {
}
for (auto& annotation : node->annotations) {
Visit(annotation.get());
}
}
void FindSymbolsVisitor::Visit(ParametrizedTypeclass* node) {
Visit(node->typeclass_expression.get());
for (auto& paramater : node->parameters) {
Visitor::Visit(paramater);
}
}
void FindSymbolsVisitor::Visit(TypeclassExpression* node) {
for (auto& typeclass_namespace : node->namespaces) {
Visitor::Visit(typeclass_namespace);
}
Visit(&node->typeclass);
}
} // namespace interpreter

183607
src/parser.c

File diff suppressed because it is too large Load diff

View file

@ -247,8 +247,8 @@ void PrintVisitor::Visit(TypeDefinition* node) {
out_ << ' ';
}
void PrintVisitor::Visit(DefinitionParameter* node) {
out_ << "[DefinitionParameter ";
void PrintVisitor::Visit(AnyAnnotatedType* node) {
out_ << "[Annotated (Abstract) Type ";
Visit(&node->type);
out_ << ']';
if (!node->typeclasses.empty() > 0) {
@ -590,19 +590,6 @@ void PrintVisitor::Visit(VariantType* node) {
out_ << ')';
}
void PrintVisitor::Visit(AnnotatedType* node) {
out_ << "[AnnotatedType ";
Visit(node->type_expression.get());
out_ << ']';
if (!node->annotations.empty()) {
out_ << " : (";
for (auto& annotation : node->annotations) {
Visitor::Visit(annotation);
}
out_ << ')';
}
}
void PrintVisitor::Visit(ParametrizedType* node) {
out_ << "[ParametrizedType] (";
Visit(node->type_expression.get());