X-Git-Url: https://git.proxmox.com/?p=mirror_edk2.git;a=blobdiff_plain;f=edksetup.bat;h=91b83c637d21ead17e07639b06bc7b6b9af383bf;hp=3e2da9a5e816d7d28a4d350685f01eb042354f30;hb=61066b8d7475929f9f453e1ebea4f72d0c020096;hpb=08e4a4125b8602817ee66a7d813259d650bce185 diff --git a/edksetup.bat b/edksetup.bat index 3e2da9a5e8..91b83c637d 100644 --- a/edksetup.bat +++ b/edksetup.bat @@ -10,12 +10,12 @@ @REM @REM set following environment in this file or in command shell -@REM set JAVA_HOME=C:\Java\jdk1.5.0_04 +@REM set JAVA_HOME=C:\Java\jdk1.5.0_06 @REM set ANT_HOME=C:\ANT @REM set XMLBEANS_HOME=C:\xmlbeans @REM set CYGWIN_HOME=C:\cygwin -@REM usage: edksetup.bat [skip] +@REM usage: edksetup.bat [Rebuild] [ForceRebuild] [Reconfig] @REM if the argument, skip is present, only the paths and the @REM test and set of environment settings are performed. @@ -25,6 +25,39 @@ @echo off +@REM +@REM Set the WORKSPACE to the current working directory +@REM +pushd . +cd %~dp0 +set WORKSPACE=%CD% + +@if /I "%1"=="-h" goto Usage +@if /I "%1"=="-help" goto Usage +@if /I "%1"=="--help" goto Usage +@if /I "%1"=="/h" goto Usage +@if /I "%1"=="/?" goto Usage +@if /I "%1"=="/help" goto Usage +@if /I not "%1"=="--nt32" goto check_new_build +if not defined VCINSTALLDIR ( + if defined VS71COMNTOOLS ( + call "%VS71COMNTOOLS%\vsvars32.bat" + ) else ( + if defined VS80COMNTOOLS ( + call "%VS80COMNTOOLS%\vsvars32.bat" + ) else ( + echo. + echo !!! WARNING !!! Cannot find Visual Studio !!! + echo. + ) + ) +) +shift + +:check_new_build +@if /I "%1"=="NewBuild" goto NewBuild + +:AntBuild @REM @REM Check the required system environment variables @REM @@ -32,10 +65,10 @@ :check_vc if defined VCINSTALLDIR goto check_cygwin if defined VS71COMNTOOLS ( - call "%VS71COMNTOOLS%vsvars32.bat" + call "%VS71COMNTOOLS%\vsvars32.bat" ) else ( echo. - echo !!! WARNING !!!! Cannot find Visual Studio !!! + echo !!! WARNING !!! Cannot find Visual Studio !!! echo. ) @@ -45,7 +78,7 @@ if exist c:\cygwin ( set CYGWIN_HOME=c:\cygwin ) else ( echo. - echo !!! WARNING !!!! Not set CYGWIN_HOME, gcc build may not be used !!! + echo !!! WARNING !!! No CYGWIN_HOME set, gcc build may not be used !!! echo. ) @@ -60,43 +93,80 @@ if not exist %ANT_HOME%\lib\ant-contrib.jar goto no_antcontrib if "%XMLBEANS_HOME%"=="" goto no_xmlbeans if not exist %XMLBEANS_HOME%\lib\saxon8.jar goto no_saxon8 -@REM -@REM Set the WORKSPACE to the current working directory -@REM -set WORKSPACE=%CD% - set FRAMEWORK_TOOLS_PATH=%WORKSPACE%\Tools\bin +if not defined ORIGINAL_CLASSPATH set ORIGINAL_CLASSPATH=%CLASSPATH% +set CLASSPATH=%ORIGINAL_CLASSPATH% + if defined WORKSPACE_TOOLS_PATH goto check_path set PATH=%FRAMEWORK_TOOLS_PATH%;%JAVA_HOME%\bin;%ANT_HOME%\bin;%XMLBEANS_HOME%\bin;%PATH% set WORKSPACE_TOOLS_PATH=%FRAMEWORK_TOOLS_PATH% -echo Setting the PATH variable to include the Framework_Tools_Path for this WORKSPACE +echo Setting the PATH variable to include the FRAMEWORK_TOOLS_PATH for this WORKSPACE goto path_ok :check_path if "%FRAMEWORK_TOOLS_PATH%"=="%WORKSPACE_TOOLS_PATH%" goto path_ok set PATH=%FRAMEWORK_TOOLS_PATH%;%PATH% -set WORKSPACE_PATH=%WORKSPACE% -echo Resetting the PATH variable to include the Framework_Tools_Path for this WORKSPACE +set WORKSPACE_TOOLS_PATH=%WORKSPACE%\Tools\bin +echo Resetting the PATH variable to include the FRAMEWORK_TOOLS_PATH for this WORKSPACE :path_ok -if "%1"=="skip" goto skipbuild - -echo. -echo WORKSPACE: %WORKSPACE% -echo JAVA_HOME: %JAVA_HOME% -echo ANT_HOME: %ANT_HOME% -echo XMLBEANS_HOME: %XMLBEANS_HOME% -echo CYGWIN_HOME: %CYGWIN_HOME% -echo PATH: %PATH% -echo. +@if /I "%1"=="ForceRebuild" goto ForceBuild +@if /I "%1"=="Reconfig" goto Reconfig + +@IF NOT EXIST "Tools\Jars\Common.jar" goto NormalBuild +@IF NOT EXIST "Tools\Jars\PcdTools.jar" goto NormalBuild +@IF NOT EXIST "Tools\Jars\GenBuild.jar" goto NormalBuild +@IF NOT EXIST "Tools\Jars\SurfaceArea.jar" goto NormalBuild +@IF NOT EXIST "Tools\Jars\cpptasks.jar" goto NormalBuild +@IF NOT EXIST "Tools\Jars\frameworktasks.jar" goto NormalBuild +@IF NOT EXIST "Tools\bin\FrameworkWizard.jar" goto NormalBuild +@IF NOT EXIST "Tools\bin\CompressDll.dll" goto NormalBuild +@IF NOT EXIST "Tools\bin\CompressDll.lib" goto NormalBuild +@IF NOT EXIST "Tools\bin\CreateMtFile.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\EfiCompress.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\EfiRom.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\FlashMap.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\FwImage.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\GenAcpiTable.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\GenCRC32Section.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\GenCapsuleHdr.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\GenDepex.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\GenFfsFile.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\GenFvImage.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\GenSection.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\GenTEImage.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\GuidChk.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\MakeDeps.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\ModifyInf.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\PeiRebase_Ia32.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\PeiRebase_Ipf.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\PeiRebase_X64.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\SecApResetVectorFixup.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\SecFixup.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\SetStamp.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\SplitFile.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\StrGather.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\Strip.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\VfrCompile.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\ZeroDebugData.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\antlr.exe" goto NormalBuild +@IF NOT EXIST "Tools\bin\dlg.exe" goto NormalBuild + +@if /I "%1"=="Rebuild" goto NormalBuild +@if NOT "%1"=="" goto Usage + +goto skipbuild + +:ForceBuild +call ant -f %WORKSPACE%\Tools\build.xml -noclasspath cleanall +:NormalBuild @REM @REM Start to build the Framework Tools @REM - echo. echo Building the Framework Tools echo. @@ -106,22 +176,21 @@ echo. @REM Java Programs can use it. @REM It needs the XMLBEANS libraries in order to compile. @REM -set CLASSPATH=.;%XMLBEANS_HOME%\lib\jsr173_1.0_api.jar;%XMLBEANS_HOME%\lib\xbean.jar -set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\xbean_xpath.jar;%XMLBEANS_HOME%\lib\xmlpublic.jar -set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\saxon8.jar;%XMLBEANS_HOME%\lib\resolver.jar - -@if "%1" neq "ForceRebuild" goto NormalBuild -call ant -f %WORKSPACE%\Tools\build.xml cleanall +set CLASSPATH=%XMLBEANS_HOME%\lib;%CLASSPATH% +set CLASSPATH=%XMLBEANS_HOME%\lib\jsr173_1.0_api.jar;%CLASSPATH% +set CLASSPATH=%XMLBEANS_HOME%\lib\xbean.jar;%CLASSPATH% +set CLASSPATH=%XMLBEANS_HOME%\lib\xbean_xpath.jar;%CLASSPATH% +set CLASSPATH=%XMLBEANS_HOME%\lib\xmlpublic.jar;%CLASSPATH% +set CLASSPATH=%XMLBEANS_HOME%\lib\saxon8.jar;%CLASSPATH% +set CLASSPATH=%XMLBEANS_HOME%\lib\resolver.jar;%CLASSPATH% -:NormalBuild call ant -f %WORKSPACE%\Tools\build.xml SurfaceArea @REM @REM Now we can make the other Java Programs @REM All of the remaining Java Programs require the SurfaceArea library to compile @REM -set CLASSPATH=%CLASSPATH%;%WORKSPACE%\%Tools\Jars\SurfaceArea.jar - +set CLASSPATH=%WORKSPACE%\Tools\Jars\SurfaceArea.jar;%CLASSPATH% call ant -f %WORKSPACE%\Tools\build.xml JavaCode @@ -129,10 +198,13 @@ call ant -f %WORKSPACE%\Tools\build.xml JavaCode @REM We have all of the Java Programs and add-in classes created, so we can start @REM using the cpp-tasks to create our tools @REM -set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\Common.jar -set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\GenBuild.jar -set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\cpptasks.jar -set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\frameworktasks.jar +set CLASSPATH=%WORKSPACE%\Tools\Jars\Common.jar;%CLASSPATH% +set CLASSPATH=%WORKSPACE%\Tools\Jars\PcdTools.jar;%CLASSPATH% +set CLASSPATH=%WORKSPACE%\Tools\Jars\GenBuild.jar;%CLASSPATH% +set CLASSPATH=%WORKSPACE%\Tools\Jars\cpptasks.jar;%CLASSPATH% +set CLASSPATH=%WORKSPACE%\Tools\Jars\frameworktasks.jar;%CLASSPATH% +set CLASSPATH=%WORKSPACE%\Tools\Bin\FrameworkWizard.jar;%CLASSPATH% +set CLASSPATH=%WORKSPACE%\Tools\Bin\MigrationTools.jar;%CLASSPATH% call ant -f %WORKSPACE%\Tools\build.xml C_Code @@ -183,14 +255,55 @@ echo XMLBEANS_HOME: %XMLBEANS_HOME% echo CYGWIN_HOME: %CYGWIN_HOME% echo PATH: %PATH% echo. -set CLASSPATH=%XMLBEANS_HOME%\lib\jsr173_1.0_api.jar;%XMLBEANS_HOME%\lib\xbean.jar -set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\xbean_xpath.jar;%XMLBEANS_HOME%\lib\xmlpublic.jar -set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\saxon8.jar;%XMLBEANS_HOME%\lib\resolver.jar -set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\SurfaceArea.jar -set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\Common.jar;%WORKSPACE%\Tools\Jars\GenBuild.jar -set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\cpptasks.jar;%WORKSPACE%\Tools\Jars\frameworktasks.jar +set CLASSPATH=%XMLBEANS_HOME%\lib;%CLASSPATH% +set CLASSPATH=%XMLBEANS_HOME%\lib\jsr173_1.0_api.jar;%CLASSPATH% +set CLASSPATH=%XMLBEANS_HOME%\lib\xbean.jar;%CLASSPATH% +set CLASSPATH=%XMLBEANS_HOME%\lib\xbean_xpath.jar;%CLASSPATH% +set CLASSPATH=%XMLBEANS_HOME%\lib\xmlpublic.jar;%CLASSPATH% +set CLASSPATH=%XMLBEANS_HOME%\lib\saxon8.jar;%CLASSPATH% +set CLASSPATH=%XMLBEANS_HOME%\lib\saxon8-dom.jar;%CLASSPATH% +set CLASSPATH=%XMLBEANS_HOME%\lib\saxon8-xpath.jar;%CLASSPATH% +set CLASSPATH=%XMLBEANS_HOME%\lib\resolver.jar;%CLASSPATH% +set CLASSPATH=%WORKSPACE%\Tools\Jars\SurfaceArea.jar;%CLASSPATH% +set CLASSPATH=%WORKSPACE%\Tools\Jars\Common.jar;%CLASSPATH% +set CLASSPATH=%WORKSPACE%\Tools\Jars\PcdTools.jar;%CLASSPATH% +set CLASSPATH=%WORKSPACE%\Tools\Jars\GenBuild.jar;%CLASSPATH% +set CLASSPATH=%WORKSPACE%\Tools\Jars\cpptasks.jar;%CLASSPATH% +set CLASSPATH=%WORKSPACE%\Tools\Jars\frameworktasks.jar;%CLASSPATH% +set CLASSPATH=%WORKSPACE%\Tools\Bin\FrameworkWizard.jar;%CLASSPATH% +set CLASSPATH=%WORKSPACE%\Tools\Bin\MigrationTools.jar;%CLASSPATH% +echo CLASSPATH: %CLASSPATH% goto end +:Reconfig +@REM +@REM Reinstall all config files +@REM +call ant -f %WORKSPACE%\Tools\build.xml reconfig +goto end + +:Usage +echo. +echo Usage: "%0 [--nt32] [NewBuild | Rebuild | ForceRebuild | Reconfig]" +echo --nt32 Call vsvars32.bat for NT32 platform build +echo NewBuild Using new build tools in BaseTools package +echo Rebuild Incremental build, only build those updated tools (Ant build only) +echo ForceRebuild Rebuild all tools neither updated or not (Ant build only) +echo Reconfig Reinstall target.txt, tools_def.txt, FrameworkDatabase.db (Ant build only) +echo. +echo Note that target.template, tools_def.template, FrameworkDatabase.template will be +echo only copied to target.txt, tools_def.txt, FrameworkDatabase.db respectively if they +echo are not existed. Using option [Reconfig] to do the force copy. +echo. +@goto end + +:NewBuild +@IF NOT EXIST "BaseTools\toolsetup.bat" goto AntBuild +if not defined EDK_TOOLS_PATH set EDK_TOOLS_PATH=%WORKSPACE%\BaseTools +@call BaseTools\toolsetup.bat +@goto end + :end +@popd @echo on