mirror of
https://github.com/open-goal/jak-project.git
synced 2024-10-20 11:26:18 -04:00
89ccb8cbc7
* cleanup `main` * whitespace * start `progress` decomp pt1 * fill in more stuff * Update label_types.jsonc * run cheats * clang * make most of `progress` decompile * `progress` pt 2 * [decompiler] support dynamic format strings * Make `progress-draw` decompile and almost all `progress` * make clang shut up * fix unhandled format string * fix `progress-draw` * Update DecompilerTypeSystem.cpp * fix? * fixes * fix a few functions * make `language-enum` * warn on weird floats * fix minor pad bug * dump stuff in `progress` * make `progress-screen` enum * progress progress * update refs and fix stupid bug * trying to get it to work * it works!? * disable sound functions * fixes * final touches * tests * tests * add process allocations * use the right register for windows * another try for windows, counting is hard * one more try * use process allocations Co-authored-by: water <awaterford111445@gmail.com>
61 lines
2.2 KiB
C++
61 lines
2.2 KiB
C++
#pragma once
|
|
|
|
#include "common/type_system/TypeSystem.h"
|
|
#include "decompiler/Disasm/Register.h"
|
|
#include "common/goos/Reader.h"
|
|
|
|
namespace decompiler {
|
|
class TP_Type;
|
|
class TypeState;
|
|
|
|
class DecompilerTypeSystem {
|
|
public:
|
|
DecompilerTypeSystem();
|
|
TypeSystem ts;
|
|
std::unordered_map<std::string, TypeSpec> symbol_types;
|
|
std::unordered_set<std::string> symbols;
|
|
std::vector<std::string> symbol_add_order;
|
|
std::unordered_map<std::string, u64> type_flags;
|
|
std::unordered_map<std::string, std::string> type_parents;
|
|
std::unordered_map<std::string, int> bad_format_strings;
|
|
std::unordered_map<std::string, std::vector<std::vector<int>>>
|
|
format_ops_with_dynamic_string_by_func_name;
|
|
|
|
void add_symbol(const std::string& name) {
|
|
if (symbols.find(name) == symbols.end()) {
|
|
symbols.insert(name);
|
|
symbol_add_order.push_back(name);
|
|
}
|
|
}
|
|
|
|
void add_symbol(const std::string& name, const std::string& base_type) {
|
|
add_symbol(name, TypeSpec(base_type));
|
|
}
|
|
|
|
void add_symbol(const std::string& name, const TypeSpec& type_spec);
|
|
void parse_type_defs(const std::vector<std::string>& file_path);
|
|
TypeSpec parse_type_spec(const std::string& str) const;
|
|
void add_type_flags(const std::string& name, u64 flags);
|
|
void add_type_parent(const std::string& child, const std::string& parent);
|
|
std::string dump_symbol_types();
|
|
std::string lookup_parent_from_inspects(const std::string& child) const;
|
|
bool lookup_flags(const std::string& type, u64* dest) const;
|
|
TP_Type tp_lca(const TP_Type& existing, const TP_Type& add, bool* changed) const;
|
|
bool tp_lca(TypeState* combined, const TypeState& add);
|
|
int get_format_arg_count(const std::string& str) const;
|
|
int get_format_arg_count(const TP_Type& type) const;
|
|
int get_dynamic_format_arg_count(const std::string& func_name, int op_idx) const;
|
|
TypeSpec lookup_symbol_type(const std::string& name) const;
|
|
bool should_attempt_cast_simplify(const TypeSpec& expected, const TypeSpec& actual) const;
|
|
|
|
// todo - totally eliminate this.
|
|
struct {
|
|
std::string current_method_type;
|
|
void reset() { current_method_type.clear(); }
|
|
} type_prop_settings;
|
|
|
|
private:
|
|
mutable goos::Reader m_reader;
|
|
};
|
|
} // namespace decompiler
|