我只需要一份冲突文件列表。
还有什么比:
git ls-files -u | cut -f 2 | sort -u
or:
git ls-files -u | awk '{print $4}' | sort | uniq
我想我可以为此设置一个方便的别名,但我想知道专业人士是如何做到的。我会用它来写shell循环,比如自动解决冲突等等。也许可以通过插入mergetool.cmd来替换这个循环?
我只需要一份冲突文件列表。
还有什么比:
git ls-files -u | cut -f 2 | sort -u
or:
git ls-files -u | awk '{print $4}' | sort | uniq
我想我可以为此设置一个方便的别名,但我想知道专业人士是如何做到的。我会用它来写shell循环,比如自动解决冲突等等。也许可以通过插入mergetool.cmd来替换这个循环?
当前回答
git status --short | grep "^UU "
其他回答
我在这里的2美分(即使有很多很酷/有用的回应)
我在.gitconfig中创建了这个别名
[alias]
...
conflicts = !git diff --name-only --diff-filter=U | grep -oE '[^/ ]+$'
它只会显示有冲突的文件的名称。不是他们的全部路线:)
查尔斯·贝利的回答略有变化,提供了更多信息:
git diff --name-only --diff-filter=U | xargs git status
我一直只使用git状态。
可以在最后添加awk来获得文件名吗
git status -s | grep ^U | awk '{print $2}'
这里有一个万无一失的方法:
grep -H -r "<<<<<<< HEAD" /path/to/project/dir
你可以在命令行上点击git ls-files -u,它会列出有冲突的文件