gpt4 book ai didi

java - Git:查找仅更改了serialVersionUID的文件

转载 作者:行者123 更新时间:2023-11-30 10:05:54 25 4
gpt4 key购买 nike

我有一组自动生成的Java文件,已将其检入git。每个文件包含以下行

final static long serialVersionUID = -4268385597939353497L;


其中,每次重新生成后,serialVersionUID之后的部分都会更改为随机数。

注意:这是一成不变的,我知道“不将生成的代码检入版本控制等中”。

如何识别仅更改serialVersionUID的所有文件?
更改表示文件已在工作副本中被修改,但尚未提交。

我的目标是通过预提交挂钩还原这些文件。

我已经走了

git diff -U10000 --raw MyFile.java


这给了我整个文件的差异
要么

git diff -U0 --raw --word-diff=porcelain MyFile.java


这给了我一个“差异标题”以及更改列表。

最佳答案

注意:这个特定的StackOverflow答案无法解决您的问题(由于我没有Java解析器,因此我无法正确解决该问题)。这将涉及您将要遇到的所有其他绊脚石,以及如何避免它们,因此您的任务实际上只是与Java相关的部分。

请务必注意,这里每个文件都有三个副本:


当前提交中的一个,HEAD:MyFile.java(使用git show HEAD:MyFile.java查看这一行);
建议的下一个提交中的一个,:MyFile.java(再次使用git show进行查看);和
您工作树中的一个MyFile.java,您可以直接查看和编辑它。


通常,git diff命令将从三个比较中选择两个进行比较。

不带任何参数或仅选择一个文件(而不是提交)的参数运行git diff会将文件的索引副本与工作树副本进行比较。它不会提取当前提交的文件。索引副本是git commit将写入新提交的副本,因此实际上就是您现在要提交的内容。

使用git diff --cached告诉Git将HEAD中的文件与索引中的文件进行比较。使用git diff HEAD告诉Git将HEAD中的文件与工作树中的文件进行比较。因此,这些都是您选择比较哪些文件对的方式。但是无论如何,每个git diff只会选择一对文件,或者如果让Git比较所有文件,则会选择一对对。

如果您运行git commit -a(我建议您不要在这里运行),则该命令与git add -u && git commit大致相同,不同之处在于它会使用更新的文件构建临时索引。由于现在存在多个具有不同的protocol-next-commits的不同索引文件,因此在各个commit挂钩中,事情变得特别棘手。这就是为什么我建议在此处避免使用git commit -a的原因。使用一个文件的三个副本已经足够困难,并要进行推理,并且使用棘手的提交选项,例如-a--only--include会将第四套副本,有时甚至是第五套副本扔到文件中。混合。

(Git一次只能处理一个索引文件。标准git commit仅具有一个标准索引文件。标准索引文件包含将要或将要进行下一次提交的文件的副本。1这些选项导致Git创建其他临时索引​​文件,在其中构建建议的新提交,然后在环境中设置$GIT_INDEX_FILE的情况下运行其余操作(包括您的钩子),以使这些子命令查看将要使用的临时索引如果一切顺利,并且git commit完成了新的提交,则这些各种临时索引文件之一(具有基于选项和参数而适当的内容)将成为新索引,然后返回到正常情况下,每个文件只有三个副本。)

由于您的计划是在预提交挂钩中进行的,因此您可能应该将HEAD文件与索引中建议提交的文件进行比较,即您可能应该在此处使用git diff --cached。但是,如果您打算通过计算机程序来执行此操作,而不是像人类在闲暇时阅读的内容那样,则根本不应该使用git diff。前端git diff命令供人类使用,这就是为什么它对输出进行分页和着色并执行所有使计算机程序烦恼的事情的原因。 Git称这些花哨的前端瓷器命令。

每种git diff都是通过后端管道命令实现的。将提交(技术上是树)与索引进行比较的管道命令是git diff-index,它仍然需要--cached告诉它进行所需的比较:git diff-index --cached HEAD产生可预测的输出,而不取决于每个用户的首选的寻呼机,颜色样式等。

(如果您是专门为自己使用而编写此挂钩,则可以使用git diffgit diff-index,因为您可以补偿自己的个人git diff设置。但是,从某种意义上讲,最好使用管道无论如何都要指挥,那么就不需要补偿任何东西了。)

无论您在这里选择什么,都仍然必须编写自己的代码来解释diff输出。您可能改为选择编写一个程序,该程序仅从当前提交和索引中提取感兴趣的两个文件(HEAD:MyFile.java:MyFile.java),然后在您自己的程序中比较它们,而不是使用 。您可以使用 git diff提取文件,但是有一点缺陷,那就是它是另一个瓷器命令。您可以使用 git show(这是基本的管道命令)直接提取文件,而无需通过 git cat-file -p

实际上,解析Java代码将是最可靠的方法,这样您就不会因某种愚蠢的格式更改而烦恼。一种更加棘手的方法,例如假设awk(除了以某种特定形式的一行除外)所有内容都必须匹配(例如一次读取两个文件,请检查两个文件中只有一行是不同的)文件,并具有预期的形式)。所有这些似乎都比尝试解析diff输出要简单,尽管如果要解析diff输出,非Git非上下文diff可能会更简单。

最后,关于:


  我的目标是通过预提交挂钩还原这些文件。


这样做是可以的(对于某些“正确”的定义,Git会正确处理),但是对于许多Git用户而言,这也有些令人惊讶。这样的Git钩子不应该改变事情。人们编写Git的意图是为了像这样的Git钩子只是为了验证事物。如果某项未通过验证步骤,则该挂钩应退出非零值,这将导致 git show停止。任何固定都应该通过一些非挂钩操作完成。

请注意, git commit完全跳过预提交挂钩。



1技术上,索引引用了每个文件的只读副本。因为这些副本是只读的,所以可以共享它们。因此“复制”索引很便宜,因为它实际上只是复制所有引用。此外,提议的新提交中的每个文件与某个现有提交中的文件的每个位100%逐位相同,实际上只是对该文件的引用,因为每个提交中存储的每个文件本身都是完全可读的-只要。

关于java - Git:查找仅更改了serialVersionUID的文件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54985789/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com