mirror of
https://github.com/git/git.git
synced 2024-11-30 21:44:02 +08:00
rebase --update-refs: fix loops
The `total_nr` field in the `todo_list` structure merely serves display purposes, and should only be used when generating the progress message. In these two instances, however, we want to loop over all of the commands in the parsed rebase script. The loop limit therefore needs to be `nr`, which refers to the count of commands in the current `todo_list`. This is important because the two numbers, `nr` and `total_nr` can differ wildly, e.g. due to `total_nr` _not_ counting comments or empty lines, while `nr` skips any commands that already moved from the `git-rebase-todo` file to the `done` file. Signed-off-by: Johannes Schindelin <johannes.schindelin@gmx.de> Acked-by: Phillip Wood <phillip.wood@dunelm.org.uk> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
ec58344906
commit
fa5103dd89
@ -4205,7 +4205,7 @@ void todo_list_filter_update_refs(struct repository *r,
|
||||
if (!is_null_oid(&rec->after))
|
||||
continue;
|
||||
|
||||
for (j = 0; !found && j < todo_list->total_nr; j++) {
|
||||
for (j = 0; !found && j < todo_list->nr; j++) {
|
||||
struct todo_item *item = &todo_list->items[j];
|
||||
const char *arg = todo_list->buf.buf + item->arg_offset;
|
||||
|
||||
@ -4235,7 +4235,7 @@ void todo_list_filter_update_refs(struct repository *r,
|
||||
* For each todo_item, check if its ref is in the update_refs list.
|
||||
* If not, then add it as an un-updated ref.
|
||||
*/
|
||||
for (i = 0; i < todo_list->total_nr; i++) {
|
||||
for (i = 0; i < todo_list->nr; i++) {
|
||||
struct todo_item *item = &todo_list->items[i];
|
||||
const char *arg = todo_list->buf.buf + item->arg_offset;
|
||||
int j, found = 0;
|
||||
|
Loading…
Reference in New Issue
Block a user