为什么 Eclipse CDT 代码格式化程序有时会在模板参数中引入空格?

Why does the Eclipse CDT code formatter sometimes introduce spaces in template arguments?

我正在使用 Eclipse 4.12.0 和 Eclipse CDT 9.8.1,并且正在编写使用 std::tuple 的 C++ 代码。有时,代码格式化程序会在我检索元组条目的代码中引入额外的空格。

请考虑以下示例文件:

#include <tuple>

int main(int, char**)
{
    std::tuple<int, int> myTuple; // First important line

    std::get<0>(myTuple) = 2; // Second important line

    return 0;
}

我在这里粘贴了Eclipse格式化的代码。在这个例子中一切都很好。但是当我将注释标记为重要的两行复制并粘贴到我项目的另一个 .cpp 文件中并格式化它们时,结果是这样的:

    std::tuple<int, int> myTuple; // First important line

    std::get < 0 > (myTuple) = 2; // Second important line

格式化程序在模板尖括号前后引入了空格,就好像我要进行 "greater than" 或 "lower than" 比较一样。这种效果似乎在某种程度上取决于项目。如果它发生在我的项目资源管理器中一个项目的源文件中,它似乎发生在该项目的每个源文件中。但是只要我将这些行粘贴到 另一个 项目的源文件中,代码格式化程序就会正确运行(就像上面给出的示例文件一样)。

我没有将此作为错误报告,因为我不知道如何使其可重现。有谁知道原因可能是什么?我没有启用项目特定的代码格式化程序设置,因此它不应该是一个简单的配置错误。添加或删除行 #include <tuple> 也没有什么区别。我还能尝试什么?

这个问题的直接原因几乎可以肯定是 Eclipse 错误地解析了代码,并认为 <> 字符实际上是比较运算符,因为它在它们周围放置了空格.

至于为什么会把代码解析错? C++ 是一种难以解析的语言,CDT 的解析器一直没有跟上新的 C++ 语言版本(即使对于旧的 C++ 版本,它也从未完全准确)。

事实 "if it happens within a source file of one project, it seems to happen within every source file of that project" 表明错误解析发生在头文件中,该头文件的解析表示由项目中的所有文件共享。

如果格式化是您使用 Eclipse CDT 的唯一问题,我推荐 CppStyle plugin。它使用基于 clang 的格式化程序,可以正确解析 C++。