contexts merged with type_info_contexts

This commit is contained in:
ProgramSnail 2023-05-09 15:37:30 +03:00
parent e1b9d42da1
commit 6850863f58
7 changed files with 143 additions and 315 deletions

View file

@ -3,14 +3,15 @@
#include <string>
#include <utility>
#include <vector>
#include <optional>
#include <unordered_map>
// for clangd
#include "values.hpp"
#include "utils.hpp"
namespace info {
template<typename Value, typename ValueManager>
class ContextManager {
public:
ContextManager() {
@ -22,29 +23,37 @@ public:
return value_manager_.AddValue(value, value_type);
}
utils::IdType AddAnyValue(value::Value&& value, utils::ValueType value_type) {
utils::IdType AddAnyValue(Value&& value, utils::ValueType value_type) {
return value_manager_.AddAnyValue(std::move(value), value_type);
}
template<typename T>
std::optional<T*> GetValue(utils::IdType value_id) {
return value_manager_.GetValue<T>(value_id);
return value_manager_.template GetValue<T>(value_id);
}
value::Value* GetAnyValue(utils::IdType value_id) {
Value* GetAnyValue(utils::IdType value_id) {
return value_manager_.GetAnyValue(value_id);
}
bool AddValueRequirement(utils::IdType type, utils::IdType requrement) {
return value_manager_.AddTypeRequirement(type, requrement);
}
bool EqualValues(utils::IdType first_type, utils::IdType second_type) {
return value_manager_.EqualTypes(first_type, second_type);
}
utils::ValueType GetValueType(utils::IdType value_id) {
return value_manager_.GetValueType(value_id);
}
utils::IdType ToModifiedValue(utils::IdType value_id, utils::ValueType new_value_type) {
value::Value value = *GetAnyValue(value_id);
Value value = *GetAnyValue(value_id);
return AddAnyValue(std::move(value), new_value_type);
}
value::ValueManager* GetValueManager() {
ValueManager* GetValueManager() {
return &value_manager_;
}
@ -168,7 +177,7 @@ private:
};
std::vector<Context> contexts_;
value::ValueManager value_manager_;
ValueManager value_manager_;
};
} // namespace info