Version 3.20.6-2 is a maintenance release; it adds support for Apple Silicon and uses the latest build scripts.

The xPack CMake is a standalone cross-platform binary distribution of CMake.

There are separate binaries for Windows (x64 and x86), macOS (x64, arm64) and GNU/Linux (x64 and x86, arm64 and arm).

Download

The binary files are available from GitHub Releases.

Prerequisites

  • x86/x64 GNU/Linux: any system with GLIBC 2.15 or higher (like Ubuntu 12 or later, Debian 8 or later, RedHat/CentOS 7 later, Fedora 20 or later, etc)
  • arm64/arm GNU/Linux: any system with GLIBC 2.23 or higher (like Ubuntu 16 or later, Debian 9 or later, RedHat/CentOS 8 or later, Fedora 24 or later, etc)
  • x86/x64 Windows: Windows 7 with the Universal C Runtime (UCRT), Windows 8, Windows 10
  • x64 macOS: 10.13 or later
  • arm64 macOS: 11.6 or later

Install

The full details of installing the xPack CMake on various platforms are presented in the separate Install page.

Easy install

The easiest way to install CMake is with xpm by using the binary xPack, available as @xpack-dev-tools/cmake from the npmjs.com registry.

With the xpm tool available, installing the latest version of the package and adding it as a dependency for a project is quite easy:

cd my-project
xpm init # Only at first use.

xpm install @xpack-dev-tools/cmake@latest

ls -l xpacks/.bin

To install this specific version, use:

xpm install @xpack-dev-tools/cmake@3.20.6-2.1

It is also possible to install Meson Build globally, in the user home folder, but this requires xPack aware tools to automatically identify them and manage paths.

xpm install --global @xpack-dev-tools/cmake@latest --verbose

Uninstall

To remove the links from the current project:

cd my-project

xpm uninstall @xpack-dev-tools/cmake

To completely remove the package from the central xPacks store:

xpm uninstall --global @xpack-dev-tools/cmake

Compliance

The xPack CMake is based on the official CMake, with minimal changes.

The current version is based on:

  • CMake release 3.20.6 from Sep 20, 2021.

Changes

Compared to the upstream version, the Windows version also supports spawning scripts via cmd.exe /c. These scripts are used by npm/xpm to redirect invocations to the central packages repository.

Bug fixes

  • none

Enhancements

  • none

Known problems

  • none

Shared libraries

On all platforms the packages are standalone, and expect only the standard runtime to be present on the host.

All dependencies that are build as shared libraries are copied locally in the libexec folder (or in the same folder as the executable for Windows).

DT_RPATH and LD_LIBRARY_PATH

On GNU/Linux the binaries are adjusted to use a relative path:

$ readelf -d library.so | grep runpath
 0x000000000000001d (RPATH)            Library rpath: [$ORIGIN]

In the GNU ld.so search strategy, the DT_RPATH has the highest priority, higher than LD_LIBRARY_PATH, so if this later one is set in the environment, it should not interfere with the xPack binaries.

Please note that previous versions, up to mid-2020, used DT_RUNPATH, which has a priority lower than LD_LIBRARY_PATH, and does not tolerate setting it in the environment.

@rpath and @loader_path

Similarly, on macOS, the binaries are adjusted with install_name_tool to use a relative path.

Documentation

The current version specific CMake documentation is available in each packet:

  • doc/cmake-X.Y/html/index.html

and online from:

Build

The binaries for all supported platforms (Windows, macOS and GNU/Linux) were built using the xPack Build Box (XBB), a set of build environments based on slightly older distributions, that should be compatible with most recent systems.

The scripts used to build this distribution are in:

  • distro-info/scripts

For the prerequisites and more details on the build procedure, please see the README-MAINTAINER page.

CI tests

Before publishing, a set of simple tests were performed on an exhaustive set of platforms. The results are available from:

Tests

TBD

Checksums

The SHA-256 hashes for the files are:

80cfe688c6290a2eb527b5de19ed60848cc7d423dc643fa7152eedbf4c336a85
xpack-cmake-3.20.6-2-darwin-arm64.tar.gz

4647c8bd45cc2ee151fa6cf60d60db991fa96cd8b4593126569af0e382d17c44
xpack-cmake-3.20.6-2-darwin-x64.tar.gz

4c942096abb275139a1c21474c87112ba731419af386dc84cbd6c4f9e49c6a05
xpack-cmake-3.20.6-2-linux-arm.tar.gz

04aae33537e211cfc6062faece07ac0f4ab28062015186658ac7a02ad5ae6dea
xpack-cmake-3.20.6-2-linux-arm64.tar.gz

d43267651a018ef004e2689f5ce25276491701470a6e33d250b640c69cac197f
xpack-cmake-3.20.6-2-linux-ia32.tar.gz

0995feab1594eeb39d51ed008c122f56328d4f7bf702be4919e1a82a0e13bcb6
xpack-cmake-3.20.6-2-linux-x64.tar.gz

59b8906e6e2a62920b59a742458c392a3a0a8965666a58c2fa4e2a3a96f9038d
xpack-cmake-3.20.6-2-win32-ia32.zip

1c2bd6c8c035367da7dd37f3f972596097764c488fb01c7eb13ac558a7aa900e
xpack-cmake-3.20.6-2-win32-x64.zip

Deprecation notices

32-bit support

Support for 32-bit x86 GNU/Linux and x86 Windows will most probably be dropped in 2022. Support for 32-bit Arm GNU/Linux will be preserved for a while, due to the large user base of 32-bit Raspberry Pi systems.

GNU/Linux minimum requirements

Support for RedHat 7 will most probably be dropped in 2022, and the minimum requirement will be raised to GLIBC 2.27, available starting with Ubuntu 18 and RedHat 8.

Download analytics

Credit to Shields IO for the badges and to Somsubhra/github-release-stats for the individual file counters.