[英]How to deal with combinations of git aliases
我在 .gitconfig 中定义了三个 git 别名(使用一个外部 bash 脚本定义了一个名为 diff-lines 的函数):
[alias]
diffc = diff --cached
diffnw = diff -w --ignore-cr-at-eol --ignore-all-space
diffln =!bash -c 'source $HOME/.bash_functions/diff-lines && git diff | diff-lines'
如何定义“diffln”,以便我可以告诉它使用哪个版本的 diff 别名?
我正在寻找一些东西来防止我必须定义类似于以下内容的每个版本:
diffcln =!bash -c 'source $HOME/.bash_functions/diff-lines && git diffc | diff-lines'
diffnwln =!bash -c 'source $HOME/.bash_functions/diff-lines && git diffnw | diff-lines'
diffcnwln =!bash -c 'source $HOME/.bash_functions/diff-lines && git diffnw --cached | diff-lines'
etc...
感谢@KamilCuk的解决方案。 我需要在别名之后包含一些东西/任何东西,并将整个别名用双引号括起来。
完整的工作命令是这样的(如果没有提供参数,则默认使用 git diff 选项):
diffln ="!bash -c 'source $HOME/.bash_functions/diff-lines && if ((!$#)); then set -- diff; fi && git $@ | diff-lines' _"
我试过这个:
diffln =!bash -c 'source $HOME/.bash_functions/diff-lines && git $@ | diff-lines'
并通过以下方式调用:
$ git diffln diffc
但它只是给了我默认的 git 选项,就好像我只是在调用$ git
在它后面添加一个东西。 通常: bash -c "blabla" _
或bash -c "balbla" --
。
bash -c "" <here>
之后的第一个参数是$0
-第二个参数是$1
。
还要记住引用 - 将$anything
放在双引号内以防止分词和文件名扩展。 但我不确定 git 是如何处理的。
diffln =!bash -c 'source "$HOME/.bash_functions/diff-lines" && git "$@" | diff-lines' _
如果你想有一个“默认”参数,你可以:
diffln =!bash -c 'source "$HOME/.bash_functions/diff-lines" && if ((!$#)); then set -- diff; fi && git "$@" | diff-lines' _
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.