gitcredentials(7): clarify quoting of helper examples

We give several helper config examples, but don't make clear that these
are raw values. It's up to the user to add the appropriate quoting to
put them into a config file (either by running with "git config" and
quoting against the shell, or by adding double-quotes as appropriate
within the git-config file).

Let's flesh them out as full config blocks, which makes the syntax more
clear (and makes it possible for people to just cut-and-paste them as a
starting point). I added double-quotes to any values larger than a
single word. That isn't strictly necessary in all cases, but it
sidesteps explaining the rules about exactly when you need to quote a
value.

The existing quotes can be converted to single-quotes in one instance,
and backslash-esccaped in the other. I also swapped out backticks for
our preferred $().

Reported-by: douglas.fuller@gmail.com
Signed-off-by: Jeff King <peff@peff.net>
Signed-off-by: Junio C Hamano <gitster@pobox.com>
This commit is contained in:
Jeff King 2020-05-01 03:33:05 -04:00 коммит произвёл Junio C Hamano
Родитель af6b65d45e
Коммит dbe80f928c
1 изменённых файлов: 10 добавлений и 5 удалений

Просмотреть файл

@ -216,20 +216,25 @@ Here are some example specifications:
---------------------------------------------------- ----------------------------------------------------
# run "git credential-foo" # run "git credential-foo"
foo [credential]
helper = foo
# same as above, but pass an argument to the helper # same as above, but pass an argument to the helper
foo --bar=baz [credential]
helper = "foo --bar=baz"
# the arguments are parsed by the shell, so use shell # the arguments are parsed by the shell, so use shell
# quoting if necessary # quoting if necessary
foo --bar="whitespace arg" [credential]
helper = "foo --bar='whitespace arg'"
# you can also use an absolute path, which will not use the git wrapper # you can also use an absolute path, which will not use the git wrapper
/path/to/my/helper --with-arguments [credential]
helper = "/path/to/my/helper --with-arguments"
# or you can specify your own shell snippet # or you can specify your own shell snippet
!f() { echo "password=`cat $HOME/.secret`"; }; f [credential]
helper = "!f() { echo \"password=$(cat $HOME/.secret)\"; }; f"
---------------------------------------------------- ----------------------------------------------------
Generally speaking, rule (3) above is the simplest for users to specify. Generally speaking, rule (3) above is the simplest for users to specify.