Skip to content

Commit 5790d25

Browse files
Martin Ågrengitster
authored andcommitted
merge: always roll back lock in checkout_fast_forward()
This function originated in builtin/merge.c. It was moved to merge.c in commit db699a8 (Move try_merge_command and checkout_fast_forward to libgit.a, 2012-10-26), but was used from sequencer.c even before that. If a problem occurs, the function returns without rolling back the lockfile. Teach it to do so. Signed-off-by: Martin Ågren <[email protected]> Signed-off-by: Junio C Hamano <[email protected]>
1 parent 51d3f43 commit 5790d25

File tree

1 file changed

+9
-3
lines changed

1 file changed

+9
-3
lines changed

merge.c

Lines changed: 9 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -113,17 +113,23 @@ int checkout_fast_forward(const struct object_id *head,
113113
setup_unpack_trees_porcelain(&opts, "merge");
114114

115115
trees[nr_trees] = parse_tree_indirect(head);
116-
if (!trees[nr_trees++])
116+
if (!trees[nr_trees++]) {
117+
rollback_lock_file(&lock_file);
117118
return -1;
119+
}
118120
trees[nr_trees] = parse_tree_indirect(remote);
119-
if (!trees[nr_trees++])
121+
if (!trees[nr_trees++]) {
122+
rollback_lock_file(&lock_file);
120123
return -1;
124+
}
121125
for (i = 0; i < nr_trees; i++) {
122126
parse_tree(trees[i]);
123127
init_tree_desc(t+i, trees[i]->buffer, trees[i]->size);
124128
}
125-
if (unpack_trees(nr_trees, t, &opts))
129+
if (unpack_trees(nr_trees, t, &opts)) {
130+
rollback_lock_file(&lock_file);
126131
return -1;
132+
}
127133
if (write_locked_index(&the_index, &lock_file, COMMIT_LOCK))
128134
return error(_("unable to write new index file"));
129135
return 0;

0 commit comments

Comments
 (0)