11

我的 build.bat 文件中有这段代码

for /R %~dp0 %%A In (*.sln) do (
c:\Windows\Microsoft.NET\Framework\v4.0.30319\msbuild.exe %%A /t:rebuild /nologo /verbosity:minimal /flp:Verbosity=detailed;LogFile=%~dp0\Logs.txt;append=true /m /p:Configuration=Debug;Platform="Any CPU" /p:VisualStudioVersion="12.0"
if not %errorlevel%==0 set Failed+=1
pause)

我的问题是 %errorlevel% 始终为 0,即使日志文件有错误和警告。

4

2 回答 2

6

JozefZ 的评论帮助了我:

使用 SETLOCAL EnableDelayedExpansion 和 !errorlevel! 而不是 %errorlevel% 或(更好)返回 If ErrorLevel 1 语法。设置 EnabledDelayedExpansion 将导致每个变量在执行时而不是在解析时展开:解析时,命令解释器逐行计算变量和/或 command_by_command,但 () 括号中的所有代码块都认为是一个命令。另一方面,如果 ErrorLevel 1 应该被读取为好像 ErrorLevel 大于或等于 1 因此不等于 0

于 2015-03-23T16:40:41.343 回答
5

我花了一点时间来解决这个问题,但这对我有用:

msbuild mySolution.sln
if errorlevel 1 exit /b errorlevel

我不需要使用SETLOCAL EnableDelayedExpansion

于 2018-03-09T18:54:06.807 回答