summaryrefslogtreecommitdiff
path: root/src/branch.c
diff options
context:
space:
mode:
authornulltoken <emeric.fermas@gmail.com>2012-10-19 20:34:33 +0200
committernulltoken <emeric.fermas@gmail.com>2012-10-19 21:23:22 +0200
commit0532e7bb87713921f34f24ba5599d3b4d2922e1e (patch)
tree71c811aea87ab6eff169777638efb2184048ab59 /src/branch.c
parent8dd0bef92116fe365302f2139d28dbeb28e16e9d (diff)
downloadlibgit2-0532e7bb87713921f34f24ba5599d3b4d2922e1e.tar.gz
branch: allow deletion of branch when HEAD's missing
Diffstat (limited to 'src/branch.c')
-rw-r--r--src/branch.c8
1 files changed, 7 insertions, 1 deletions
diff --git a/src/branch.c b/src/branch.c
index d0bd1c45b..d9fa9eb97 100644
--- a/src/branch.c
+++ b/src/branch.c
@@ -265,13 +265,19 @@ int git_branch_is_head(
{
git_reference *head;
bool is_same = false;
+ int error;
assert(branch);
if (!git_reference_is_branch(branch))
return false;
- if (git_repository_head(&head, git_reference_owner(branch)) < 0)
+ error = git_repository_head(&head, git_reference_owner(branch));
+
+ if (error == GIT_ENOTFOUND)
+ return false;
+
+ if (error < 0)
return -1;
is_same = strcmp(