Skip to content

Commit

Permalink
reset [--mixed]: only write index file once
Browse files Browse the repository at this point in the history
When doing a mixed reset without paths, the index is locked, read,
reset, and written back as part of the actual reset operation (in
reset_index()). Then, when showing the list of worktree modifications,
we lock the index again, refresh it, and write it.

Change this so we only write the index once, making "git reset" a
little faster. It does mean that the index lock will be held a little
longer, but the difference is small compared to the time spent
refreshing the index.

There is one minor functional difference: We used to say "Could not
write new index file." if the first write failed, and "Could not
refresh index" if the second write failed. Now, we will only use the
first message.

This speeds up "git reset" a little on the linux-2.6 repo (best of
five, warm cache):

        Before      After
real    0m0.239s    0m0.214s
user    0m0.160s    0m0.130s
sys     0m0.070s    0m0.080s

Signed-off-by: Martin von Zweigbergk <martinvonz@gmail.com>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
  • Loading branch information
Martin von Zweigbergk authored and Junio C Hamano committed Jan 15, 2013
1 parent 01a19df commit bc41bf4
Showing 1 changed file with 5 additions and 9 deletions.
14 changes: 5 additions & 9 deletions builtin/reset.c
Original file line number Diff line number Diff line change
Expand Up @@ -336,6 +336,11 @@ int cmd_reset(int argc, const char **argv, const char *prefix)
err = reset_index(sha1, MIXED, quiet);
if (err)
die(_("Could not reset index file to revision '%s'."), rev);

if (reset_type == MIXED) /* Report what has not been updated. */
update_index_refresh(
quiet ? REFRESH_QUIET : REFRESH_IN_PORCELAIN);

if (write_cache(newfd, active_cache, active_nr) ||
commit_locked_index(lock))
die(_("Could not write new index file."));
Expand All @@ -347,15 +352,6 @@ int cmd_reset(int argc, const char **argv, const char *prefix)

if (reset_type == HARD && !update_ref_status && !quiet)
print_new_head_line(commit);
else if (reset_type == MIXED) { /* Report what has not been updated. */
struct lock_file *index_lock = xcalloc(1, sizeof(struct lock_file));
int fd = hold_locked_index(index_lock, 1);
update_index_refresh(
quiet ? REFRESH_QUIET : REFRESH_IN_PORCELAIN);
if (write_cache(fd, active_cache, active_nr) ||
commit_locked_index(index_lock))
error("Could not refresh index");
}

remove_branch_state();

Expand Down

0 comments on commit bc41bf4

Please sign in to comment.