From b223d9b0ff92ea5fd8cb61cc6d222ea1c682aafa Mon Sep 17 00:00:00 2001 From: shenleban tongying Date: Tue, 20 Jun 2023 18:30:26 -0400 Subject: [PATCH] fix: Wrong drawing logic for custom encoding characters (#1150) fix https://github.com/WerWolv/ImHex/issues/1146 related https://github.com/WerWolv/ImHex/commit/3a840c4ceddd050371d744761b0194ffcbfe7773 --- plugins/builtin/source/ui/hex_editor.cpp | 52 ++++++++++-------------- 1 file changed, 21 insertions(+), 31 deletions(-) diff --git a/plugins/builtin/source/ui/hex_editor.cpp b/plugins/builtin/source/ui/hex_editor.cpp index 3626556cd..a28b45c68 100644 --- a/plugins/builtin/source/ui/hex_editor.cpp +++ b/plugins/builtin/source/ui/hex_editor.cpp @@ -122,35 +122,13 @@ namespace hex::plugin::builtin::ui { ImColor color; }; - static CustomEncodingData queryCustomEncodingData(prv::Provider *provider, const EncodingFile &encodingFile, std::vector &lineStartAddresses, u32 bytesPerRow, u64 address) { + static CustomEncodingData queryCustomEncodingData(prv::Provider *provider, const EncodingFile &encodingFile, u64 address) { const auto longestSequence = encodingFile.getLongestSequence(); if (longestSequence == 0) return { ".", 1, 0xFFFF8000 }; - if (lineStartAddresses.empty() || lineStartAddresses.size() <= address / bytesPerRow) { - auto prevSize = lineStartAddresses.size(); - auto newSize = address / bytesPerRow + 1; - lineStartAddresses.reserve(newSize); - - std::vector buffer; - for (auto i = prevSize; i < newSize; i++) { - u32 offset = 0; - while (offset < bytesPerRow) { - size_t readSize = std::min(longestSequence, provider->getActualSize() - address); - buffer.resize(readSize); - provider->read(address, buffer.data(), readSize); - - offset += encodingFile.getEncodingLengthFor(buffer); - } - - lineStartAddresses.push_back(offset % bytesPerRow); - } - } - - address += lineStartAddresses[address / bytesPerRow]; - - size_t size = std::min(longestSequence, provider->getActualSize() - address); + size_t size = std::min(longestSequence, provider->getActualSize() - address); std::vector buffer(size); provider->read(address, buffer.data(), size); @@ -517,15 +495,27 @@ namespace hex::plugin::builtin::ui { // Draw Custom encoding column if (this->m_showCustomEncoding && this->m_currCustomEncoding.has_value()) { std::vector> encodingData; - u32 offset = 0; - do { - const u64 address = y * this->m_bytesPerRow + offset + this->m_provider->getBaseAddress() + this->m_provider->getCurrentPageAddress(); - auto result = queryCustomEncodingData(this->m_provider, *this->m_currCustomEncoding, this->m_encodingLineStartAddresses, this->m_bytesPerRow, address); - offset += std::max(1, result.advance); + if (this->m_encodingLineStartAddresses.empty()) { + this->m_encodingLineStartAddresses.push_back(0); + } - encodingData.emplace_back(address, result); - } while (offset < this->m_bytesPerRow); + if (this->m_encodingLineStartAddresses[y] >= this->m_bytesPerRow) { + encodingData.emplace_back(y * this->m_bytesPerRow + this->m_provider->getBaseAddress() + this->m_provider->getCurrentPageAddress(), CustomEncodingData(".", 1, ImGui::GetCustomColorU32(ImGuiCustomCol_ToolbarRed))); + this->m_encodingLineStartAddresses.push_back(0); + } else { + u32 offset = this->m_encodingLineStartAddresses[y]; + do { + const u64 address = y * this->m_bytesPerRow + offset + this->m_provider->getBaseAddress() + this->m_provider->getCurrentPageAddress(); + + auto result = queryCustomEncodingData(this->m_provider, *this->m_currCustomEncoding, address); + + offset += result.advance; + encodingData.emplace_back(address, result); + } while (offset < this->m_bytesPerRow); + + this->m_encodingLineStartAddresses.push_back(offset - this->m_bytesPerRow); + } ImGui::PushStyleVar(ImGuiStyleVar_CellPadding, ImVec2(0, 0)); ImGui::PushID(y);