Merge branch 'mh/packed-refs-do-one-ref-recursion'
Fix a NULL-pointer dereference during nested iterations over references (for example, when replace references are being used). * mh/packed-refs-do-one-ref-recursion: do_one_ref(): save and restore value of current_ref
This commit is contained in:
commit
f1093b0f60
6
refs.c
6
refs.c
@ -634,7 +634,9 @@ struct ref_entry_cb {
|
||||
static int do_one_ref(struct ref_entry *entry, void *cb_data)
|
||||
{
|
||||
struct ref_entry_cb *data = cb_data;
|
||||
struct ref_entry *old_current_ref;
|
||||
int retval;
|
||||
|
||||
if (prefixcmp(entry->name, data->base))
|
||||
return 0;
|
||||
|
||||
@ -642,10 +644,12 @@ static int do_one_ref(struct ref_entry *entry, void *cb_data)
|
||||
!ref_resolves_to_object(entry))
|
||||
return 0;
|
||||
|
||||
/* Store the old value, in case this is a recursive call: */
|
||||
old_current_ref = current_ref;
|
||||
current_ref = entry;
|
||||
retval = data->fn(entry->name + data->trim, entry->u.value.sha1,
|
||||
entry->flag, data->cb_data);
|
||||
current_ref = NULL;
|
||||
current_ref = old_current_ref;
|
||||
return retval;
|
||||
}
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user