我们有一个C ++ Builder XE项目(VCL Forms Application),里面有几十个表单和单元。每当添加,删除或重命名属于项目的文件时,IDE都应该做两件事:
然而,IDE不是仅进行必要的更改,而是对现有的USEFORM和CppCompile记录进行洗牌,即使它们不受更改的影响。如果我添加一个单元(cpp和头文件),即使不需要对项目源进行任何更改,也只需要对cbproj文件进行任何更改,USEFORM都会被洗牌。
我没有看到新订单如何形成的具体模式。如果我编辑或重命名一个单元,大约一半的USEFORMs似乎改变了位置,只改变了一对或没有CppCompile记录。如果在两台不同的机器上对项目副本进行了更改,则大多数更改似乎都相似,但并非全部。这表明重新排序不是随机的。
使用Subversion合并更改时,该行为会导致问题,因为它会强制手动解决更改顺序造成的冲突。
所以问题是:什么可能导致上述行为以及如何摆脱它?
答案 0 :(得分:1)
我一直无法找到问题的正确解决方案,但这里有一个简单的方法可以让它稍微烦人:
采用永远不会将随机IDE生成的更改提交到版本控制存储库的策略。每当您对触发混合文件的代码进行更改时,请在{{1}中还原所有不必要的更改}和ProjectName.cpp
。在这一点上它仍然相当容易,因为你知道文件的哪些部分实际上应该已经改变。这样,手工劳动是在仍然需要最少量工作的情况下进行的。此外,工作只需执行一次,而不是保持不变,所以每次有人合并更改时都必须重复工作。