diff options
author | Junio C Hamano <gitster@pobox.com> | 2012-11-20 10:14:41 -0800 |
---|---|---|
committer | Junio C Hamano <gitster@pobox.com> | 2012-11-20 10:14:41 -0800 |
commit | c5afc5b73e33e47537936ef4bb738c9d8e2f1963 (patch) | |
tree | 203c06c52039a6dfda9a64f394b36a72dd95bdc0 | |
parent | e87719fc944f8a9961ba9c371c485efe54dd08b5 (diff) | |
parent | 547d058fb6fefad147675a6d3fdb9439c57916a1 (diff) | |
download | git-c5afc5b73e33e47537936ef4bb738c9d8e2f1963.tar.gz git-c5afc5b73e33e47537936ef4bb738c9d8e2f1963.tar.xz |
Merge branch 'rs/lock-correct-ref-during-delete' into maint
* 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
@@ -1753,26 +1753,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 |