diff options
author | Jeff King <peff@peff.net> | 2012-11-09 12:42:28 -0500 |
---|---|---|
committer | Jeff King <peff@peff.net> | 2012-11-09 12:42:28 -0500 |
commit | 15ba878a1dc4ae929ed121c109a9ff7d35149bea (patch) | |
tree | 8b2baa8d1b17dd9b39aae1768748f6a4b13fc77f | |
parent | 5f836422aba81b5a990ca5251892bfe26ec8125c (diff) | |
parent | 547d058fb6fefad147675a6d3fdb9439c57916a1 (diff) | |
download | git-15ba878a1dc4ae929ed121c109a9ff7d35149bea.tar.gz |
Merge branch 'rs/lock-correct-ref-during-delete'
When "update-ref -d --no-deref SYM" tried to delete a symbolic ref
SYM, it incorrectly locked the underlying reference pointed by SYM,
not the symbolic ref itself.
* rs/lock-correct-ref-during-delete:
refs: lock symref that is to be deleted, not its target
-rw-r--r-- | refs.c | 18 |
1 files changed, 5 insertions, 13 deletions
@@ -1762,26 +1762,18 @@ int delete_ref(const char *refname, const unsigned char *sha1, int delopt) struct ref_lock *lock; int err, i = 0, ret = 0, flag = 0; - lock = lock_ref_sha1_basic(refname, sha1, 0, &flag); + lock = lock_ref_sha1_basic(refname, sha1, delopt, &flag); if (!lock) return 1; if (!(flag & REF_ISPACKED) || flag & REF_ISSYMREF) { /* loose */ - const char *path; - - if (!(delopt & REF_NODEREF)) { - i = strlen(lock->lk->filename) - 5; /* .lock */ - lock->lk->filename[i] = 0; - path = lock->lk->filename; - } else { - path = git_path("%s", refname); - } - err = unlink_or_warn(path); + i = strlen(lock->lk->filename) - 5; /* .lock */ + lock->lk->filename[i] = 0; + err = unlink_or_warn(lock->lk->filename); if (err && errno != ENOENT) ret = 1; - if (!(delopt & REF_NODEREF)) - lock->lk->filename[i] = '.'; + lock->lk->filename[i] = '.'; } /* removing the loose one could have resurrected an earlier * packed one. Also, if it was not loose we need to repack |