我如何区分一个文件,比如pom.xml,从主分支到Git中的任意旧版本?
当前回答
通用语法:
$git diff oldCommit..newCommit -- **FileName.xml > ~/diff.txt
所有名为“FileName.xml”的文件在你的repo的任何地方。
注意“——”和“**”之间的空格
回答你的问题:
$git checkout master
$git diff oldCommit..HEAD -- **pom.xml
or
$git diff oldCommit..HEAD -- relative/path/to/pom.xml
和git一样,你可以使用标签/sha1/"HEAD^"来标识提交。
在Ubuntu上用git 1.9.1测试。
其他回答
git diff -w HEAD origin/master path/to/file
如果commit都不是你的HEAD,那么bash的大括号扩展非常有用,特别是如果你的文件名很长,比如上面的例子:
git diff master~20:pom.xml master:pom.xml
将成为
git diff {master~20,master}:pom.xml
更多关于bash的大括号展开。
如果你需要区分一个单独的文件在藏匿,例如,你可以这样做
git diff stash@{0} -- path/to/file
通用语法:
$git diff oldCommit..newCommit -- **FileName.xml > ~/diff.txt
所有名为“FileName.xml”的文件在你的repo的任何地方。
注意“——”和“**”之间的空格
回答你的问题:
$git checkout master
$git diff oldCommit..HEAD -- **pom.xml
or
$git diff oldCommit..HEAD -- relative/path/to/pom.xml
和git一样,你可以使用标签/sha1/"HEAD^"来标识提交。
在Ubuntu上用git 1.9.1测试。
你可以:
git diff master~20:pom.xml pom.xml
... 通过第一个父文件将当前的pom.xml与master在20个修订之前的版本进行比较。当然,您可以用提交的对象名(SHA1sum)或指定修订的任何其他方式来替换master~20。
请注意,这实际上是将旧的pom.xml与工作树中的版本进行比较,而不是在master中提交的版本。如果你想这样做,那么你可以做以下事情:
git diff master~20:pom.xml master:pom.xml
推荐文章
- Git分支之间的视觉差异
- 在GitHub中编辑git提交消息
- 是否有可能' git状态'只修改文件?
- Git:如何区分两个不同的文件在不同的分支?
- 如何从远程Git存储库中提取并覆盖本地存储库中的更改?
- Github:导入上游分支到fork
- Git单次修订的日志
- Git在不改变提交时间戳的情况下进行改基
- VS 2017 Git本地提交数据库。每次提交时锁定错误
- 如何在过去的一些任意提交之间注入一个提交?
- 从GitHub克隆项目后拉git子模块
- GitHub上的分叉和克隆有什么区别?
- 递归地按模式添加文件
- 我如何使用notepad++(或其他)与msysgit?
- 我怎么能显示线在公共(反向差异)?