2023-05-07 19:52:35 +03:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#include <ostream>
|
|
|
|
|
|
|
|
|
|
// for clangd
|
|
|
|
|
#include "contexts.hpp"
|
|
|
|
|
#include "global_info.hpp"
|
2023-05-08 20:34:36 +03:00
|
|
|
#include "interpreter_tree.hpp"
|
2023-05-09 15:37:30 +03:00
|
|
|
#include "types.hpp"
|
2023-05-09 14:55:04 +03:00
|
|
|
#include "utils.hpp"
|
|
|
|
|
#include "values.hpp"
|
2023-05-07 19:52:35 +03:00
|
|
|
#include "visitor.hpp"
|
2023-05-08 20:34:36 +03:00
|
|
|
#include "error_handling.hpp"
|
2023-05-07 19:52:35 +03:00
|
|
|
|
|
|
|
|
namespace interpreter {
|
|
|
|
|
|
|
|
|
|
class ExecuteVisitor : public Visitor {
|
|
|
|
|
public:
|
|
|
|
|
explicit ExecuteVisitor(info::GlobalInfo& global_info,
|
2023-05-09 15:37:30 +03:00
|
|
|
info::ContextManager<info::type::Type, info::type::TypeManager>& type_context_manager,
|
2023-05-19 10:27:14 +03:00
|
|
|
info::ContextManager<info::value::Value, info::value::ValueManager>& context_manager)
|
|
|
|
|
: global_info_(global_info),
|
2023-05-18 20:56:03 +03:00
|
|
|
typeclass_graph_(*global_info.GetTypeclassGraph()),
|
2023-05-09 15:37:30 +03:00
|
|
|
type_context_manager_(type_context_manager),
|
2023-05-07 19:52:35 +03:00
|
|
|
context_manager_(context_manager) {}
|
|
|
|
|
|
2023-05-20 00:01:54 +03:00
|
|
|
void VisitSourceFile(SourceFile* node) override {
|
|
|
|
|
error_handling::HandleInternalError("VisitSourceFile unavailible",
|
|
|
|
|
"ExecuteVisitor.VisitSourceFile",
|
|
|
|
|
&node->base);
|
2023-05-08 20:34:36 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
void ExecutePartition(interpreter::tokens::PartitionStatement* partition) {
|
2023-05-23 00:51:51 +03:00
|
|
|
for (size_t i = 0; i < info::type::InternalTypesCount; ++i) {
|
|
|
|
|
info::type::InternalType type = static_cast<info::type::InternalType>(i);
|
|
|
|
|
std::string type_name = info::type::ToString(type);
|
|
|
|
|
context_manager_.DefineLocalType(type_name, global_info_.FindAbstractType(type_name).value()->node->type->graph_id_);
|
|
|
|
|
}
|
2023-05-08 20:34:36 +03:00
|
|
|
Visit(partition);
|
|
|
|
|
}
|
|
|
|
|
|
2023-05-07 19:52:35 +03:00
|
|
|
private:
|
|
|
|
|
// Sources -----------------
|
|
|
|
|
|
|
|
|
|
void Visit(SourceFile* node) override;
|
|
|
|
|
|
|
|
|
|
// Namespaces, partitions -----------------
|
|
|
|
|
|
|
|
|
|
void Visit(NamespaceSources* node) override;
|
|
|
|
|
void Visit(Namespace* node) override;
|
|
|
|
|
|
|
|
|
|
// Definitions -----------------
|
|
|
|
|
|
|
|
|
|
void Visit(ImportStatement* node) override;
|
|
|
|
|
void Visit(AliasDefinitionStatement* node) override;
|
|
|
|
|
void Visit(VariableDefinitionStatement* node) override;
|
|
|
|
|
void Visit(FunctionDeclaration* node) override;
|
|
|
|
|
void Visit(FunctionDefinitionStatement* node) override;
|
|
|
|
|
void Visit(TypeDefinitionStatement* node) override;
|
|
|
|
|
void Visit(AbstractTypeDefinitionStatement* node) override;
|
|
|
|
|
void Visit(TypeclassDefinitionStatement* node) override;
|
2023-05-08 20:34:36 +03:00
|
|
|
void Visit(PartitionStatement* node) override;
|
2023-05-07 19:52:35 +03:00
|
|
|
|
|
|
|
|
// Definition parts
|
|
|
|
|
|
2023-05-09 14:55:04 +03:00
|
|
|
// // void Visit(FunctionDefinition* node) override;
|
|
|
|
|
// // void Visit(TypeDefinition* node) override;
|
|
|
|
|
// // void Visit(AnyAnnotatedType* node) override;
|
2023-05-07 19:52:35 +03:00
|
|
|
|
|
|
|
|
// Flow control -----------------
|
|
|
|
|
|
|
|
|
|
void Visit(TypeConstructorPatternParameter* node) override;
|
|
|
|
|
void Visit(TypeConstructorPattern* node) override;
|
|
|
|
|
void Visit(MatchCase* node) override;
|
|
|
|
|
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;
|
|
|
|
|
|
|
|
|
|
// Statements, expressions, blocks, etc. -----------------
|
|
|
|
|
|
|
|
|
|
void Visit(Block* node) override;
|
|
|
|
|
|
|
|
|
|
void Visit(ScopedStatement* node) override;
|
|
|
|
|
|
|
|
|
|
// Operators
|
|
|
|
|
|
|
|
|
|
void Visit(ReferenceExpression* node) override;
|
|
|
|
|
void Visit(AccessExpression* node) override;
|
|
|
|
|
|
|
|
|
|
// Simple Expressions
|
|
|
|
|
|
|
|
|
|
void Visit(FunctionCallExpression* node) override;
|
|
|
|
|
|
|
|
|
|
void Visit(TupleExpression* node) override;
|
|
|
|
|
void Visit(VariantExpression* node) override;
|
|
|
|
|
void Visit(ReturnExpression* node) override;
|
|
|
|
|
void Visit(TypeConstructorParameter* node) override;
|
|
|
|
|
void Visit(TypeConstructor* node) override;
|
|
|
|
|
void Visit(LambdaFunction* node) override;
|
|
|
|
|
void Visit(ArrayExpression* node) override;
|
|
|
|
|
|
|
|
|
|
void Visit(LoopControlExpression& node) override; // enum
|
|
|
|
|
|
|
|
|
|
// Name
|
|
|
|
|
|
2023-05-09 14:55:04 +03:00
|
|
|
// // void Visit(PartitionName* node) override;
|
2023-05-07 19:52:35 +03:00
|
|
|
void Visit(NameExpression* node) override;
|
|
|
|
|
void Visit(TupleName* node) override;
|
|
|
|
|
void Visit(VariantName* node) override;
|
|
|
|
|
void Visit(AnnotatedName* node) override;
|
|
|
|
|
|
|
|
|
|
// Type, typeclass, etc. -----------------
|
|
|
|
|
|
|
|
|
|
// Type
|
|
|
|
|
|
|
|
|
|
void Visit(FunctionType* node) override;
|
|
|
|
|
void Visit(TupleType* node) override;
|
|
|
|
|
void Visit(VariantType* node) override;
|
|
|
|
|
void Visit(TypeExpression* node) override;
|
|
|
|
|
|
|
|
|
|
void Visit(ExtendedScopedAnyType* node) override;
|
|
|
|
|
|
|
|
|
|
// Typeclass
|
|
|
|
|
|
|
|
|
|
void Visit(ParametrizedTypeclass* node) override;
|
|
|
|
|
|
|
|
|
|
// Typeclass & Type
|
|
|
|
|
|
|
|
|
|
void Visit(ParametrizedType* node) override;
|
|
|
|
|
|
|
|
|
|
// Identifiers, constants, etc. -----------------
|
|
|
|
|
|
2023-05-09 14:55:04 +03:00
|
|
|
// // void Visit(std::string* node) override; // std::string
|
2023-05-07 19:52:35 +03:00
|
|
|
|
|
|
|
|
void Visit(FloatNumberLiteral* node) override;
|
|
|
|
|
void Visit(NumberLiteral* node) override;
|
|
|
|
|
void Visit(StringLiteral* node) override;
|
|
|
|
|
void Visit(CharLiteral* node) override;
|
|
|
|
|
void Visit(UnitLiteral* node) override;
|
2023-05-08 20:34:36 +03:00
|
|
|
void Visit(BoolLiteral* node) override;
|
2023-05-07 19:52:35 +03:00
|
|
|
|
2023-05-09 14:55:04 +03:00
|
|
|
bool HandleCondition(Expression& condition, const BaseNode& base_node);
|
2023-05-09 17:42:35 +03:00
|
|
|
void CollectTypeContext(const ParametrizedType& type);
|
2023-05-09 23:36:47 +03:00
|
|
|
void CheckPattern(Pattern& node, const BaseNode& base_node);
|
2023-05-09 14:55:04 +03:00
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
|
T* ExtractValue(utils::IdType value, const BaseNode& base_node) {
|
|
|
|
|
std::optional<T*> maybe_value_info = context_manager_.GetValue<T>(value);
|
|
|
|
|
if (!maybe_value_info.has_value()) {
|
|
|
|
|
error_handling::HandleRuntimeError("Value has value class that is different from exprected one", base_node);
|
|
|
|
|
}
|
|
|
|
|
return maybe_value_info.value();
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
template<typename T>
|
|
|
|
|
T* ExtractInternalValue(utils::IdType value, const BaseNode& base_node) {
|
|
|
|
|
info::value::InternalValue* value_info = ExtractValue<info::value::InternalValue>(value, base_node);
|
|
|
|
|
std::optional<T*> maybe_internal_value_info = value_info->GetValue<T>();
|
|
|
|
|
if (!maybe_internal_value_info.has_value()) {
|
|
|
|
|
error_handling::HandleRuntimeError("Value has internal value class that is different from exprected one", base_node);
|
|
|
|
|
}
|
|
|
|
|
return maybe_internal_value_info.value();
|
|
|
|
|
}
|
2023-05-20 00:01:54 +03:00
|
|
|
|
2023-05-22 21:00:43 +03:00
|
|
|
utils::IdType GraphIdByTypeId(utils::IdType type_id) {
|
|
|
|
|
auto maybe_any_type = global_info_.GetTypeInfo<info::definition::AnyType>(type_id);
|
|
|
|
|
if (!maybe_any_type.has_value()) {
|
|
|
|
|
error_handling::HandleInternalError("Only AnyType implemented",
|
|
|
|
|
"ExecuteVisitor.ExtractInternalValue",
|
|
|
|
|
std::nullopt);
|
|
|
|
|
}
|
|
|
|
|
return maybe_any_type.value()->node->definition->type->graph_id_;
|
|
|
|
|
}
|
|
|
|
|
|
2023-05-20 00:01:54 +03:00
|
|
|
//
|
|
|
|
|
|
|
|
|
|
bool HandleBuiltinFunctionCall(FunctionCallExpression* node);
|
|
|
|
|
|
2023-05-22 16:03:50 +03:00
|
|
|
bool HandleBuiltinTypeFunctionCall(FunctionCallExpression* node,
|
|
|
|
|
info::type::InternalType type);
|
2023-05-07 19:52:35 +03:00
|
|
|
private:
|
2023-05-18 20:56:03 +03:00
|
|
|
info::GlobalInfo& global_info_;
|
|
|
|
|
info::TypeclassGraph& typeclass_graph_;
|
2023-05-09 15:37:30 +03:00
|
|
|
info::ContextManager<info::type::Type, info::type::TypeManager>& type_context_manager_;
|
2023-05-22 21:00:43 +03:00
|
|
|
|
2023-05-09 15:37:30 +03:00
|
|
|
info::ContextManager<info::value::Value, info::value::ValueManager>& context_manager_;
|
2023-05-22 21:00:43 +03:00
|
|
|
// local types store types graph ids
|
2023-05-09 14:55:04 +03:00
|
|
|
|
|
|
|
|
utils::IdType current_value_;
|
|
|
|
|
std::optional<LoopControlExpression> active_loop_control_expression_;
|
2023-05-09 17:42:35 +03:00
|
|
|
std::optional<utils::IsConstModifier> is_const_definition_;
|
2023-05-09 23:36:47 +03:00
|
|
|
bool case_matched_;
|
2023-05-07 19:52:35 +03:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
} // namespace interpreter
|