verify_lock(): on errors, let the caller unlock the lock
authorMichael Haggerty <mhagger@alum.mit.edu>
Fri, 22 May 2015 23:34:54 +0000 (01:34 +0200)
committerJunio C Hamano <gitster@pobox.com>
Wed, 27 May 2015 19:40:29 +0000 (12:40 -0700)
The caller already knows how to do it, so always do it in the same
place.

Signed-off-by: Michael Haggerty <mhagger@alum.mit.edu>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
refs.c
diff --git a/refs.c b/refs.c
index 27b769afddb97bd9ab6611cf16761666093ae23c..af49e5cbaa0f99ae5aa855ee1930c4653e1cd7b0 100644 (file)
--- a/refs.c
+++ b/refs.c
@@ -2232,14 +2232,12 @@ static int verify_lock(struct ref_lock *lock,
                          lock->old_sha1, NULL)) {
                int save_errno = errno;
                error("Can't verify ref %s", lock->ref_name);
-               unlock_ref(lock);
                errno = save_errno;
                return -1;
        }
        if (hashcmp(lock->old_sha1, old_sha1)) {
                error("Ref %s is at %s but expected %s", lock->ref_name,
                        sha1_to_hex(lock->old_sha1), sha1_to_hex(old_sha1));
-               unlock_ref(lock);
                errno = EBUSY;
                return -1;
        }
@@ -2471,8 +2469,10 @@ static struct ref_lock *lock_ref_sha1_basic(const char *refname,
                        goto error_return;
                }
        }
-       if (old_sha1 && verify_lock(lock, old_sha1, mustexist))
-               return NULL;
+       if (old_sha1 && verify_lock(lock, old_sha1, mustexist)) {
+               last_errno = errno;
+               goto error_return;
+       }
        return lock;
 
  error_return: