From 3e6e62d86112d301067fa181330ed4114fa578c7 Mon Sep 17 00:00:00 2001 From: kgv Date: Sat, 12 Jun 2021 17:16:37 +0300 Subject: [PATCH] 0032438: Configuration - add batch files to build OCCT using Mingw-w64 --- adm/scripts/mingw_build.bat | 260 ++++++++++++++++++++++++++ adm/scripts/mingw_custom.bat.template | 27 +++ 2 files changed, 287 insertions(+) create mode 100644 adm/scripts/mingw_build.bat create mode 100644 adm/scripts/mingw_custom.bat.template diff --git a/adm/scripts/mingw_build.bat b/adm/scripts/mingw_build.bat new file mode 100644 index 0000000000..69a289285c --- /dev/null +++ b/adm/scripts/mingw_build.bat @@ -0,0 +1,260 @@ +@echo OFF + +rem Auxiliary script for semi-automated building of OCCT for Mingw-w64 platform. +rem mingw_custom.bat should be configured with paths to CMake, 3rd-parties and MinGW. + +set "aCasSrc=%~dp0..\.." +set "aBuildRoot=%aCasSrc%\work" + +set aNbJobs=%NUMBER_OF_PROCESSORS% + +rem Paths to 3rd-party tools and libraries +set "aCmakeBin=" +set "aMingwVars=" +set "aFreeType=" +set "aFreeImage=" +set "aRapidJson=" +set "aTclTk=" + +rem Build stages to perform +set "toCMake=1" +set "toClean=0" +set "toMake=1" +set "toInstall=1" +set "toPack=0" +set "toDebug=0" +set "isStatic=0" + +rem OCCT Modules to build +set "BUILD_ModelingData=ON" +set "BUILD_ModelingAlgorithms=ON" +set "BUILD_Visualization=ON" +set "BUILD_ApplicationFramework=ON" +set "BUILD_DataExchange=ON" +set "BUILD_Draw=ON" + +rem Optional 3rd-party libraries to enable +set "USE_RAPIDJSON=OFF" +set "USE_FREEIMAGE=ON" + +rem Archive tool +set "THE_7Z_PARAMS=-t7z -m0=lzma -mx=9 -mfb=64 -md=32m -ms=on" +set "THE_7Z_PATH=%ProgramW6432%\7-Zip\7z.exe" + +rem Configuration file +if exist "%~dp0mingw_custom.bat" call "%~dp0mingw_custom.bat" + +if not ["%aMingwVars%"] == [""] ( call "%aMingwVars%" ) +if not ["%aCmakeBin%"] == [""] ( set "PATH=%aCmakeBin%;%PATH%" ) + +set "anOcctVerSuffix=" +set "anOcctVersion=0.0.0" +set "aGitBranch=" +for /f tokens^=2^ delims^=^" %%i in ('findstr /b /c:"#define OCC_VERSION_DEVELOPMENT" "%aCasSrc%\src\Standard\Standard_Version.hxx"') do ( set "anOcctVerSuffix=%%i" ) +for /f tokens^=2^ delims^=^" %%i in ('findstr /b /c:"#define OCC_VERSION_COMPLETE" "%aCasSrc%\src\Standard\Standard_Version.hxx"') do ( set "anOcctVersion=%%i" ) +for /f %%i in ('git symbolic-ref --short HEAD') do ( set "aGitBranch=%%i" ) + +set "aBuildType=Release" +set "aBuildTypePrefix=" +set "aLibType=Shared" +if ["%isStatic%"] == ["1"] set "aLibType=Static" +if ["%toDebug%"] == ["1"] ( + set "aBuildType=Debug" + set "aBuildTypePrefix=-debug" +) + +call :cmakeGenerate +if errorlevel 1 ( + if not ["%1"] == ["-nopause"] ( + pause + ) + exit /B 1 + goto :eof +) + +for /F "skip=1 delims=" %%F in (' + wmic PATH Win32_LocalTime GET Day^,Month^,Year /FORMAT:TABLE +') do ( + for /F "tokens=1-3" %%L in ("%%F") do ( + set DAY00=0%%L + set MONTH00=0%%M + set YEAR=%%N + ) +) +set DAY00=%DAY00:~-2% +set MONTH00=%MONTH00:~-2% +set "aRevision=-%YEAR%-%MONTH00%-%DAY00%" +rem set "aRevision=-%aGitBranch%" +set "anArchName=occt-%anOcctVersion%%anOcctVerSuffix%%aRevision%-mingw64%aBuildTypePrefix%" +set "aTarget=%aBuildRoot%\%anArchName%" +if ["%toPack%"] == ["1"] ( + echo Creating archive %anArchName%.7z + rmdir /S /Q "%aTarget%" + if not exist "%aTarget%" ( mkdir "%aTarget%" ) + if exist "%aBuildRoot%/%anArchName%.7z" del "%aBuildRoot%/%anArchName%.7z" + xcopy /S /Y "%aDestDir%\*" "%aTarget%\" + + echo Copying dependencies... + for %%i in (libstdc++-6.dll libwinpthread-1.dll libgcc_s_seh-1.dll) do ( + if "%%~$PATH:i" == "" ( + echo "Error: could not find %%i" + ) else ( + xcopy /Y "%%~$PATH:i" "%aTarget%\win64\gcc\bin" + ) + ) + + "%THE_7Z_PATH%" a -r %THE_7Z_PARAMS% "%aBuildRoot%/%anArchName%.7z" "%aTarget%" +) +if not ["%1"] == ["-nopause"] ( + pause +) + +goto :eof + +:cmakeGenerate +set "aPlatformAndCompiler=mingw64%aBuildTypePrefix%" +set "aWorkDir=%aBuildRoot%\occt-%aPlatformAndCompiler%-make" +set "aDestDir=%aBuildRoot%\occt-%aPlatformAndCompiler%" +set "aLogFile=%aBuildRoot%\occt-%aPlatformAndCompiler%-build.log" +if ["%toCMake%"] == ["1"] ( + if ["%toClean%"] == ["1"] ( + rmdir /S /Q %aWorkDir%" + rmdir /S /Q %aDestDir%" + ) +) +if not exist "%aWorkDir%" ( mkdir "%aWorkDir%" ) +if exist "%aLogFile%" ( del "%aLogFile%" ) + +rem include some information about OCCT into archive +echo ^> "%aWorkDir%\VERSION.html" +git status >> "%aWorkDir%\VERSION.html" +git log -n 100 >> "%aWorkDir%\VERSION.html" +echo ^>> "%aWorkDir%\VERSION.html" + +echo Start building OCCT for %aPlatformAndCompiler% +echo Start building OCCT for %aPlatformAndCompiler%>> %aLogFile% + +pushd "%aWorkDir%" + +set "aTimeZERO=%TIME%" +if ["%toCMake%"] == ["1"] ( + echo Configuring OCCT for MinGW-w64... + cmake -G "MinGW Makefiles" ^ + -D CMAKE_BUILD_TYPE:STRING="%aBuildType%" ^ + -D BUILD_LIBRARY_TYPE:STRING="%aLibType%" ^ + -D INSTALL_DIR:PATH="%aDestDir%" ^ + -D INSTALL_DIR_INCLUDE:STRING="inc" ^ + -D INSTALL_DIR_RESOURCE:STRING="src" ^ + -D BUILD_DOC_Overview:BOOL="OFF" ^ + -D BUILD_MODULE_FoundationClasses:BOOL="ON" ^ + -D BUILD_MODULE_ModelingData:BOOL="%BUILD_ModelingData%" ^ + -D BUILD_MODULE_ModelingAlgorithms:BOOL="%BUILD_ModelingAlgorithms%" ^ + -D BUILD_MODULE_Visualization:BOOL="%BUILD_Visualization%" ^ + -D BUILD_MODULE_ApplicationFramework:BOOL="%BUILD_ApplicationFramework%" ^ + -D BUILD_MODULE_DataExchange:BOOL="%BUILD_DataExchange%" ^ + -D BUILD_MODULE_Draw:BOOL="%BUILD_Draw%" ^ + -D 3RDPARTY_TCL_DIR:PATH="%aTclTk%" ^ + -D 3RDPARTY_TCL_INCLUDE_DIR:FILEPATH="%aTclTk%/include" ^ + -D 3RDPARTY_TCL_LIBRARY_DIR:PATH="%aTclTk%/lib" ^ + -D 3RDPARTY_TCL_DLL_DIR:PATH="%aTclTk%/bin" ^ + -D 3RDPARTY_TK_DIR:PATH="%aTclTk%" ^ + -D 3RDPARTY_TK_INCLUDE_DIR:FILEPATH="%aTclTk%/include" ^ + -D 3RDPARTY_TK_LIBRARY_DIR:PATH="%aTclTk%/lib" ^ + -D 3RDPARTY_TK_DLL_DIR:PATH="%aTclTk%/bin" ^ + -D USE_D3D:BOOL="ON" ^ + -D USE_FREETYPE:BOOL="ON" ^ + -D 3RDPARTY_FREETYPE_DIR:PATH="%aFreeType%" ^ + -D 3RDPARTY_FREETYPE_INCLUDE_DIR_freetype2:FILEPATH="%aFreeType%/include" ^ + -D 3RDPARTY_FREETYPE_INCLUDE_DIR_ft2build:FILEPATH="%aFreeType%/include" ^ + -D 3RDPARTY_FREETYPE_LIBRARY_DIR:PATH="%aFreeType%/lib" ^ + -D USE_FREEIMAGE:BOOL="%USE_FREEIMAGE%" ^ + -D 3RDPARTY_FREEIMAGE_DIR:PATH="%aFreeImage%" ^ + -D 3RDPARTY_FREEIMAGE_INCLUDE_DIR:FILEPATH="%aFreeImage%/include" ^ + -D 3RDPARTY_FREEIMAGE_LIBRARY_DIR:PATH="%aFreeImage%/lib" ^ + -D USE_RAPIDJSON:BOOL="%USE_RAPIDJSON%" ^ + -D 3RDPARTY_RAPIDJSON_DIR:PATH="%aRapidJson%" ^ + -D 3RDPARTY_RAPIDJSON_INCLUDE_DIR:PATH="%aRapidJson%/include" ^ + "%aCasSrc%" + + if errorlevel 1 ( + popd + exit /B 1 + goto :eof + ) +) +set "aTimeGEN=%TIME%" +call :computeDuration %aTimeZERO% %aTimeGEN% +if ["%toCMake%"] == ["1"] ( + echo Generation time: %DURATION% + echo Generation time: %DURATION%>> "%aLogFile%" +) + +if ["%toClean%"] == ["1"] ( + mingw32-make clean +) + +if ["%toMake%"] == ["1"] ( + echo Building... + mingw32-make -j %aNbJobs% 2>> "%aLogFile%" + if errorlevel 1 ( + type "%aLogFile%" + popd + exit /B 1 + goto :eof + ) + type "%aLogFile%" +) +set "aTimeBUILD=%TIME%" +call :computeDuration %aTimeGEN% %aTimeBUILD% +if ["%toMake%"] == ["1"] ( + echo Building time: %DURATION% + echo Building time: %DURATION%>> "%aLogFile%" +) +call :computeDuration %aTimeZERO% %aTimeBUILD% +if ["%toMake%"] == ["1"] ( + echo Total building time: %DURATION% + echo Total building time: %DURATION%>> "%aLogFile%" +) + +if ["%toInstall%"] == ["1"] ( + echo Installing into %aDestDir%... + mingw32-make install 2>> "%aLogFile%" + copy /Y "%aWorkDir%\VERSION.html" "%aDestDir%\VERSION.html" +) +set "aTimeINSTALL=%TIME%" +call :computeDuration "%aTimeBUILD%" "%aTimeINSTALL%" +if ["%toInstall%"] == ["1"] ( + echo Install time: %DURATION% + echo Install time: %DURATION%>> "%aLogFile%" +) + +call :computeDuration "%aTimeZERO%" "%aTimeINSTALL%" +echo Total time: %DURATION% +echo Total time: %DURATION%>> "%aLogFile%" + +popd +goto :eof + +:computeDuration +set "aTimeFrom=%~1" +set "aTimeEnd=%~2" +rem handle time before 10AM (win10 - remove empty space at the beginning) +if "%aTimeFrom:~0,1%"==" " set "aTimeFrom=%aTimeFrom:~1%" +if "%aTimeEnd:~0,1%"==" " set "aTimeEnd=%aTimeEnd:~1%" +rem handle time before 10AM (win7 - add 0 at the beginning) +if "%aTimeFrom:~1,1%"==":" set "aTimeFrom=0%aTimeFrom%" +if "%aTimeEnd:~1,1%"==":" set "aTimeEnd=0%aTimeEnd%" +rem convert hours:minutes:seconds:ms into duration +set /A aTimeFrom=(1%aTimeFrom:~0,2%-100)*360000 + (1%aTimeFrom:~3,2%-100)*6000 + (1%aTimeFrom:~6,2%-100)*100 + (1%aTimeFrom:~9,2%-100) +set /A aTimeEnd= (1%aTimeEnd:~0,2%-100)*360000 + (1%aTimeEnd:~3,2%-100)*6000 + (1%aTimeEnd:~6,2%-100)*100 + (1%aTimeEnd:~9,2%-100) +set /A aDurTotalSec=%aTimeEnd%-%aTimeFrom% +if %aTimeEnd% LSS %aTimeFrom% set set /A aDurTotalSec=%aTimeFrom%-%aTimeEnd% +set /A aDurHH=%aDurTotalSec% / 360000 +set /A aDurMM=(%aDurTotalSec% - %aDurHH%*360000) / 6000 +set /A aDurSS=(%aDurTotalSec% - %aDurHH%*360000 - %aDurMM%*6000) / 100 +if %aDurHH% LSS 10 set aDurHH=0%aDurHH% +if %aDurMM% LSS 10 set aDurMM=0%aDurMM% +if %aDurSS% LSS 10 set aDurSS=0%aDurSS% + +set "DURATION=%aDurHH%:%aDurMM%:%aDurSS%" +goto :eof diff --git a/adm/scripts/mingw_custom.bat.template b/adm/scripts/mingw_custom.bat.template new file mode 100644 index 0000000000..8870a53ec9 --- /dev/null +++ b/adm/scripts/mingw_custom.bat.template @@ -0,0 +1,27 @@ +rem Environment configuration template for mingw_build.bat (to be renamed as mingw_custom.bat) +set "aCmakeBin=%ProgramW6432%\CMake\bin" +set "aFreeType=%aCasSrc%/../3rdparty/freetype-2.6.3-mingw-64" +set "aTclTk=%aCasSrc%/../3rdparty/tcltk-8.6.4-mingw-64" +set "aFreeImage=%aCasSrc%/../3rdparty/freeimage-3.17-0-mingw-64" +set "aRapidJson=%aCasSrc%/../3rdparty/rapidjson-1.1.0" + +set "aMingwVars=c:\mingw-8.3.0-msys2\mingwvars.bat" + +rem Uncomment to customize building steps +rem set "aBuildRoot=work" +rem set "toCMake=1" +rem set "toClean=1" +rem set "toMake=1" +rem set "toInstall=1" +rem set "toPack=1" +rem set "toDebug=0" + +rem set "BUILD_ModelingData=ON" +rem set "BUILD_ModelingAlgorithms=ON" +rem set "BUILD_Visualization=ON" +rem set "BUILD_ApplicationFramework=ON" +rem set "BUILD_DataExchange=ON" +rem set "BUILD_Draw=ON" + +rem set "USE_RAPIDJSON=ON" +rem set "USE_FREEIMAGE=ON"