tj / git-extras

GIT utilities -- repo summary, repl, changelog population, author commit percentages and more
MIT License
17.3k stars 1.21k forks source link

Usage output should use `git foo` when invoked via git #1154

Open sparr opened 1 month ago

sparr commented 1 month ago

If I run the git-cp script directly with no parameters, the output says USAGE: /foo/bar/bin/git-cp [...] which is on point. I might want it to just say git-cp there, but that's a minor quibble.

More importantly, and the subject of this issue, is that if I run git cp and git searches my path to find the git-cp script, then the output STILL says USAGE: /foo/bar/bin/git-cp [...] when I think it should say USAGE: git cp [...] in keeping with the behavior of most other git commands.

Some git command scripts included with git use different approaches for this:

I propose one of the following solutions:

  1. Hard code git foo as the usage invocation for git-foo across all the scripts
  2. Use git-sh-setup's usage()
  3. Implement a custom detection of git invocation, perhaps by checking for GIT_EXEC_PATH

I volunteer to implement any of these if you pick one.

spacewander commented 1 month ago

PR is welcome!

sparr commented 1 month ago

@spacewander Any suggestion on whether I pursue option 1, 2, or 3?

Also, how complete would such a change need to be to get accepted? I notice a lot of the git-extras scripts were written with different usage string paradigms already, probably copied from different upstream behaviors. Some of them will be easy to convert to use something more flexible. Others are already very complex and may be difficult to convert.

spacewander commented 1 month ago

I don't have a strong opinion, but I would vote for option 1. It's the easiest way to implement.

sparr commented 3 weeks ago

I have underestimated how many different usage output paradigms there would be in the different scripts here. This will be a bigger undertaking than I originally thought. I still want to do it, just not today.

spacewander commented 2 weeks ago

@sparr Thanks for your investigation! We can wait for it.