Add pre-commit config
This commit is contained in:
@@ -2,17 +2,23 @@ cmake_minimum_required(VERSION 3.18)
|
|||||||
project(
|
project(
|
||||||
conflict_set
|
conflict_set
|
||||||
VERSION 0.0.1
|
VERSION 0.0.1
|
||||||
DESCRIPTION "A data structure for detecting mvcc read-write conflicts in a keyspace of lexicographically-ordered byte sequences."
|
DESCRIPTION
|
||||||
|
"A data structure for detecting mvcc read-write conflicts in a keyspace of lexicographically-ordered byte sequences."
|
||||||
LANGUAGES C CXX)
|
LANGUAGES C CXX)
|
||||||
set(CMAKE_CXX_STANDARD 20)
|
set(CMAKE_CXX_STANDARD 20)
|
||||||
|
|
||||||
set(DEFAULT_BUILD_TYPE "Release")
|
set(DEFAULT_BUILD_TYPE "Release")
|
||||||
|
|
||||||
if(NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CONFIGURATION_TYPES)
|
if(NOT CMAKE_BUILD_TYPE AND NOT CMAKE_CONFIGURATION_TYPES)
|
||||||
message(STATUS "Setting build type to '${DEFAULT_BUILD_TYPE}' as none was specified.")
|
message(
|
||||||
set(CMAKE_BUILD_TYPE "${DEFAULT_BUILD_TYPE}" CACHE STRING "Choose the type of build." FORCE)
|
STATUS
|
||||||
|
"Setting build type to '${DEFAULT_BUILD_TYPE}' as none was specified.")
|
||||||
|
set(CMAKE_BUILD_TYPE
|
||||||
|
"${DEFAULT_BUILD_TYPE}"
|
||||||
|
CACHE STRING "Choose the type of build." FORCE)
|
||||||
# Set the possible values of build type for cmake-gui
|
# Set the possible values of build type for cmake-gui
|
||||||
set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS "Debug" "Release" "MinSizeRel" "RelWithDebInfo")
|
set_property(CACHE CMAKE_BUILD_TYPE PROPERTY STRINGS "Debug" "Release"
|
||||||
|
"MinSizeRel" "RelWithDebInfo")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_compile_options(-fdata-sections -ffunction-sections)
|
add_compile_options(-fdata-sections -ffunction-sections)
|
||||||
@@ -40,11 +46,15 @@ if (HAS_ARM_NEON)
|
|||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_library(${PROJECT_NAME} SHARED ConflictSet.cpp)
|
add_library(${PROJECT_NAME} SHARED ConflictSet.cpp)
|
||||||
target_compile_options(conflict_set PRIVATE -fPIC -fno-exceptions -fvisibility=hidden)
|
target_compile_options(conflict_set PRIVATE -fPIC -fno-exceptions
|
||||||
target_link_options(conflict_set PRIVATE $<$<NOT:$<CONFIG:Debug>>: -nodefaultlibs -lc>)
|
-fvisibility=hidden)
|
||||||
|
target_link_options(conflict_set PRIVATE $<$<NOT:$<CONFIG:Debug>>:
|
||||||
|
-nodefaultlibs -lc>)
|
||||||
|
|
||||||
if(NOT APPLE)
|
if(NOT APPLE)
|
||||||
target_link_options(conflict_set PRIVATE "LINKER:--version-script=${CMAKE_CURRENT_SOURCE_DIR}/linker.map")
|
target_link_options(
|
||||||
|
conflict_set PRIVATE
|
||||||
|
"LINKER:--version-script=${CMAKE_CURRENT_SOURCE_DIR}/linker.map")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
set(TEST_FLAGS -Wall -Wextra -Wpedantic -Wunreachable-code -UNDEBUG)
|
set(TEST_FLAGS -Wall -Wextra -Wpedantic -Wunreachable-code -UNDEBUG)
|
||||||
@@ -52,7 +62,8 @@ set(TEST_FLAGS -Wall -Wextra -Wpedantic -Wunreachable-code -UNDEBUG)
|
|||||||
include(CTest)
|
include(CTest)
|
||||||
|
|
||||||
add_executable(conflict_set_main ConflictSet.cpp)
|
add_executable(conflict_set_main ConflictSet.cpp)
|
||||||
target_include_directories(conflict_set_main PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include)
|
target_include_directories(conflict_set_main
|
||||||
|
PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include)
|
||||||
target_compile_definitions(conflict_set_main PRIVATE ENABLE_MAIN)
|
target_compile_definitions(conflict_set_main PRIVATE ENABLE_MAIN)
|
||||||
|
|
||||||
# libfuzzer target, to generate/manage corpus
|
# libfuzzer target, to generate/manage corpus
|
||||||
@@ -65,11 +76,13 @@ cmake_pop_check_state()
|
|||||||
|
|
||||||
if(HAS_LIB_FUZZER)
|
if(HAS_LIB_FUZZER)
|
||||||
add_executable(conflict_set_fuzz_test ConflictSet.cpp)
|
add_executable(conflict_set_fuzz_test ConflictSet.cpp)
|
||||||
target_include_directories(conflict_set_fuzz_test PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include)
|
target_include_directories(conflict_set_fuzz_test
|
||||||
|
PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include)
|
||||||
target_compile_definitions(conflict_set_fuzz_test PRIVATE ENABLE_FUZZ)
|
target_compile_definitions(conflict_set_fuzz_test PRIVATE ENABLE_FUZZ)
|
||||||
target_compile_options(conflict_set_fuzz_test PRIVATE ${TEST_FLAGS})
|
target_compile_options(conflict_set_fuzz_test PRIVATE ${TEST_FLAGS})
|
||||||
target_compile_options(conflict_set_fuzz_test PRIVATE ${FUZZ_FLAGS})
|
target_compile_options(conflict_set_fuzz_test PRIVATE ${FUZZ_FLAGS})
|
||||||
target_link_options(conflict_set_fuzz_test PRIVATE ${FUZZ_FLAGS} -fsanitize=fuzzer)
|
target_link_options(conflict_set_fuzz_test PRIVATE ${FUZZ_FLAGS}
|
||||||
|
-fsanitize=fuzzer)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# corpus tests
|
# corpus tests
|
||||||
@@ -79,10 +92,12 @@ file(GLOB CORPUS_TESTS ${CMAKE_SOURCE_DIR}/corpus/*)
|
|||||||
add_executable(conflict_set_test_driver ConflictSet.cpp TestDriver.cpp)
|
add_executable(conflict_set_test_driver ConflictSet.cpp TestDriver.cpp)
|
||||||
target_compile_options(conflict_set_test_driver PRIVATE ${TEST_FLAGS})
|
target_compile_options(conflict_set_test_driver PRIVATE ${TEST_FLAGS})
|
||||||
target_compile_definitions(conflict_set_test_driver PRIVATE ENABLE_FUZZ)
|
target_compile_definitions(conflict_set_test_driver PRIVATE ENABLE_FUZZ)
|
||||||
target_include_directories(conflict_set_test_driver PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include)
|
target_include_directories(conflict_set_test_driver
|
||||||
|
PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include)
|
||||||
foreach(TEST ${CORPUS_TESTS})
|
foreach(TEST ${CORPUS_TESTS})
|
||||||
get_filename_component(hash ${TEST} NAME)
|
get_filename_component(hash ${TEST} NAME)
|
||||||
add_test(NAME conflict_set_corpus_${hash} COMMAND conflict_set_test_driver ${TEST})
|
add_test(NAME conflict_set_corpus_${hash} COMMAND conflict_set_test_driver
|
||||||
|
${TEST})
|
||||||
endforeach()
|
endforeach()
|
||||||
|
|
||||||
# api smoke tests
|
# api smoke tests
|
||||||
@@ -107,18 +122,22 @@ add_test(NAME conflict_set_cxx_api_test COMMAND conflict_set_cxx_api_test)
|
|||||||
|
|
||||||
include(GNUInstallDirs)
|
include(GNUInstallDirs)
|
||||||
|
|
||||||
target_include_directories(${PROJECT_NAME} PUBLIC
|
target_include_directories(
|
||||||
$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
|
${PROJECT_NAME}
|
||||||
|
PUBLIC $<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
|
||||||
$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}>)
|
$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME}>)
|
||||||
|
|
||||||
set_target_properties(${PROJECT_NAME} PROPERTIES
|
set_target_properties(
|
||||||
VERSION ${PROJECT_VERSION}
|
${PROJECT_NAME} PROPERTIES VERSION ${PROJECT_VERSION}
|
||||||
SOVERSION ${PROJECT_VERSION_MAJOR})
|
SOVERSION ${PROJECT_VERSION_MAJOR})
|
||||||
|
|
||||||
install(TARGETS ${PROJECT_NAME} EXPORT ConflictSetConfig
|
install(
|
||||||
|
TARGETS ${PROJECT_NAME}
|
||||||
|
EXPORT ConflictSetConfig
|
||||||
ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}
|
ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}
|
||||||
LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
|
LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
|
||||||
RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
|
RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
|
||||||
install(DIRECTORY include/ DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME})
|
install(DIRECTORY include/
|
||||||
|
DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}/${PROJECT_NAME})
|
||||||
|
|
||||||
install(EXPORT ConflictSetConfig DESTINATION share/ConflictSet/cmake)
|
install(EXPORT ConflictSetConfig DESTINATION share/ConflictSet/cmake)
|
||||||
|
Reference in New Issue
Block a user