1
0
mirror of synced 2025-01-19 01:24:15 +01:00

patterns: Properly treat arrays and custom types as references

This commit is contained in:
WerWolv 2022-02-21 20:00:54 +01:00
parent 7d9c24ff51
commit ef8e9a83bb

View File

@ -23,6 +23,8 @@ namespace hex::pl {
auto pattern = type == nullptr ? nullptr : type->createPatterns(this).front();
this->dataOffset() = startOffset;
bool referenceType = false;
if (pattern == nullptr) {
// Handle auto variables
if (!value.has_value())
@ -38,19 +40,23 @@ namespace hex::pl {
pattern = new PatternDataBoolean(this, 0);
else if (std::get_if<char>(&value.value()) != nullptr)
pattern = new PatternDataCharacter(this, 0);
else if (std::get_if<PatternData *>(&value.value()) != nullptr)
pattern = std::get<PatternData *>(value.value())->clone();
else if (std::get_if<std::string>(&value.value()) != nullptr)
pattern = new PatternDataString(this, 0, 1);
else
else if (std::get_if<PatternData *>(&value.value()) != nullptr) {
pattern = std::get<PatternData *>(value.value())->clone();
referenceType = true;
} else
LogConsole::abortEvaluation("cannot determine type of auto variable", type);
}
pattern->setVariableName(name);
pattern->setLocal(true);
pattern->setOffset(this->getStack().size());
this->getStack().emplace_back();
if (!referenceType) {
pattern->setOffset(this->getStack().size());
pattern->setLocal(true);
this->getStack().emplace_back();
}
variables.push_back(pattern);
if (outVariable)
@ -86,6 +92,8 @@ namespace hex::pl {
if (pattern == nullptr)
LogConsole::abortEvaluation(hex::format("no variable with name '{}' found", name));
if (!pattern->isLocal()) return;
Token::Literal castedLiteral = std::visit(overloaded {
[&](double &value) -> Token::Literal {
if (dynamic_cast<PatternDataUnsigned *>(pattern))