8

我们有一个 C++Builder XE 项目(VCL 表单应用程序),其中包含几十个表单和单元。每当添加、删除或重命名属于项目的文件时,IDE 应该做两件事:

  1. 如果受影响的单元是窗体或框架,则会在项目源文件 (ProjectName.cpp) 中添加或更改对 USEFORM 宏的调用
  2. 添加或更改项目文件 (ProjectName.cbproj) 中的 CppCompile 元素

但是,IDE 不仅会进行必要的更改,还会对一些现有的 USEFORM 和 CppCompile 记录进行洗牌,即使它们不受更改的影响。如果我添加一个单元(cpp 和头文件),则即使不需要对项目源进行任何更改,也会对 USEFORM 进行改组,仅对 cbproj 文件进行更改。

我没有看到新订单如何形成的具体模式。如果我编辑或重命名单个单元,大约一半的 USEFORM 似乎改变了位置,只有几个或没有 CppCompile 记录。如果在两台不同的机器上对项目的副本进行更改,大多数更改似乎相似,但不是全部。这表明重新排序不是随机的。

当使用 Subversion 合并更改时,该行为会导致问题,因为它强制手动解决更改顺序造成的冲突。

所以问题是:什么可能导致上述行为以及如何摆脱它?

4

1 回答 1

3

我一直无法找到解决问题的适当方法,但这里有一个简单的方法可以让它稍微不那么烦人:

采用从不将 IDE 生成的随机更改提交到版本控制存储库的策略。每当您对触发混合文件的代码进行更改时,请还原ProjectName.cpp和中所有不必要的更改ProjectName.cbproj。在这一点上,它仍然相当容易,因为您知道文件的哪些部分实际上应该更改。这样,在仍然需要最少工作量的情况下进行体力劳动。此外,这项工作只需要执行一次,而不是让更改保持不变,在这种情况下,每次有人合并更改时都必须重复这项工作。

于 2014-02-15T15:32:43.850 回答