忽略多行注释 git diff

Ignore multiline comments git diff

我试图找出 C/C++ 源代码中只有源代码发生变化的显着差异。我知道您可以使用 git diff -G<regex>,但在可以是 运行 的正则表达式类型方面似乎非常有限。例如,它似乎没有提供一种方法来忽略 C/C++.

中的多行注释

git 或最好是 libgit2 中是否有任何方法可以在差异 运行 之前忽略注释(包括多行)、空格等?或者确定 diff 输出中的一行是否是注释的方法?

git diff -w 忽略空格差异。

您不能忽略多行注释,因为 git 是一个版本控制工具,而不是依赖于语言的解释器。它不知道你的代码是 C++。它不解析文件的语义,因此它无法解释什么是注释,什么不是。特别是,它依赖于 diff(或配置的 difftool)来比较文本文件,并且需要逐行比较。

我同意@andrew-c 的观点,您真正要问的是在没有注释的情况下比较两段代码。更具体地说,您要求比较所有多行注释已变成空行的代码行。您将空白行保留在那里,以便在普通副本上引用正确的行号。

因此您可以手动转换这两种代码状态以清除多行注释...或者您可以考虑构建自己的差异包装器来为您进行剥离。但后者可能不值得付出努力。

您可以使用 git 属性和差异过滤器来实现此目的,如 中所述,以调用 sed 脚本,但是如果您希望它处理所有情况,那么它本身就非常复杂字符串文字中的注释分隔符等