|
|
@ -274,7 +274,6 @@ const DIFF_HEAD = "diff --git " |
|
|
|
|
|
|
|
func ParsePatch(reader io.Reader) (*Diff, error) { |
|
|
|
scanner := bufio.NewScanner(reader) |
|
|
|
var totalAdd, totalDel int |
|
|
|
var curFile *DiffFile |
|
|
|
curSection := &DiffSection{ |
|
|
|
Lines: make([]*DiffLine, 0, 10), |
|
|
@ -285,6 +284,10 @@ func ParsePatch(reader io.Reader) (*Diff, error) { |
|
|
|
for scanner.Scan() { |
|
|
|
line := scanner.Text() |
|
|
|
fmt.Println(i, line) |
|
|
|
if strings.HasPrefix(line, "+++ ") || strings.HasPrefix(line, "--- ") { |
|
|
|
continue |
|
|
|
} |
|
|
|
|
|
|
|
i = i + 1 |
|
|
|
if line == "" { |
|
|
|
continue |
|
|
@ -300,40 +303,51 @@ func ParsePatch(reader io.Reader) (*Diff, error) { |
|
|
|
diffLine := &DiffLine{Type: DIFF_LINE_SECTION, Content: "@@" + ss[len(ss)-2] + "@@"} |
|
|
|
curSection.Lines = append(curSection.Lines, diffLine) |
|
|
|
|
|
|
|
diffLine = &DiffLine{Type: DIFF_LINE_PLAIN, Content: ss[len(ss)-1]} |
|
|
|
curSection.Lines = append(curSection.Lines, diffLine) |
|
|
|
if len(ss[len(ss)-1]) > 0 { |
|
|
|
diffLine = &DiffLine{Type: DIFF_LINE_PLAIN, Content: ss[len(ss)-1]} |
|
|
|
curSection.Lines = append(curSection.Lines, diffLine) |
|
|
|
} |
|
|
|
continue |
|
|
|
} else if line[0] == '+' { |
|
|
|
curFile.Addition++ |
|
|
|
diff.TotalAddition++ |
|
|
|
diffLine := &DiffLine{Type: DIFF_LINE_ADD, Content: line} |
|
|
|
curSection.Lines = append(curSection.Lines, diffLine) |
|
|
|
continue |
|
|
|
} else if line[0] == '-' { |
|
|
|
curFile.Deletion++ |
|
|
|
diff.TotalDeletion++ |
|
|
|
diffLine := &DiffLine{Type: DIFF_LINE_DEL, Content: line} |
|
|
|
curSection.Lines = append(curSection.Lines, diffLine) |
|
|
|
continue |
|
|
|
} |
|
|
|
|
|
|
|
// Get new file.
|
|
|
|
if strings.HasPrefix(line, DIFF_HEAD) { |
|
|
|
if curFile != nil { |
|
|
|
curFile.Addition, totalAdd = totalAdd, 0 |
|
|
|
curFile.Deletion, totalDel = totalDel, 0 |
|
|
|
curFile = nil |
|
|
|
} |
|
|
|
fs := strings.Split(line[len(DIFF_HEAD):], " ") |
|
|
|
a := fs[0] |
|
|
|
|
|
|
|
curFile = &DiffFile{ |
|
|
|
Name: a[strings.Index(a, "/")+1:], |
|
|
|
Type: DIFF_FILE_CHANGE, |
|
|
|
Sections: make([]*DiffSection, 0), |
|
|
|
Sections: make([]*DiffSection, 0, 10), |
|
|
|
} |
|
|
|
diff.Files = append(diff.Files, curFile) |
|
|
|
scanner.Scan() |
|
|
|
scanner.Scan() |
|
|
|
if scanner.Text() == "--- /dev/null" { |
|
|
|
curFile.Type = DIFF_FILE_ADD |
|
|
|
|
|
|
|
// Check file diff type.
|
|
|
|
for scanner.Scan() { |
|
|
|
switch { |
|
|
|
case strings.HasPrefix(scanner.Text(), "new file"): |
|
|
|
curFile.Type = DIFF_FILE_ADD |
|
|
|
case strings.HasPrefix(scanner.Text(), "deleted"): |
|
|
|
curFile.Type = DIFF_FILE_DEL |
|
|
|
case strings.HasPrefix(scanner.Text(), "index"): |
|
|
|
curFile.Type = DIFF_FILE_CHANGE |
|
|
|
} |
|
|
|
if curFile.Type > 0 { |
|
|
|
break |
|
|
|
} |
|
|
|
} |
|
|
|
scanner.Scan() |
|
|
|
} |
|
|
|
} |
|
|
|
|
|
|
@ -351,14 +365,13 @@ func GetDiff(repoPath, commitid string) (*Diff, error) { |
|
|
|
return nil, err |
|
|
|
} |
|
|
|
|
|
|
|
// ????
|
|
|
|
if commit.ParentCount() == 0 { |
|
|
|
return &Diff{}, err |
|
|
|
} |
|
|
|
|
|
|
|
rd, wr := io.Pipe() |
|
|
|
go func() { |
|
|
|
cmd := exec.Command("git", "diff", commitid, commit.Parent(0).Oid.String()) |
|
|
|
cmd := exec.Command("git", "diff", commit.Parent(0).Oid.String(), commitid) |
|
|
|
cmd.Dir = repoPath |
|
|
|
cmd.Stdout = wr |
|
|
|
cmd.Stdin = os.Stdin |
|
|
|