lang_2023/include/global_info.hpp

203 lines
6.8 KiB
C++
Raw Normal View History

2023-03-26 15:20:53 +03:00
#pragma once
#include <asm-generic/errno.h>
2023-03-26 15:20:53 +03:00
#include <string>
2023-04-14 16:43:56 +03:00
#include <functional>
2023-03-26 15:20:53 +03:00
#include <unordered_map>
// for clangd
#include "definitions.hpp"
2023-05-04 16:11:25 +03:00
#include "interpreter_tree.hpp"
2023-04-17 11:14:33 +03:00
#include "utils.hpp"
2023-03-26 15:20:53 +03:00
namespace info {
// TODO: better test / executable partitions support (tree, etc.)
// TODO: add classes / structs and functions module interface
2023-03-26 15:20:53 +03:00
class GlobalInfo {
2023-04-17 11:14:33 +03:00
friend class NamespaceVisitor;
2023-03-26 15:20:53 +03:00
public:
struct PartitionInfo {
std::vector<std::string> path;
std::string name;
interpreter::tokens::PartitionStatement* node = nullptr;
};
2023-04-17 11:14:33 +03:00
class NamespaceVisitor {
friend GlobalInfo;
NamespaceVisitor() = delete;
public:
2023-05-02 16:16:55 +03:00
struct Path {
std::vector<std::optional<utils::IdType>> path_types;
definition::Namespace* result;
2023-05-02 16:51:47 +03:00
};
2023-05-02 16:16:55 +03:00
void AddImport(definition::Import&& import_info, const std::optional<std::string>& name = std::nullopt);
2023-04-07 12:13:31 +03:00
2023-04-17 11:14:33 +03:00
void AddEnterNamespace(const std::string& name,
2023-05-08 20:34:36 +03:00
std::optional<utils::IsConstModifier> modifier,
const interpreter::tokens::BaseNode& base_node);
2023-04-07 12:13:31 +03:00
2023-04-17 11:14:33 +03:00
void EnterNamespace(const std::string& name);
2023-04-14 14:37:46 +03:00
2023-04-17 11:14:33 +03:00
void ExitNamespace();
2023-04-14 14:37:46 +03:00
2023-04-17 11:14:33 +03:00
void ToGlobalNamespace();
2023-04-07 12:13:31 +03:00
2023-04-17 11:14:33 +03:00
utils::IdType AddFunctionDeclaration(const std::string& name,
definition::FunctionDeclaration&& function_declaration_info);
2023-04-07 12:13:31 +03:00
2023-04-17 11:14:33 +03:00
utils::IdType AddFunctionDefinition(const std::string& name,
definition::FunctionDefinition&& function_definition_info);
2023-04-07 12:13:31 +03:00
utils::IdType AddType(const std::string& type,
definition::Type&& type_info,
const interpreter::tokens::BaseNode& base_node);
2023-04-07 12:13:31 +03:00
2023-05-02 15:18:08 +03:00
utils::IdType AddAbstractType(const std::string& abstract_type,
definition::AbstractType&& abstract_type_info,
const interpreter::tokens::BaseNode& base_node);
2023-05-02 15:18:08 +03:00
utils::IdType AddTypeclass(const std::string& typeclass,
definition::Typeclass&& typeclass_info,
const interpreter::tokens::BaseNode& base_node);
2023-04-07 12:13:31 +03:00
utils::IdType AddConstructor(const std::string& constructor,
definition::Constructor&& constructor_info,
const interpreter::tokens::BaseNode& base_node);
2023-04-07 12:13:31 +03:00
utils::IdType AddPartition(const std::vector<std::string>& path, // including name
interpreter::tokens::PartitionStatement* node);
std::optional<definition::Namespace*> FindNamespace(const std::optional<std::vector<std::string>>& path);
2023-04-07 12:13:31 +03:00
std::optional<utils::IdType> FindFunction(const std::optional<std::vector<std::string>>& path,
const std::string& name);
std::optional<utils::IdType> FindMethod(const std::optional<std::vector<std::string>>& path,
2023-04-17 11:14:33 +03:00
const std::string& type,
const std::string& name,
utils::IsConstModifier modifier);
2023-04-07 12:13:31 +03:00
std::optional<utils::IdType> FindType(const std::optional<std::vector<std::string>>& path,
const std::string& type);
2023-05-02 16:16:55 +03:00
std::optional<utils::IdType> FindLocalType(const std::string& type);
2023-05-02 15:18:08 +03:00
std::optional<utils::IdType> FindAbstractType(const std::string& abstract_type);
std::optional<utils::IdType> FindTypeclass(const std::string& typeclass);
2023-04-07 12:13:31 +03:00
std::optional<utils::IdType> FindConstructor(const std::optional<std::vector<std::string>>& path,
2023-05-02 15:18:08 +03:00
const std::string& constructor);
NamespaceVisitor CreateVisitor() {
return global_info_.CreateVisitor();
}
2023-04-22 19:30:16 +03:00
GlobalInfo* GetGlobalInfo() {
return &global_info_;
}
const std::vector<std::string>& GetCurrentPath() {
return current_path_;
}
2023-05-04 16:11:25 +03:00
definition::Namespace* GetCurrentNamespace() {
return namespace_stack_.back();
}
2023-04-17 11:14:33 +03:00
private:
NamespaceVisitor(GlobalInfo& global_info) : global_info_(global_info),
namespace_stack_({&global_info.global_namespace_}) {}
2023-04-07 12:13:31 +03:00
2023-04-17 11:14:33 +03:00
template<typename T>
std::optional<T> FindSomething(
const std::optional<std::vector<std::string>>& path,
std::function<std::optional<T>(definition::Namespace*)> search_func);
2023-04-14 16:43:56 +03:00
std::optional<definition::Namespace*> FindNamespaceIn(
definition::Namespace* current_namespace,
const std::vector<std::string>& path);
2023-04-17 11:14:33 +03:00
private:
GlobalInfo& global_info_;
std::vector<definition::Namespace*> namespace_stack_;
std::vector<std::string> current_path_;
2023-04-17 11:14:33 +03:00
};
2023-04-14 16:43:56 +03:00
2023-04-17 11:14:33 +03:00
NamespaceVisitor CreateVisitor() {
return NamespaceVisitor(*this);
2023-04-14 16:43:56 +03:00
}
2023-05-02 16:16:55 +03:00
// remember about vector realloc
2023-05-04 16:11:25 +03:00
const definition::Function& GetFunctionInfo(utils::IdType id) {
return functions_.at(id);
}
template<typename T>
std::optional<T*> GetTypeInfo(utils::IdType id) {
2023-05-04 16:11:25 +03:00
if (!std::holds_alternative<T>(types_.at(id).type)) {
return std::nullopt;
}
return &std::get<T>(types_[id].type);
2023-04-14 14:37:46 +03:00
}
2023-04-07 12:13:31 +03:00
2023-05-02 16:16:55 +03:00
// remember about vector realloc
2023-05-04 16:11:25 +03:00
const definition::Type& GetAnyTypeInfo(utils::IdType id) {
return types_.at(id);
2023-04-14 16:43:56 +03:00
}
2023-05-02 16:16:55 +03:00
// remember about vector realloc
2023-05-04 16:11:25 +03:00
const definition::Typeclass& GetTypeclassInfo(utils::IdType id) {
return typeclasses_.at(id);
2023-04-14 14:37:46 +03:00
}
2023-03-26 15:20:53 +03:00
2023-05-02 16:16:55 +03:00
// remember about vector realloc
2023-05-04 16:11:25 +03:00
const definition::Constructor& GetConstructorInfo(utils::IdType id) {
return constructors_.at(id);
}
// remember about vector realloc
const PartitionInfo& GetPartitionInfo(utils::IdType id) {
return partitions_.at(id);
}
std::optional<utils::IdType> FindPartition(const std::vector<std::string>& path) {
auto trie_ans = partitions_trie_.Find(path);
return trie_ans.has_value() ? std::optional<utils::IdType>(*trie_ans.value()) : std::nullopt;
}
std::vector<utils::IdType> FindPartitionsByPrefix(const std::vector<std::string>& path) { // optimize ??
auto trie_ans = partitions_trie_.FindByPrefix(path);
std::vector<utils::IdType> ans(trie_ans.size());
for (size_t i = 0; i < ans.size(); ++i) {
ans[i] = *trie_ans[i];
}
return ans;
}
2023-03-26 15:20:53 +03:00
private:
std::vector<definition::Function> functions_;
std::vector<definition::Type> types_;
2023-05-02 15:18:08 +03:00
std::vector<definition::AbstractType> abstract_types_;
std::vector<definition::Typeclass> typeclasses_;
std::vector<definition::Constructor> constructors_;
2023-04-07 12:13:31 +03:00
2023-05-02 15:18:08 +03:00
std::unordered_map<std::string, utils::IdType> name_to_typeclass_;
std::unordered_map<std::string, utils::IdType> name_to_abstract_type_;
std::vector<PartitionInfo> partitions_;
utils::Trie<std::string, utils::IdType> partitions_trie_;
definition::Namespace global_namespace_;
std::vector<definition::Import> imports_;
std::unordered_map<std::string, definition::Import> usages_;
2023-03-26 15:20:53 +03:00
};
} // namespace info