Skip to content

Commit 5af2971

Browse files
committed
fsck_commit_buffer(): do not special case the last validation
The pattern taken by all the validations in this function is: if (notice a violation exists) { err = report(... VIOLATION_KIND ...); if (err) return err; } where report() returns zero if specified kind of violation is set to be ignored, and otherwise shows an error message and returns non-zero. The last validation in the function immediately before the function returns 0 to declare "all good" can cheat and directly return the return value from report(), and the current code does so, i.e. if (notice a violation exists) return report(... VIOLATION_KIND ...); return 0; But that is a selfish code that declares it is the ultimate and final form of the function, never to be enhanced later. To allow and invite future enhancements, make the last test follow the same pattern. Signed-off-by: Junio C Hamano <[email protected]>
1 parent a0feb1b commit 5af2971

File tree

1 file changed

+5
-3
lines changed

1 file changed

+5
-3
lines changed

fsck.c

Lines changed: 5 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -666,9 +666,11 @@ static int fsck_commit_buffer(struct commit *commit, const char *buffer,
666666
err = fsck_ident(&buffer, &commit->object, options);
667667
if (err)
668668
return err;
669-
if (!commit->tree)
670-
return report(options, &commit->object, FSCK_MSG_BAD_TREE, "could not load commit's tree %s", sha1_to_hex(tree_sha1));
671-
669+
if (!commit->tree) {
670+
err = report(options, &commit->object, FSCK_MSG_BAD_TREE, "could not load commit's tree %s", sha1_to_hex(tree_sha1));
671+
if (err)
672+
return err;
673+
}
672674
return 0;
673675
}
674676

0 commit comments

Comments
 (0)