Bri*_*ola 12 zsh git autocomplete
我使用这种方法跟踪我的点文件:
$HOME/repos/dotfiles
.$HOME/.vim/vimrc
,不是$HOME/repos/dotfiles/vimrc
.git --git-dir=$HOME/repos/dotfiles --work-tree=$HOME ...
管理事情。(实际上,我有一个函数g()
可以在我进入时扩展为上述命令$HOME
,git
否则扩展为。)
一切都很好,除了...
问题: Zsh git 文件名补全不起作用。
例子:
% pwd
/home/brian
% g status ~
On branch master
Your branch is up-to-date with 'origin/master'.
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git checkout -- <file>..." to discard changes in working directory)
modified: .vim/vimrc
modified: .xmonad/xmonad.hs
no changes added to commit (use "git add" and/or "git commit -a")
% g add <Tab>
Completing not a git repository
Run Code Online (Sandbox Code Playgroud)
(“正在完成......”的东西是由于zstyle ':completion:*' format $'%{\e[0;31m%}Completing %B%d%b%{\e[0m%}'
。)
值得注意的是,以某种方式告诉 zsh 的 git 完成“移动到/跟随” 的给定值是不够的--work-tree
,就好像git
是从该目录调用一样,因为明确地这样做也不起作用:
% cd repos/dotfiles
% g status
fatal: This operation must be run in a work tree
% g add <Tab>
Completing not a git repository
Run Code Online (Sandbox Code Playgroud)
问题:有没有一种简单的方法可以将 zsh 的 git 完成扩展到这种情况?
zsh
遗憾的是,它是git 完成过程中的一个错误。您可以在此处找到有关“zsh”邮件列表的讨论。
Daniel Shahaf 确实提供了“_git”的补丁:
diff --git a/Completion/Unix/Command/_git b/Completion/Unix/Command/_git
index 518e6d198..45a0fa622 100644
--- a/Completion/Unix/Command/_git
+++ b/Completion/Unix/Command/_git
@@ -6609,20 +6609,33 @@ __git_files_relative () {
(( $+functions[__git_files] )) ||
__git_files () {
local compadd_opts opts tag description gitcdup gitprefix files expl
+ local pref
zparseopts -D -E -a compadd_opts V: J: 1 2 n f X: M: P: S: r: R: q F:
zparseopts -D -E -a opts -- -cached -deleted -modified -others -ignored -unmerged -killed x+: --exclude+:
tag=$1 description=$2; shift 2
- gitcdup=$(_call_program gitcdup git rev-parse --show-cdup 2>/dev/null)
- __git_command_successful $pipestatus || return 1
+ case $(_call_program gitinworktree git rev-parse --is-inside-work-tree 2>/dev/null) in
+ (true)
+ gitcdup=$(_call_program gitcdup git rev-parse --show-cdup 2>/dev/null)
+ __git_command_successful $pipestatus || return 1
- gitprefix=$(_call_program gitprefix git rev-parse --show-prefix 2>/dev/null)
- __git_command_successful $pipestatus || return 1
+ gitprefix=$(_call_program gitprefix git rev-parse --show-prefix 2>/dev/null)
+ __git_command_successful $pipestatus || return 1
+
+ local pref=$gitcdup$gitprefix$PREFIX
+ ;;
+ (false)
+ local pref=
+ ;;
+ (*)
+ # XXX what to do?
+ return 1
+ ;;
+ esac
# TODO: --directory should probably be added to $opts when --others is given.
- local pref=$gitcdup$gitprefix$PREFIX
# First allow ls-files to pattern-match in case of remote repository
files=(${(0)"$(_call_program files git ls-files -z --exclude-standard ${(q)opts} -- ${(q)${pref:+$pref\\\*}} 2>/dev/null)"})
@@ -7585,7 +7598,8 @@ _git() {
;;
(option-or-argument)
curcontext=${curcontext%:*:*}:git-$words[1]:
- (( $+opt_args[--git-dir] )) && local -x GIT_DIR=$opt_args[--git-dir]
+ (( $+opt_args[--git-dir] )) && local -x GIT_DIR=${(e)opt_args[--git-dir]}
+ (( $+opt_args[--work-tree] )) && local -x GIT_WORK_TREE=${(e)opt_args[--work-tree]}
if ! _call_function ret _git-$words[1]; then
if zstyle -T :completion:$curcontext: use-fallback; then
_default && ret=0
Run Code Online (Sandbox Code Playgroud)
它显然适用于zsh 5.4.1
但对我来说不起作用,YMMV。
当问题正在解决时,我会更新这个答案。
编辑:
使用上面的补丁它确实可以工作,但是你放置的位置add
很重要 - 它必须在最后:
git --git-dir=$HOME/.dotfiles --work-tree=$HOME/ add
Run Code Online (Sandbox Code Playgroud)
还有一件事值得注意 - 它有点慢。
归档时间: |
|
查看次数: |
1075 次 |
最近记录: |