Please note: This solution is for 64-bit builds only.
The provided code has been tried and tested on Windows 11 and Windows 2019 server.
To build the solution you need:
- Visual Studio 17.11.6 Ensure that you have installed support for .Net 8, 64-bit C++ development and 64-bit python development.
- boost c++ libraries
- nasm
- yasm
- ICU4C
- julia version 1.10 - Only needed to build
Harlinn.Julia
and related projects. - Oracle OCI - Only needed to build
Harlinn.OCI
and related projects. - Intel® oneAPI Base Toolkit
- WinFlexBison - Flex and Bison for Microsoft Windows
- swig
- perl
- OpenSSL
- nVidia CUDA toolkit
- VLC media player source code - Only needed to build
Harlinn.Media
and related projects. - GStreamer - Only needed to build
Harlinn.Media
and related projects. - XDP and XDP devkit
Make sure you install 64-bit binaries, libraries and headers.
Before building you need to set a few environment variables:
- BOOST_ROOT must point to the root of your boost C++ installation
- HCC_TEST_DATA_ROOT must point to a folder where the test programs can create sub folders used by the test and example programs for the LMDB and ESE databases. Make sure you have about 40GB of available free space for the databases.
- ICU4C_HOME must point to the root of your ICU4C installation
- JULIA_HOME must point to the root of your Julia installation.
- ORACLE_HOME must point to the root of your Oracle installation.
- HCC_HOME must point to the directory containing Harlinn.Windows.sln.
- PROJ_LIB must point to %HCC_HOME%\Share\proj
- GDAL_DATA must point to %HCC_HOME%\Share\gdal
- OPENSSL_HOME must point to the root of your openssl 3.x installation, which is the directory containing the bin, include and lib directories.
- VLC_SOURCE must point to the directory that contains the source code for the VLC media player.
- INTEL_MKL_INCLUDE must point to the directory containing the Intel Math Kernel Library include files
- INTEL_MKL_LIB must point to the directory containing the Intel Math Kernel Library *.lib files
- PYTHON_HOME must point to the root folder of your python installation.
- XDP_DEVKIT_HOME must point to the root folder of your XDP Devkit installation.
The PATH environment variable must be updated to reference:
- %BOOST_ROOT%\stage\lib
- %ICU4C_HOME%\bin64
- %JULIA_HOME%\bin
- %ORACLE_HOME%\bin
- The directory containing yasm.exe
- The directory containing nasm.exe
- The directory containing perl.exe
- The directory containing flex.exe
- The directory containing bison.exe
- The directory containing swig.exe
- The directory containing the MKL redistributable dlls
Visual Studio sometimes hangs while building the entire solution. The work-around is to split the build, and this can be done by first building 3rdParty\Harlinn.skia and then 3rdParty\Harlinn.gdal separately, before building the rest of the solution.
It looks like this is caused by a race inside Visual Studio. When it hangs, Visual Studio uses 100% of one core, and the devenv.exe process must be killed and restarted before continuing the build.
After downloading the boost libraries, you need to build boost using the following commands:
bootstrap
b2 -j8 address-model=64 threading=multi variant=debug link=shared --build-type=complete cxxstd=latest cflags=/arch:AVX2 cflags=/fsanitize=address cflags=/sdl stage
b2 -j8 address-model=64 threading=multi variant=release link=shared --build-type=complete cxxstd=latest cflags=/arch:AVX2 stage
The first invocation of b2 performs a debug build of the boost libraries as dlls with the address sanitizer and sdl enabled, while the second performs a dll release build.
Make sure you compile for x64 by selecting x64 from the solution platforms drop-down in Visual Studio, and if you plan to test the code on a system that does not support AVX2, you need to change the Enable Enhanced Instruction Set setting under C/C++ ⇒ Code Generation to a value suitable for your system.
The .Net 8.0 SDK, or newer, is required to build the C# code.
If you want to build the Harlinn.Julia library you need to have a 64-bit version of Julia installed on your computer. The JULIA_HOME environment variable must point to the root of your Julia installation.
You need to manually copy $(SolutionDir)Tests\Harlinn.OCI.Tests\Harlinn.OCI.Tests.xml* into both the $(SolutionDir)x64\Debug folder and the $(SolutionDir)x64\Release folder. You also need to edit this file before copying to provide Oracle login information for the Harlinn.OCI.Tests project.
If you want to build Harlinn.OCI, Harlinn.OCI.Tests and related the examples you need a 64-bit Oracle installation that includes the oracle C based OCI API. The build expects the ORACLE_HOME environment variable to point to the root of your oracle installation.
Before running the unit tests in Harlinn.OCI.Tests you need to create the tables defined in $(SolutionDir)Tests\Harlinn.OCI.Tests\SQL\TestTables.sql
The Harlinn.Media
project creates a dll that locates the installation of the 64-bit
version of the VLC media player from the registry. Harlinn.Media.dll
exports most of the
entry points exported by the libvlc.dll
and forwards the calls to the dynamically
located libvlc.dll
.
Make sure that the $(VLC_SOURCE)\include\vlc
contains a valid libvlc_version.h
. If you don't want to build
VLC media player from the source code, you will need to make the appropriate changes to libvlc_version.h.in
and save it as libvlc_version.h
.
/** LibVLC major version number */
# define LIBVLC_VERSION_MAJOR 3
/** LibVLC minor version number */
# define LIBVLC_VERSION_MINOR 0
/** LibVLC revision */
# define LIBVLC_VERSION_REVISION 20