Add more hex editor shortcuts

This commit is contained in:
WerWolv 2020-11-16 00:07:42 +01:00
parent 9ffd393a4a
commit 8b9b284ae9
4 changed files with 79 additions and 3 deletions

View File

@ -6,6 +6,10 @@
#include "event.hpp" #include "event.hpp"
#include <functional>
#include <vector>
namespace hex { namespace hex {
class View { class View {
@ -17,6 +21,10 @@ namespace hex {
virtual void createMenu() { } virtual void createMenu() { }
virtual bool handleShortcut(int key, int mods) { return false; } virtual bool handleShortcut(int key, int mods) { return false; }
static std::vector<std::function<void()>>& getDeferedCalls() {
return View::s_deferedCalls;
}
protected: protected:
void subscribeEvent(Events eventType, std::function<void(void*)> callback) { void subscribeEvent(Events eventType, std::function<void(void*)> callback) {
View::s_eventManager.subscribe(eventType, this, callback); View::s_eventManager.subscribe(eventType, this, callback);
@ -30,8 +38,13 @@ namespace hex {
View::s_eventManager.post(eventType, userData); View::s_eventManager.post(eventType, userData);
} }
void doLater(std::function<void()> &&function) {
View::s_deferedCalls.push_back(function);
}
private: private:
static inline EventManager s_eventManager; static inline EventManager s_eventManager;
static inline std::vector<std::function<void()>> s_deferedCalls;
}; };
} }

View File

@ -51,6 +51,9 @@ namespace hex {
void drawSearchPopup(); void drawSearchPopup();
void drawGotoPopup(); void drawGotoPopup();
void copyBytes();
void copyString();
}; };
} }

View File

@ -83,14 +83,60 @@ namespace hex {
} }
void ViewHexEditor::copyBytes() {
size_t copySize = (this->m_memoryEditor.DataPreviewAddrEnd - this->m_memoryEditor.DataPreviewAddr) + 1;
std::vector<u8> buffer(copySize, 0x00);
this->m_dataProvider->read(this->m_memoryEditor.DataPreviewAddr, buffer.data(), buffer.size());
std::string str;
for (const auto &byte : buffer)
str += hex::format("%x ", byte);
str.pop_back();
ImGui::SetClipboardText(str.c_str());
}
void ViewHexEditor::copyString() {
size_t copySize = (this->m_memoryEditor.DataPreviewAddrEnd - this->m_memoryEditor.DataPreviewAddr) + 1;
std::string buffer;
buffer.reserve(copySize + 1);
this->m_dataProvider->read(this->m_memoryEditor.DataPreviewAddr, buffer.data(), copySize);
ImGui::SetClipboardText(buffer.c_str());
}
void ViewHexEditor::createMenu() { void ViewHexEditor::createMenu() {
if (ImGui::BeginMenu("File")) { if (ImGui::BeginMenu("File")) {
if (ImGui::MenuItem("Open File...")) { if (ImGui::MenuItem("Open File...", "CTRL + O")) {
this->m_fileBrowser.SetTitle("Open File"); this->m_fileBrowser.SetTitle("Open File");
this->m_fileBrowser.Open(); this->m_fileBrowser.Open();
} }
ImGui::Separator();
if (ImGui::MenuItem("Search", "CTRL + F")) {
View::doLater([]{ ImGui::OpenPopup("Search"); });
}
if (ImGui::MenuItem("Goto", "CTRL + G")) {
View::doLater([]{ ImGui::OpenPopup("Goto"); });
}
ImGui::EndMenu();
}
if (ImGui::BeginMenu("Edit")) {
if (ImGui::MenuItem("Copy bytes", "CTRL + ALT + C")) {
this->copyBytes();
}
if (ImGui::MenuItem("Copy string", "CTRL + SHIFT + C")) {
this->copyString();
}
ImGui::EndMenu(); ImGui::EndMenu();
} }
@ -101,12 +147,22 @@ namespace hex {
} }
bool ViewHexEditor::handleShortcut(int key, int mods) { bool ViewHexEditor::handleShortcut(int key, int mods) {
if (mods & GLFW_MOD_CONTROL && key == GLFW_KEY_F) { if (mods == GLFW_MOD_CONTROL && key == GLFW_KEY_F) {
ImGui::OpenPopup("Search"); ImGui::OpenPopup("Search");
return true; return true;
} else if (mods & GLFW_MOD_CONTROL && key == GLFW_KEY_G) { } else if (mods == GLFW_MOD_CONTROL && key == GLFW_KEY_G) {
ImGui::OpenPopup("Goto"); ImGui::OpenPopup("Goto");
return true; return true;
} else if (mods == GLFW_MOD_CONTROL && key == GLFW_KEY_O) {
this->m_fileBrowser.SetTitle("Open File");
this->m_fileBrowser.Open();
return true;
} else if (mods == (GLFW_MOD_CONTROL | GLFW_MOD_ALT) && key == GLFW_KEY_C) {
this->copyBytes();
return true;
} else if (mods == (GLFW_MOD_CONTROL | GLFW_MOD_SHIFT) && key == GLFW_KEY_C) {
this->copyString();
return true;
} }
return false; return false;

View File

@ -67,6 +67,10 @@ namespace hex {
while (!glfwWindowShouldClose(this->m_window)) { while (!glfwWindowShouldClose(this->m_window)) {
this->frameBegin(); this->frameBegin();
for (const auto &call : View::getDeferedCalls())
call();
View::getDeferedCalls().clear();
for (auto &view : this->m_views) { for (auto &view : this->m_views) {
view->createView(); view->createView();
} }