files_transaction_prepare(): don't leak flags to packed transaction
The files backend uses `ref_update::flags` for several internal flags. But those flags have no meaning to the packed backend. So when adding updates for the packed-refs transaction, only use flags that make sense to the packed backend. `REF_NODEREF` is part of the public interface, and it's logically what we want, so include it. In fact it is actually ignored by the packed backend (which doesn't support symbolic references), but that's its own business. Signed-off-by: Michael Haggerty <mhagger@alum.mit.edu> Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
parent
ff08e56cde
commit
b0ca411051
@ -2594,8 +2594,8 @@ static int files_transaction_prepare(struct ref_store *ref_store,
|
||||
|
||||
ref_transaction_add_update(
|
||||
packed_transaction, update->refname,
|
||||
update->flags & ~REF_HAVE_OLD,
|
||||
&update->new_oid, &update->old_oid,
|
||||
REF_HAVE_NEW | REF_NODEREF,
|
||||
&update->new_oid, NULL,
|
||||
NULL);
|
||||
}
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user