8

我在 VS 2010 中发生了一个相对简单的构建后事件,只有两个复制操作。

复制操作的输出显示它们已成功,并且我检查了目录并且文件复制工作正常。

VS 告诉我构建失败但没有告诉我为什么......这是确切的输出:

1>PostBuildEvent:
1>  Description: Copying Library to Animation-Calibrator
1>          1 file(s) copied.
1>  
1>  -------------------------------------------------------------------------------
1>     ROBOCOPY     ::     Robust File Copy for Windows                              
1>  -------------------------------------------------------------------------------
1>  
1>    Started : Thu Jul 05 14:26:34 2012
1>  
1>     Source : C:\Users\Tag\Google Drive\Projects\TGAEngine\VS2010\obj\
1>       Dest : C:\Users\Tag\Google Drive\Projects\Animation-Calibrator\lib\TGAEngine\obj\
1>  
1>      Files : *.*
1>          
1>    Options : *.* /S /COPY:DAT /R:1000000 /W:30 
1>  
1>  ------------------------------------------------------------------------------
... List of files copied, no errors
1>  
1>  ------------------------------------------------------------------------------
1>  
1>                 Total    Copied   Skipped  Mismatch    FAILED    Extras
1>      Dirs :         2         0         2         0         0         0
1>     Files :        29        29         0         0         0         1
1>     Bytes :    1.92 m    1.92 m         0         0         0       697
1>     Times :   0:00:00   0:00:00                       0:00:00   0:00:00
1>  
1>  
1>     Speed :           100824150 Bytes/sec.
1>     Speed :            5769.204 MegaBytes/min.
1>  
1>     Ended : Thu Jul 05 14:26:34 2012
1>C:\Program Files (x86)\MSBuild\Microsoft.Cpp\v4.0\Microsoft.CppCommon.targets(113,5): error MSB3073: The command "copy /y .\TGAEngine.lib .\..\..\Animation-Calibrator\lib\TGAEngine
1>C:\Program Files (x86)\MSBuild\Microsoft.Cpp\v4.0\Microsoft.CppCommon.targets(113,5): error MSB3073: robocopy /s ".\obj" ".\..\..\Animation-Calibrator\lib\TGAEngine\obj"
1>C:\Program Files (x86)\MSBuild\Microsoft.Cpp\v4.0\Microsoft.CppCommon.targets(113,5): error MSB3073: :VCEnd" exited with code 3.
1>
1>Build FAILED.
1>
1>Time Elapsed 00:00:00.11
========== Build: 0 succeeded, 1 failed, 0 up-to-date, 0 skipped ==========

我已将其范围缩小到 robocopy 命令。
如果我做robocopy /s source destVS失败。
如果我不使用参数 '/s' 它不会失败,但文件不会被复制。

有什么想法吗?

我只是不发布脚本,因为我手动运行它并且没有任何类型的错误。

4

2 回答 2

11

通常,如果进程成功则返回退出状态0,如果失败则返回非零。 robocopy似乎有一个非标准的退出代码定义:1 也意味着成功;0 意味着没有文件被复制。你现在明白为什么如果你省略 VS 不会抱怨/s吗?

您的进程似乎以状态 3 退出。robocopy如果这符合您的要求,请查看 's 文档。据我了解,任何 2 或更大的值都意味着麻烦。

如果它指示错误情况,您应该自己检查退出代码,如果一切正常,则以 0 退出(下面的代码未经测试):

if ERRORLEVEL 2 goto HandleError
exit 0
:HandleError
exit %ERRORLEVEL%
于 2012-07-05T21:51:44.490 回答
1

我在这里找到了这个

(robocopy /s source dest) ^& IF %ERRORLEVEL% LEQ 3 exit 0

It's a shorter version of krlmlr's answer that can be run in a single command line. I deem error level 3 or below as successful as it is the exit code when it copies files (exit code 1) and there are extra files in the destination (exit code 2).

于 2017-08-30T03:29:18.027 回答