diff options
author | jkobus <jaroslaw.kobus@digia.com> | 2014-02-13 16:43:28 +0100 |
---|---|---|
committer | Jarek Kobus <jaroslaw.kobus@digia.com> | 2014-06-06 12:33:59 +0200 |
commit | 8cad94534f97849081bd595da458670d168d6b63 (patch) | |
tree | 5575aab843ad47d38a30d5bbc38f1449254eaf4e /src/plugins/diffeditor/diffutils.h | |
parent | 8cb25f9e3e1afcc1ccfa17966cdcc31a95c02289 (diff) |
Implement unified diff editor
Change-Id: I93e0bfd71a8a650afbe2ca9e0f1f3dbfc9d57db0
Reviewed-by: Jarek Kobus <jaroslaw.kobus@digia.com>
Diffstat (limited to 'src/plugins/diffeditor/diffutils.h')
-rw-r--r-- | src/plugins/diffeditor/diffutils.h | 78 |
1 files changed, 54 insertions, 24 deletions
diff --git a/src/plugins/diffeditor/diffutils.h b/src/plugins/diffeditor/diffutils.h index 75102c7406a..9043969929a 100644 --- a/src/plugins/diffeditor/diffutils.h +++ b/src/plugins/diffeditor/diffutils.h @@ -30,11 +30,12 @@ #ifndef DIFFUTILS_H #define DIFFUTILS_H +#include "diffeditor_global.h" + #include <QString> #include <QMap> #include <QTextEdit> -#include "diffeditorcontroller.h" #include "texteditor/texteditorconstants.h" namespace TextEditor { class FontSettings; } @@ -43,9 +44,18 @@ namespace DiffEditor { class Diff; -namespace Internal { +class DIFFEDITOR_EXPORT DiffFileInfo { +public: + DiffFileInfo() : devNull(false) {} + DiffFileInfo(const QString &file) : fileName(file), devNull(false) {} + DiffFileInfo(const QString &file, const QString &type) + : fileName(file), typeInfo(type), devNull(false) {} + QString fileName; + QString typeInfo; + bool devNull; +}; -class TextLineData { +class DIFFEDITOR_EXPORT TextLineData { public: enum TextLineType { TextLine, @@ -66,7 +76,7 @@ public: QMap<int, int> changedPositions; // counting from the beginning of the line }; -class RowData { +class DIFFEDITOR_EXPORT RowData { public: RowData() : equal(false) {} RowData(const TextLineData &l) @@ -78,35 +88,55 @@ public: bool equal; }; -class ChunkData { +class DIFFEDITOR_EXPORT ChunkData { public: - ChunkData() : contextChunk(false) {} + ChunkData() : contextChunk(false), + leftStartingLineNumber(0), rightStartingLineNumber(0) {} QList<RowData> rows; bool contextChunk; + int leftStartingLineNumber; + int rightStartingLineNumber; }; -class FileData { +class DIFFEDITOR_EXPORT FileData { public: - FileData() {} - FileData(const ChunkData &chunkData) { chunks.append(chunkData); } + FileData() + : binaryFiles(false), + lastChunkAtTheEndOfFile(false), + contextChunksIncluded(false) {} + FileData(const ChunkData &chunkData) + : binaryFiles(false), + lastChunkAtTheEndOfFile(false), + contextChunksIncluded(false) { chunks.append(chunkData); } QList<ChunkData> chunks; - DiffEditorController::DiffFileInfo leftFileInfo; - DiffEditorController::DiffFileInfo rightFileInfo; + DiffFileInfo leftFileInfo; + DiffFileInfo rightFileInfo; + bool binaryFiles; + bool lastChunkAtTheEndOfFile; + bool contextChunksIncluded; +}; + +class DIFFEDITOR_EXPORT DiffUtils { +public: + + static ChunkData calculateOriginalData(const QList<Diff> &leftDiffList, + const QList<Diff> &rightDiffList); + static FileData calculateContextData(const ChunkData &originalData, + int contextLinesNumber, + int joinChunkThreshold = 1); + static QString makePatchLine(const QChar &startLineCharacter, + const QString &textLine, + bool lastChunk, + bool lastLine); + static QString makePatch(const ChunkData &chunkData, + const QString &leftFileName, + const QString &rightFileName, + bool lastChunk = false); + static QList<FileData> readPatch(const QString &patch, + bool ignoreWhitespace, + bool *ok = 0); }; -ChunkData calculateOriginalData(const QList<Diff> &leftDiffList, - const QList<Diff> &rightDiffList); -FileData calculateContextData(const ChunkData &originalData, - int contextLinesNumber); -void addChangedPositions(int positionOffset, - const QMap<int, int> &originalChangedPositions, - QMap<int, int> *changedPositions); -QList<QTextEdit::ExtraSelection> colorPositions(const QTextCharFormat &format, - QTextCursor &cursor, - const QMap<int, int> &positions); -QTextCharFormat fullWidthFormatForTextStyle(const TextEditor::FontSettings &fontSettings, - TextEditor::TextStyle textStyle); -} // namespace Internal } // namespace DiffEditor #endif // DIFFUTILS_H |