From b06f5630c70cdef364484bca51f9764951ce4fb0 Mon Sep 17 00:00:00 2001 From: WerWolv Date: Sun, 6 Dec 2020 23:15:51 +0100 Subject: [PATCH] Fixed additional issues with padding and zero sized arrays --- include/lang/pattern_data.hpp | 3 +++ source/lang/evaluator.cpp | 6 +++--- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/include/lang/pattern_data.hpp b/include/lang/pattern_data.hpp index 969413b52..9f6e63e74 100644 --- a/include/lang/pattern_data.hpp +++ b/include/lang/pattern_data.hpp @@ -354,6 +354,9 @@ namespace hex::lang { : PatternData(Type::Array, offset, size, name, endianess, color), m_entries(entries) { } void createEntry(prv::Provider* &provider) override { + if (this->m_entries.empty()) + return; + ImGui::TableNextRow(); ImGui::TableNextColumn(); bool open = ImGui::TreeNodeEx(this->getName().c_str(), ImGuiTreeNodeFlags_SpanFullWidth); diff --git a/source/lang/evaluator.cpp b/source/lang/evaluator.cpp index d128713e0..8a1f25c02 100644 --- a/source/lang/evaluator.cpp +++ b/source/lang/evaluator.cpp @@ -46,7 +46,7 @@ namespace hex::lang { std::tie(pattern, memberSize) = this->createStringPattern(member, memberOffset); } - else if (member->getArraySize() > 1) { + else if (member->getArraySize() > 1 || member->getVariableType() == Token::TypeToken::Type::Padding) { std::tie(pattern, memberSize) = this->createArrayPattern(member, memberOffset); } else if (member->getArraySizeVariable().has_value()) { @@ -140,7 +140,7 @@ namespace hex::lang { std::tie(pattern, memberSize) = this->createStringPattern(member, memberOffset); } - else if (member->getArraySize() > 1) { + else if (member->getArraySize() > 1 || member->getVariableType() == Token::TypeToken::Type::Padding) { std::tie(pattern, memberSize) = this->createArrayPattern(member, memberOffset); } @@ -277,7 +277,7 @@ namespace hex::lang { delete nonArrayVarDeclNode; } - return { new PatternDataArray(offset, arrayOffset, varDeclNode->getVariableName(), varDeclNode->getEndianess().value_or(this->m_defaultDataEndianess), entries, arrayColor.value()), arrayOffset }; + return { new PatternDataArray(offset, arrayOffset, varDeclNode->getVariableName(), varDeclNode->getEndianess().value_or(this->m_defaultDataEndianess), entries, arrayColor.value_or(0xFF000000)), arrayOffset }; } std::pair Evaluator::createStringPattern(ASTNodeVariableDecl *varDeclNode, u64 offset) {