feat: Implement Myers' diffing algorithm (#1508)

This commit is contained in:
Nik
2024-01-21 18:39:13 +01:00
committed by GitHub
parent 9d351317b8
commit a13b5bf8c0
41 changed files with 624 additions and 215 deletions

View File

@@ -0,0 +1,44 @@
#pragma once
#include <hex.hpp>
#include <hex/ui/view.hpp>
#include <hex/api/task_manager.hpp>
#include <array>
#include <vector>
#include "ui/hex_editor.hpp"
namespace hex::plugin::diffing {
class ViewDiff : public View::Window {
public:
ViewDiff();
~ViewDiff() override;
void drawContent() override;
ImGuiWindowFlags getWindowFlags() const override { return ImGuiWindowFlags_NoScrollbar | ImGuiWindowFlags_NoScrollWithMouse; }
public:
struct Column {
ui::HexEditor hexEditor;
ContentRegistry::Diffing::DiffTree diffTree;
int provider = -1;
i32 scrollLock = 0;
};
private:
std::function<std::optional<color_t>(u64, const u8*, size_t)> createCompareFunction(size_t otherIndex) const;
void analyze(prv::Provider *providerA, prv::Provider *providerB);
private:
std::array<Column, 2> m_columns;
TaskHolder m_diffTask;
std::atomic<bool> m_analyzed = false;
ContentRegistry::Diffing::Algorithm *m_algorithm = nullptr;
};
}