Hi,
Junio C Hamano wrote:
> Things like @{-1} would not make any sense when the command is run
> outside a repository, and the documentation is quite clear that it
> is the primary reason why we added "--branch" option to the command,
> i.e.
>
> With the `--branch` option, it expands the ``previous branch syntax''
> `@{-n}`. For example, `@{-1}` is a way to refer the last branch you
> were on. This option should be used by porcelains to accept this
> syntax anywhere a branch name is expected, so they can act as if you
> typed the branch name.
>
> So I am tempted to take this patch to make sure that we won't gain
> more people who abuse the command outside a repository.
That seems very sensible on its face. My only worry is that a script
that can be run both inside and outside a repository and does
branch=$(git check-ref-format --branch "$user_supplied_branch_arg")
currently works with user_supplied_branch_arg='master' and would stop
working. If we have reason to believe that no such scripts exist,
then this would be a good way to go, but I don't believe we can count
on that.
And in that spirit, I think the patch you replied with aims to go in
the right direction, by providing the core functionality when in a
repository while avoiding breaking such a script outside of one
(though I do not understand it fully yet).
> Having said that, there may still be a use case where a Porcelain
> script wants a way to see if a $name it has is appropriate as a
> branch name before it has a repository
This seems like a different goal than "git check-ref-format --branch"
was originally designed to fulfill (even though it fits well with the
check-ref-format name and coincides with --branch behavior when in a
repository). I think it's fine for us not to fulfill it.
> (e.g. a wrapper to "git
> clone" that wants to verify the name it is going to give to the "-b"
> option), and a check desired in such a context is different from
> (and is stricter than) feeding refs/heads/$name to the same command
> without the "--branch" option.
Can you say more about this example? E.g. why is this hypothetical
wrapper unable to rely on "git clone -b"'s own error handling?
> So I think the right endgame in the longer term is:
>
> - Find (or add if it doesn't exist) a way to recommend to Porcelain
> scripts to use to expand an end-user generated string, and to map
> it to a branch name (it may be "rev-parse --symbolic-full-name
> $name"; I dunno).
--symbolic-full-name seems like a good fit. Do you remember why
check-ref-format was introduced instead? Was it just a matter of
implementation simplicity, since --symbolic-full-name can handle a
broader class of revision specifications like --remotes? The commit
message to v1.6.3-rc0~29^2~4 (give Porcelain a way to grok branch
shorthand, 2009-03-21) is appropriately apologetic but doesn't give
more clues.
> - Keep check-ref-format as (or revert it to be) a tool to "check".
> This would involve split strbuf_check_branch_ref() into two:
Without an example of where this tool would be used, if we consider
"check-ref-format --branch" to be a mistake then I'd rather deprecate
it with a goal of removing it completely.
Ok, time to look in more detail.
Thanks for your thoughtfulness,
Jonathan