Using the slash character in Git branch name

GitBranch

Git Problem Overview


I'm pretty sure I saw somewhere in a popular Git project the branches had a pattern like "feature/xyz".

However when I try to create a branch with the slash character, I get an error:

$ git branch labs/feature
error: unable to resolve reference refs/heads/labs/feature: Not a directory
fatal: Failed to lock ref for update: Not a directory

Same problem for (my initial attempt):

$ git checkout -b labs/feature

How does one create a branch in Git with the slash character?

Git Solutions


Solution 1 - Git

Are you sure branch labs does not already exist (as in this thread)?

> You can't have both a file, and a directory with the same name. > > You're trying to get git to do basically this: > > % cd .git/refs/heads > % ls -l > total 0 > -rw-rw-r-- 1 jhe jhe 41 2009-11-14 23:51 labs > -rw-rw-r-- 1 jhe jhe 41 2009-11-14 23:51 master > % mkdir labs > mkdir: cannot create directory 'labs': File exists > > You're getting the equivalent of the "cannot create directory" error.
When you have a branch with slashes in it, it gets stored as a directory hierarchy under .git/refs/heads.

Note that labs must not be an existing branch, as ddruganov points out in the comments:

 git switch -c 19023-commerce/19033-commerce-view 19023-commerce

 # Fails with:

 fatal: cannot lock ref 'refs/heads/19073-commerce-view/99999-test-branch': 
 'refs/heads/19073-commerce-view' exists; 
  cannot create 'refs/heads/19073-commerce-view/99999-test-branch'

As explained in "git push: refs/heads/my/subbranch exists, cannot create":

> - If branch b exists, no branch named b/anything can be created. > - Likewise, if branch dev/b exists, dev/b/c cannot be created. > > This is a git internal limitation.

Solution 2 - Git

It is possible to have hierarchical branch names (branch names with slash). For example in my repository I have such branch(es). One caveat is that you can't have both branch 'foo' and branch 'foo/bar' in repository.

Your problem is not with creating branch with slash in name.

$ git branch foo/bar
error: unable to resolve reference refs/heads/labs/feature: Not a directory
fatal: Failed to lock ref for update: Not a directory
The above error message talks about 'labs/feature' branch, not 'foo/bar' (unless it is a mistake in copy'n'paste, i.e you edited parts of session). What is the result of git branch or git rev-parse --symbolic-full-name HEAD?

Solution 3 - Git

I forgot that I had already an unused labs branch. Deleting it solved my problem:

git branch -d labs
git checkout -b labs/feature

Explanation:

Each name can only be a parent branch or a normal branch, not both. Thats why the branches labs and labs/feature can't exists both at the same time.

The reason: Branches are stored in the file system and there you also can't have a file labs and a directory labs at the same level.

Solution 4 - Git

Sometimes that problem occurs if you already have a branch with the base name.

I tried this:

git checkout -b features/aName origin/features/aName

Unfortunately, I already had a branch named features, and I got the exception of the question asker.

Removing the branch features resolved the problem, the above command worked.

Solution 5 - Git

Branch name is case sensitive and so if there are folders created in Azure by your release manager, folder names should match exactly. Learned it hard way raising it with manager.

Solution 6 - Git

just had the same issue, but i could not find the conflicting branch anymore.

in my case the repo had and "foo" branch before, but not anymore and i tried to create and checkout "foo/bar" from remote. As i said "foo" did not exist anymore, but the issue persisted.

In the end, the branch "foo" was still in the .git/config file, after deleting it everything was alright :)

Solution 7 - Git

In case someone has this issue where they're not able to checkout to a branch for eg: features/23 because it says branch features exists, but you cannot find it on Github - it might be that you have a local branch named features which is causing it.

Delete the local branch with git branch -D features and then you should be able to checkout with git checkout features/23 and it should work as expected.

Attributions

All content for this solution is sourced from the original question on Stackoverflow.

The content on this page is licensed under the Attribution-ShareAlike 4.0 International (CC BY-SA 4.0) license.

Content TypeOriginal AuthorOriginal Content on Stackoverflow
Questionuser58777View Question on Stackoverflow
Solution 1 - GitVonCView Answer on Stackoverflow
Solution 2 - GitJakub NarębskiView Answer on Stackoverflow
Solution 3 - GitfloriView Answer on Stackoverflow
Solution 4 - GitelbkindView Answer on Stackoverflow
Solution 5 - Gituser3685852View Answer on Stackoverflow
Solution 6 - GitMonocroMView Answer on Stackoverflow
Solution 7 - GitnkhilView Answer on Stackoverflow