]> git.proxmox.com Git - mirror_edk2.git/blobdiff - edksetup.bat
MdePkg: introduce standalone MM entry point library implementation
[mirror_edk2.git] / edksetup.bat
index f066d869e1e3f8e146dc8e64a554e50c638da84d..57b5a8c8684ed65902ad0e96966425373ac0946e 100755 (executable)
@@ -2,6 +2,7 @@
 @REM   Windows batch file to setup a WORKSPACE environment\r
 @REM\r
 @REM Copyright (c) 2006 - 2016, Intel Corporation. All rights reserved.<BR>\r
+@REM (C) Copyright 2016 Hewlett Packard Enterprise Development LP<BR>\r
 @REM This program and the accompanying materials\r
 @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
 \r
 @REM set CYGWIN_HOME=C:\cygwin\r
 \r
-@REM usage: \r
+@REM usage:\r
 @REM   edksetup.bat [--nt32] [AntBuild] [Rebuild] [ForceRebuild] [Reconfig]\r
 @REM if the argument, skip is present, only the paths and the\r
-@REM test and set of environment settings are performed. \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
@@ -41,11 +42,8 @@ if %WORKSPACE% == %CD% (
 \r
 :SetWorkSpace\r
 @REM set new workspace\r
-@REM clear EFI_SOURCE and EDK_SOURCE for the new workspace\r
 if not defined WORKSPACE (\r
   set WORKSPACE=%CD%\r
-  set EFI_SOURCE=\r
-  set EDK_SOURCE=\r
 )\r
 \r
 :ParseArgs\r
@@ -56,70 +54,52 @@ if /I "%1"=="/h" goto Usage
 if /I "%1"=="/?" goto Usage\r
 if /I "%1"=="/help" goto Usage\r
 \r
-if /I not "%1"=="--nt32" goto no_nt32\r
-\r
-@REM Flag, --nt32 is set\r
-@REM The Nt32 Emluation Platform requires Microsoft Libraries\r
-@REM and headers to interface with Windows.\r
+if /I "%1"=="NewBuild" shift\r
+if not defined EDK_TOOLS_PATH (\r
+  goto SetEdkToolsPath\r
+) else (\r
+  goto checkNt32Flag\r
+)\r
 \r
-if not defined VCINSTALLDIR (\r
-  if defined VS140COMNTOOLS (\r
-    call "%VS140COMNTOOLS%\vsvars32.bat"\r
-  ) else (\r
-    if defined VS120COMNTOOLS (\r
-      call "%VS120COMNTOOLS%\vsvars32.bat"\r
-    ) else (   \r
-      if defined VS110COMNTOOLS (\r
-        call "%VS110COMNTOOLS%\vsvars32.bat"\r
-      ) else (\r
-        if defined VS100COMNTOOLS (\r
-          call "%VS100COMNTOOLS%\vsvars32.bat"\r
-        ) else (\r
-          if defined VS90COMNTOOLS (\r
-            call "%VS90COMNTOOLS%\vsvars32.bat"\r
-          ) else (\r
-            if defined VS80COMNTOOLS (\r
-              call "%VS80COMNTOOLS%\vsvars32.bat"\r
-            ) else (\r
-              if defined VS71COMNTOOLS (\r
-                call "%VS71COMNTOOLS%\vsvars32.bat"\r
-              ) else (\r
-                echo.\r
-                echo !!! WARNING !!! Cannot find Visual Studio !!!\r
-                echo.\r
-              )\r
-            )\r
-          )\r
-        )\r
+:SetEdkToolsPath\r
+if %WORKSPACE:~-1% EQU \ (\r
+  @set EDK_BASETOOLS=%WORKSPACE%BaseTools\r
+) else (\r
+  @set EDK_BASETOOLS=%WORKSPACE%\BaseTools\r
+)\r
+if exist %EDK_BASETOOLS% (\r
+  set EDK_TOOLS_PATH=%EDK_BASETOOLS%\r
+  set EDK_BASETOOLS=\r
+) else (\r
+  if defined PACKAGES_PATH (\r
+    for %%i IN (%PACKAGES_PATH%) DO (\r
+      if exist %%~fi\BaseTools (\r
+        set EDK_TOOLS_PATH=%%~fi\BaseTools\r
+        goto checkNt32Flag\r
       )\r
     )\r
+  ) else (\r
+    echo.\r
+    echo !!! ERROR !!! Cannot find BaseTools !!!\r
+    echo.\r
+    goto BadBaseTools\r
   )\r
 )\r
-shift\r
 \r
-:no_nt32\r
+:checkNt32Flag\r
+if exist %EDK_TOOLS_PATH%\Source set BASE_TOOLS_PATH=%EDK_TOOLS_PATH%\r
 \r
-if /I "%1"=="NewBuild" shift\r
-if not defined EDK_TOOLS_PATH (\r
-  if exist %WORKSPACE%\BaseTools (\r
-    set EDK_TOOLS_PATH=%WORKSPACE%\BaseTools\r
+@REM The Nt32 Emluation Platform requires Microsoft Libraries\r
+@REM and headers to interface with Windows.\r
+if /I "%1"=="--nt32" (\r
+  if /I "%2"=="X64" (\r
+    shift\r
+    call "%BASE_TOOLS_PATH%\Scripts\SetVisualStudio.bat"\r
   ) else (\r
-    if defined PACKAGES_PATH (\r
-      for %%i IN (%PACKAGES_PATH%) DO (\r
-        if exist %%~fi\BaseTools (\r
-          set EDK_TOOLS_PATH=%%~fi\BaseTools\r
-          goto checkBaseTools\r
-        )\r
-      )\r
-    ) else (\r
-      echo.\r
-      echo !!! ERROR !!! Cannot find BaseTools !!!\r
-      echo. \r
-      goto BadBaseTools\r
-    )\r
+    call "%BASE_TOOLS_PATH%\get_vsvars.bat"\r
   )\r
+  shift\r
 )\r
-if exist %EDK_TOOLS_PATH%\Source set BASE_TOOLS_PATH=%EDK_TOOLS_PATH%\r
 \r
 :checkBaseTools\r
 IF NOT EXIST "%EDK_TOOLS_PATH%\toolsetup.bat" goto BadBaseTools\r
@@ -169,14 +149,26 @@ if defined CYGWIN_HOME (
 )\r
 \r
 :cygwin_done\r
+if /I "%1"=="Rebuild" shift\r
+if /I "%1"=="ForceRebuild" shift\r
 if "%1"=="" goto end\r
 \r
 :Usage\r
   @echo.\r
-  @echo  Usage: "%0 [-h | -help | --help | /h | /help | /?] [--nt32] [Reconfig]"\r
-  @echo         --nt32         Call vsvars32.bat for NT32 platform build.\r
+  @echo  Usage: "%0 [-h | -help | --help | /h | /help | /?] [--nt32 [X64]] [Reconfig] [Rebuild] [ForceRebuild]"\r
+  @echo         --nt32 [X64]   If a compiler tool chain is not available in the\r
+  @echo                        environment, call a script to attempt to set one up.\r
+  @echo                        This flag is only required if building the\r
+  @echo                        Nt32Pkg/Nt32Pkg.dsc system emulator.\r
+  @echo                        If the X64 argument is set, and a compiler tool chain is\r
+  @echo                        not available, attempt to set up a tool chain that will\r
+  @echo                        create X64 binaries. Setting these two options have the\r
+  @echo                        potential side effect of changing tool chains used for a\r
+  @echo                        rebuild.\r
   @echo.\r
   @echo         Reconfig       Reinstall target.txt, tools_def.txt and build_rule.txt.\r
+  @echo         Rebuild        Perform incremental rebuild of BaseTools binaries.\r
+  @echo         ForceRebuild   Force a full rebuild of BaseTools binaries.\r
   @echo.\r
   @echo  Note that target.template, tools_def.template and build_rules.template\r
   @echo  will only be copied to target.txt, tools_def.txt and build_rule.txt\r
@@ -186,4 +178,3 @@ if "%1"=="" goto end
 \r
 :end\r
   popd\r
-\r