|
|
|
@@ -1,7 +1,7 @@
|
|
|
|
|
cmake_minimum_required(VERSION 3.18)
|
|
|
|
|
project(
|
|
|
|
|
conflict-set
|
|
|
|
|
VERSION 0.0.1
|
|
|
|
|
VERSION 0.0.2
|
|
|
|
|
DESCRIPTION
|
|
|
|
|
"A data structure for optimistic concurrency control on ranges of bitwise-lexicographically-ordered keys."
|
|
|
|
|
HOMEPAGE_URL "https://git.weaselab.dev/weaselab/conflict-set"
|
|
|
|
@@ -32,10 +32,7 @@ option(USE_SIMD_FALLBACK
|
|
|
|
|
# https://valgrind.org/docs/manual/manual-core-adv.html#manual-core-adv.clientreq
|
|
|
|
|
include_directories(SYSTEM ${CMAKE_SOURCE_DIR}/third_party/valgrind)
|
|
|
|
|
|
|
|
|
|
if(CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
|
|
|
|
|
add_compile_options(-Wno-maybe-uninitialized
|
|
|
|
|
$<$<COMPILE_LANGUAGE:CXX>:-Wno-invalid-offsetof>)
|
|
|
|
|
endif()
|
|
|
|
|
add_compile_options($<$<COMPILE_LANGUAGE:CXX>:-Wno-invalid-offsetof>)
|
|
|
|
|
|
|
|
|
|
if(APPLE)
|
|
|
|
|
add_link_options(-Wl,-dead_strip)
|
|
|
|
@@ -43,10 +40,21 @@ else()
|
|
|
|
|
add_link_options(-Wl,--gc-sections)
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
|
|
if(EMSCRIPTEN)
|
|
|
|
|
# https://github.com/emscripten-core/emscripten/issues/15377#issuecomment-1285167486
|
|
|
|
|
add_link_options(-lnodefs.js -lnoderawfs.js)
|
|
|
|
|
add_link_options(-s ALLOW_MEMORY_GROWTH)
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
|
|
include(CheckIncludeFileCXX)
|
|
|
|
|
include(CMakePushCheckState)
|
|
|
|
|
|
|
|
|
|
if(NOT USE_SIMD_FALLBACK)
|
|
|
|
|
if(EMSCRIPTEN)
|
|
|
|
|
# https://emscripten.org/docs/porting/simd.html#using-simd-with-webassembly
|
|
|
|
|
add_compile_options(-msimd128)
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
|
|
cmake_push_check_state()
|
|
|
|
|
list(APPEND CMAKE_REQUIRED_FLAGS -mavx)
|
|
|
|
|
check_include_file_cxx("immintrin.h" HAS_AVX)
|
|
|
|
@@ -79,8 +87,10 @@ if(NOT CMAKE_BUILD_TYPE STREQUAL Debug)
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
|
|
if(NOT APPLE)
|
|
|
|
|
target_link_options(${PROJECT_NAME} PRIVATE
|
|
|
|
|
LINKER:--version-script=${CMAKE_SOURCE_DIR}/linker.map)
|
|
|
|
|
target_link_options(
|
|
|
|
|
${PROJECT_NAME} PRIVATE
|
|
|
|
|
LINKER:--version-script=${CMAKE_SOURCE_DIR}/linker.map
|
|
|
|
|
LINKER:-z,relro,-z,now,-z,noexecstack)
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
|
|
add_library(${PROJECT_NAME}-static STATIC
|
|
|
|
@@ -104,30 +114,50 @@ include(CTest)
|
|
|
|
|
|
|
|
|
|
if(BUILD_TESTING)
|
|
|
|
|
|
|
|
|
|
# Shared library version of FoundationDB's skip list implementation
|
|
|
|
|
add_library(skip_list SHARED SkipList.cpp)
|
|
|
|
|
target_compile_options(skip_list PRIVATE -fPIC -fno-exceptions
|
|
|
|
|
-fvisibility=hidden)
|
|
|
|
|
target_include_directories(skip_list PUBLIC ${CMAKE_SOURCE_DIR}/include)
|
|
|
|
|
set_target_properties(skip_list PROPERTIES LIBRARY_OUTPUT_DIRECTORY
|
|
|
|
|
"${CMAKE_BINARY_DIR}/skip_list")
|
|
|
|
|
set_target_properties(skip_list PROPERTIES OUTPUT_NAME ${PROJECT_NAME})
|
|
|
|
|
set_target_properties(skip_list PROPERTIES VERSION ${PROJECT_VERSION}
|
|
|
|
|
SOVERSION ${PROJECT_VERSION_MAJOR})
|
|
|
|
|
# corpus tests, which are test
|
|
|
|
|
|
|
|
|
|
# Shared library version of a std::unordered_map-based conflict set (point
|
|
|
|
|
# queries only)
|
|
|
|
|
add_library(hash_table SHARED HashTable.cpp)
|
|
|
|
|
target_compile_options(hash_table PRIVATE -fPIC -fno-exceptions
|
|
|
|
|
-fvisibility=hidden)
|
|
|
|
|
target_include_directories(hash_table PUBLIC ${CMAKE_SOURCE_DIR}/include)
|
|
|
|
|
set_target_properties(hash_table PROPERTIES LIBRARY_OUTPUT_DIRECTORY
|
|
|
|
|
"${CMAKE_BINARY_DIR}/hash_table")
|
|
|
|
|
set_target_properties(hash_table PROPERTIES OUTPUT_NAME ${PROJECT_NAME})
|
|
|
|
|
set_target_properties(
|
|
|
|
|
hash_table PROPERTIES VERSION ${PROJECT_VERSION} SOVERSION
|
|
|
|
|
${PROJECT_VERSION_MAJOR})
|
|
|
|
|
file(GLOB CORPUS_TESTS ${CMAKE_SOURCE_DIR}/corpus/*)
|
|
|
|
|
|
|
|
|
|
# extra testing that relies on shared libraries, which aren't available with
|
|
|
|
|
# emscripten
|
|
|
|
|
if(NOT EMSCRIPTEN)
|
|
|
|
|
# Shared library version of FoundationDB's skip list implementation
|
|
|
|
|
add_library(skip_list SHARED SkipList.cpp)
|
|
|
|
|
target_compile_options(skip_list PRIVATE -fPIC -fno-exceptions
|
|
|
|
|
-fvisibility=hidden)
|
|
|
|
|
target_include_directories(skip_list PUBLIC ${CMAKE_SOURCE_DIR}/include)
|
|
|
|
|
set_target_properties(skip_list PROPERTIES LIBRARY_OUTPUT_DIRECTORY
|
|
|
|
|
"${CMAKE_BINARY_DIR}/skip_list")
|
|
|
|
|
set_target_properties(skip_list PROPERTIES OUTPUT_NAME ${PROJECT_NAME})
|
|
|
|
|
set_target_properties(
|
|
|
|
|
skip_list PROPERTIES VERSION ${PROJECT_VERSION} SOVERSION
|
|
|
|
|
${PROJECT_VERSION_MAJOR})
|
|
|
|
|
|
|
|
|
|
# Shared library version of a std::unordered_map-based conflict set (point
|
|
|
|
|
# queries only)
|
|
|
|
|
add_library(hash_table SHARED HashTable.cpp)
|
|
|
|
|
target_compile_options(hash_table PRIVATE -fPIC -fno-exceptions
|
|
|
|
|
-fvisibility=hidden)
|
|
|
|
|
target_include_directories(hash_table PUBLIC ${CMAKE_SOURCE_DIR}/include)
|
|
|
|
|
set_target_properties(
|
|
|
|
|
hash_table PROPERTIES LIBRARY_OUTPUT_DIRECTORY
|
|
|
|
|
"${CMAKE_BINARY_DIR}/hash_table")
|
|
|
|
|
set_target_properties(hash_table PROPERTIES OUTPUT_NAME ${PROJECT_NAME})
|
|
|
|
|
set_target_properties(
|
|
|
|
|
hash_table PROPERTIES VERSION ${PROJECT_VERSION} SOVERSION
|
|
|
|
|
${PROJECT_VERSION_MAJOR})
|
|
|
|
|
|
|
|
|
|
add_executable(driver_skip_list TestDriver.cpp)
|
|
|
|
|
target_compile_options(driver_skip_list PRIVATE ${TEST_FLAGS})
|
|
|
|
|
target_link_libraries(driver_skip_list PRIVATE skip_list)
|
|
|
|
|
|
|
|
|
|
foreach(TEST ${CORPUS_TESTS})
|
|
|
|
|
get_filename_component(hash ${TEST} NAME)
|
|
|
|
|
add_test(NAME skip_list_${hash} COMMAND driver_skip_list ${TEST})
|
|
|
|
|
endforeach()
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
|
|
# ad hoc testing
|
|
|
|
|
add_executable(conflict_set_main ConflictSet.cpp)
|
|
|
|
|
target_include_directories(conflict_set_main
|
|
|
|
|
PRIVATE ${CMAKE_CURRENT_SOURCE_DIR}/include)
|
|
|
|
@@ -154,10 +184,7 @@ if(BUILD_TESTING)
|
|
|
|
|
endif()
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
|
|
# corpus tests
|
|
|
|
|
|
|
|
|
|
file(GLOB CORPUS_TESTS ${CMAKE_SOURCE_DIR}/corpus/*)
|
|
|
|
|
|
|
|
|
|
# fuzz/whitebox tests
|
|
|
|
|
add_executable(fuzz_driver ConflictSet.cpp FuzzTestDriver.cpp)
|
|
|
|
|
target_compile_options(fuzz_driver PRIVATE ${TEST_FLAGS})
|
|
|
|
|
if(NOT CMAKE_CROSSCOMPILING)
|
|
|
|
@@ -172,8 +199,7 @@ if(BUILD_TESTING)
|
|
|
|
|
add_test(NAME conflict_set_fuzz_${hash} COMMAND fuzz_driver ${TEST})
|
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
|
|
# tsan
|
|
|
|
|
|
|
|
|
|
# tsan tests
|
|
|
|
|
if(NOT CMAKE_CROSSCOMPILING AND NOT CMAKE_BUILD_TYPE STREQUAL Debug)
|
|
|
|
|
add_executable(tsan_driver ConflictSet.cpp FuzzTestDriver.cpp)
|
|
|
|
|
target_compile_options(tsan_driver PRIVATE ${TEST_FLAGS} -fsanitize=thread)
|
|
|
|
@@ -187,9 +213,14 @@ if(BUILD_TESTING)
|
|
|
|
|
endforeach()
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
|
|
# blackbox tests
|
|
|
|
|
add_executable(driver TestDriver.cpp)
|
|
|
|
|
target_compile_options(driver PRIVATE ${TEST_FLAGS})
|
|
|
|
|
target_link_libraries(driver PRIVATE ${PROJECT_NAME})
|
|
|
|
|
foreach(TEST ${CORPUS_TESTS})
|
|
|
|
|
get_filename_component(hash ${TEST} NAME)
|
|
|
|
|
add_test(NAME conflict_set_blackbox_${hash} COMMAND driver ${TEST})
|
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
|
|
add_executable(script_test ScriptTest.cpp)
|
|
|
|
|
target_compile_options(script_test PRIVATE ${TEST_FLAGS})
|
|
|
|
@@ -201,10 +232,6 @@ if(BUILD_TESTING)
|
|
|
|
|
add_test(NAME conflict_set_script_${name} COMMAND script_test ${TEST})
|
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
|
|
add_executable(driver_skip_list TestDriver.cpp)
|
|
|
|
|
target_compile_options(driver_skip_list PRIVATE ${TEST_FLAGS})
|
|
|
|
|
target_link_libraries(driver_skip_list PRIVATE skip_list)
|
|
|
|
|
|
|
|
|
|
find_program(VALGRIND_EXE valgrind)
|
|
|
|
|
if(VALGRIND_EXE AND NOT CMAKE_CROSSCOMPILING)
|
|
|
|
|
add_test(NAME conflict_set_blackbox_valgrind
|
|
|
|
@@ -212,12 +239,6 @@ if(BUILD_TESTING)
|
|
|
|
|
$<TARGET_FILE:driver> ${CORPUS_TESTS})
|
|
|
|
|
endif()
|
|
|
|
|
|
|
|
|
|
foreach(TEST ${CORPUS_TESTS})
|
|
|
|
|
get_filename_component(hash ${TEST} NAME)
|
|
|
|
|
add_test(NAME conflict_set_blackbox_${hash} COMMAND driver ${TEST})
|
|
|
|
|
add_test(NAME skip_list_${hash} COMMAND driver_skip_list ${TEST})
|
|
|
|
|
endforeach()
|
|
|
|
|
|
|
|
|
|
# api smoke tests
|
|
|
|
|
|
|
|
|
|
# c90
|
|
|
|
@@ -238,7 +259,9 @@ if(BUILD_TESTING)
|
|
|
|
|
PROPERTIES CXX_STANDARD_REQUIRED ON)
|
|
|
|
|
add_test(NAME conflict_set_cxx_api_test COMMAND conflict_set_cxx_api_test)
|
|
|
|
|
|
|
|
|
|
if(NOT APPLE AND NOT CMAKE_BUILD_TYPE STREQUAL Debug)
|
|
|
|
|
if(NOT EMSCRIPTEN
|
|
|
|
|
AND NOT APPLE
|
|
|
|
|
AND NOT CMAKE_BUILD_TYPE STREQUAL Debug)
|
|
|
|
|
add_test(
|
|
|
|
|
NAME conflict_set_shared_symbols
|
|
|
|
|
COMMAND ${CMAKE_SOURCE_DIR}/test_symbols.sh
|
|
|
|
|