curl-curl/docs/INTERNALS.md
Viktor Szakats 89043ba906
cmake: drop support for CMake 3.17 and older
Require CMake 3.18 (2020-07-15) or newer, up from 3.7 (2016-11-11)
prior to this patch.

This requirement also applies to the distributed `curl-config.cmake`.

To allow dropping compatibility code maintained for old versions, and to
use features which were unpractical in separate code paths. Also to make
testing, documentation and development easier, CI builds faster due to
CMake performance improvements over time. (e.g. integration tests on
macOS run 8x faster (10 minutes is now under 1.5m) in CI, 2.5x faster on
Windows.)

CMake offers pre-built binaries for major platforms. They work without
an install step, just by unpacking and pointing the cmake command to
them. Making upgrades easy in many cases:
https://cmake.org/download/
https://cmake.org/files/
https://github.com/Kitware/CMake/releases

CMake 3.18 brings these feature as generally available when building or
consuming curl/libcurl:

LTO support, improved performance, `pkg-config` and interface target
support, `OBJECT` target (for faster libcurl builds), modern invocation
with `-S`/`-B` options, better support for custom linker options,
FetchContent, `GnuTLS::GnuTLS` target, `--verbose` and `--install`
options, `CMAKE_GENERATOR` env, last but not least unity mode and Ninja
generator.

For maximum build speed, use:
`-DCMAKE_UNITY_BUILD=ON -DCURL_DROP_UNUSED=ON`

As for deprecations, C++11 is required to build CMake itself, which may
be a limit on some platforms. autotools continues to cover them.

Follow-up to 9bcdfb3809 #20408
Follow-up to a7c974e038 #19902
Follow-up to dfbe035c8b #10161
Discussion: https://github.com/curl/curl/discussions/18704

Closes #20407
2026-03-21 13:24:47 +01:00

2.4 KiB

curl internals

The canonical libcurl internals documentation is now in the everything curl book. This file lists supported versions of libs and build tools.

Portability

We write curl and libcurl to compile with C89 compilers on 32-bit and up machines. Most of libcurl assumes more or less POSIX compliance but that is not a requirement. The compiler must support a 64-bit integer type as well as supply a stdint.h header file that defines C99-style fixed-width integer types like uint32_t.

We write libcurl to build and work with lots of third party tools, and we want it to remain functional and buildable with these and later versions (older versions may still work but is not what we work hard to maintain):

Dependencies

We aim to support these or later versions.

  • brotli 1.0.0 (2017-09-21)
  • c-ares 1.6.0 (2008-12-09)
  • GnuTLS 3.6.5 (2018-12-01)
  • libidn2 2.0.0 (2017-03-29)
  • LibreSSL 2.9.1 (2019-04-22)
  • libssh 0.9.0 (2019-06-28)
  • libssh2 1.9.0 (2019-06-20)
  • mbedTLS 3.2.0 (2022-07-11)
  • MIT Kerberos 1.3 (2003-07-31)
  • nghttp2 1.15.0 (2016-09-25)
  • OpenLDAP 2.0 (2000-08-01)
  • OpenSSL 3.0.0 (2021-09-07)
  • Windows Vista 6.0 (2006-11-08 - 2012-04-10)
  • wolfSSL 3.4.6 (2017-09-22)
  • zlib 1.2.5.2 (2011-12-11)
  • zstd 1.0 (2016-08-31)

Build tools

When writing code (mostly for generating stuff included in release tarballs) we use a few "build tools" and we make sure that we remain functional with these versions:

  • clang-tidy 17.0.0 (2023-09-19), recommended: 19.1.0 or later (2024-09-17)
  • cmake 3.18 (2020-07-15)
  • GNU autoconf 2.59 (2003-11-06)
  • GNU automake 1.7 (2002-09-25)
  • GNU libtool 1.4.2 (2001-09-11)
  • GNU m4 1.4 (2007-09-21)
  • mingw-w64 3.0 (2013-09-20)
  • perl 5.8 (2002-07-19), on Windows: 5.22 (2015-06-01)
  • Visual Studio 2010 10.0 (2010-04-12 - 2020-07-14)

Library Symbols

All symbols used internally in libcurl must use a Curl_ prefix if they are used in more than a single file. Single-file symbols must be made static. Public ("exported") symbols must use a curl_ prefix. Public API functions are marked with CURL_EXTERN in the public header files so that all others can be hidden on platforms where this is possible.