如何查看单个文件的历史记录以及更改内容的完整详细信息?
git-log--[filename]显示文件的提交历史,但如何查看更改的文件内容?
如何查看单个文件的历史记录以及更改内容的完整详细信息?
git-log--[filename]显示文件的提交历史,但如何查看更改的文件内容?
当前回答
如果您使用TortoiseGit,您应该能够右键单击该文件并执行TortoiseGit-->显示日志。在弹出的窗口中,确保:
未选中“显示整个项目”选项。选中“所有分支”选项。
其他回答
将此别名添加到.gitconfig中:
[alias]
lg = log --all --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset'\n--abbrev-commit --date=relative
使用如下命令:
> git lg
> git lg -- filename
输出看起来几乎与gitk输出完全相同。享受
您也可以尝试这个方法,它列出了更改文件特定部分的提交(在Git1.8.4中实现)。
返回的结果将是修改此特定部分的提交列表。命令:
git log --pretty=short -u -L <upperLimit>,<lowerLimit>:<path_to_filename>
其中upperLimit是文件的起始行号,lowerLimit是结束行号。
更多详情请访问http://techpurohit.in/list-some-useful-git-commands.
我大概是想知道OP开始时的位置,寻找一些简单的东西,让我可以使用gitdifftool和vimdiff从特定提交开始查看repo中文件的更改。我对我找到的答案不太满意,所以我把这个gitincremental reporter(gitincrement reporter)脚本放在一起,它对我很有用:
#!/usr/bin/env bash
STARTWITH="${1:-}"
shift 1
DFILES=( "$@" )
RunDiff()
{
GIT1=$1
GIT2=$2
shift 2
if [ "$(git diff $GIT1 $GIT2 "$@")" ]
then
git log ${GIT1}..${GIT2}
git difftool --tool=vimdiff $GIT1 $GIT2 "$@"
fi
}
OLDVERS=""
RUNDIFF=""
for NEWVERS in $(git log --format=format:%h --reverse)
do
if [ "$RUNDIFF" ]
then
RunDiff $OLDVERS $NEWVERS "${DFILES[@]}"
elif [ "$OLDVERS" ]
then
if [ "$NEWVERS" = "${STARTWITH:=${NEWVERS}}" ]
then
RUNDIFF=true
RunDiff $OLDVERS $NEWVERS "${DFILES[@]}"
fi
fi
OLDVERS=$NEWVERS
done
调用时不带任何参数,这将从回购历史的开始处开始,否则它将从您提供的任何缩写提交哈希开始,并继续到现在-您可以随时使用ctrl-C退出。第一个参数之后的任何参数都将限制差异报告仅包括这些参数中列出的文件(我认为这是OP想要的,我建议所有项目都使用这些文件,但小项目除外)。如果您正在检查对特定文件的更改,并希望从头开始,则需要为arg1提供空字符串。如果你不是vim用户,你可以用你喜欢的diff工具替换vimdiff。
行为是在发现相关更改时输出提交注释,并开始为每个更改的文件提供vimdiff运行(这是gitdifftool行为,但它在这里起作用)。
这种方法可能很幼稚,但在这里和一篇相关文章中查看了许多解决方案,其中许多涉及在我没有管理员权限的系统上安装新工具,界面有自己的学习曲线。上面的脚本做了我想做的事情,但没有处理这些。当我需要更复杂的东西时,我会研究这里的许多优秀建议,但我认为这是对OP的直接响应。
阅读并播放一点后,总结其他答案:
通常的命令行命令是
git log --follow --all -p dir/file.c
但是,您也可以使用gitk(GUI)或tig(文本UI)来提供更多人类可读的方式来查看它。
gitk --follow --all -p dir/file.c
tig --follow --all -p dir/file.c
在Debian/Uubuntu下,这些可爱工具的安装命令如下所示:
sudo apt-get install gitk tig
我目前正在使用:
alias gdf='gitk --follow --all -p'
这样我就可以键入gdf-dir来获取子目录dir中所有内容的集中历史。
最近我发现了tig,发现它非常有用。有些情况下,我希望它能做到A或B,但大多数时候它都很整洁。
对于您的情况,tig<filename>可能是您需要的。
https://jonas.github.io/tig/