This is a compile script that compiles HDF5 libraries from source statically with multithread support, i.e., “/MT” flag in Visual Studio. automatically.
After discussing with one of the programmers of HDF5, it was made clear that linking statically works safely only in the condition HDF5 library wasn’t compiled with parallel support.
The script involves going to the file
and copying the file’s contents to “UserMacros.cmake”. The same is also done for ZLib and SZip after extracting them, and rezipping them again.
@echo off ::The following is the name of the folder of HDF5 source set "hdffolder=hdf5-1.8.16" ::add a new line then add /MT compilation options call echo & echo. >> %hdffolder%\UserMacros.cmake cat %hdffolder%\config\cmake\UserMacros\Windows_MT.cmake >> %hdffolder%\UserMacros.cmake for %%i in (%hdffolder%\UserMacros.cmake) do sed -i "s/\"Build With Static CRT Libraries\" OFF/\"Build With Static CRT Libraries\" ON/g" %%i ::add a new line then add /MT to SZip after extracting it, and then recompress it gzip -dc SZip.tar.gz | tar -xf - mv SZip.tar.gz SZip-dynamic.tar.gz call echo & echo. >> UserMacros.cmake cat SZip\config\cmake\UserMacros\Windows_MT.cmake >>SZip\UserMacros.cmake for %%i in (SZip\UserMacros.cmake) do sed -i "s/\"Build With Static CRT Libraries\" OFF/\"Build With Static CRT Libraries\" ON/g" %%i tar cf SZip.tar SZip\ gzip SZip.tar rm -r SZip ::do the same to ZLib gzip -dc ZLib.tar.gz | tar -xf - mv ZLib.tar.gz ZLib-dynamic.tar.gz call echo & echo. >> UserMacros.cmake cat ZLib\config\cmake\UserMacros\Windows_MT.cmake >>ZLib\UserMacros.cmake for %%i in (ZLib\UserMacros.cmake) do sed -i "s/\"Build With Static CRT Libraries\" OFF/\"Build With Static CRT Libraries\" ON/g" %%i tar cf ZLib.tar ZLib\ gzip ZLib.tar rm -r ZLib build-VS2013-32.bat
Note: If CMake won’t show in path in command prompt, run prompt as administrator, or use this command to add the path you want to the environment variable %PATH%
set PATH=C:\Program Files (x86)\CMake\bin;%PATH%
Gow is GNU tools for windows, like tar, gzip and sed. These are important for the script.
Whether you’d like to have a 32-bit or 64-bit version of visual studio used depends on the environment variables that are defined. The easiest way is to run the run command prompt for the version you want. For example, in Visual Studio 2013, if one goes to Start, then types in quick search “Visual”, you’ll find a folder called “Visual Studio Tools”. This folder will have both command prompts with the relevant environment variables. The following shows this folder:
Prepare to run the script
Go to this page, and download the CMake source. Extract it; put the script in a file there; if the version you want to compile is different than the one in the script, modify the folder name; and finally run the script. After the script is finished, you’ll have a compressed zip file with compiled source and an installer executable.