如何解决我可以使用它的索引而不是它的路径来引用“git diff path/to/file”中的脚本吗?
我确实经常想快速检查我所做的更改。使用 git status
通常如下所示:
$ git status
On branch develop
Your branch is ahead of 'develop' by 2 commits.
(use "git push" to publish your local commits)
Changes not staged for commit:
(use "git add <file>..." to update what will be committed)
(use "git restore <file>..." to discard changes in working directory)
modified: Assets/_Project/Scripts/Controls/ControllerManager.cs
modified: Assets/_Project/Scripts/UI/TabletManager.cs
no changes added to commit (use "git add" and/or "git commit -a")
要检查我所做的更改,我必须使用 git diff Assets/_Project/Scripts/UI/TabletManager.cs
和文件的完整路径,这些文件通常很长。但是由于我经常使用这个功能,只是修改了一些脚本,我想知道是否有类似快速访问选项的东西?也许通过传递修改后的文件的索引?类似于 git diff 1
的内容,用于查看 TabletManager 中所做的更改而不是完整路径。
解决方法
我认为 git 没有您希望的快速访问选项,因为大多数情况下自动完成就足够了,正如@torek 在评论中告诉您的那样。
如果你真的想要这个功能,你可以自己创建。
-
首先创建一个专用于 git 扩展的文件夹,然后
cd
到它 -
创建一个脚本文件并将其命名为类似
git-easydiff
。现在我将它添加为本地别名,但您甚至可以使用自定义命令扩展 git,here 描述了如何。顺便说一下,一个可能的脚本可能是:#!/bin/bash changed_files=( $(git diff --name-only) ) for ((i = 0; i < ${#changed_files[@]}; i++)) do echo "$i - ${changed_files[$i]}" done; read -p "Index of file to git-diff: " git diff ${changed_files[$REPLY]}
-
现在是别名
git config alias.easydiff '!/directory_with_git_extensions/git-easydiff'
开头的
!
是必须的,因为该命令不是 git 命令。
您可以将其称为git easydiff
,输出为:
0 - file1
1 - file2
Index of file to git-diff: 1
... diff for file2 ...
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。