123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865 |
- @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 _CECHO2 (SET _CECHO2=REM)
- IF NOT DEFINED _CECHO3 (SET _CECHO3=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
- %_CECHO2% PUSHD "%ROOT%"
- %__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
- CALL :fn_ResetPath
- 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
- %_CECHO3% CALL "%VCVARSALL%" %%P
- %__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
- %_CECHO2% POPD
- %__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_ResetPath
- SET PATH=%TOOLPATH%;%SystemRoot%\System32;%SystemRoot%
- 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%
|