- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
给定一个提交范围 <old_sha>..<new_sha>
,我想要 committed 的内容(不是已更改文件的列表,也不是它们的差异),截至 <new_sha>
, 在 <old_sha>
之间更改的所有文件中和 <new_sha>
.我不能简单地从磁盘读取,因为我想忽略未提交的更改。
附加约束:
我得到的最接近的是:
git show head:path/to/file_a head:path/to/file_b
,它将提交的文件内容写入标准输出,但没有分隔符,因此无法以编程方式知道每个文件的结束/开始位置。最佳答案
某些已提交文件的内容只能通过读出该文件(Git 术语中的“blob 对象”)获得。因此,给定两个提交哈希 $O
和 $N
(旧的和新的,尽管任何顺序都可以)你将需要:
git diff-tree -r --name-status $O $N
(或任何等效的东西——见下文)并读取它的输出以确定你关心哪些文件;您的 git show
方法可以工作——将 HEAD:path/to/file_a
替换为 $N:path/to/file_a
除非你保证 $N
和 HEAD
引用相同提交——但你需要一个 git show
每个文件的命令。考虑使用 read-tree
和带有临时索引的 git checkout-index
:
tf=$(mktemp)
# an empty file, as made by mktemp, is unsuitable, but a nonexistent
# one is OK, so:
rm -f $tf
假设您也想要旧版本的文件(如果不需要,将其修剪为一个 $N
案例):
GIT_INDEX_FILE=$tf git read-tree $O
# you can now `git checkout-index` files using $tf as the index
如果在名为 $filelist
的文件中有一个 \0
分隔或换行分隔的文件名列表,请考虑使用 --stdin
和一个临时的(空的)工作树,例如:
td=$(mktemp -d)
GIT_WORK_TREE=$td GIT_INDEX_FILE=$tf git checkout-index --stdin < $filelist
为 \0
分隔的文件添加 -z
选项,以防止文件名中出现换行符;例如,如果您编写一个 Python 脚本来使用它自己的 -z
选项运行 git diff-tree
,这将很有用。请记住过滤掉 $O
中不存在但存在于 $N
中的所有文件(这些文件在 中显示为
,这就是我们需要 A
$N--name-status
的原因。
临时目录现在填充了来自 $O
的有趣文件。
重复第二个临时目录,用来自 $N
的有趣文件填充其中一个;请记住包含 A
添加的文件并省略 D
删除的文件。如果您在 git diff-tree
步骤中没有明确启用重命名和/或复制检测器,您将不必处理 R
和/或 C
状态文件——这是一个很大的优势——但你将无法检测重命名和/或复制的文件,这可能是一个可怕的错误。
如果您确实需要旧的和新的提交,请注意您可以像上面那样使用 read-tree 和 checkout-index 但没有对文件名的任何限制,现在您有两个完整的提交'树。所以现在您可以使用普通的 diff
或您喜欢的任何其他递归树遍历器。对于很多情况(许多文件相同),这会更慢,但可能更方便。
您现在在两个临时目录中拥有各种文件的内容,您可以在其中对它们进行任何操作。要清理,只需删除两个临时目录和临时索引。
整个过程可能不会非常快(尽管使用 SSD 存储临时文件和目录应该会有很大帮助),但它可能是您能做的最好的。
关于Git:显示在两个修订版之间更改的所有文件的提交内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/71889477/
我试图理解基数排序,但在理解实现实际代码时改 rebase 数时遇到问题。这是我用来学习基数排序的代码,我会尝试解释我不明白的地方。 此代码由 GeeksForGeeks 提供: // C++ imp
话不多说,请看代码: ? 1
本文实例讲述了mysql语句实现简单的增、删、改、查操作。分享给大家供大家参考,具体如下: 1、创建db_shop数据库,如果该数据库不存在则创建 ?
使用oracle触发器 实现对某个表的增改删的监控操作,并记录到另一个表中。 代码: 复制代码代码如下: create or replace trigger test_trigge
java连接数据库增、删、改、查工具类 数据库操作工具类,因为各厂家数据库的分页条件不同,目前支持Mysql、Oracle、Postgresql的分页查询 在Postgresql环境测试过了,其他
1、修改数据 复制代码代码如下: DataRow dr =
注册表可以用来进行存储一些程序的信息,例如用户的权限、或者某些值等,可以根据个人需要进行存储和删减。 当前注册表主目录: 引用包 Wesky.Net.OpenTools 1.0.5或
是否可以将 pdf 页面的页眉更改为与当前所选书签同名的名称?我正在为我的 pdf 生成使用 Flying Saucer 。你能举个例子吗?提前致谢。 最佳答案 这对我适用于 flyingsaucer
好家伙,写后端,这多是一件美逝. 关于这个项目的代码前面的博客有写 我的第一个独立项目 - 随笔分类 - 养肥胖虎 - 博客园 (cnblogs.com
准备工作: 增、删、改、查的方法有很多很多种,这里只展示出常用的几种。 ?
需要5个类: 1.实体类:Person.java 2.抽象类:SQLOperate.java(封装了对数据库的操作) 3.助手类:DBOpenHelper.java(继承SQLiteOpenH
首先是是一个简单的例子,单链表的建立和输出。 程序1.1 复制代码 代码如下: #include<iostream> #include<string> using na
数据库操纵基本流程为: 1、连接数据库服务器 2、选择数据库 3、执行SQL语句 4、处理结果集 5、打印操作信息 其中用到的相关函数有 •resource m
我需要为 iPad 和 iPhone 设置不同颜色的标签,我知道我们可以为不同的尺寸类别更改字体大小,但是有什么方法可以根据尺寸类别的值设置不同的颜色 我知道有可用的代码解决方案,但我想知道 size
假设我有一个物体相对于相机的坐标 X、Y、Z 和方向 Rx、Ry、Rz。此外,我有这个相机在世界上的坐标 U、V、W 和方向 Ru、Rv、Rw。 如何将对象的位置(位置和旋转)转换为其在世界中的位置?
CRUD是Create(创建)、Read(读取)、Update(更新)和Delete(删除)的缩写,它是普通应用程序的缩影。如果您掌握了某框架的CRUD编写,那么意味可以使用该框架创建普通应用程序了
项目结构: 添加页面: &
本文实例讲述了android操作sqlite数据库(增、删、改、查、分页等)及listview显示数据的方法。分享给大家供大家参考,具体如下: 由于刚接触android开发,故此想把学到的基础知识
总括 pandas的索引函数主要有三种: loc 标签索引,行和列的名称 iloc 整型索引(绝对位置索引),绝对意义上的几行几列,起始索引为0 ix 是 iloc 和 loc的合体 at
我是一名优秀的程序员,十分优秀!