summaryrefslogtreecommitdiffstats
path: root/refs.c
diff options
context:
space:
mode:
authorStefan Beller <sbeller@google.com>2015-03-03 12:43:14 +0100
committerJunio C Hamano <gitster@pobox.com>2015-03-05 21:35:36 +0100
commit5a6f47077b31be45bfadd6cef3b8b1a79ad57de5 (patch)
tree4273e9c6a583f54c66c102f36674df64d37589d1 /refs.c
parentlock_ref_sha1_basic(): do not set force_write for missing references (diff)
downloadgit-5a6f47077b31be45bfadd6cef3b8b1a79ad57de5.tar.xz
git-5a6f47077b31be45bfadd6cef3b8b1a79ad57de5.zip
struct ref_lock: delete the force_write member
Instead, compute the value when it is needed. Signed-off-by: Stefan Beller <sbeller@google.com> Edited-by: Michael Haggerty <mhagger@alum.mit.edu> Signed-off-by: Michael Haggerty <mhagger@alum.mit.edu> Reviewed-by: Stefan Beller <sbeller@google.com> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to '')
-rw-r--r--refs.c14
1 files changed, 9 insertions, 5 deletions
diff --git a/refs.c b/refs.c
index b6a2535fd0..5d8d57d349 100644
--- a/refs.c
+++ b/refs.c
@@ -12,7 +12,6 @@ struct ref_lock {
struct lock_file *lk;
unsigned char old_sha1[20];
int lock_fd;
- int force_write;
};
/*
@@ -2319,8 +2318,6 @@ static struct ref_lock *lock_ref_sha1_basic(const char *refname,
lock->ref_name = xstrdup(refname);
lock->orig_ref_name = xstrdup(orig_refname);
ref_file = git_path("%s", refname);
- if ((flags & REF_NODEREF) && (type & REF_ISSYMREF))
- lock->force_write = 1;
retry:
switch (safe_create_leading_directories(ref_file)) {
@@ -3788,8 +3785,15 @@ int ref_transaction_commit(struct ref_transaction *transaction,
struct ref_update *update = updates[i];
if (!is_null_sha1(update->new_sha1)) {
- if (!update->lock->force_write &&
- !hashcmp(update->lock->old_sha1, update->new_sha1)) {
+ int overwriting_symref = ((update->type & REF_ISSYMREF) &&
+ (update->flags & REF_NODEREF));
+
+ if (!overwriting_symref
+ && !hashcmp(update->lock->old_sha1, update->new_sha1)) {
+ /*
+ * The reference already has the desired
+ * value, so we don't need to write it.
+ */
unlock_ref(update->lock);
update->lock = NULL;
} else if (write_ref_sha1(update->lock, update->new_sha1,