Installing ClamAV on Windows from Source
The following are instructions to build ClamAV version 0.104 and newer using CMake.
Tip: If you wish to build ClamAV from source in ClamAV version 0.103 and older, you'll have to use the Visual Studio solution, please see the Win32 ClamAV Build Instructions located in our source release materials on ClamAV.net and on GitHub.
Note: Some of the dependencies are optional if you elect to not build all of the command line applications, or elect to only build the libclamav library. Specifically:
- libcurl: required for libfreshclam, freshclam, clamsubmit
- ncurses: required for clamdtop
For more information about customized builds and which dependencies can be skipped, please see the
INSTALL.mddocument accompanying the source code.
Install prerequisites
The following commands for building on Windows are written for Powershell.
At a minimum you will need:
- Visual Studio 2015 or newer
- CMake
- The Rust programming language toolchain (for ClamAV version 0.105+)
If you want to build the installer, you'll also need WiX Toolset.
If you're using Chocolatey, you can install CMake and WiX simply like this:
choco install cmake wixtoolset
If you're using Mussels to build the library dependencies (see below), then you may also need to install Netwide Assembler (NASM) and StrawberryPerl. These are also simple to install using Chocolatey:
choco install nasm strawberryperl
Then open a new terminal so that CMake and WiX will be in your $PATH.
Building the library dependencies
There are two options for building and supplying the library dependencies. These are Mussels and vcpkg.
Mussels is an open source project developed in-house by the ClamAV team. It offers great flexibility for defining your own collections (cookbooks) of build instructions (recipes) instead of solely relying on a centralized repository of ports. And unlike vcpkg, Mussels does not implement CMake build tooling for projects that don't support CMake, but instead leverages whatever build system is provided by the project. This means that Mussels builds may require installing additional tools, like NMake and StrawberryPerl rather than simply requiring CMake. The advantage is that you'll be building those projects the same way that those developers intended, and that Mussels recipes are generally very light weight. Mussels has some sharp edges because it's a newer and much smaller project than vcpkg.
Vcpkg is an open source project developed by Microsoft and is heavily oriented towards CMake projects. Vcpkg offers a very large collection of "ports" for almost any project you may need to build. It is very easy to get started with vcpkg.
Mussels is the preferred tool to supply the library dependencies at least until such time as the vcpkg Debug-build libclamav unit test heap-corruption crash is resolved (see below).
Details for how to use Mussels and vcpkg will be provided with the build instructions (below), as the instructions differ significantly depending on which you choose.
Tip: Installing the Python 3
pytestpackage is also recommended in case the unit tests fail so that the test output is easy to read. You're welcome to skip it. However, if you have Python 2'spytestinstalled but not Python 3'spytest, the tests may fail to run.You can install pytest by running:
python3 -m pip install --user pytest
Install Rust toolchain
Starting with ClamAV version 0.105, the Rust toolchain is required to compile ClamAV. You can install the appropriate toolchain for your development environment by following the instructions on the rustup website. This ensures that you have the most up-to-date compiler available at the time of installation; keep your toolchain updated for new features and bug/security fixes by periodically executing: rustup update.
Building ClamAV requires, at a minimum, Rust compiler version 1.56, as it relies on features introduced in the Rust 2021 Edition.
Download the source code
Download the source from the clamav.net downloads page.
Extract the archive. You should be able to right click on it and extract it to a folder, then in that folder, do the same for the clamav-[ver].tar file.
The rest of the instructions will assume you've opened Powershell in the clamav source directory.
Build ClamAV
First, make a "build" subdirectory. This will enable you to easily delete your build files if something goes wrong and you need to re-configure and try again.
mkdir build && cd build
Building with Mussels
Building the library dependencies with Mussels
Much like vcpkg, Mussels can be used to automatically build the ClamAV library dependencies. Unlike vcpkg, Mussels does not provide a mechanism for CMake to automatically detect the
library paths.
To build the library dependencies with Mussels, use Python's pip package manager to install Mussels:
python3 -m pip install mussels
Important: Always run
musselsormslin a small sub-directory. Mussels will recursively search your current directory for YAML recipe files. In a large directory, such as your home directory, this may take a long time.
Update the Mussels cookbooks to get the latest build recipes and set the
clamav cookbook to be trusted:
msl update
msl cookbook trust clamav
Use msl list if you wish to see the recipes provided by the clamav cookbook.
To build with Mussels, you may need to install a few extra tools required to build some of the libraries. These include NASM and StrawberryPerl. See install prerequisites, above.
Build the clamav_deps recipe to compile ClamAV's library dependencies. By default, Mussels will install them to ~\.mussels\install\<target>
msl build clamav_deps
If this worked, you should be ready to build ClamAV.
Tip: You can also build for 32-bit systems, using
msl build clamav_deps -t x86.
Building ClamAV
To configure the project, run the following, substiting "Visual Studio 16 2019" with your Visual Studio version:
cmake ..  -G "Visual Studio 16 2019" -A x64 `
  -D JSONC_INCLUDE_DIR="$home\.mussels\install\x64\include\json-c"         `
  -D JSONC_LIBRARY="$home\.mussels\install\x64\lib\json-c.lib"             `
  -D ENABLE_JSON_SHARED=OFF                                              `
  -D BZIP2_INCLUDE_DIR="$home\.mussels\install\x64\include"                `
  -D BZIP2_LIBRARY_RELEASE="$home\.mussels\install\x64\lib\libbz2.lib"     `
  -D CURL_INCLUDE_DIR="$home\.mussels\install\x64\include"                 `
  -D CURL_LIBRARY="$home\.mussels\install\x64\lib\libcurl_imp.lib"         `
  -D OPENSSL_ROOT_DIR="$home\.mussels\install\x64"                         `
  -D OPENSSL_INCLUDE_DIR="$home\.mussels\install\x64\include"              `
  -D OPENSSL_CRYPTO_LIBRARY="$home\.mussels\install\x64\lib\libcrypto.lib" `
  -D OPENSSL_SSL_LIBRARY="$home\.mussels\install\x64\lib\libssl.lib"       `
  -D ZLIB_LIBRARY="$home\.mussels\install\x64\lib\libssl.lib"              `
  -D LIBXML2_INCLUDE_DIR="$home\.mussels\install\x64\include"              `
  -D LIBXML2_LIBRARY="$home\.mussels\install\x64\lib\libxml2.lib"          `
  -D PCRE2_INCLUDE_DIR="$home\.mussels\install\x64\include"                `
  -D PCRE2_LIBRARY="$home\.mussels\install\x64\lib\pcre2-8.lib"            `
  -D CURSES_INCLUDE_DIR="$home\.mussels\install\x64\include"               `
  -D CURSES_LIBRARY="$home\.mussels\install\x64\lib\pdcurses.lib"          `
  -D PThreadW32_INCLUDE_DIR="$home\.mussels\install\x64\include"           `
  -D PThreadW32_LIBRARY="$home\.mussels\install\x64\lib\pthreadVC3.lib"    `
  -D ZLIB_INCLUDE_DIR="$home\.mussels\install\x64\include"                 `
  -D ZLIB_LIBRARY="$home\.mussels\install\x64\lib\zlibstatic.lib"          `
  -D LIBCHECK_INCLUDE_DIR="$home\.mussels\install\x64\include"             `
  -D LIBCHECK_LIBRARY="$home\.mussels\install\x64\lib\checkDynamic.lib"    `
  -D CMAKE_INSTALL_PREFIX="install"
Tip: You have to drop the
-A x64arguments if you're building for 32-bits (or specify-A win32) and substitutex64withx86in the library paths.
Now, go ahead and build the project:
cmake --build . --config RelWithDebInfo
Tip: If you're having include-path issues when building, try building with detailed verbosity so you can verify that the paths are correct:
cmake --build . --config RelWithDebInfo -- /verbosity:detailed
You can run the test suite with ctest:
ctest -C RelWithDebInfo
And you can install to the install (set above) like this:
cmake --build . --config RelWithDebInfo --target install
Tip: For a full list of configuration options, see the "Custom CMake Config Options" section of the
INSTALL.mdfile included with the source code.
Building with vcpkg
vcpkg can be used to build the ClamAV library dependencies automatically.
vcpkg integrates really well with CMake, enabling CMake to find your compiled libraries automatically, so you don't have to specify the include & library paths manually as you do when using Mussels.
DISCLAIMER: There is a known issue with the unit tests when building with vcpkg in
Debugmode. When you run the libclamav unit tests (check_clamav), the program will crash and a popup will claim there was heap corruption. If > you use Task Manager to kill thecheck_clamav.exeprocess, the rest of the tests pass just fine. This issue does not occur when using Mussels to supply the library dependencies. Commenting out the following lines inreaddb.cresolves the heap corruption crash when runningcheck_clamav, but of course introduces a memory leak:if (engine->stats_data) free(engine->stats_data);If anyone has time to figure out the real cause of the vcpkg
Debug-build crash incheck_clamav, it would be greatly appreciated.
You'll need to install vcpkg. See the vcpkg README for installation instructions.
Once installed, set the variable $VCPKG_PATH to the location where you installed vcpkg:
$VCPKG_PATH="..." # Path to your vcpkg installation
By default, CMake and vcpkg build for 32-bit. If you want to build for 64-bit, set the VCPKG_DEFAULT_TRIPLET environment variable:
$env:VCPKG_DEFAULT_TRIPLET="x64-windows"
Next, use vcpkg to build the required library dependencies:
& "$VCPKG_PATH\vcpkg" install 'curl[openssl]' 'json-c' 'libxml2' 'pcre2' 'pthreads' 'zlib' 'pdcurses' 'bzip2' 'check'
Now configure the ClamAV build using the CMAKE_TOOLCHAIN_FILE variable which will enable CMake to automatically find the libraries we built with vcpkg.
cmake .. -A x64 `
  -D CMAKE_TOOLCHAIN_FILE="$VCPKG_PATH\scripts\buildsystems\vcpkg.cmake" `
  -D CMAKE_INSTALL_PREFIX="install"
Now, go ahead and build the project:
cmake --build . --config RelWithDebInfo
You can run the test suite with ctest:
ctest -C RelWithDebInfo
And you can install to the install directory (set above) like this:
cmake --build . --config RelWithDebInfo --target install
Build the Installer
To build the installer, you must have WIX Toolset installed. If you're using Chocolatey, you can install it simply with choco install wixtoolset and then open a new terminal so that WIX will be in your PATH.
cpack -C RelWithDebInfo
What now?
Now that ClamAV is installed, you will want to customize your configuration and perhaps set up some scanning automation and alerting mechanisms.