Windows – 从函数内部退出批处理脚本

前端之家收集整理的这篇文章主要介绍了Windows – 从函数内部退出批处理脚本前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我的批处理文件有问题.
它通过执行以下操作自动生成几个程序:

>设置一些编译标志
>运行’gmake all’
调用“检查错误级别”功能,如果errorlevel 1,退出

所以看起来像这样:

  1. set FLAG=1
  2. ...
  3. gmake all
  4. call :interactive_check
  5. set OTHERFLAG=1
  6. ...
  7. gmake all
  8. call :interactive_check

有6或7个(可能会增长).所以我做了一个功能来检查错误级别,而不是在每一步复制/粘贴它.
问题是这样的:错误检查是通过一个函数进行的:

  1. :interactive_check
  2. if errorlevel 1 (
  3. echo.
  4. echo /!\/!\/!\/!\/!\/!\/!\/!\/!\/!\/!\/!\/!\
  5. echo Error in compilation process... exiting
  6. echo /!\/!\/!\/!\/!\/!\/!\/!\/!\/!\/!\/!\/!\
  7. echo.
  8. cd %root_dir%
  9. exit /B 1
  10. ) ELSE (
  11. echo.Continuing to next step
  12. )
  13. goto:eof

现在,运行它时,退出/ B 1只是退出函数,而不是批处理文件.

你知道如何退出完整的批处理文件,而无需复制/粘贴我的“if errorlevel 1 ..”在每一步?

使用致命的语法错误,如jeb所示,确实会杀死所有批处理,但它也有一个令人讨厌的副作用 – 即在保留SETLOCAL之后的环境变化,即使在批处理结束时它们应该通过隐式ENDLOCAL被丢弃.有关更多信息,请参阅我的DosTips post SETLOCAL continues after batch termination!.

根据Why does a non-interactive batch script think I’ve pressed control-C?上的信息,我发现了一种清除方法,可以从CALLed例程或脚本中退出所有批处理脚本,并且SETLOCAL之后的所有更改都将被正确丢弃.

  1. @echo off
  2. setlocal
  3. set test=AFTER main SETLOCAL
  4. call :sub
  5. echo returning from main NEVER REACHED
  6. exit /b
  7.  
  8. :sub
  9. setlocal
  10. set test=AFTER sub SETLOCAL
  11. set test
  12. call :ExitBatch
  13. echo returning from sub2 NEVER REACHED
  14. exit /b
  15.  
  16.  
  17. :ExitBatch - Cleanly exit batch processing,regardless how many CALLs
  18. if not exist "%temp%\ExitBatchYes.txt" call :buildYes
  19. call :CtrlC <"%temp%\ExitBatchYes.txt" 1>nul 2>&1
  20. :CtrlC
  21. cmd /c exit -1073741510
  22.  
  23. :buildYes - Establish a Yes file for the language used by the OS
  24. pushd "%temp%"
  25. set "yes="
  26. copy nul ExitBatchYes.txt >nul
  27. for /f "delims=(/ tokens=2" %%Y in (
  28. '"copy /-y nul ExitBatchYes.txt <nul"'
  29. ) do if not defined yes set "yes=%%Y"
  30. echo %yes%>ExitBatchYes.txt
  31. popd
  32. exit /b

这是运行上面test.bat的示例输出.您可以看到该脚本从未退出:ExitBatch调用,并且一旦批处理终止,测试变量定义已被正确丢弃.

  1. C:\test>test.bat
  2. test=AFTER sub SETLOCAL
  3.  
  4. C:\test>set test
  5. Environment variable test not defined
  6.  
  7. C:\test>

ExitBatch例程可以放在自己的ExitBatch.bat脚本中,并放置在PATH中的某个位置,以便可以方便地使用任何批处理脚本.

  1. @echo off
  2. :ExitBatch - Cleanly exit batch processing,regardless how many CALLs
  3. if not exist "%temp%\ExitBatchYes.txt" call :buildYes
  4. call :CtrlC <"%temp%\ExitBatchYes.txt" 1>nul 2>&1
  5. :CtrlC
  6. cmd /c exit -1073741510
  7.  
  8. :buildYes - Establish a Yes file for the language used by the OS
  9. pushd "%temp%"
  10. set "yes="
  11. copy nul ExitBatchYes.txt >nul
  12. for /f "delims=(/ tokens=2" %%Y in (
  13. '"copy /-y nul ExitBatchYes.txt <nul"'
  14. ) do if not defined yes set "yes=%%Y"
  15. echo %yes%>ExitBatchYes.txt
  16. popd
  17. exit /b

重要更新:

现在可以使用纯批次来实现强大的异常处理.不仅可以抛出一个可以从任何CALL级别终止所有批处理的异常,而且还可以在更高级别捕获异常,优化特殊异常处理清理代码并恢复处理,或者继续通过另一个抛出来退出!有关更多信息,请参阅Does Windows batch support exception handling?.

猜你在找的Windows相关文章