c051f5d3e7
* patterns: Rewrite most of the evaluator to mainly use polymorphism instead of just RTTI * patterns: Fixed a couple of AST memory leaks * patterns: Parse string operations correctly * patterns: Various fixes and cleanup * patterns: Implement primitive function definitions Function parameters now need to provide their type in the definition * patterns: Added function variable definition and assignment * patterns: Added remaining function statements * patterns: Added unsized and while-sized arrays * patterns: Added multi variable declarations to functions * patterns: Added std::format built-in function * patterns: Allow passing custom types to functions * patterns: Added attributes and new "format" attribute * patterns: Use libfmt for std::print instead of custom version * patterns: Remove unnecessary string compare function * pattern: Fix preprocessor directives * patterns: Fix unit tests * patterns: Added cast expression * patterns: Handle endianess in function parameters * patterns: Added casting to different endian * patterns: Added 'str' type for functions
65 lines
1.8 KiB
C++
65 lines
1.8 KiB
C++
#pragma once
|
|
|
|
#include <hex.hpp>
|
|
|
|
#include <string>
|
|
#include <string_view>
|
|
#include <utility>
|
|
#include <vector>
|
|
|
|
#include <hex/pattern_language/ast_node_base.hpp>
|
|
|
|
namespace hex::pl {
|
|
|
|
class ASTNode;
|
|
|
|
class LogConsole {
|
|
public:
|
|
enum Level {
|
|
Debug,
|
|
Info,
|
|
Warning,
|
|
Error
|
|
};
|
|
|
|
[[nodiscard]]
|
|
const auto& getLog() const { return this->m_consoleLog; }
|
|
|
|
using EvaluateError = std::pair<u32, std::string>;
|
|
|
|
void log(Level level, const std::string &message) {
|
|
switch (level) {
|
|
default:
|
|
case Level::Debug: this->m_consoleLog.emplace_back(level, "[-] " + message); break;
|
|
case Level::Info: this->m_consoleLog.emplace_back(level, "[i] " + message); break;
|
|
case Level::Warning: this->m_consoleLog.emplace_back(level, "[*] " + message); break;
|
|
case Level::Error: this->m_consoleLog.emplace_back(level, "[!] " + message); break;
|
|
}
|
|
}
|
|
|
|
[[noreturn]]
|
|
static void abortEvaluation(const std::string &message) {
|
|
throw EvaluateError(0, message);
|
|
}
|
|
|
|
[[noreturn]]
|
|
static void abortEvaluation(const std::string &message, const auto *node) {
|
|
throw EvaluateError(static_cast<const ASTNode*>(node)->getLineNumber(), message);
|
|
}
|
|
|
|
void clear() {
|
|
this->m_consoleLog.clear();
|
|
this->m_lastHardError = { };
|
|
}
|
|
|
|
void setHardError(const EvaluateError &error) { this->m_lastHardError = error; }
|
|
|
|
[[nodiscard]]
|
|
const LogConsole::EvaluateError& getLastHardError() { return this->m_lastHardError; };
|
|
|
|
private:
|
|
std::vector<std::pair<Level, std::string>> m_consoleLog;
|
|
EvaluateError m_lastHardError;
|
|
};
|
|
|
|
} |