Simplify the script. It now allows normal ant targets and flags to be passed straight...
[mirror_edk2.git] / edksetup.bat
index be35f97..722df88 100644 (file)
@@ -4,15 +4,20 @@
 @REM are licensed and made available under the terms and conditions of the BSD License\r
 @REM which accompanies this distribution.  The full text of the license may be found at\r
 @REM http://opensource.org/licenses/bsd-license.php\r
-@REM \r
+@REM\r
 @REM THE PROGRAM IS DISTRIBUTED UNDER THE BSD LICENSE ON AN "AS IS" BASIS,\r
 @REM WITHOUT WARRANTIES OR REPRESENTATIONS OF ANY KIND, EITHER EXPRESS OR IMPLIED.\r
 @REM\r
 \r
 @REM set following environment in this file or in command shell\r
 @REM set JAVA_HOME=C:\Java\jdk1.5.0_04\r
-@REM set WORKSPACE=C:\mdk\r
+@REM set ANT_HOME=C:\ANT\r
+@REM set XMLBEANS_HOME=C:\xmlbeans\r
+@REM set CYGWIN_HOME=C:\cygwin\r
 \r
+@REM usage: edksetup.bat [skip]\r
+@REM if the argument, skip is present, only the paths and the\r
+@REM test and set of environment settings are performed. \r
 \r
 @REM ##############################################################\r
 @REM # You should not have to modify anything below this line\r
 \r
 @echo off\r
 \r
+@REM\r
+@REM Check the required system environment variables\r
+@REM\r
+\r
 :check_vc\r
