File: GitDiffOutputParser.cpp

package info (click to toggle)
codelite 14.0+dfsg-1
  • links: PTS, VCS
  • area: main
  • in suites: bullseye, sid
  • size: 112,816 kB
  • sloc: cpp: 483,662; ansic: 150,144; php: 9,569; lex: 4,186; python: 3,417; yacc: 2,820; sh: 1,147; makefile: 52; xml: 13
file content (60 lines) | stat: -rw-r--r-- 2,227 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#include "GitDiffOutputParser.h"
#include <wx/tokenzr.h>

GitDiffOutputParser::GitDiffOutputParser() {}

GitDiffOutputParser::~GitDiffOutputParser() {}

void GitDiffOutputParser::GetDiffMap(const wxString& rawDiff, wxStringMap_t& M, wxArrayString* commitMessage) const
{
    wxArrayString diffList = wxStringTokenize(rawDiff, wxT("\n"), wxTOKEN_RET_EMPTY_ALL);
    unsigned index = 0;
    wxString currentFile;
    wxString currentDiff;
    const wxString diffPrefix = "diff --git a/";
    bool foundFirstDiff = false;
    eGitDiffStates state = kLookingForFileName; // Searching for file name
    for(size_t i = 0; i < diffList.size(); ++i) {
        wxString& line = diffList.Item(i);
        if (commitMessage && !foundFirstDiff) {
            // The git blame and git CommitList need to display the commit message
            // This can be found at the top of the output, before the first "diff "
            if (!line.StartsWith("diff ")) {
                commitMessage->Add(line + "\n");
                continue;
            } else {
                foundFirstDiff = true;
            }
        }

        switch(state) {
        case kLookingForFileName: {
            if(line.StartsWith(diffPrefix)) {
                int where = line.Find(diffPrefix);
                line = line.Mid(where + diffPrefix.length());
                where = line.Find(" b/");
                if(where != wxNOT_FOUND) { line = line.Mid(0, where); }
                currentFile = line;
                state = kLookingForDiff;
            }
        } break;
        case kLookingForDiff: {
            if(line.StartsWith(diffPrefix)) {
                // Add the current outpt to the result output and continue
                M[currentFile] = currentDiff;
                currentDiff.Clear();
                currentFile.Clear();

                // Reset the scanner loop
                state = kLookingForFileName;
                --i; // This will make sure we process this line again, however, in the other state switch case
            } else {
                currentDiff << line << "\n";
            }
        } break;
        }
    }

    // Add any leftovers
    if(!currentFile.IsEmpty()) { M[currentFile] = currentDiff; }
}