Kyle Meyer <k...@kyleam.com> writes:

>> git rev-parse "${BRANCH_NAME}"  || git rev-parse 
>> "refs/remotes/${UPSTREAM}/${BRANCH_NAME}"
>>
>> Unfortunately somebody used the branch name "add-gcc10" and `git rev-parse` 
>> which didn't exist on one repository. However `git rev-parse`
>> also supports to parse the `git-describe` format which resulted in checkout 
>> a commit starting with "cc10".
>
> Can't you prepend "refs/heads/" to BRANCH_NAME to disambiguate?

Yes, that is the kosher way for most commands.  

It gets a bit tricky for "checkout <branch-or-committish>" that
changes its behaviour (a local branch is checked out and the next
commit extends it, other committishes like tags and remote-tracking
branch tips are checked out on a detached HEAD), and has special
rules for a "${BRANCH_NAME}" that is both the name of a local branch
and something else.

Hopefully (Duy Cc'ed) "git switch" would improve the situation.

Reply via email to