2019-06-25 08:50:43 +00:00
|
|
|
# Copyright (c) 2014-present, Facebook, Inc.
|
|
|
|
# All rights reserved.
|
2018-11-30 01:27:21 +00:00
|
|
|
#
|
2019-06-25 08:50:43 +00:00
|
|
|
# This source code is licensed in accordance with the terms specified in
|
|
|
|
# the LICENSE file found in the root directory of this source tree.
|
2018-11-30 01:27:21 +00:00
|
|
|
|
|
|
|
# Generates an include namespace; this is sadly required by the Buck-based project and can't be removed
|
|
|
|
function(generateIncludeNamespace target_name namespace_path mode)
|
|
|
|
# Make sure we actually have parameters
|
|
|
|
if(${ARGC} EQUAL 0)
|
|
|
|
message(SEND_ERROR "No library specified")
|
|
|
|
return()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
# Validate the mode
|
|
|
|
if(NOT "${mode}" STREQUAL "FILE_ONLY" AND NOT "${mode}" STREQUAL "FULL_PATH")
|
|
|
|
message(SEND_ERROR "Invalid namespace generation mode")
|
|
|
|
return()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
# Generate a root target that we'll attach to the user target
|
|
|
|
set(index 1)
|
|
|
|
|
|
|
|
while(true)
|
2019-06-25 08:50:43 +00:00
|
|
|
set(root_target_name "${target_name}_ns_gen_${index}")
|
2018-11-30 01:27:21 +00:00
|
|
|
if(NOT TARGET "${root_target_name}")
|
|
|
|
break()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
MATH(EXPR index "${index}+1")
|
|
|
|
endwhile()
|
|
|
|
|
|
|
|
add_custom_target("${root_target_name}"
|
|
|
|
COMMENT "Generating namespace '${namespace_path}' for target '${target_name}'"
|
|
|
|
)
|
|
|
|
|
|
|
|
add_dependencies("${target_name}" "${root_target_name}")
|
|
|
|
|
2019-06-30 21:24:56 +00:00
|
|
|
get_target_property(target_type "${target_name}" TYPE)
|
|
|
|
if("${target_type}" STREQUAL "INTERFACE_LIBRARY")
|
|
|
|
set(target_mode "INTERFACE")
|
|
|
|
else()
|
|
|
|
set(target_mode "PUBLIC")
|
|
|
|
endif()
|
|
|
|
|
2018-11-30 01:27:21 +00:00
|
|
|
foreach(relative_source_file_path ${ARGN})
|
|
|
|
get_filename_component(source_name "${relative_source_file_path}" NAME)
|
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
set(target_namespace_root_directory "${CMAKE_BINARY_DIR}/ns_${target_name}")
|
|
|
|
|
2018-11-30 01:27:21 +00:00
|
|
|
if("${mode}" STREQUAL "FILE_ONLY")
|
2019-06-25 08:50:43 +00:00
|
|
|
set(output_source_file_path "${target_namespace_root_directory}/${namespace_path}/${source_name}")
|
2018-11-30 01:27:21 +00:00
|
|
|
else()
|
2019-06-25 08:50:43 +00:00
|
|
|
set(output_source_file_path "${target_namespace_root_directory}/${namespace_path}/${relative_source_file_path}")
|
2018-11-30 01:27:21 +00:00
|
|
|
endif()
|
|
|
|
|
|
|
|
get_filename_component(parent_folder_path "${output_source_file_path}" DIRECTORY)
|
2019-06-25 08:50:43 +00:00
|
|
|
set(source_base_path "${CMAKE_CURRENT_SOURCE_DIR}")
|
|
|
|
set(absolute_source_file_path "${source_base_path}/${relative_source_file_path}")
|
2018-11-30 01:27:21 +00:00
|
|
|
|
|
|
|
add_custom_command(
|
|
|
|
OUTPUT "${output_source_file_path}"
|
|
|
|
COMMAND "${CMAKE_COMMAND}" -E make_directory "${parent_folder_path}"
|
|
|
|
COMMAND "${CMAKE_COMMAND}" -E create_symlink "${absolute_source_file_path}" "${output_source_file_path}"
|
|
|
|
VERBATIM
|
|
|
|
)
|
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
string(REPLACE "/" "_" file_generator_name "${target_name}_ns_${relative_source_file_path}")
|
2018-11-30 01:27:21 +00:00
|
|
|
add_custom_target("${file_generator_name}" DEPENDS "${output_source_file_path}")
|
|
|
|
add_dependencies("${root_target_name}" "${file_generator_name}")
|
|
|
|
|
2019-06-30 21:24:56 +00:00
|
|
|
if(ADD_HEADERS_AS_SOURCES)
|
|
|
|
target_sources("${target_name}" ${target_mode} "${absolute_source_file_path}")
|
|
|
|
endif()
|
|
|
|
endforeach()
|
2018-11-30 01:27:21 +00:00
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
# So that the IDE finds all the necessary headers
|
|
|
|
add_dependencies("prepare_for_ide" "${root_target_name}")
|
|
|
|
|
2019-06-30 21:24:56 +00:00
|
|
|
target_include_directories("${target_name}" ${target_mode} "${target_namespace_root_directory}")
|
2018-11-30 01:27:21 +00:00
|
|
|
endfunction()
|
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
# Marks the specified target to enable link whole archive
|
|
|
|
function(enableLinkWholeArchive target_name)
|
2018-11-30 01:27:21 +00:00
|
|
|
if(DEFINED PLATFORM_LINUX)
|
2019-06-25 08:50:43 +00:00
|
|
|
set(new_project_target_link_options
|
|
|
|
"SHELL:-Wl,--whole-archive $<TARGET_FILE:${target_name}> -Wl,--no-whole-archive"
|
2018-11-30 01:27:21 +00:00
|
|
|
)
|
|
|
|
elseif(DEFINED PLATFORM_MACOS)
|
2019-06-25 08:50:43 +00:00
|
|
|
set(new_project_target_link_options
|
|
|
|
"SHELL:-Wl,-force_load $<TARGET_FILE:${target_name}>"
|
|
|
|
)
|
|
|
|
elseif(DEFINED PLATFORM_WINDOWS)
|
|
|
|
set(new_project_target_link_options
|
|
|
|
"/WHOLEARCHIVE:$<TARGET_FILE:${target_name}>"
|
2018-11-30 01:27:21 +00:00
|
|
|
)
|
|
|
|
endif()
|
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
target_link_options(${target_name} INTERFACE ${new_project_target_link_options})
|
|
|
|
endfunction()
|
2018-11-30 01:27:21 +00:00
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
function(findPythonExecutablePath)
|
2019-11-26 18:50:21 +00:00
|
|
|
find_package(Python3 3.5 COMPONENTS Interpreter REQUIRED)
|
2019-11-19 17:54:40 +00:00
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
set(EX_TOOL_PYTHON3_EXECUTABLE_PATH "${Python3_EXECUTABLE}" PARENT_SCOPE)
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
function(generateBuildTimeSourceFile file_path content)
|
|
|
|
add_custom_command(
|
|
|
|
OUTPUT "${file_path}"
|
|
|
|
COMMAND "${CMAKE_COMMAND}" -E echo "${content}" > "${file_path}"
|
|
|
|
VERBATIM
|
2018-11-30 01:27:21 +00:00
|
|
|
)
|
|
|
|
endfunction()
|
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
function(generateUnsupportedPlatformSourceFile)
|
|
|
|
set(source_file "${CMAKE_CURRENT_BINARY_DIR}/osquery_unsupported_platform_target_source_file.cpp")
|
|
|
|
set(file_content "#error This target does not support this platform")
|
2018-11-30 01:27:21 +00:00
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
generateBuildTimeSourceFile(${source_file} ${file_content})
|
|
|
|
|
|
|
|
set(unsupported_platform_source_file "${source_file}" PARENT_SCOPE)
|
2018-11-30 01:27:21 +00:00
|
|
|
endfunction()
|
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
function(generateCopyFileTarget name type relative_file_paths destination)
|
|
|
|
set(source_base_path "${CMAKE_CURRENT_SOURCE_DIR}")
|
2018-11-30 01:27:21 +00:00
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
if(type STREQUAL "REGEX")
|
|
|
|
file(GLOB_RECURSE relative_file_paths RELATIVE "${source_base_path}" "${source_base_path}/${relative_file_paths}")
|
|
|
|
endif()
|
2018-11-30 01:27:21 +00:00
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
add_library("${name}" INTERFACE)
|
2018-11-30 01:27:21 +00:00
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
foreach(file ${relative_file_paths})
|
|
|
|
get_filename_component(intermediate_directory "${file}" DIRECTORY)
|
|
|
|
list(APPEND intermediate_directories "${intermediate_directory}")
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
list(REMOVE_DUPLICATES intermediate_directories)
|
|
|
|
|
|
|
|
foreach(directory ${intermediate_directories})
|
|
|
|
add_custom_command(
|
|
|
|
OUTPUT "${destination}/${directory}"
|
|
|
|
COMMAND "${CMAKE_COMMAND}" -E make_directory "${destination}/${directory}"
|
|
|
|
)
|
|
|
|
list(APPEND created_directories "${destination}/${directory}")
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
add_custom_target("${name}_create_dirs" DEPENDS "${created_directories}")
|
|
|
|
|
|
|
|
foreach(file ${relative_file_paths})
|
|
|
|
|
|
|
|
get_filename_component(filename "${file}" NAME)
|
|
|
|
|
|
|
|
if("${filename}" STREQUAL "BUCK")
|
|
|
|
continue()
|
2018-11-30 01:27:21 +00:00
|
|
|
endif()
|
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
add_custom_command(
|
|
|
|
OUTPUT "${destination}/${file}"
|
|
|
|
COMMAND "${CMAKE_COMMAND}" -E copy "${source_base_path}/${file}" "${destination}/${file}"
|
|
|
|
)
|
|
|
|
list(APPEND copied_files "${destination}/${file}")
|
2018-11-30 01:27:21 +00:00
|
|
|
endforeach()
|
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
add_custom_target("${name}_copy_files" DEPENDS "${name}_create_dirs" "${copied_files}")
|
2018-11-30 01:27:21 +00:00
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
add_dependencies("${name}" "${name}_copy_files")
|
2018-11-30 01:27:21 +00:00
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
set_target_properties("${name}" PROPERTIES INTERFACE_BINARY_DIR "${destination}")
|
2018-11-30 01:27:21 +00:00
|
|
|
endfunction()
|
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
function(add_osquery_executable)
|
|
|
|
set(osquery_exe_options EXCLUDE_FROM_ALL;WIN32;MACOSX_BUNDLE)
|
|
|
|
set(osquery_exe_ARGN ${ARGN})
|
2018-11-30 01:27:21 +00:00
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
list(GET osquery_exe_ARGN 0 osquery_exe_name)
|
|
|
|
list(REMOVE_AT osquery_exe_ARGN 0)
|
2018-11-30 01:27:21 +00:00
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
foreach(arg ${osquery_exe_ARGN})
|
|
|
|
list(FIND osquery_exe_options "${arg}" arg_POS)
|
|
|
|
if(${arg_POS} EQUAL -1 AND NOT IS_ABSOLUTE "${arg}")
|
|
|
|
set(base_path "${CMAKE_CURRENT_SOURCE_DIR}")
|
|
|
|
list(APPEND osquery_exe_args "${base_path}/${arg}")
|
|
|
|
else()
|
|
|
|
list(APPEND osquery_exe_args "${arg}")
|
|
|
|
endif()
|
|
|
|
endforeach()
|
2018-11-30 01:27:21 +00:00
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
add_executable(${osquery_exe_name} ${osquery_exe_args})
|
2018-11-30 01:27:21 +00:00
|
|
|
|
2019-11-07 00:11:27 +00:00
|
|
|
if(DEFINED PLATFORM_WINDOWS)
|
|
|
|
set(OSQUERY_MANIFEST_TARGET_NAME "${osquery_exe_name}")
|
|
|
|
|
|
|
|
string(REGEX MATCH "^[0-9]+\.[0-9]+\.[0-9]+" osquery_cleaned_version "${OSQUERY_VERSION_INTERNAL}")
|
|
|
|
set(OSQUERY_MANIFEST_VERSION "${osquery_cleaned_version}")
|
|
|
|
|
|
|
|
configure_file(
|
|
|
|
"${CMAKE_SOURCE_DIR}/tools/osquery.manifest.in"
|
|
|
|
"${osquery_exe_name}.manifest"
|
|
|
|
@ONLY NEWLINE_STYLE WIN32
|
|
|
|
)
|
|
|
|
target_sources(${osquery_exe_name} PRIVATE "${osquery_exe_name}.manifest")
|
|
|
|
endif()
|
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
if("${osquery_exe_name}" MATCHES "-test$" AND DEFINED PLATFORM_POSIX)
|
|
|
|
target_link_options("${osquery_exe_name}" PRIVATE -Wno-sign-compare)
|
2018-11-30 01:27:21 +00:00
|
|
|
endif()
|
|
|
|
endfunction()
|
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
function(add_osquery_library)
|
|
|
|
set(osquery_lib_options STATIC;SHARED;MODULE;OBJECT;UNKNOWN;EXCLUDE_FROM_ALL;IMPORTED;GLOBAL;INTERFACE)
|
|
|
|
set(osquery_lib_ARGN ${ARGN})
|
2018-11-30 01:27:21 +00:00
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
list(GET osquery_lib_ARGN 0 osquery_lib_name)
|
|
|
|
list(REMOVE_AT osquery_lib_ARGN 0)
|
2018-11-30 01:27:21 +00:00
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
foreach(arg ${osquery_lib_ARGN})
|
|
|
|
list(FIND osquery_lib_options "${arg}" arg_POS)
|
|
|
|
if(${arg_POS} EQUAL -1 AND NOT IS_ABSOLUTE "${arg}")
|
|
|
|
set(base_path "${CMAKE_CURRENT_SOURCE_DIR}")
|
|
|
|
list(APPEND osquery_lib_args "${base_path}/${arg}")
|
|
|
|
else()
|
|
|
|
list(APPEND osquery_lib_args "${arg}")
|
2018-11-30 01:27:21 +00:00
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
add_library(${osquery_lib_name} ${osquery_lib_args})
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
# This function modifies an existing cache variable but without changing its description
|
2019-07-23 11:01:20 +00:00
|
|
|
function(overwrite_cache_variable variable_name type value)
|
2019-06-25 08:50:43 +00:00
|
|
|
get_property(current_help_string CACHE "${variable_name}" PROPERTY HELPSTRING)
|
Refactor third-party libraries to build from source on Linux (#5706)
Add a way to compile third-party libraries from source instead of downloading prebuilt ones.
Each library source code is downloaded with git into a submodule at configure time,
in response to the find_package(library_name) CMake call,
except for OpenSSL where the official source archive is used.
Each submodule is attached to a release tag on its own upstream repository.
All the libraries are built using CMake directly, except for OpenSSL which uses a formula system,
which permits to build libraries with a separate build system
when there's no easy way to integrate it directly with CMake.
This new dependency system determines which library is fetched from where using the concept of "layers".
Currently we have three of them: source, formula, facebook,
where the last layer represents the pre-built libraries.
The provided order will be used when looking for libraries.
A system to patch submodule source code has been added and it's currently used with googletest, libudev and util-linux.
Patches should be put under libraries/cmake/source/<library name>/patches/<submodule>,
where <submodule> is often one and is "src", but in other cases, like AWS,
there are multiple with a more specific name.
If for whatever reason the submodule cloning or the patching fails,
the submodule has to be unregistered and its folder should be cleared.
This should be achievable with "git submodule deinit -f <submodule path>"
Following some other changes on existing functionality:
- Changed the CMake variable BUILD_TESTING to OSQUERY_BUILD_TESTS
to avoid enabling tests on third party libraries.
Due to an issue with glog the BUILD_TESTING variable
will be always forced to OFF.
- Moved compiler and linker flags to their own file cmake/flags.cmake
- Moved all the third-party CMakeLists.txt used for pre-built libraries under libraries/cmake/facebook
- Added the --exclude-folders option to tools/format-check.py and tools/git-clang-format.py,
so that it's possible to ignore any third party library source code.
- The format and format_check target use the new --exclude-folders option
to exclude libraries/cmake/source from formatting.
- The test and osquery binaries are properly compiled with PIE (osquery/osquery#5611)
Co-authored-by: Stefano Bonicatti <stefano.bonicatti@gmail.com>
Co-authored-by: Teddy Reed <teddy@casualhacking.io>
2019-08-30 14:25:19 +00:00
|
|
|
if(NOT DEFINED current_help_string)
|
|
|
|
set(current_help_string "No description")
|
|
|
|
endif()
|
2019-07-23 11:01:20 +00:00
|
|
|
list(APPEND cache_args "CACHE" "${type}" "${current_help_string}")
|
|
|
|
set("${variable_name}" "${value}" ${cache_args} FORCE)
|
2019-06-25 08:50:43 +00:00
|
|
|
endfunction()
|
|
|
|
|
|
|
|
function(generateSpecialTargets)
|
|
|
|
# Used to generate all the files necessary to have a complete view of the project in the IDE
|
|
|
|
add_custom_target(prepare_for_ide)
|
2018-11-30 01:27:21 +00:00
|
|
|
|
Refactor third-party libraries to build from source on Linux (#5706)
Add a way to compile third-party libraries from source instead of downloading prebuilt ones.
Each library source code is downloaded with git into a submodule at configure time,
in response to the find_package(library_name) CMake call,
except for OpenSSL where the official source archive is used.
Each submodule is attached to a release tag on its own upstream repository.
All the libraries are built using CMake directly, except for OpenSSL which uses a formula system,
which permits to build libraries with a separate build system
when there's no easy way to integrate it directly with CMake.
This new dependency system determines which library is fetched from where using the concept of "layers".
Currently we have three of them: source, formula, facebook,
where the last layer represents the pre-built libraries.
The provided order will be used when looking for libraries.
A system to patch submodule source code has been added and it's currently used with googletest, libudev and util-linux.
Patches should be put under libraries/cmake/source/<library name>/patches/<submodule>,
where <submodule> is often one and is "src", but in other cases, like AWS,
there are multiple with a more specific name.
If for whatever reason the submodule cloning or the patching fails,
the submodule has to be unregistered and its folder should be cleared.
This should be achievable with "git submodule deinit -f <submodule path>"
Following some other changes on existing functionality:
- Changed the CMake variable BUILD_TESTING to OSQUERY_BUILD_TESTS
to avoid enabling tests on third party libraries.
Due to an issue with glog the BUILD_TESTING variable
will be always forced to OFF.
- Moved compiler and linker flags to their own file cmake/flags.cmake
- Moved all the third-party CMakeLists.txt used for pre-built libraries under libraries/cmake/facebook
- Added the --exclude-folders option to tools/format-check.py and tools/git-clang-format.py,
so that it's possible to ignore any third party library source code.
- The format and format_check target use the new --exclude-folders option
to exclude libraries/cmake/source from formatting.
- The test and osquery binaries are properly compiled with PIE (osquery/osquery#5611)
Co-authored-by: Stefano Bonicatti <stefano.bonicatti@gmail.com>
Co-authored-by: Teddy Reed <teddy@casualhacking.io>
2019-08-30 14:25:19 +00:00
|
|
|
|
|
|
|
set(excluded_folders
|
|
|
|
"libraries/cmake/source"
|
|
|
|
)
|
|
|
|
|
2019-09-24 23:17:55 +00:00
|
|
|
set(command_prefix)
|
|
|
|
if(OSQUERY_TOOLCHAIN_SYSROOT)
|
|
|
|
set(command_prefix "${CMAKE_COMMAND}" -E env "PATH=${OSQUERY_TOOLCHAIN_SYSROOT}/usr/bin:$ENV{PATH}")
|
|
|
|
endif()
|
|
|
|
|
2019-06-25 08:50:43 +00:00
|
|
|
add_custom_target(format_check
|
2019-11-06 23:37:00 +00:00
|
|
|
COMMAND ${command_prefix} ${EX_TOOL_PYTHON3_EXECUTABLE_PATH} ${CMAKE_SOURCE_DIR}/tools/formatting/format-check.py --exclude-folders ${excluded_folders} origin/master
|
2019-06-25 08:50:43 +00:00
|
|
|
WORKING_DIRECTORY "${CMAKE_SOURCE_DIR}"
|
|
|
|
VERBATIM
|
|
|
|
)
|
|
|
|
add_custom_target(format
|
2019-11-06 23:37:00 +00:00
|
|
|
COMMAND ${command_prefix} ${EX_TOOL_PYTHON3_EXECUTABLE_PATH} ${CMAKE_SOURCE_DIR}/tools/formatting/git-clang-format.py --exclude-folders ${excluded_folders} -f --style=file
|
2019-06-25 08:50:43 +00:00
|
|
|
WORKING_DIRECTORY "${CMAKE_SOURCE_DIR}"
|
2019-09-24 23:17:55 +00:00
|
|
|
VERBATIM
|
|
|
|
)
|
2018-11-30 01:27:21 +00:00
|
|
|
endfunction()
|
Refactor third-party libraries to build from source on Linux (#5706)
Add a way to compile third-party libraries from source instead of downloading prebuilt ones.
Each library source code is downloaded with git into a submodule at configure time,
in response to the find_package(library_name) CMake call,
except for OpenSSL where the official source archive is used.
Each submodule is attached to a release tag on its own upstream repository.
All the libraries are built using CMake directly, except for OpenSSL which uses a formula system,
which permits to build libraries with a separate build system
when there's no easy way to integrate it directly with CMake.
This new dependency system determines which library is fetched from where using the concept of "layers".
Currently we have three of them: source, formula, facebook,
where the last layer represents the pre-built libraries.
The provided order will be used when looking for libraries.
A system to patch submodule source code has been added and it's currently used with googletest, libudev and util-linux.
Patches should be put under libraries/cmake/source/<library name>/patches/<submodule>,
where <submodule> is often one and is "src", but in other cases, like AWS,
there are multiple with a more specific name.
If for whatever reason the submodule cloning or the patching fails,
the submodule has to be unregistered and its folder should be cleared.
This should be achievable with "git submodule deinit -f <submodule path>"
Following some other changes on existing functionality:
- Changed the CMake variable BUILD_TESTING to OSQUERY_BUILD_TESTS
to avoid enabling tests on third party libraries.
Due to an issue with glog the BUILD_TESTING variable
will be always forced to OFF.
- Moved compiler and linker flags to their own file cmake/flags.cmake
- Moved all the third-party CMakeLists.txt used for pre-built libraries under libraries/cmake/facebook
- Added the --exclude-folders option to tools/format-check.py and tools/git-clang-format.py,
so that it's possible to ignore any third party library source code.
- The format and format_check target use the new --exclude-folders option
to exclude libraries/cmake/source from formatting.
- The test and osquery binaries are properly compiled with PIE (osquery/osquery#5611)
Co-authored-by: Stefano Bonicatti <stefano.bonicatti@gmail.com>
Co-authored-by: Teddy Reed <teddy@casualhacking.io>
2019-08-30 14:25:19 +00:00
|
|
|
|
|
|
|
function(collectInterfaceOptionsFromTarget)
|
|
|
|
set(oneValueArgs TARGET COMPILE DEFINES LINK)
|
|
|
|
cmake_parse_arguments(PARSE_ARGV 0 osquery "" "${oneValueArgs}" "")
|
|
|
|
|
|
|
|
if(NOT osquery_TARGET OR NOT TARGET ${osquery_TARGET})
|
|
|
|
message(FATAL_ERROR "A valid target has to be provided")
|
|
|
|
endif()
|
|
|
|
|
|
|
|
set(target_list ${osquery_TARGET})
|
|
|
|
set(target_list_length 1)
|
|
|
|
|
|
|
|
while(${target_list_length} GREATER 0)
|
|
|
|
foreach(target ${target_list})
|
|
|
|
|
|
|
|
if(NOT TARGET ${target})
|
|
|
|
continue()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
get_target_property(target_type ${target} TYPE)
|
|
|
|
|
|
|
|
if(NOT "${target_type}" STREQUAL "INTERFACE_LIBRARY")
|
|
|
|
continue()
|
|
|
|
endif()
|
|
|
|
|
|
|
|
get_target_property(dependencies ${target} INTERFACE_LINK_LIBRARIES)
|
|
|
|
|
|
|
|
if(NOT "${dependencies}" STREQUAL "dependencies-NOTFOUND")
|
|
|
|
list(APPEND new_target_list ${dependencies})
|
|
|
|
endif()
|
|
|
|
|
|
|
|
get_target_property(compile_options ${target} INTERFACE_COMPILE_OPTIONS)
|
|
|
|
get_target_property(compile_definitions ${target} INTERFACE_COMPILE_DEFINITIONS)
|
|
|
|
get_target_property(link_options ${target} INTERFACE_LINK_OPTIONS)
|
|
|
|
|
|
|
|
if(osquery_COMPILE AND NOT "${compile_options}" STREQUAL "compile_options-NOTFOUND")
|
|
|
|
list(APPEND compile_options_list ${compile_options})
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(osquery_DEFINES AND NOT "${compile_definitions}" STREQUAL "compile_definitions-NOTFOUND")
|
|
|
|
list(APPEND compile_definitions_list ${compile_definitions})
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(osquery_LINK AND NOT "${link_options}" STREQUAL "link_options-NOTFOUND")
|
|
|
|
list(APPEND link_options_list ${link_options})
|
|
|
|
endif()
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
set(target_list ${new_target_list})
|
|
|
|
list(LENGTH target_list target_list_length)
|
|
|
|
unset(new_target_list)
|
|
|
|
endwhile()
|
|
|
|
|
|
|
|
list(REMOVE_DUPLICATES compile_options_list)
|
|
|
|
list(REMOVE_DUPLICATES compile_definitions_list)
|
|
|
|
list(REMOVE_DUPLICATES link_options_list)
|
|
|
|
|
|
|
|
if(osquery_COMPILE)
|
|
|
|
set(${osquery_COMPILE} ${compile_options_list} PARENT_SCOPE)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(osquery_LINK_OPTIONS)
|
|
|
|
set(${osquery_LINK_OPTIONS} ${link_options_list} PARENT_SCOPE)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if(osquery_DEFINES)
|
|
|
|
set(${osquery_DEFINES} ${compile_definitions_list} PARENT_SCOPE)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
endfunction()
|
|
|
|
|
|
|
|
function(copyInterfaceTargetFlagsTo destination_target source_target mode)
|
|
|
|
|
|
|
|
collectInterfaceOptionsFromTarget(TARGET ${source_target}
|
|
|
|
COMPILE compile_options_list
|
|
|
|
LINK link_options_list
|
|
|
|
DEFINES compile_definitions_list
|
|
|
|
)
|
|
|
|
|
|
|
|
get_target_property(dest_compile_options_list ${destination_target} INTERFACE_COMPILE_OPTIONS)
|
|
|
|
get_target_property(dest_compile_definitions_list ${destination_target} INTERFACE_COMPILE_DEFINITIONS)
|
|
|
|
get_target_property(dest_link_options_list ${destination_target} INTERFACE_LINK_OPTIONS)
|
|
|
|
|
|
|
|
if("${dest_compile_options_list}" STREQUAL "dest_compile_options_list-NOTFOUND")
|
|
|
|
unset(dest_compile_options_list)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if("${dest_compile_definitions_list}" STREQUAL "dest_compile_definitions_list-NOTFOUND")
|
|
|
|
unset(dest_compile_definitions_list)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
if("${dest_link_options_list}" STREQUAL "dest_link_options_list-NOTFOUND")
|
|
|
|
unset(dest_link_options_list)
|
|
|
|
endif()
|
|
|
|
|
|
|
|
list(APPEND dest_compile_options_list ${compile_options_list})
|
|
|
|
list(APPEND dest_compile_definitions_list ${compile_definitions_list})
|
|
|
|
list(APPEND dest_link_options_list ${link_options_list})
|
|
|
|
|
|
|
|
target_compile_options(${destination_target} ${mode} ${dest_compile_options_list})
|
|
|
|
target_compile_definitions(${destination_target} ${mode} ${dest_compile_definitions_list})
|
|
|
|
target_link_options(${destination_target} ${mode} ${dest_link_options_list})
|
|
|
|
endfunction()
|