X-Git-Url: https://git.proxmox.com/?p=mirror_edk2.git;a=blobdiff_plain;f=edksetup.bat;h=f066d869e1e3f8e146dc8e64a554e50c638da84d;hp=6e526cdd03c6c12b4cd85177a23358bcd527b1d6;hb=b752e8a3fb685ae04155bf6a34a9aac83810613f;hpb=7ef23d9c2c2fe8e295f85d44591dd9f0d1fbc0bc diff --git a/edksetup.bat b/edksetup.bat index 6e526cdd03..f066d869e1 100755 --- a/edksetup.bat +++ b/edksetup.bat @@ -1,7 +1,7 @@ @REM @file @REM Windows batch file to setup a WORKSPACE environment @REM -@REM Copyright (c) 2006 - 2013, Intel Corporation. All rights reserved.
+@REM Copyright (c) 2006 - 2016, Intel Corporation. All rights reserved.
@REM This program and the accompanying materials @REM are licensed and made available under the terms and conditions of the BSD License @REM which accompanies this distribution. The full text of the license may be found at @@ -42,9 +42,11 @@ if %WORKSPACE% == %CD% ( :SetWorkSpace @REM set new workspace @REM clear EFI_SOURCE and EDK_SOURCE for the new workspace -set WORKSPACE=%CD% -set EFI_SOURCE= -set EDK_SOURCE= +if not defined WORKSPACE ( + set WORKSPACE=%CD% + set EFI_SOURCE= + set EDK_SOURCE= +) :ParseArgs if /I "%1"=="-h" goto Usage @@ -61,24 +63,32 @@ if /I not "%1"=="--nt32" goto no_nt32 @REM and headers to interface with Windows. if not defined VCINSTALLDIR ( - if defined VS110COMNTOOLS ( - call "%VS110COMNTOOLS%\vsvars32.bat" + if defined VS140COMNTOOLS ( + call "%VS140COMNTOOLS%\vsvars32.bat" ) else ( - if defined VS100COMNTOOLS ( - call "%VS100COMNTOOLS%\vsvars32.bat" - ) else ( - if defined VS90COMNTOOLS ( - call "%VS90COMNTOOLS%\vsvars32.bat" + if defined VS120COMNTOOLS ( + call "%VS120COMNTOOLS%\vsvars32.bat" + ) else ( + if defined VS110COMNTOOLS ( + call "%VS110COMNTOOLS%\vsvars32.bat" ) else ( - if defined VS80COMNTOOLS ( - call "%VS80COMNTOOLS%\vsvars32.bat" + if defined VS100COMNTOOLS ( + call "%VS100COMNTOOLS%\vsvars32.bat" ) else ( - if defined VS71COMNTOOLS ( - call "%VS71COMNTOOLS%\vsvars32.bat" + if defined VS90COMNTOOLS ( + call "%VS90COMNTOOLS%\vsvars32.bat" ) else ( - echo. - echo !!! WARNING !!! Cannot find Visual Studio !!! - echo. + if defined VS80COMNTOOLS ( + call "%VS80COMNTOOLS%\vsvars32.bat" + ) else ( + if defined VS71COMNTOOLS ( + call "%VS71COMNTOOLS%\vsvars32.bat" + ) else ( + echo. + echo !!! WARNING !!! Cannot find Visual Studio !!! + echo. + ) + ) ) ) ) @@ -88,11 +98,34 @@ if not defined VCINSTALLDIR ( shift :no_nt32 + if /I "%1"=="NewBuild" shift -if not defined EDK_TOOLS_PATH set EDK_TOOLS_PATH=%WORKSPACE%\BaseTools +if not defined EDK_TOOLS_PATH ( + if exist %WORKSPACE%\BaseTools ( + set EDK_TOOLS_PATH=%WORKSPACE%\BaseTools + ) else ( + if defined PACKAGES_PATH ( + for %%i IN (%PACKAGES_PATH%) DO ( + if exist %%~fi\BaseTools ( + set EDK_TOOLS_PATH=%%~fi\BaseTools + goto checkBaseTools + ) + ) + ) else ( + echo. + echo !!! ERROR !!! Cannot find BaseTools !!! + echo. + goto BadBaseTools + ) + ) +) +if exist %EDK_TOOLS_PATH%\Source set BASE_TOOLS_PATH=%EDK_TOOLS_PATH% + +:checkBaseTools IF NOT EXIST "%EDK_TOOLS_PATH%\toolsetup.bat" goto BadBaseTools call %EDK_TOOLS_PATH%\toolsetup.bat %* if /I "%1"=="Reconfig" shift +goto check_NASM goto check_cygwin :BadBaseTools @@ -109,7 +142,23 @@ goto check_cygwin @echo. goto end +:check_NASM +if not defined NASM_PREFIX ( + @echo. + @echo !!! WARNING !!! NASM_PREFIX environment variable is not set + @if exist "C:\nasm\nasm.exe" @set "NASM_PREFIX=C:\nasm\" + @if exist "C:\nasm\nasm.exe" @echo Found nasm.exe, setting the environment variable to C:\nasm\ + @if not exist "C:\nasm\nasm.exe" echo Attempting to build modules that require NASM will fail. +) + :check_cygwin +if defined CYGWIN_HOME ( + if not exist "%CYGWIN_HOME%" ( + @echo. + @echo !!! WARNING !!! CYGWIN_HOME not found, gcc build may not be used !!! + @echo. + ) +) else ( if exist c:\cygwin ( set CYGWIN_HOME=c:\cygwin ) else ( @@ -117,9 +166,10 @@ goto check_cygwin @echo !!! WARNING !!! No CYGWIN_HOME set, gcc build may not be used !!! @echo. ) +) -if NOT "%1"=="" goto Usage -goto end +:cygwin_done +if "%1"=="" goto end :Usage @echo. @@ -129,8 +179,8 @@ goto end @echo Reconfig Reinstall target.txt, tools_def.txt and build_rule.txt. @echo. @echo Note that target.template, tools_def.template and build_rules.template - @echo will be only copied to target.txt, tools_def.txt and build_rule.txt - @echo respectively if they do not exist. Using option [Reconfig] to force the copy. + @echo will only be copied to target.txt, tools_def.txt and build_rule.txt + @echo respectively if they do not exist. Use option [Reconfig] to force the copy. @echo. goto end