diff options
author | Junio C Hamano <gitster@pobox.com> | 2017-09-25 08:24:07 +0200 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2017-09-25 08:24:07 +0200 |
commit | d019010559b26784b0aea6cf08b43f576ef027f9 (patch) | |
tree | 3b89930775ebcca6151ec6163782881b2dd8c134 | |
parent | Merge branch 'rs/archive-excluded-directory' (diff) | |
parent | refs: strip out not allowed flags from ref_transaction_update (diff) | |
download | git-d019010559b26784b0aea6cf08b43f576ef027f9.tar.xz git-d019010559b26784b0aea6cf08b43f576ef027f9.zip |
Merge branch 'tg/refs-allowed-flags'
API error-proofing which happens to also squelch warnings from GCC.
* tg/refs-allowed-flags:
refs: strip out not allowed flags from ref_transaction_update
-rw-r--r-- | refs.c | 2 | ||||
-rw-r--r-- | refs.h | 8 |
2 files changed, 10 insertions, 0 deletions
@@ -939,6 +939,8 @@ int ref_transaction_update(struct ref_transaction *transaction, return -1; } + flags &= REF_TRANSACTION_UPDATE_ALLOWED_FLAGS; + flags |= (new_sha1 ? REF_HAVE_NEW : 0) | (old_sha1 ? REF_HAVE_OLD : 0); ref_transaction_add_update(transaction, refname, flags, @@ -345,6 +345,14 @@ int refs_pack_refs(struct ref_store *refs, unsigned int flags); #define REF_FORCE_CREATE_REFLOG 0x40 /* + * Flags that can be passed in to ref_transaction_update + */ +#define REF_TRANSACTION_UPDATE_ALLOWED_FLAGS \ + REF_ISPRUNING | \ + REF_FORCE_CREATE_REFLOG | \ + REF_NODEREF + +/* * Setup reflog before using. Fill in err and return -1 on failure. */ int refs_create_reflog(struct ref_store *refs, const char *refname, |