X-Git-Url: https://git.proxmox.com/?a=blobdiff_plain;f=BaseTools%2Ftoolsetup.bat;h=5629bbaa41da03d6a1ab768c0e7a813c3faf7ce2;hb=08283b966ea10c0430140dc2b2951d8534d05aaa;hp=b58560d4d7d5d62538bfd1cdd6a8088c75f2f294;hpb=7702ceb8afa4f94b949eca4fbbc5dc84e550e082;p=mirror_edk2.git diff --git a/BaseTools/toolsetup.bat b/BaseTools/toolsetup.bat index b58560d4d7..5629bbaa41 100755 --- a/BaseTools/toolsetup.bat +++ b/BaseTools/toolsetup.bat @@ -270,11 +270,11 @@ goto check_build_environment :check_c_tools echo. - echo !!! ERROR !!! Binary C tools are missing. They are requried to be built from BaseTools Source. + echo !!! ERROR !!! Binary C tools are missing. They are required to be built from BaseTools Source. echo. :check_build_environment - if defined BASETOOLS_PYTHON_SOURCE goto VisualStudioAvailable + set PYTHONHASHSEED=1 if not defined BASE_TOOLS_PATH ( if not exist "Source\C\Makefile" ( @@ -285,24 +285,92 @@ goto check_build_environment ) ) - if not defined PYTHON_HOME ( - if defined PYTHONHOME ( - set PYTHON_HOME=%PYTHONHOME% - ) else ( +:defined_python +if defined PYTHON_COMMAND if not defined PYTHON3_ENABLE ( + goto check_python_available +) +if defined PYTHON3_ENABLE ( + if "%PYTHON3_ENABLE%" EQU "TRUE" ( + set PYTHON_COMMAND=py -3 + goto check_python_available + ) else ( + goto check_python2 + ) +) +if not defined PYTHON_COMMAND if not defined PYTHON3_ENABLE ( + set PYTHON_COMMAND=py -3 + py -3 %BASE_TOOLS_PATH%\Tests\PythonTest.py >PythonCheck.txt 2>&1 + setlocal enabledelayedexpansion + set /p PythonCheck=<"PythonCheck.txt" + del PythonCheck.txt + if "!PythonCheck!" NEQ "TRUE" ( + if not defined PYTHON_HOME if not defined PYTHONHOME ( + endlocal + set PYTHON_COMMAND= echo. - echo !!! ERROR !!! Binary python tools are missing. PYTHON_HOME environment variable is not set. - echo PYTHON_HOME is required to build or execute the python tools. + echo !!! ERROR !!! Binary python tools are missing. + echo PYTHON_COMMAND, PYTHON3_ENABLE or PYTHON_HOME + echo Environment variable is not set successfully. + echo They is required to build or execute the python tools. echo. goto end + ) else ( + goto check_python2 ) + ) else ( + goto check_freezer_path + ) +) + +:check_python2 +endlocal +if defined PYTHON_HOME ( + if EXIST "%PYTHON_HOME%" ( + set PYTHON_COMMAND=%PYTHON_HOME%\python.exe + goto check_python_available + ) +) +if defined PYTHONHOME ( + if EXIST "%PYTHONHOME%" ( + set PYTHON_HOME=%PYTHONHOME% + set PYTHON_COMMAND=%PYTHON_HOME%\python.exe + goto check_python_available + ) +) +echo. +echo !!! ERROR !!! PYTHON_HOME is not defined or The value of this variable does not exist +echo. +goto end +:check_python_available +%PYTHON_COMMAND% %BASE_TOOLS_PATH%\Tests\PythonTest.py >PythonCheck.txt 2>&1 + setlocal enabledelayedexpansion + set /p PythonCheck=<"PythonCheck.txt" + del PythonCheck.txt + if "!PythonCheck!" NEQ "TRUE" ( + echo. + echo ! ERROR ! "%PYTHON_COMMAND%" is not installed or added to environment variables + echo. + goto end + ) else ( + goto check_freezer_path ) +:check_freezer_path + endlocal + if defined BASETOOLS_PYTHON_SOURCE goto print_python_info set "PATH=%BASE_TOOLS_PATH%\BinWrappers\WindowsLike;%PATH%" set BASETOOLS_PYTHON_SOURCE=%BASE_TOOLS_PATH%\Source\Python set PYTHONPATH=%BASETOOLS_PYTHON_SOURCE%;%PYTHONPATH% +:print_python_info echo PATH = %PATH% - echo PYTHON_HOME = %PYTHON_HOME% + if defined PYTHON3_ENABLE if "%PYTHON3_ENABLE%" EQU "TRUE" ( + echo PYTHON3_ENABLE = %PYTHON3_ENABLE% + echo PYTHON3 = %PYTHON_COMMAND% + ) else ( + echo PYTHON3_ENABLE = FALSE + echo PYTHON_COMMAND = %PYTHON_COMMAND% + ) echo PYTHONPATH = %PYTHONPATH% echo.