Index: third_party/sqlite/sqlite-src-3170000/tool/build-all-msvc.bat |
diff --git a/third_party/sqlite/sqlite-src-3170000/tool/build-all-msvc.bat b/third_party/sqlite/sqlite-src-3170000/tool/build-all-msvc.bat |
new file mode 100755 |
index 0000000000000000000000000000000000000000..37aa1bf6fcad8987c7a84c5ff802af4584d4f139 |
--- /dev/null |
+++ b/third_party/sqlite/sqlite-src-3170000/tool/build-all-msvc.bat |
@@ -0,0 +1,855 @@ |
+@ECHO OFF |
+ |
+:: |
+:: build-all-msvc.bat -- |
+:: |
+:: Multi-Platform Build Tool for MSVC |
+:: |
+ |
+REM |
+REM This batch script is used to build the SQLite DLL for multiple platforms |
+REM and configurations using MSVC. The built SQLite DLLs, their associated |
+REM import libraries, and optionally their symbols files, are placed within |
+REM the directory specified on the command line, in sub-directories named for |
+REM their respective platforms and configurations. This batch script must be |
+REM run from inside a Visual Studio Command Prompt for the desired version of |
+REM Visual Studio ^(the initial platform configured for the command prompt does |
+REM not really matter^). Exactly one command line argument is required, the |
+REM name of an existing directory to be used as the final destination directory |
+REM for the generated output files, which will be placed in sub-directories |
+REM created therein. Ideally, the directory specified should be empty. |
+REM |
+REM Example: |
+REM |
+REM CD /D C:\dev\sqlite\core |
+REM CALL tool\build-all-msvc.bat C:\Temp |
+REM |
+REM In the example above, "C:\dev\sqlite\core" represents the root of the |
+REM source tree for SQLite and "C:\Temp" represents the final destination |
+REM directory for the generated output files. |
+REM |
+REM Please note that the SQLite build process performed by the Makefile |
+REM associated with this batch script requires a Tcl shell to be present |
+REM in a directory contained in the PATH environment variable unless a |
+REM pre-existing amalgamation file is used. |
+REM |
+REM There are several environment variables that may be set to modify the |
+REM behavior of this batch script and its associated Makefile. The list of |
+REM platforms to build may be overriden by using the PLATFORMS environment |
+REM variable, which should contain a list of platforms ^(e.g. x86 x86_amd64 |
+REM x86_arm^). All platforms must be supported by the version of Visual Studio |
+REM being used. The list of configurations to build may be overridden by |
+REM setting the CONFIGURATIONS environment variable, which should contain a |
+REM list of configurations to build ^(e.g. Debug Retail^). Neither of these |
+REM variable values may contain any double quotes, surrounding or embedded. |
+REM |
+REM Finally, the NCRTLIBPATH, NUCRTLIBPATH, and NSDKLIBPATH environment |
+REM variables may be set to specify the location of the CRT, Universal CRT, and |
+REM Windows SDK, respectively, that may be needed to compile executables native |
+REM to the architecture of the build machine during any cross-compilation that |
+REM may be necessary, depending on the platforms to be built. These values in |
+REM these three variables should be surrounded by double quotes if they contain |
+REM spaces. |
+REM |
+REM There are a few other environment variables that impact the build process |
+REM when set ^(to anything^), they are: |
+REM |
+REM USE_AUTOCONF_MAKEFILE |
+REM |
+REM When set, the "autoconf" Makefile for MSVC will be used instead of the main |
+REM Makefile for MSVC. It must exist at "%ROOT%\autoconf\Makefile.msc". |
+REM |
+REM NOCLEAN |
+REM |
+REM When set, the "clean" target will not be used during each build iteration. |
+REM However, the target binaries, if any, will still be deleted manually prior |
+REM to being rebuilt. Setting this environment variable is only rarely needed |
+REM and could cause issues in some circumstances; therefore, setting it is not |
+REM recommended. |
+REM |
+REM NOSYMBOLS |
+REM |
+REM When set, copying of symbol files ^(*.pdb^) created during the build will |
+REM be skipped and they will not appear in the final destination directory. |
+REM Setting this environment variable is never strictly needed and could cause |
+REM issues in some circumstances; therefore, setting it is not recommended. |
+REM |
+REM NOMEMDEBUG |
+REM |
+REM When set, disables use of MEMDEBUG when building binaries for the "Debug" |
+REM configuration. |
+REM |
+REM BUILD_ALL_SHELL |
+REM |
+REM When set, the command line shell will be built for each selected platform |
+REM and configuration as well. In addition, the command line shell binaries |
+REM will be copied, with their symbols, to the final destination directory. |
+REM |
+REM USE_WINV63_NSDKLIBPATH |
+REM |
+REM When set, modifies how the NSDKLIBPATH environment variable is built, based |
+REM on the WindowsSdkDir environment variable. It forces this batch script to |
+REM assume the Windows 8.1 SDK location should be used. |
+REM |
+REM USE_WINV100_NSDKLIBPATH |
+REM |
+REM When set, modifies how the NSDKLIBPATH environment variable is built, based |
+REM on the WindowsSdkDir environment variable. It causes this batch script to |
+REM assume the Windows 10.0 SDK location should be used. |
+REM |
+REM NMAKE_ARGS |
+REM NMAKE_ARGS_DEBUG |
+REM NMAKE_ARGS_RETAIL |
+REM |
+REM When set, these values are expanded and passed to the NMAKE command line, |
+REM after its other arguments. These may be used to specify additional NMAKE |
+REM options, for example: |
+REM |
+REM SET NMAKE_ARGS=FOR_WINRT=1 |
+REM SET NMAKE_ARGS_DEBUG=MEMDEBUG=1 |
+REM SET NMAKE_ARGS_RETAIL=WIN32HEAP=1 |
+REM |
+REM Using the above command before running this tool will cause the compiled |
+REM binaries to target the WinRT environment, which provides a subset of the |
+REM Win32 API. |
+REM |
+REM DLL_FILE_NAME |
+REM DLL_PDB_FILE_NAME |
+REM LIB_FILE_NAME |
+REM EXE_FILE_NAME |
+REM EXE_PDB_FILE_NAME |
+REM |
+REM When set, these values will override the associated target file name used |
+REM for the build. |
+REM |
+SETLOCAL |
+ |
+REM SET __ECHO=ECHO |
+REM SET __ECHO2=ECHO |
+REM SET __ECHO3=ECHO |
+IF NOT DEFINED _AECHO (SET _AECHO=REM) |
+IF NOT DEFINED _CECHO (SET _CECHO=REM) |
+IF NOT DEFINED _VECHO (SET _VECHO=REM) |
+ |
+SET REDIRECT=^> |
+IF DEFINED __ECHO SET REDIRECT=^^^> |
+ |
+%_AECHO% Running %0 %* |
+ |
+REM SET DFLAGS=/L |
+ |
+%_VECHO% DFlags = '%DFLAGS%' |
+ |
+SET FFLAGS=/V /F /G /H /I /R /Y /Z |
+ |
+%_VECHO% FFlags = '%FFLAGS%' |
+ |
+SET ROOT=%~dp0\.. |
+SET ROOT=%ROOT:\\=\% |
+ |
+%_VECHO% Root = '%ROOT%' |
+ |
+REM |
+REM NOTE: The first and only argument to this batch file should be the output |
+REM directory where the platform-specific binary directories should be |
+REM created. |
+REM |
+SET BINARYDIRECTORY=%1 |
+ |
+IF NOT DEFINED BINARYDIRECTORY ( |
+ GOTO usage |
+) |
+ |
+%_VECHO% BinaryDirectory = '%BINARYDIRECTORY%' |
+ |
+SET DUMMY=%2 |
+ |
+IF DEFINED DUMMY ( |
+ GOTO usage |
+) |
+ |
+REM |
+REM NOTE: From this point, we need a clean error level. Reset it now. |
+REM |
+CALL :fn_ResetErrorLevel |
+ |
+REM |
+REM NOTE: Change the current directory to the root of the source tree, saving |
+REM the current directory on the directory stack. |
+REM |
+%__ECHO2% PUSHD "%ROOT%" |
+ |
+IF ERRORLEVEL 1 ( |
+ ECHO Could not change directory to "%ROOT%". |
+ GOTO errors |
+) |
+ |
+REM |
+REM NOTE: This batch file requires the ComSpec environment variable to be set, |
+REM typically to something like "C:\Windows\System32\cmd.exe". |
+REM |
+IF NOT DEFINED ComSpec ( |
+ ECHO The ComSpec environment variable must be defined. |
+ GOTO errors |
+) |
+ |
+REM |
+REM NOTE: This batch file requires the VcInstallDir environment variable to be |
+REM set. Tyipcally, this means this batch file needs to be run from an |
+REM MSVC command prompt. |
+REM |
+IF NOT DEFINED VCINSTALLDIR ( |
+ ECHO The VCINSTALLDIR environment variable must be defined. |
+ GOTO errors |
+) |
+ |
+REM |
+REM NOTE: If the list of platforms is not already set, use the default list. |
+REM |
+IF NOT DEFINED PLATFORMS ( |
+ SET PLATFORMS=x86 x86_amd64 x86_arm |
+) |
+ |
+%_VECHO% Platforms = '%PLATFORMS%' |
+ |
+REM |
+REM NOTE: If the list of configurations is not already set, use the default |
+REM list. |
+REM |
+IF NOT DEFINED CONFIGURATIONS ( |
+ SET CONFIGURATIONS=Debug Retail |
+) |
+ |
+%_VECHO% Configurations = '%CONFIGURATIONS%' |
+ |
+REM |
+REM NOTE: If the command used to invoke NMAKE is not already set, use the |
+REM default. |
+REM |
+IF NOT DEFINED NMAKE_CMD ( |
+ IF DEFINED USE_AUTOCONF_MAKEFILE ( |
+ SET NMAKE_CMD=nmake -B -f autoconf\Makefile.msc |
+ ) ELSE ( |
+ SET NMAKE_CMD=nmake -B -f Makefile.msc |
+ ) |
+) |
+ |
+%_VECHO% NmakeCmd = '%NMAKE_CMD%' |
+%_VECHO% NmakeArgs = '%NMAKE_ARGS%' |
+%_VECHO% NmakeArgsDebug = '%NMAKE_ARGS_DEBUG%' |
+%_VECHO% NmakeArgsRetail = '%NMAKE_ARGS_RETAIL%' |
+ |
+REM |
+REM NOTE: Setup environment variables to translate between the MSVC platform |
+REM names and the names to be used for the platform-specific binary |
+REM directories. |
+REM |
+SET amd64_NAME=x64 |
+SET arm_NAME=ARM |
+SET x64_NAME=x64 |
+SET x86_NAME=x86 |
+SET x86_amd64_NAME=x64 |
+SET x86_arm_NAME=ARM |
+SET x86_x64_NAME=x64 |
+ |
+%_VECHO% amd64_Name = '%amd64_NAME%' |
+%_VECHO% arm_Name = '%arm_NAME%' |
+%_VECHO% x64_Name = '%x64_NAME%' |
+%_VECHO% x86_Name = '%x86_NAME%' |
+%_VECHO% x86_amd64_Name = '%x86_amd64_NAME%' |
+%_VECHO% x86_arm_Name = '%x86_arm_NAME%' |
+%_VECHO% x86_x64_Name = '%x86_x64_NAME%' |
+ |
+REM |
+REM NOTE: Check for the external tools needed during the build process ^(i.e. |
+REM those that do not get compiled as part of the build process itself^) |
+REM along the PATH. |
+REM |
+IF DEFINED TCLSH_CMD ( |
+ SET TCLSH_FILE=%TCLSH_CMD% |
+) ELSE ( |
+ SET TCLSH_FILE=tclsh.exe |
+) |
+ |
+FOR %%T IN (%TCLSH_FILE%) DO ( |
+ SET %%T_PATH=%%~dp$PATH:T |
+) |
+ |
+REM |
+REM NOTE: A Tcl shell executable is required during the SQLite build process |
+REM unless a pre-existing amalgamation file is used. |
+REM |
+IF NOT DEFINED %TCLSH_FILE%_PATH ( |
+ ECHO The Tcl shell executable "%TCLSH_FILE%" is required to be in the PATH. |
+ GOTO errors |
+) |
+ |
+REM |
+REM NOTE: Setup the default names for the build targets we are creating. Any |
+REM ^(or all^) of these may end up being overridden. |
+REM |
+IF NOT DEFINED DLL_FILE_NAME ( |
+ SET DLL_FILE_NAME=sqlite3.dll |
+) |
+ |
+IF NOT DEFINED DLL_PDB_FILE_NAME ( |
+ SET DLL_PDB_FILE_NAME=sqlite3.pdb |
+) |
+ |
+IF NOT DEFINED LIB_FILE_NAME ( |
+ SET LIB_FILE_NAME=sqlite3.lib |
+) |
+ |
+IF NOT DEFINED EXE_FILE_NAME ( |
+ SET EXE_FILE_NAME=sqlite3.exe |
+) |
+ |
+IF NOT DEFINED EXE_PDB_FILE_NAME ( |
+ SET EXE_PDB_FILE_NAME=sqlite3sh.pdb |
+) |
+ |
+REM |
+REM NOTE: Set the TOOLPATH variable to contain all the directories where the |
+REM external tools were found in the search above. |
+REM |
+CALL :fn_CopyVariable %TCLSH_FILE%_PATH TOOLPATH |
+ |
+%_VECHO% ToolPath = '%TOOLPATH%' |
+ |
+REM |
+REM NOTE: Setting the Windows SDK library path is only required for MSVC |
+REM 2012, 2013, and 2015. |
+REM |
+CALL :fn_UnsetVariable SET_NSDKLIBPATH |
+ |
+REM |
+REM NOTE: Setting the Universal CRT library path is only required for MSVC |
+REM 2015. |
+REM |
+CALL :fn_UnsetVariable SET_NUCRTLIBPATH |
+ |
+REM |
+REM NOTE: Check for MSVC 2012, 2013, and 2015 specially because the Windows |
+REM SDK directory handling is slightly different for those versions. |
+REM |
+IF "%VisualStudioVersion%" == "11.0" ( |
+ REM |
+ REM NOTE: If the Windows SDK library path has already been set, do not set |
+ REM it to something else later on. |
+ REM |
+ IF NOT DEFINED NSDKLIBPATH ( |
+ SET SET_NSDKLIBPATH=1 |
+ ) |
+) ELSE IF "%VisualStudioVersion%" == "12.0" ( |
+ REM |
+ REM NOTE: If the Windows SDK library path has already been set, do not set |
+ REM it to something else later on. |
+ REM |
+ IF NOT DEFINED NSDKLIBPATH ( |
+ SET SET_NSDKLIBPATH=1 |
+ ) |
+) ELSE IF "%VisualStudioVersion%" == "14.0" ( |
+ REM |
+ REM NOTE: If the Windows SDK library path has already been set, do not set |
+ REM it to something else later on. |
+ REM |
+ IF NOT DEFINED NSDKLIBPATH ( |
+ SET SET_NSDKLIBPATH=1 |
+ ) |
+ |
+ REM |
+ REM NOTE: If the Universal CRT library path has already been set, do not set |
+ REM it to something else later on. |
+ REM |
+ IF NOT DEFINED NUCRTLIBPATH ( |
+ SET SET_NUCRTLIBPATH=1 |
+ ) |
+) |
+ |
+REM |
+REM NOTE: This is the name of the sub-directory where the UCRT libraries may |
+REM be found. It is only used when compiling against the UCRT. |
+REM |
+IF DEFINED UCRTVersion ( |
+ SET NUCRTVER=%UCRTVersion% |
+) ELSE ( |
+ SET NUCRTVER=10.0.10586.0 |
+) |
+ |
+REM |
+REM NOTE: This is the name of the sub-directory where the Windows 10.0 SDK |
+REM libraries may be found. It is only used when compiling with the |
+REM Windows 10.0 SDK. |
+REM |
+IF DEFINED WindowsSDKLibVersion ( |
+ SET WIN10SDKVER=%WindowsSDKLibVersion:\=% |
+) ELSE ( |
+ SET WIN10SDKVER=%NUCRTVER% |
+) |
+ |
+REM |
+REM NOTE: Check if this is the Windows Phone SDK. If so, a different batch |
+REM file is necessary to setup the build environment. Since the variable |
+REM values involved here may contain parenthesis, using GOTO instead of |
+REM an IF block is required. |
+REM |
+IF DEFINED WindowsPhoneKitDir GOTO set_vcvarsall_phone |
+SET VCVARSALL=%VCINSTALLDIR%\vcvarsall.bat |
+GOTO set_vcvarsall_done |
+:set_vcvarsall_phone |
+SET VCVARSALL=%VCINSTALLDIR%\WPSDK\WP80\vcvarsphoneall.bat |
+:set_vcvarsall_done |
+SET VCVARSALL=%VCVARSALL:\\=\% |
+ |
+REM |
+REM NOTE: This is the outer loop. There should be exactly one iteration per |
+REM platform. |
+REM |
+FOR %%P IN (%PLATFORMS%) DO ( |
+ REM |
+ REM NOTE: Using the MSVC platform name, lookup the simpler platform name to |
+ REM be used for the name of the platform-specific binary directory via |
+ REM the environment variables setup earlier. |
+ REM |
+ CALL :fn_CopyVariable %%P_NAME PLATFORMNAME |
+ |
+ REM |
+ REM NOTE: This is the second loop. There should be exactly one iteration. |
+ REM This loop is necessary because the PlatformName environment |
+ REM variable was set above and that value is needed by some of the |
+ REM commands contained in the inner loop. If these commands were |
+ REM directly contained in the outer loop, the PlatformName environment |
+ REM variable would be stuck with its initial empty value instead. |
+ REM |
+ FOR /F "tokens=2* delims==" %%D IN ('SET PLATFORMNAME') DO ( |
+ REM |
+ REM NOTE: Attempt to clean the environment of all variables used by MSVC |
+ REM and/or Visual Studio. This block may need to be updated in the |
+ REM future to account for additional environment variables. |
+ REM |
+ CALL :fn_UnsetVariable CommandPromptType |
+ CALL :fn_UnsetVariable DevEnvDir |
+ CALL :fn_UnsetVariable DNX_HOME |
+ CALL :fn_UnsetVariable ExtensionSdkDir |
+ CALL :fn_UnsetVariable Framework35Version |
+ CALL :fn_UnsetVariable Framework40Version |
+ CALL :fn_UnsetVariable FrameworkDir |
+ CALL :fn_UnsetVariable FrameworkDir32 |
+ CALL :fn_UnsetVariable FrameworkVersion |
+ CALL :fn_UnsetVariable FrameworkVersion32 |
+ CALL :fn_UnsetVariable FSHARPINSTALLDIR |
+ CALL :fn_UnsetVariable INCLUDE |
+ CALL :fn_UnsetVariable LIB |
+ CALL :fn_UnsetVariable LIBPATH |
+ CALL :fn_UnsetVariable NETFXSDKDir |
+ CALL :fn_UnsetVariable Platform |
+ CALL :fn_UnsetVariable UCRTVersion |
+ CALL :fn_UnsetVariable UniversalCRTSdkDir |
+ REM CALL :fn_UnsetVariable VCINSTALLDIR |
+ CALL :fn_UnsetVariable VSINSTALLDIR |
+ CALL :fn_UnsetVariable WindowsLibPath |
+ CALL :fn_UnsetVariable WindowsPhoneKitDir |
+ CALL :fn_UnsetVariable WindowsSdkDir |
+ CALL :fn_UnsetVariable WindowsSdkDir_35 |
+ CALL :fn_UnsetVariable WindowsSdkDir_old |
+ CALL :fn_UnsetVariable WindowsSDKLibVersion |
+ CALL :fn_UnsetVariable WindowsSDKVersion |
+ CALL :fn_UnsetVariable WindowsSDK_ExecutablePath_x86 |
+ CALL :fn_UnsetVariable WindowsSDK_ExecutablePath_x64 |
+ |
+ REM |
+ REM NOTE: Reset the PATH here to the absolute bare minimum required. |
+ REM |
+ SET PATH=%TOOLPATH%;%SystemRoot%\System32;%SystemRoot% |
+ |
+ REM |
+ REM NOTE: This is the inner loop. There are normally two iterations, one |
+ REM for each supported build configuration, e.g. Debug or Retail. |
+ REM |
+ FOR %%B IN (%CONFIGURATIONS%) DO ( |
+ REM |
+ REM NOTE: When preparing the debug build, set the DEBUG and MEMDEBUG |
+ REM environment variables to be picked up by the MSVC makefile |
+ REM itself. |
+ REM |
+ %_AECHO% Building the %%B configuration for platform %%P with name %%D... |
+ |
+ IF /I "%%B" == "Debug" ( |
+ REM |
+ REM NOTE: Using this level for the DEBUG environment variable should |
+ REM disable all compiler optimizations and prevent use of the |
+ REM NDEBUG define. Additionally, both SQLITE_ENABLE_API_ARMOR |
+ REM and SQLITE_DEBUG defines should be enabled. |
+ REM |
+ SET DEBUG=3 |
+ |
+ REM |
+ REM NOTE: Setting this to non-zero should enable the SQLITE_MEMDEBUG |
+ REM define. |
+ REM |
+ IF NOT DEFINED NOMEMDEBUG ( |
+ SET MEMDEBUG=1 |
+ ) |
+ ) ELSE ( |
+ CALL :fn_UnsetVariable DEBUG |
+ CALL :fn_UnsetVariable MEMDEBUG |
+ ) |
+ |
+ REM |
+ REM NOTE: Copy the extra NMAKE arguments for this configuration into the |
+ REM common variable used by the actual commands. |
+ REM |
+ CALL :fn_CopyVariable NMAKE_ARGS_%%B NMAKE_ARGS_CFG |
+ |
+ REM |
+ REM NOTE: Launch a nested command shell to perform the following steps: |
+ REM |
+ REM 1. Setup the MSVC environment for this platform using the |
+ REM official batch file. |
+ REM |
+ REM 2. Make sure that no stale build output files are present. |
+ REM |
+ REM 3. Build the "sqlite3.dll" and "sqlite3.lib" binaries for this |
+ REM platform. |
+ REM |
+ REM 4. Copy the "sqlite3.dll" and "sqlite3.lib" binaries for this |
+ REM platform to the platform-specific directory beneath the |
+ REM binary directory. |
+ REM |
+ REM 5. Unless prevented from doing so, copy the "sqlite3.pdb" |
+ REM symbols file for this platform to the platform-specific |
+ REM directory beneath the binary directory. |
+ REM |
+ "%ComSpec%" /C ( |
+ REM |
+ REM NOTE: Attempt to setup the MSVC environment for this platform. |
+ REM |
+ %__ECHO3% CALL "%VCVARSALL%" %%P |
+ |
+ IF ERRORLEVEL 1 ( |
+ ECHO Failed to call "%VCVARSALL%" for platform %%P. |
+ GOTO errors |
+ ) |
+ |
+ REM |
+ REM NOTE: If this batch file is not running in "what-if" mode, check to |
+ REM be sure we were actually able to setup the MSVC environment |
+ REM as current versions of their official batch file do not set |
+ REM the exit code upon failure. |
+ REM |
+ IF NOT DEFINED __ECHO3 ( |
+ IF NOT DEFINED WindowsPhoneKitDir ( |
+ IF NOT DEFINED WindowsSdkDir ( |
+ ECHO Cannot build, Windows SDK not found for platform %%P. |
+ GOTO errors |
+ ) |
+ ) |
+ ) |
+ |
+ REM |
+ REM NOTE: When using MSVC 2012, 2013, or 2015, the native SDK path |
+ REM cannot simply be the "lib" sub-directory beneath the location |
+ REM specified in the WindowsSdkDir environment variable because |
+ REM that location does not actually contain the necessary library |
+ REM files for x86. This must be done for each iteration because |
+ REM it relies upon the WindowsSdkDir environment variable being |
+ REM set by the batch file used to setup the MSVC environment. |
+ REM |
+ IF DEFINED SET_NSDKLIBPATH ( |
+ REM |
+ REM NOTE: The Windows Phone SDK has a slightly different directory |
+ REM structure and must be handled specially here. |
+ REM |
+ IF DEFINED WindowsPhoneKitDir ( |
+ CALL :fn_CopyVariable WindowsPhoneKitDir NSDKLIBPATH |
+ CALL :fn_AppendVariable NSDKLIBPATH \lib\x86 |
+ ) ELSE IF DEFINED WindowsSdkDir ( |
+ CALL :fn_CopyVariable WindowsSdkDir NSDKLIBPATH |
+ |
+ REM |
+ REM NOTE: The Windows 8.x and Windows 10.0 SDKs have a slightly |
+ REM different directory naming conventions. |
+ REM |
+ IF DEFINED USE_WINV100_NSDKLIBPATH ( |
+ CALL :fn_AppendVariable NSDKLIBPATH \..\10\lib\%WIN10SDKVER%\um\x86 |
+ CALL :fn_CopyVariable WindowsSdkDir PSDKLIBPATH |
+ CALL :fn_AppendVariable PSDKLIBPATH lib\%WIN10SDKVER%\um\%%D |
+ ) ELSE IF DEFINED USE_WINV63_NSDKLIBPATH ( |
+ CALL :fn_AppendVariable NSDKLIBPATH \lib\winv6.3\um\x86 |
+ ) ELSE IF "%VisualStudioVersion%" == "12.0" ( |
+ CALL :fn_AppendVariable NSDKLIBPATH \..\8.0\lib\win8\um\x86 |
+ ) ELSE IF "%VisualStudioVersion%" == "14.0" ( |
+ CALL :fn_AppendVariable NSDKLIBPATH \..\8.0\lib\win8\um\x86 |
+ ) ELSE ( |
+ CALL :fn_AppendVariable NSDKLIBPATH \lib\win8\um\x86 |
+ ) |
+ ) |
+ ) |
+ |
+ REM |
+ REM NOTE: When using MSVC 2015, setting the Universal CRT library path |
+ REM for x86 may be required as well. This must also be done for |
+ REM each iteration because it relies upon the UniversalCRTSdkDir |
+ REM environment variable being set by the batch file used to |
+ REM setup the MSVC environment. |
+ REM |
+ IF DEFINED SET_NUCRTLIBPATH ( |
+ IF DEFINED UniversalCRTSdkDir ( |
+ CALL :fn_CopyVariable UniversalCRTSdkDir NUCRTLIBPATH |
+ CALL :fn_AppendVariable NUCRTLIBPATH \lib\%NUCRTVER%\ucrt\x86 |
+ ) |
+ ) |
+ |
+ REM |
+ REM NOTE: Unless prevented from doing so, invoke NMAKE with the MSVC |
+ REM makefile to clean any stale build output from previous |
+ REM iterations of this loop and/or previous runs of this batch |
+ REM file, etc. |
+ REM |
+ IF NOT DEFINED NOCLEAN ( |
+ CALL :fn_MakeClean %%D |
+ |
+ IF ERRORLEVEL 1 ( |
+ ECHO Failed to clean for platform %%P. |
+ GOTO errors |
+ ) |
+ ) ELSE ( |
+ REM |
+ REM NOTE: Even when the cleaning step has been disabled, we still |
+ REM need to remove the build output for all the files we are |
+ REM specifically wanting to build for each platform. |
+ REM |
+ %_AECHO% Cleaning final core library output files only... |
+ %__ECHO% DEL /Q *.lo "%DLL_FILE_NAME%" "%LIB_FILE_NAME%" "%DLL_PDB_FILE_NAME%" 2%REDIRECT% NUL |
+ ) |
+ |
+ REM |
+ REM NOTE: Call NMAKE with the MSVC makefile to build the "sqlite3.dll" |
+ REM binary. The x86 compiler will be used to compile the native |
+ REM command line tools needed during the build process itself. |
+ REM Also, disable looking for and/or linking to the native Tcl |
+ REM runtime library. |
+ REM |
+ CALL :fn_MakeDll %%D |
+ |
+ IF ERRORLEVEL 1 ( |
+ ECHO Failed to build %%B "%DLL_FILE_NAME%" for platform %%P. |
+ GOTO errors |
+ ) |
+ |
+ REM |
+ REM NOTE: Copy the "sqlite3.dll" file to the appropriate directory for |
+ REM the build and platform beneath the binary directory. |
+ REM |
+ %__ECHO% XCOPY "%DLL_FILE_NAME%" "%BINARYDIRECTORY%\%%B\%%D\" %FFLAGS% %DFLAGS% |
+ |
+ IF ERRORLEVEL 1 ( |
+ ECHO Failed to copy "%DLL_FILE_NAME%" to "%BINARYDIRECTORY%\%%B\%%D\". |
+ GOTO errors |
+ ) |
+ |
+ REM |
+ REM NOTE: Copy the "sqlite3.lib" file to the appropriate directory for |
+ REM the build and platform beneath the binary directory. |
+ REM |
+ %__ECHO% XCOPY "%LIB_FILE_NAME%" "%BINARYDIRECTORY%\%%B\%%D\" %FFLAGS% %DFLAGS% |
+ |
+ IF ERRORLEVEL 1 ( |
+ ECHO Failed to copy "%LIB_FILE_NAME%" to "%BINARYDIRECTORY%\%%B\%%D\". |
+ GOTO errors |
+ ) |
+ |
+ REM |
+ REM NOTE: Copy the "sqlite3.pdb" file to the appropriate directory for |
+ REM the build and platform beneath the binary directory unless we |
+ REM are prevented from doing so. |
+ REM |
+ IF NOT DEFINED NOSYMBOLS ( |
+ IF EXIST "%DLL_PDB_FILE_NAME%" ( |
+ %__ECHO% XCOPY "%DLL_PDB_FILE_NAME%" "%BINARYDIRECTORY%\%%B\%%D\" %FFLAGS% %DFLAGS% |
+ |
+ IF ERRORLEVEL 1 ( |
+ ECHO Failed to copy "%DLL_PDB_FILE_NAME%" to "%BINARYDIRECTORY%\%%B\%%D\". |
+ GOTO errors |
+ ) |
+ ) |
+ ) |
+ |
+ REM |
+ REM NOTE: If requested, also build the shell executable. |
+ REM |
+ IF DEFINED BUILD_ALL_SHELL ( |
+ REM |
+ REM NOTE: If necessary, make sure any previous build output for the |
+ REM shell executable is deleted. |
+ REM |
+ IF DEFINED NOCLEAN ( |
+ REM |
+ REM NOTE: Even when the cleaning step has been disabled, we still |
+ REM need to remove the build output for all the files we are |
+ REM specifically wanting to build for each platform. |
+ REM |
+ %_AECHO% Cleaning final shell executable output files only... |
+ %__ECHO% DEL /Q "%EXE_FILE_NAME%" "%EXE_PDB_FILE_NAME%" 2%REDIRECT% NUL |
+ ) |
+ |
+ REM |
+ REM NOTE: Call NMAKE with the MSVC makefile to build the "sqlite3.exe" |
+ REM binary. The x86 compiler will be used to compile the native |
+ REM command line tools needed during the build process itself. |
+ REM Also, disable looking for and/or linking to the native Tcl |
+ REM runtime library. |
+ REM |
+ CALL :fn_MakeExe %%D |
+ |
+ IF ERRORLEVEL 1 ( |
+ ECHO Failed to build %%B "%EXE_FILE_NAME%" for platform %%P. |
+ GOTO errors |
+ ) |
+ |
+ REM |
+ REM NOTE: Copy the "sqlite3.exe" file to the appropriate directory |
+ REM for the build and platform beneath the binary directory. |
+ REM |
+ %__ECHO% XCOPY "%EXE_FILE_NAME%" "%BINARYDIRECTORY%\%%B\%%D\" %FFLAGS% %DFLAGS% |
+ |
+ IF ERRORLEVEL 1 ( |
+ ECHO Failed to copy "%EXE_FILE_NAME%" to "%BINARYDIRECTORY%\%%B\%%D\". |
+ GOTO errors |
+ ) |
+ |
+ REM |
+ REM NOTE: Copy the "sqlite3sh.pdb" file to the appropriate directory |
+ REM for the build and platform beneath the binary directory |
+ REM unless we are prevented from doing so. |
+ REM |
+ IF NOT DEFINED NOSYMBOLS ( |
+ IF EXIST "%EXE_PDB_FILE_NAME%" ( |
+ %__ECHO% XCOPY "%EXE_PDB_FILE_NAME%" "%BINARYDIRECTORY%\%%B\%%D\" %FFLAGS% %DFLAGS% |
+ |
+ IF ERRORLEVEL 1 ( |
+ ECHO Failed to copy "%EXE_PDB_FILE_NAME%" to "%BINARYDIRECTORY%\%%B\%%D\". |
+ GOTO errors |
+ ) |
+ ) |
+ ) |
+ ) |
+ ) |
+ ) |
+ ) |
+ |
+ REM |
+ REM NOTE: Handle any errors generated during the nested command shell. |
+ REM |
+ IF ERRORLEVEL 1 ( |
+ GOTO errors |
+ ) |
+) |
+ |
+REM |
+REM NOTE: Restore the saved current directory from the directory stack. |
+REM |
+%__ECHO2% POPD |
+ |
+IF ERRORLEVEL 1 ( |
+ ECHO Could not restore directory. |
+ GOTO errors |
+) |
+ |
+REM |
+REM NOTE: If we get to this point, we have succeeded. |
+REM |
+GOTO no_errors |
+ |
+:fn_MakeClean |
+ %__ECHO% %NMAKE_CMD% clean "PLATFORM=%1" XCOMPILE=1 USE_NATIVE_LIBPATHS=1 NO_TCL=1 %NMAKE_ARGS% %NMAKE_ARGS_CFG% |
+ GOTO :EOF |
+ |
+:fn_MakeDll |
+ %__ECHO% %NMAKE_CMD% "%DLL_FILE_NAME%" "PLATFORM=%1" XCOMPILE=1 USE_NATIVE_LIBPATHS=1 NO_TCL=1 %NMAKE_ARGS% %NMAKE_ARGS_CFG% |
+ GOTO :EOF |
+ |
+:fn_MakeExe |
+ %__ECHO% %NMAKE_CMD% "%EXE_FILE_NAME%" "PLATFORM=%1" XCOMPILE=1 USE_NATIVE_LIBPATHS=1 NO_TCL=1 %NMAKE_ARGS% %NMAKE_ARGS_CFG% |
+ GOTO :EOF |
+ |
+:fn_ShowVariable |
+ SETLOCAL |
+ SET __ECHO_CMD=ECHO %%%2%% |
+ FOR /F "delims=" %%V IN ('%__ECHO_CMD%') DO ( |
+ IF NOT "%%V" == "" ( |
+ IF NOT "%%V" == "%%%2%%" ( |
+ %_VECHO% %1 = '%%V' |
+ ) |
+ ) |
+ ) |
+ ENDLOCAL |
+ GOTO :EOF |
+ |
+:fn_ResetErrorLevel |
+ VERIFY > NUL |
+ GOTO :EOF |
+ |
+:fn_SetErrorLevel |
+ VERIFY MAYBE 2> NUL |
+ GOTO :EOF |
+ |
+:fn_CopyVariable |
+ IF NOT DEFINED %1 GOTO :EOF |
+ IF "%2" == "" GOTO :EOF |
+ SETLOCAL |
+ SET __ECHO_CMD=ECHO %%%1%% |
+ FOR /F "delims=" %%V IN ('%__ECHO_CMD%') DO ( |
+ SET VALUE=%%V |
+ ) |
+ ENDLOCAL && SET %2=%VALUE% |
+ GOTO :EOF |
+ |
+:fn_UnsetVariable |
+ SETLOCAL |
+ SET VALUE=%1 |
+ IF DEFINED VALUE ( |
+ SET VALUE= |
+ ENDLOCAL |
+ SET %VALUE%= |
+ ) ELSE ( |
+ ENDLOCAL |
+ ) |
+ CALL :fn_ResetErrorLevel |
+ GOTO :EOF |
+ |
+:fn_AppendVariable |
+ SET __ECHO_CMD=ECHO %%%1%% |
+ IF DEFINED %1 ( |
+ FOR /F "delims=" %%V IN ('%__ECHO_CMD%') DO ( |
+ SET %1=%%V%~2 |
+ ) |
+ ) ELSE ( |
+ SET %1=%~2 |
+ ) |
+ SET __ECHO_CMD= |
+ CALL :fn_ResetErrorLevel |
+ GOTO :EOF |
+ |
+:usage |
+ ECHO. |
+ ECHO Usage: %~nx0 ^<binaryDirectory^> |
+ ECHO. |
+ GOTO errors |
+ |
+:errors |
+ CALL :fn_SetErrorLevel |
+ ENDLOCAL |
+ ECHO. |
+ ECHO Failure, errors were encountered. |
+ GOTO end_of_file |
+ |
+:no_errors |
+ CALL :fn_ResetErrorLevel |
+ ENDLOCAL |
+ ECHO. |
+ ECHO Success, no errors were encountered. |
+ GOTO end_of_file |
+ |
+:end_of_file |
+%__ECHO% EXIT /B %ERRORLEVEL% |