-if defined VCINSTALLDIR goto check_java\r
+if defined VCINSTALLDIR goto check_cygwin\r
 if defined VS71COMNTOOLS (\r
   call "%VS71COMNTOOLS%vsvars32.bat"\r
 ) else (\r
@@ -30,96 +39,151 @@ if defined VS71COMNTOOLS (
   echo.\r
 )\r
 \r
-:check_java\r
-if "%JAVA_HOME%"=="" goto no_jdk\r
-echo.\r
-echo JAVA_HOME:     %JAVA_HOME%\r
-\r
-@REM Set the WORKSPACE to the Current Working Directory\r
-set WORKSPACE=%~dp0\r
-echo WORKSPACE:     %WORKSPACE%\r
-\r
-:set_cygwin\r
-if not defined CYGWIN_HOME (\r
-  if exist c:\cygwin (set CYGWIN_HOME=c:\cygwin) else (\r
-    echo.\r
-    echo !!! Not set CYGWIN_HOME, gcc build may not be used !!!\r
-    echo.\r
-  )\r
+:check_cygwin\r
+if defined CYGWIN_HOME goto check_java\r
+if exist c:\cygwin (\r
+  set CYGWIN_HOME=c:\cygwin\r
 ) else (\r
-  echo CYGWIN_HOME:   %CYGWIN_HOME%\r
+  echo.\r
+  echo !!! WARNING !!!! Not set CYGWIN_HOME, gcc build may not be used !!!\r
+  echo.\r
 )\r
 \r
+:check_java\r
+if "%JAVA_HOME%"=="" goto no_jdk\r
+\r
+:check_ant\r
 if "%ANT_HOME%"=="" goto no_ant\r
-echo ANT_HOME:      %ANT_HOME%\r
 if not exist %ANT_HOME%\lib\ant-contrib.jar goto no_antcontrib\r
 \r
+:check_xmlbeans\r
 if "%XMLBEANS_HOME%"=="" goto no_xmlbeans\r
-echo XMLBEANS_HOME: %XMLBEANS_HOME%\r
+if not exist %XMLBEANS_HOME%\lib\saxon8.jar goto no_saxon8\r
+\r
+@REM\r
+@REM Set the WORKSPACE to the current working directory\r
+@REM\r
+set WORKSPACE=%CD%\r
+\r
+set FRAMEWORK_TOOLS_PATH=%WORKSPACE%\Tools\bin\r
+\r
+if defined WORKSPACE_TOOLS_PATH goto check_path\r
+set PATH=%FRAMEWORK_TOOLS_PATH%;%JAVA_HOME%\bin;%ANT_HOME%\bin;%XMLBEANS_HOME%\bin;%PATH%\r
+set WORKSPACE_TOOLS_PATH=%FRAMEWORK_TOOLS_PATH%\r
+echo Setting the PATH variable to include the Framework_Tools_Path for this WORKSPACE\r
+goto path_ok\r
 \r
-set Framework_Tools_Path=%WORKSPACE%\Tools\bin\r
+:check_path\r
+if "%FRAMEWORK_TOOLS_PATH%"=="%WORKSPACE_TOOLS_PATH%" goto path_ok\r
+set PATH=%FRAMEWORK_TOOLS_PATH%;%PATH%\r
+set WORKSPACE_PATH=%WORKSPACE%\r
+echo Resetting the PATH variable to include the Framework_Tools_Path for this WORKSPACE\r
 \r
+:path_ok\r
 \r
-set PATH=%Framework_Tools_Path%;%PATH%\r
+if "%1"=="skip" goto skipbuild\r
 \r
-echo PATH:      %PATH%\r
+echo.\r
+echo WORKSPACE:     %WORKSPACE%\r
+echo JAVA_HOME:     %JAVA_HOME%\r
+echo ANT_HOME:      %ANT_HOME%\r
+echo XMLBEANS_HOME: %XMLBEANS_HOME%\r
+echo CYGWIN_HOME:   %CYGWIN_HOME%\r
+echo PATH:          %PATH%\r
 echo.\r
 \r
-if not exist %XMLBEANS_HOME%\lib\saxon8.jar goto no_saxon8\r
+@REM\r
+@REM Start to build the Framework Tools\r
+@REM\r
 \r
-echo Building the Tiano Tools\r
 \r
-@REM We are going to create the SurfaceArea.jar file first so that other Java Program can use it\r
-@REM It needs the xmlbeans libaries in order to compile.\r
-set CLASSPATH=%XMLBEANS_HOME%\lib\jsr173_1.0_api.jar;%XMLBEANS_HOME%\lib\xbean.jar\r
+echo.\r
+echo Building the Framework Tools\r
+echo.\r
+\r
+@REM\r
+@REM We are going to create the SurfaceArea.jar file first so that the other\r
+@REM Java Programs can use it.\r
+@REM It needs the XMLBEANS libraries in order to compile.\r
+@REM\r
+set CLASSPATH=.;%XMLBEANS_HOME%\lib\jsr173_1.0_api.jar;%XMLBEANS_HOME%\lib\xbean.jar\r
 set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\xbean_xpath.jar;%XMLBEANS_HOME%\lib\xmlpublic.jar\r
 set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\saxon8.jar;%XMLBEANS_HOME%\lib\resolver.jar\r
 \r
-call ant -f %WORKSPACE%Tools\build.xml SurfaceArea\r
+call ant -f %WORKSPACE%\Tools\build.xml SurfaceArea\r
 \r
+@REM\r
 @REM Now we can make the other Java Programs\r
 @REM All of the remaining Java Programs require the SurfaceArea library to compile\r
-set CLASSPATH=%CLASSPATH%;%WORKSPACE%Tools\Jars\SurfaceArea.jar\r
+@REM\r
+set CLASSPATH=%CLASSPATH%;%WORKSPACE%\%Tools\Jars\SurfaceArea.jar\r
 \r
-call ant -f %WORKSPACE%Tools\build.xml JavaCode\r
 \r
-@REM We have all of the Java Programs and add-in classes created, so we can start using the cpp-tasks to create our tools\r
-set CLASSPATH=%CLASSPATH%;%WORKSPACE%Tools\Jars\SurfaceArea.jar;%WORKSPACE%Tools\Jars\GenBuild.jar\r
-set CLASSPATH=%CLASSPATH%;%WORKSPACE%Tools\Jars\cpptasks.jar;%WORKSPACE%Tools\Jars\frameworktasks.jar\r
+call ant -f %WORKSPACE%\Tools\build.xml JavaCode\r
 \r
-call ant -f %WORKSPACE%Tools\build.xml C_Code\r
+@REM\r
+@REM We have all of the Java Programs and add-in classes created, so we can start\r
+@REM using the cpp-tasks to create our tools\r
+@REM\r
+set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\Common.jar\r
+set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\GenBuild.jar\r
+set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\cpptasks.jar;%WORKSPACE%\Tools\Jars\frameworktasks.jar\r
 \r
+call ant -f %WORKSPACE%\Tools\build.xml C_Code\r
+\r
+@REM\r
+@REM Done!!!\r
+@REM\r
 goto end\r
 \r
 :no_jdk\r
 echo.\r
 echo !!! Please install Java, and set JAVA_HOME !!!\r
 echo.\r
-goto end \r
+goto end\r
 \r
 :no_ant\r
 echo.\r
 echo !!! Please install Apache Ant, and set ANT_HOME !!!\r
 echo.\r
-goto end \r
+goto end\r
 \r
 :no_antcontrib\r
 echo.\r
 echo !!! Please install Ant-contrib to ANT_HOME !!!\r
 echo.\r
-goto end \r
+goto end\r
 \r
 :no_xmlbeans\r
 echo.\r
 echo !!! Please install XML Beans, and set XMLBEANS_HOME !!!\r
 echo.\r
-goto end \r
+goto end\r
 \r
 :no_saxon8\r
 echo.\r
 echo !!! Please copy saxon8.jar file to XMLBEANS_HOME\lib !!!\r
 echo.\r
-goto end \r
+goto end\r
+\r
+:skipbuild\r
+@REM\r
+@REM This just sets up the CLASSPATH, the rest of the environment should have been set already.\r
+@REM\r
+echo.\r
+echo WORKSPACE:     %WORKSPACE%\r
+echo JAVA_HOME:     %JAVA_HOME%\r
+echo ANT_HOME:      %ANT_HOME%\r
+echo XMLBEANS_HOME: %XMLBEANS_HOME%\r
+echo CYGWIN_HOME:   %CYGWIN_HOME%\r
+echo PATH:          %PATH%\r
+echo.\r
+set CLASSPATH=%XMLBEANS_HOME%\lib\jsr173_1.0_api.jar;%XMLBEANS_HOME%\lib\xbean.jar\r
+set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\xbean_xpath.jar;%XMLBEANS_HOME%\lib\xmlpublic.jar\r
+set CLASSPATH=%CLASSPATH%;%XMLBEANS_HOME%\lib\saxon8.jar;%XMLBEANS_HOME%\lib\resolver.jar\r
+set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\SurfaceArea.jar;%WORKSPACE%\Tools\Jars\GenBuild.jar\r
+set CLASSPATH=%CLASSPATH%;%WORKSPACE%\Tools\Jars\cpptasks.jar;%WORKSPACE%\Tools\Jars\frameworktasks.jar\r
+goto end\r
 \r
 :end\r
 @echo on\r