Skip to content

Latest commit

 

History

History
138 lines (109 loc) · 6.85 KB

Build.md

File metadata and controls

138 lines (109 loc) · 6.85 KB

Build instructions

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.

Requirements

To build the solution you need:

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

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.

Command line for building the boost libraries

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 x64 is selected in the Solution Platforms drop-down in Visual Studio

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.

.Net 8.0 support

The .Net 8.0 SDK, or newer, is required to build the C# code.

Julia support

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.

Oracle

Oracle authentication

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.

Oracle Call Interface (OCI) support

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

Harlinn.Media and the VLC media player source code

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