0

如何检索所有更改了具有一种或两种扩展名的文件的提交,例如“.YAML”和“.JSON”?

4

1 回答 1

5
git log --no-merges --oneline --name-status -- :*.yaml :*.json

--oneline这里--name-status基本上是眼睛糖果。

的原因--no-merges是,合并是合并历史中的所有更改,因此在合并中更改的所有文件都来自任一父项。但是由于您没有限制回退,您将看到最初进行这些更改的提交(并且git log知道这一点,并且通常不会显示合并提交的差异,因为这会变得重复并且越来越差 -随着历史变得越来越大,没用)。

--first-parent而不是--no-merges选择路径告诉您哪些文件通过(不再排除)合并仅相对于第一个父项进行了更改;它不会向您显示更改这些文件的单个合并提交,而是向您显示将这些更改带入您已签出的第一父历史记录的合并。

git log有路径,也--first-parent没有--no-merges证明仅作为取证查询有用。

于 2021-10-22T22:42:44.767 回答