diff/status: refactor opportunistic index update
When we had to refresh the index internally before running diff or status, we opportunistically updated the $GIT_INDEX_FILE so that later invocation of git can use the lstat(2) we already did in this invocation. Make them share a helper function to do so. Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
@ -1090,13 +1090,8 @@ int cmd_status(int argc, const char **argv, const char *prefix)
|
||||
refresh_index(&the_index, REFRESH_QUIET|REFRESH_UNMERGED, s.pathspec, NULL, NULL);
|
||||
|
||||
fd = hold_locked_index(&index_lock, 0);
|
||||
if (0 <= fd) {
|
||||
if (active_cache_changed &&
|
||||
!write_cache(fd, active_cache, active_nr))
|
||||
commit_locked_index(&index_lock);
|
||||
else
|
||||
rollback_lock_file(&index_lock);
|
||||
}
|
||||
if (0 <= fd)
|
||||
update_index_if_able(&the_index, &index_lock);
|
||||
|
||||
s.is_initial = get_sha1(s.reference, sha1) ? 1 : 0;
|
||||
s.in_merge = in_merge;
|
||||
|
||||
Reference in New Issue
Block a user