Only show lines that had blame run on them
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
diff --git a/examples/blame.c b/examples/blame.c
index 6423b3c..df687a7 100644
--- a/examples/blame.c
+++ b/examples/blame.c
@@ -128,22 +128,24 @@ int main(int argc, char *argv[])
while (i < git_blob_rawsize(blob)) {
const char *eol = strchr(rawdata+i, '\n');
char oid[10] = {0};
- const git_blame_hunk *hunk = git_blame_get_hunk_byline(blame, line);
git_commit *hunkcommit;
const git_signature *sig;
+ const git_blame_hunk *hunk = git_blame_get_hunk_byline(blame, line);
- git_oid_tostr(oid, 10, &hunk->final_commit_id);
- check(git_commit_lookup(&hunkcommit, repo, &hunk->final_commit_id), "Commit lookup error");
- sig = git_commit_author(hunkcommit);
-
- printf("%s ( %-30s %3d) %.*s\n",
- oid,
- sig->name,
- line,
- (int)(eol-rawdata-i),
- rawdata+i);
+ if (hunk) {
+ git_oid_tostr(oid, 10, &hunk->final_commit_id);
+ check(git_commit_lookup(&hunkcommit, repo, &hunk->final_commit_id), "Commit lookup error");
+ sig = git_commit_author(hunkcommit);
+
+ printf("%s ( %-30s %3d) %.*s\n",
+ oid,
+ sig->name,
+ line,
+ (int)(eol-rawdata-i),
+ rawdata+i);
+ git_commit_free(hunkcommit);
+ }
- git_commit_free(hunkcommit);
i = eol - rawdata + 1;
line++;
}