add (*Blame).HunkByLine (git_blame_get_hunk_byline) and test
This commit is contained in:
parent
ebb657ce2f
commit
3268bdbeb2
8
blame.go
8
blame.go
|
@ -99,6 +99,14 @@ func (blame *Blame) HunkByIndex(index int) (BlameHunk, error) {
|
||||||
return blameHunkFromC(ptr), nil
|
return blameHunkFromC(ptr), nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (blame *Blame) HunkByLine(lineno int) (BlameHunk, error) {
|
||||||
|
ptr := C.git_blame_get_hunk_byline(blame.ptr, C.uint32_t(lineno))
|
||||||
|
if ptr == nil {
|
||||||
|
return BlameHunk{}, ErrInvalid
|
||||||
|
}
|
||||||
|
return blameHunkFromC(ptr), nil
|
||||||
|
}
|
||||||
|
|
||||||
func newBlameFromC(ptr *C.git_blame) *Blame {
|
func newBlameFromC(ptr *C.git_blame) *Blame {
|
||||||
if ptr == nil {
|
if ptr == nil {
|
||||||
return nil
|
return nil
|
||||||
|
|
|
@ -27,9 +27,7 @@ func TestBlame(t *testing.T) {
|
||||||
t.Errorf("got hunk count %d, want 2", blame.HunkCount())
|
t.Errorf("got hunk count %d, want 2", blame.HunkCount())
|
||||||
}
|
}
|
||||||
|
|
||||||
hunk1, err := blame.HunkByIndex(0)
|
wantHunk1 := BlameHunk{
|
||||||
checkFatal(t, err)
|
|
||||||
checkHunk(t, hunk1, BlameHunk{
|
|
||||||
LinesInHunk: 1,
|
LinesInHunk: 1,
|
||||||
FinalCommitId: commitId1,
|
FinalCommitId: commitId1,
|
||||||
FinalStartLineNumber: 1,
|
FinalStartLineNumber: 1,
|
||||||
|
@ -37,11 +35,8 @@ func TestBlame(t *testing.T) {
|
||||||
OrigPath: "README",
|
OrigPath: "README",
|
||||||
OrigStartLineNumber: 1,
|
OrigStartLineNumber: 1,
|
||||||
Boundary: true,
|
Boundary: true,
|
||||||
})
|
}
|
||||||
|
wantHunk2 := BlameHunk{
|
||||||
hunk2, err := blame.HunkByIndex(1)
|
|
||||||
checkFatal(t, err)
|
|
||||||
checkHunk(t, hunk2, BlameHunk{
|
|
||||||
LinesInHunk: 2,
|
LinesInHunk: 2,
|
||||||
FinalCommitId: commitId2,
|
FinalCommitId: commitId2,
|
||||||
FinalStartLineNumber: 2,
|
FinalStartLineNumber: 2,
|
||||||
|
@ -49,15 +44,31 @@ func TestBlame(t *testing.T) {
|
||||||
OrigPath: "README",
|
OrigPath: "README",
|
||||||
OrigStartLineNumber: 2,
|
OrigStartLineNumber: 2,
|
||||||
Boundary: false,
|
Boundary: false,
|
||||||
})
|
}
|
||||||
|
|
||||||
|
hunk1, err := blame.HunkByIndex(0)
|
||||||
|
checkFatal(t, err)
|
||||||
|
checkHunk(t, "index 0", hunk1, wantHunk1)
|
||||||
|
|
||||||
|
hunk2, err := blame.HunkByIndex(1)
|
||||||
|
checkFatal(t, err)
|
||||||
|
checkHunk(t, "index 1", hunk2, wantHunk2)
|
||||||
|
|
||||||
|
hunkLine1, err := blame.HunkByLine(1)
|
||||||
|
checkFatal(t, err)
|
||||||
|
checkHunk(t, "line 1", hunkLine1, wantHunk1)
|
||||||
|
|
||||||
|
hunkLine2, err := blame.HunkByLine(3)
|
||||||
|
checkFatal(t, err)
|
||||||
|
checkHunk(t, "line 2", hunkLine2, wantHunk2)
|
||||||
}
|
}
|
||||||
|
|
||||||
func checkHunk(t *testing.T, hunk, want BlameHunk) {
|
func checkHunk(t *testing.T, label string, hunk, want BlameHunk) {
|
||||||
hunk.FinalSignature = nil
|
hunk.FinalSignature = nil
|
||||||
want.FinalSignature = nil
|
want.FinalSignature = nil
|
||||||
hunk.OrigSignature = nil
|
hunk.OrigSignature = nil
|
||||||
want.OrigSignature = nil
|
want.OrigSignature = nil
|
||||||
if !reflect.DeepEqual(hunk, want) {
|
if !reflect.DeepEqual(hunk, want) {
|
||||||
t.Fatalf("got hunk %+v, want %+v", hunk, want)
|
t.Fatalf("%s: got hunk %+v, want %+v", label, hunk, want)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue