1 # CMake build script for the libgit2 project
3 # Building (out of source build):
4 # > mkdir build && cd build
5 # > cmake .. [-DSETTINGS=VALUE]
12 # > cmake --build . --target install
15 CMAKE_MINIMUM_REQUIRED(VERSION 3.5.1)
16 CMAKE_POLICY(SET CMP0015 NEW)
18 CMAKE_POLICY(SET CMP0051 NEW)
21 CMAKE_POLICY(SET CMP0042 NEW)
24 CMAKE_POLICY(SET CMP0054 NEW)
27 # Add find modules to the path
28 SET(CMAKE_MODULE_PATH ${CMAKE_MODULE_PATH} "${libgit2_SOURCE_DIR}/cmake/Modules/")
30 INCLUDE(CheckLibraryExists)
31 INCLUDE(CheckFunctionExists)
32 INCLUDE(CheckSymbolExists)
33 INCLUDE(CheckStructHasMember)
34 INCLUDE(CheckPrototypeDefinition) # Added in CMake 3.0
35 INCLUDE(AddCFlagIfSupported)
36 INCLUDE(FindPkgLibraries)
39 INCLUDE(GNUInstallDirs)
40 INCLUDE(IdeSplitSources)
41 INCLUDE(FeatureSummary)
42 INCLUDE(EnableWarnings)
46 OPTION(SONAME "Set the (SO)VERSION of the target" ON)
47 OPTION(BUILD_SHARED_LIBS "Build Shared Library (OFF for Static)" ON)
48 OPTION(THREADSAFE "Build libgit2 as threadsafe" ON)
49 OPTION(BUILD_CLAR "Build Tests using the Clar suite" ON)
50 OPTION(BUILD_EXAMPLES "Build library usage example apps" OFF)
51 OPTION(BUILD_FUZZERS "Build the fuzz targets" OFF)
52 OPTION(TAGS "Generate tags" OFF)
53 OPTION(PROFILE "Generate profiling information" OFF)
54 OPTION(ENABLE_TRACE "Enables tracing support" ON)
55 OPTION(LIBGIT2_FILENAME "Name of the produced binary" OFF)
56 OPTION(USE_SSH "Link with libssh2 to enable SSH support" ON)
57 OPTION(USE_HTTPS "Enable HTTPS support. Can be set to a specific backend" ON)
58 OPTION(USE_SHA1 "Enable SHA1. Can be set to CollisionDetection(ON)/HTTPS/Generic" ON)
59 OPTION(USE_GSSAPI "Link with libgssapi for SPNEGO auth" OFF)
60 OPTION(USE_STANDALONE_FUZZERS "Enable standalone fuzzers (compatible with gcc)" OFF)
61 OPTION(USE_LEAK_CHECKER "Run tests with leak checker" OFF)
62 OPTION(DEBUG_POOL "Enable debug pool allocator" OFF)
63 OPTION(ENABLE_WERROR "Enable compilation with -Werror" OFF)
64 OPTION(USE_BUNDLED_ZLIB "Use the bundled version of zlib" OFF)
65 SET(USE_HTTP_PARSER "" CACHE STRING "Specifies the HTTP Parser implementation; either system or builtin.")
66 OPTION(DEPRECATE_HARD "Do not include deprecated functions in the library" OFF)
67 SET(REGEX_BACKEND "" CACHE STRING "Regular expression implementation. One of regcomp_l, pcre2, pcre, regcomp, or builtin.")
71 OPTION(USE_NTLMCLIENT "Enable NTLM support on Unix." OFF )
73 OPTION(USE_NTLMCLIENT "Enable NTLM support on Unix." ON )
77 IF (UNIX AND NOT APPLE)
78 OPTION(ENABLE_REPRODUCIBLE_BUILDS "Enable reproducible builds" OFF)
82 OPTION(USE_ICONV "Link with and use iconv library" ON)
86 # This option must match the settings used in your program, in particular if you
87 # are linking statically
88 OPTION(STATIC_CRT "Link the static CRT libraries" ON)
90 # If you want to embed a copy of libssh2 into libgit2, pass a
92 OPTION(EMBED_SSH_PATH "Path to libssh2 to embed (Windows)" OFF)
97 # By default, libgit2 is built with WinHTTP. To use the built-in
98 # HTTP transport, invoke CMake with the "-DWINHTTP=OFF" argument.
99 OPTION(WINHTTP "Use Win32 WinHTTP routines" ON)
103 # Enable MSVC CRTDBG memory leak reporting when in debug mode.
104 OPTION(MSVC_CRTDBG "Enable CRTDBG memory leak reporting" OFF)
107 FILE(STRINGS "${libgit2_SOURCE_DIR}/include/git2/version.h" GIT2_HEADER REGEX "^#define LIBGIT2_VERSION \"[^\"]*\"$")
109 STRING(REGEX REPLACE "^.*LIBGIT2_VERSION \"([0-9]+).*$" "\\1" LIBGIT2_VERSION_MAJOR "${GIT2_HEADER}")
110 STRING(REGEX REPLACE "^.*LIBGIT2_VERSION \"[0-9]+\\.([0-9]+).*$" "\\1" LIBGIT2_VERSION_MINOR "${GIT2_HEADER}")
111 STRING(REGEX REPLACE "^.*LIBGIT2_VERSION \"[0-9]+\\.[0-9]+\\.([0-9]+).*$" "\\1" LIBGIT2_VERSION_REV "${GIT2_HEADER}")
112 SET(LIBGIT2_VERSION_STRING "${LIBGIT2_VERSION_MAJOR}.${LIBGIT2_VERSION_MINOR}.${LIBGIT2_VERSION_REV}")
114 FILE(STRINGS "${libgit2_SOURCE_DIR}/include/git2/version.h" GIT2_HEADER_SOVERSION REGEX "^#define LIBGIT2_SOVERSION \"([0-9.]+)\"$")
115 STRING(REGEX REPLACE "^.*LIBGIT2_SOVERSION \"([0-9.]+)\"$" "\\1" LIBGIT2_SOVERSION "${GIT2_HEADER_SOVERSION}")
118 ADD_DEFINITIONS(-DGIT_DEPRECATE_HARD)
121 # Platform specific compilation flags
124 MESSAGE(FATAL_ERROR "The STDCALL option is no longer supported; libgit2 is now always built as a cdecl library. If you're using PInvoke, please add the CallingConventions.Cdecl attribute for support.")
127 ADD_DEFINITIONS(-D_SCL_SECURE_NO_WARNINGS)
128 ADD_DEFINITIONS(-D_CRT_SECURE_NO_DEPRECATE)
129 ADD_DEFINITIONS(-D_CRT_NONSTDC_NO_DEPRECATE)
131 STRING(REPLACE "/Zm1000" " " CMAKE_C_FLAGS "${CMAKE_C_FLAGS}")
133 # /GF - String pooling
134 # /MP - Parallel build
135 SET(CMAKE_C_FLAGS "/GF /MP /nologo ${CMAKE_C_FLAGS}")
137 # /Gd - explicitly set cdecl calling convention
138 SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} /Gd")
141 SET(CRT_FLAG_DEBUG "/MTd")
142 SET(CRT_FLAG_RELEASE "/MT")
144 SET(CRT_FLAG_DEBUG "/MDd")
145 SET(CRT_FLAG_RELEASE "/MD")
149 SET(GIT_MSVC_CRTDBG 1)
150 SET(CRT_FLAG_DEBUG "${CRT_FLAG_DEBUG}")
151 SET(CMAKE_C_STANDARD_LIBRARIES "${CMAKE_C_STANDARD_LIBRARIES} Dbghelp.lib")
154 # /Zi - Create debugging information
155 # /Od - Disable optimization
156 # /D_DEBUG - #define _DEBUG
157 # /MTd - Statically link the multithreaded debug version of the CRT
158 # /MDd - Dynamically link the multithreaded debug version of the CRT
159 # /RTC1 - Run time checks
160 SET(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} /Zi /Od /D_DEBUG /RTC1 ${CRT_FLAG_DEBUG}")
162 # /DNDEBUG - Disables asserts
163 # /MT - Statically link the multithreaded release version of the CRT
164 # /MD - Dynamically link the multithreaded release version of the CRT
165 # /O2 - Optimize for speed
166 # /Oy - Enable frame pointer omission (FPO) (otherwise CMake will automatically turn it off)
167 # /GL - Link time code generation (whole program optimization)
168 # /Gy - Function-level linking
169 SET(CMAKE_C_FLAGS_RELEASE "/DNDEBUG /O2 /Oy /GL /Gy ${CRT_FLAG_RELEASE}")
171 # /Oy- - Disable frame pointer omission (FPO)
172 SET(CMAKE_C_FLAGS_RELWITHDEBINFO "/DNDEBUG /Zi /O2 /Oy- /GL /Gy ${CRT_FLAG_RELEASE}")
174 # /O1 - Optimize for size
175 SET(CMAKE_C_FLAGS_MINSIZEREL "/DNDEBUG /O1 /Oy /GL /Gy ${CRT_FLAG_RELEASE}")
177 # /IGNORE:4221 - Ignore empty compilation units
178 SET(CMAKE_STATIC_LINKER_FLAGS "/IGNORE:4221")
180 # /DYNAMICBASE - Address space load randomization (ASLR)
181 # /NXCOMPAT - Data execution prevention (DEP)
182 # /LARGEADDRESSAWARE - >2GB user address space on x86
183 # /VERSION - Embed version information in PE header
184 SET(CMAKE_EXE_LINKER_FLAGS "/DYNAMICBASE /NXCOMPAT /LARGEADDRESSAWARE /VERSION:${LIBGIT2_VERSION_MAJOR}.${LIBGIT2_VERSION_MINOR}")
186 # /DEBUG - Create a PDB
187 # /LTCG - Link time code generation (whole program optimization)
188 # /OPT:REF /OPT:ICF - Fold out duplicate code at link step
189 # /INCREMENTAL:NO - Required to use /LTCG
190 # /DEBUGTYPE:cv,fixup - Additional data embedded in the PDB (requires /INCREMENTAL:NO, so not on for Debug)
191 SET(CMAKE_EXE_LINKER_FLAGS_DEBUG "/DEBUG")
192 SET(CMAKE_EXE_LINKER_FLAGS_RELEASE "/RELEASE /LTCG /OPT:REF /OPT:ICF /INCREMENTAL:NO")
193 SET(CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO "/DEBUG /RELEASE /LTCG /OPT:REF /OPT:ICF /INCREMENTAL:NO /DEBUGTYPE:cv,fixup")
194 SET(CMAKE_EXE_LINKER_FLAGS_MINSIZEREL "/RELEASE /LTCG /OPT:REF /OPT:ICF /INCREMENTAL:NO")
196 # Same linker settings for DLL as EXE
197 SET(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS}")
198 SET(CMAKE_SHARED_LINKER_FLAGS_DEBUG "${CMAKE_EXE_LINKER_FLAGS_DEBUG}")
199 SET(CMAKE_SHARED_LINKER_FLAGS_RELEASE "${CMAKE_EXE_LINKER_FLAGS_RELEASE}")
200 SET(CMAKE_SHARED_LINKER_FLAGS_RELWITHDEBINFO "${CMAKE_EXE_LINKER_FLAGS_RELWITHDEBINFO}")
201 SET(CMAKE_SHARED_LINKER_FLAGS_MINSIZEREL "${CMAKE_EXE_LINKER_FLAGS_MINSIZEREL}")
203 IF (ENABLE_REPRODUCIBLE_BUILDS)
204 SET(CMAKE_C_ARCHIVE_CREATE "<CMAKE_AR> Dqc <TARGET> <LINK_FLAGS> <OBJECTS>")
205 SET(CMAKE_C_ARCHIVE_APPEND "<CMAKE_AR> Dq <TARGET> <LINK_FLAGS> <OBJECTS>")
206 SET(CMAKE_C_ARCHIVE_FINISH "<CMAKE_RANLIB> -D <TARGET>")
209 SET(CMAKE_C_FLAGS "-D_GNU_SOURCE ${CMAKE_C_FLAGS}")
212 ENABLE_WARNINGS(extra)
214 IF (CMAKE_SYSTEM_NAME MATCHES "(Solaris|SunOS)")
215 SET(CMAKE_C_FLAGS "-D_POSIX_C_SOURCE=200112L -D__EXTENSIONS__ -D_POSIX_PTHREAD_SEMANTICS ${CMAKE_C_FLAGS}")
218 SET(CMAKE_C_FLAGS_DEBUG "${CMAKE_C_FLAGS_DEBUG} -D_DEBUG -O0")
220 IF (MINGW OR MSYS) # MinGW and MSYS always do PIC and complain if we tell them to
221 STRING(REGEX REPLACE "-fPIC" "" CMAKE_SHARED_LIBRARY_C_FLAGS "${CMAKE_SHARED_LIBRARY_C_FLAGS}")
222 ELSEIF (BUILD_SHARED_LIBS)
223 ADD_C_FLAG_IF_SUPPORTED(-fvisibility=hidden)
225 SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fPIC")
229 # MinGW >= 3.14 uses the C99-style stdio functions
230 # automatically, but forks like mingw-w64 still want
231 # us to define this in order to use them
232 ADD_DEFINITIONS(-D__USE_MINGW_ANSI_STDIO=1)
235 ENABLE_WARNINGS(documentation)
236 DISABLE_WARNINGS(missing-field-initializers)
237 ENABLE_WARNINGS(strict-aliasing)
238 ENABLE_WARNINGS(strict-prototypes)
239 ENABLE_WARNINGS(declaration-after-statement)
240 ENABLE_WARNINGS(shift-count-overflow)
241 ENABLE_WARNINGS(unused-const-variable)
242 ENABLE_WARNINGS(unused-function)
243 ENABLE_WARNINGS(int-conversion)
245 # MinGW uses gcc, which expects POSIX formatting for printf, but
246 # uses the Windows C library, which uses its own format specifiers.
247 # Disable format specifier warnings.
249 DISABLE_WARNINGS(format)
250 DISABLE_WARNINGS(format-security)
252 ENABLE_WARNINGS(format)
253 ENABLE_WARNINGS(format-security)
256 IF("${CMAKE_C_COMPILER_ID}" STREQUAL "Clang")
257 DISABLE_WARNINGS(documentation-deprecated-sync)
261 SET(CMAKE_C_FLAGS "-pg ${CMAKE_C_FLAGS}")
262 SET(CMAKE_EXE_LINKER_FLAGS "-pg ${CMAKE_EXE_LINKER_FLAGS}")
266 # Ensure that MinGW provides the correct header files.
267 IF (WIN32 AND NOT CYGWIN)
268 ADD_DEFINITIONS(-DWIN32 -D_WIN32_WINNT=0x0600)
271 IF( NOT CMAKE_CONFIGURATION_TYPES )
272 # Build Debug by default
273 IF (NOT CMAKE_BUILD_TYPE)
274 SET(CMAKE_BUILD_TYPE "Debug" CACHE STRING "Choose the type of build, options are: Debug Release RelWithDebInfo MinSizeRel." FORCE)
277 # Using a multi-configuration generator eg MSVC or Xcode
278 # that uses CMAKE_CONFIGURATION_TYPES and not CMAKE_BUILD_TYPE
281 IF(BUILD_FUZZERS AND NOT USE_STANDALONE_FUZZERS)
282 # The actual sanitizer link target will be added when linking the fuzz
284 SET(CMAKE_REQUIRED_FLAGS "-fsanitize=fuzzer-no-link")
285 ADD_C_FLAG(-fsanitize=fuzzer-no-link)
286 UNSET(CMAKE_REQUIRED_FLAGS)
289 ADD_SUBDIRECTORY(src)
293 IF (NOT BUILD_SHARED_LIBS)
294 SET(CMAKE_FIND_LIBRARY_SUFFIXES ".a")
300 ADD_SUBDIRECTORY(tests)
304 FIND_PROGRAM(CTAGS ctags)
306 MESSAGE(FATAL_ERROR "Could not find ctags command")
309 FILE(GLOB_RECURSE SRC_ALL *.[ch])
313 COMMAND ${CTAGS} -a ${SRC_ALL}
323 ADD_SUBDIRECTORY(examples)
327 IF(NOT USE_STANDALONE_FUZZERS)
329 MESSAGE(FATAL_ERROR "Cannot build the fuzzer targets and the examples together")
332 MESSAGE(FATAL_ERROR "Cannot build the fuzzer targets and the tests together")
335 ADD_SUBDIRECTORY(fuzzers)
338 FEATURE_SUMMARY(WHAT ENABLED_FEATURES DESCRIPTION "Enabled features:")
339 FEATURE_SUMMARY(WHAT DISABLED_FEATURES DESCRIPTION "Disabled features:")