From 5218f1f80c9cfb79a97fc311deefd258101a2b9c Mon Sep 17 00:00:00 2001 From: Thomas Devoogdt Date: Thu, 6 Jun 2024 14:50:38 +0200 Subject: [PATCH] build: fix cmake build with ninja (#8835) $ cmake -GNinja -B build/ && cmake --build build/ Results in this error: ninja: error: build.ninja:158: bad $-escape (literal $ must be written as $$) Replacing the $(MAKE) command with make gives us this new error: ninja: error: 'backtrace-prefix/lib/libbacktrace.a', needed by 'bin/fluent-bit', missing and no known rule to make it So fix that by properly defining the BUILD_BYPRODUCTS. (Also see https://cmake.org/cmake/help/latest/module/ExternalProject.html#build-step-options) Signed-off-by: Thomas Devoogdt --- CMakeLists.txt | 26 ++++++++++++++++++++------ 1 file changed, 20 insertions(+), 6 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index 2879659cb62..5a6c866b846 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -938,6 +938,16 @@ else() set(AUTOCONF_HOST_OPT "--host=${GNU_HOST}") endif() +if(CMAKE_GENERATOR MATCHES "Ninja") + if(FLB_SYSTEM_WINDOWS) + MESSAGE(FATAL_ERROR "Building with Ninja is not supported on Windows") + else() + set(EXTERNAL_BUILD_TOOL "make") + endif() +else() + set(EXTERNAL_BUILD_TOOL "$(MAKE)") +endif() + # Memory Allocator # ================ if(FLB_JEMALLOC AND ${CMAKE_SYSTEM_NAME} MATCHES "Linux") @@ -953,15 +963,17 @@ if(FLB_JEMALLOC AND ${CMAKE_SYSTEM_NAME} MATCHES "Linux") message(STATUS "jemalloc configure: ${FLB_JEMALLOC_OPTIONS_LIST}") # Link to Jemalloc as an external dependency + set(FLB_LIBJEMALLOC_PATH "${CMAKE_CURRENT_BINARY_DIR}/lib/libjemalloc_pic.a") ExternalProject_Add(jemalloc SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/lib/jemalloc-5.3.0 CONFIGURE_COMMAND ${CMAKE_CURRENT_SOURCE_DIR}/lib/jemalloc-5.3.0/configure ${AUTOCONF_HOST_OPT} "${FLB_JEMALLOC_OPTIONS_LIST}" --prefix= CFLAGS=-std=gnu99\ -Wall\ -pipe\ -g3\ -O3\ -funroll-loops - BUILD_COMMAND $(MAKE) + BUILD_COMMAND ${EXTERNAL_BUILD_TOOL} + BUILD_BYPRODUCTS ${FLB_LIBJEMALLOC_PATH} INSTALL_DIR ${CMAKE_CURRENT_BINARY_DIR}/ - INSTALL_COMMAND $(MAKE) install_lib_static install_include) + INSTALL_COMMAND ${EXTERNAL_BUILD_TOOL} install_lib_static install_include) add_library(libjemalloc STATIC IMPORTED GLOBAL) - set_target_properties(libjemalloc PROPERTIES IMPORTED_LOCATION "${CMAKE_CURRENT_BINARY_DIR}/lib/libjemalloc_pic.a") + set_target_properties(libjemalloc PROPERTIES IMPORTED_LOCATION ${FLB_LIBJEMALLOC_PATH}) add_dependencies(libjemalloc jemalloc) include_directories("${CMAKE_BINARY_DIR}/include/") else() @@ -979,14 +991,16 @@ if(FLB_BACKTRACE) else() set(DEPS_C_COMPILER "${CMAKE_C_COMPILER}") endif() + set(FLB_LIBBACKTRACE_PATH "${CMAKE_CURRENT_BINARY_DIR}/backtrace-prefix/lib/libbacktrace.a") ExternalProject_Add(backtrace SOURCE_DIR ${CMAKE_CURRENT_SOURCE_DIR}/lib/libbacktrace-8602fda/ CONFIGURE_COMMAND ${CMAKE_CURRENT_SOURCE_DIR}/lib/libbacktrace-8602fda/configure ${AUTOCONF_HOST_OPT} --prefix= --enable-shared=no --enable-static=yes - BUILD_COMMAND $(MAKE) - INSTALL_COMMAND $(MAKE) DESTDIR= install + BUILD_COMMAND ${EXTERNAL_BUILD_TOOL} + BUILD_BYPRODUCTS ${FLB_LIBBACKTRACE_PATH} + INSTALL_COMMAND ${EXTERNAL_BUILD_TOOL} DESTDIR= install ) add_library(libbacktrace STATIC IMPORTED GLOBAL) - set_target_properties(libbacktrace PROPERTIES IMPORTED_LOCATION "${CMAKE_CURRENT_BINARY_DIR}/backtrace-prefix/lib/libbacktrace.a") + set_target_properties(libbacktrace PROPERTIES IMPORTED_LOCATION ${FLB_LIBBACKTRACE_PATH}) add_dependencies(libbacktrace backtrace) include_directories("${CMAKE_CURRENT_BINARY_DIR}/backtrace-prefix/include/") endif()