如果一个项目无法构建,默认情况下,Visual Studio会继续尝试构建依赖于该项目的所有其他项目,因此会出现愚蠢的错误,因为这些其他项目现在正在针对陈旧版本的二进制文件进行构建。
我怎样才能改变这种行为,并让它在失败时停止?
例如,假设我有一个名为 MyApp.Core 的库项目和一个名为 MyApp 的可执行项目。MyApp 调用 MyApp.Core 中的方法。假设我向该方法添加了一个新参数,然后尝试构建,但我无意中在 MyApp.Core 中引入了一个不相关的编译器错误。当我构建时,Visual Studio 将:
- 尝试构建 MyApp.Core,但由于编译器错误而失败。由于构建失败,磁盘上的 MyApp.Core.dll 保持不变。
- 继续尝试针对旧版本的 MyApp.Core.dll 构建 MyApp,并报告编译器错误,因为它传递的参数比旧 DLL 中的方法预期的要多。
- 在错误窗口顶部报告第二批错误,因此很难找到实际问题。
自 1977 年以来, Make已经解决了这个问题:当它意识到它无法构建时,它就会停止构建。我使用过的所有其他构建系统和 IDE 也足够聪明,可以停止失败的原因。但是 Visual Studio 还没有完全赶上 1977 年的先进技术。
《Visual Studio Hacks》这本书的宏部分有一个解决方法:您可以编写一个在项目构建完成时触发的宏;如果项目的构建状态为“失败”,宏可以发出取消构建命令。我经常在我使用的每台装有 Visual Studio 的计算机上安装这个 hack。但是,我在家里使用不支持宏的 Visual C# Express。
有什么方法可以让 Visual Studio 2010(包括 Express 版本)在构建失败时停止构建?