mirror of
https://github.com/HowardHinnant/date.git
synced 2025-08-04 21:24:26 +02:00
use target_include_directories instead of include_directories
This commit is contained in:
committed by
Howard Hinnant
parent
c2e139ef53
commit
d3b8d4af8d
@@ -10,11 +10,11 @@ option( USE_SYSTEM_TZ_DB "Use the operating system's timezone database" OFF )
|
|||||||
option( USE_TZ_DB_IN_DOT "Save the timezone database in the current folder" OFF )
|
option( USE_TZ_DB_IN_DOT "Save the timezone database in the current folder" OFF )
|
||||||
option( BUILD_STATIC "Build a static version of library" ON )
|
option( BUILD_STATIC "Build a static version of library" ON )
|
||||||
|
|
||||||
if( USE_SYSTEM_TZ_DB )
|
if( USE_SYSTEM_TZ_DB )
|
||||||
add_definitions( -DUSE_AUTOLOAD=0 )
|
add_definitions( -DUSE_AUTOLOAD=0 )
|
||||||
add_definitions( -DHAS_REMOTE_API=0 )
|
add_definitions( -DHAS_REMOTE_API=0 )
|
||||||
# cannot set USE_OS_TZDB to 1 on Windows
|
# cannot set USE_OS_TZDB to 1 on Windows
|
||||||
if( NOT WIN32 )
|
if( NOT WIN32 )
|
||||||
add_definitions( -DUSE_OS_TZDB=1 )
|
add_definitions( -DUSE_OS_TZDB=1 )
|
||||||
endif( )
|
endif( )
|
||||||
else( )
|
else( )
|
||||||
@@ -27,7 +27,7 @@ else( )
|
|||||||
set( OPTIONAL_LIBRARIES ${CURL_LIBRARIES} )
|
set( OPTIONAL_LIBRARIES ${CURL_LIBRARIES} )
|
||||||
endif( )
|
endif( )
|
||||||
|
|
||||||
if( USE_TZ_DB_IN_DOT )
|
if( USE_TZ_DB_IN_DOT )
|
||||||
add_definitions( -DINSTALL=. )
|
add_definitions( -DINSTALL=. )
|
||||||
endif( )
|
endif( )
|
||||||
|
|
||||||
@@ -35,8 +35,6 @@ set( HEADER_FOLDER "include" )
|
|||||||
set( SOURCE_FOLDER "src" )
|
set( SOURCE_FOLDER "src" )
|
||||||
set( TEST_FOLDER "test" )
|
set( TEST_FOLDER "test" )
|
||||||
|
|
||||||
include_directories( ${HEADER_FOLDER} )
|
|
||||||
|
|
||||||
# This is needed so IDE's live MSVC show header files
|
# This is needed so IDE's live MSVC show header files
|
||||||
set( HEADER_FILES
|
set( HEADER_FILES
|
||||||
${HEADER_FOLDER}/date/chrono_io.h
|
${HEADER_FOLDER}/date/chrono_io.h
|
||||||
@@ -49,7 +47,7 @@ set( HEADER_FILES
|
|||||||
${HEADER_FOLDER}/date/tz_private.h
|
${HEADER_FOLDER}/date/tz_private.h
|
||||||
)
|
)
|
||||||
|
|
||||||
if( BUILD_STATIC )
|
if( BUILD_STATIC )
|
||||||
add_library( tz STATIC ${HEADER_FILES} ${SOURCE_FOLDER}/tz.cpp )
|
add_library( tz STATIC ${HEADER_FILES} ${SOURCE_FOLDER}/tz.cpp )
|
||||||
else( )
|
else( )
|
||||||
add_library( tz SHARED ${HEADER_FILES} ${SOURCE_FOLDER}/tz.cpp )
|
add_library( tz SHARED ${HEADER_FILES} ${SOURCE_FOLDER}/tz.cpp )
|
||||||
@@ -57,6 +55,16 @@ endif( )
|
|||||||
set_property(TARGET tz PROPERTY CXX_STANDARD 14)
|
set_property(TARGET tz PROPERTY CXX_STANDARD 14)
|
||||||
target_link_libraries( tz ${CMAKE_THREAD_LIBS_INIT} ${OPTIONAL_LIBRARIES} ${CMAKE_THREAD_LIBS_INIT} )
|
target_link_libraries( tz ${CMAKE_THREAD_LIBS_INIT} ${OPTIONAL_LIBRARIES} ${CMAKE_THREAD_LIBS_INIT} )
|
||||||
|
|
||||||
|
# add include folders to the library and targets that consume it
|
||||||
|
target_include_directories(tz PUBLIC
|
||||||
|
$<BUILD_INTERFACE:
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/${HEADER_FOLDER}
|
||||||
|
>
|
||||||
|
$<INSTALL_INTERFACE:
|
||||||
|
include
|
||||||
|
>
|
||||||
|
)
|
||||||
|
|
||||||
install( TARGETS tz DESTINATION lib )
|
install( TARGETS tz DESTINATION lib )
|
||||||
install( DIRECTORY ${HEADER_FOLDER}/ DESTINATION include/ )
|
install( DIRECTORY ${HEADER_FOLDER}/ DESTINATION include/ )
|
||||||
|
|
||||||
@@ -70,7 +78,7 @@ function( add_pass_tests TEST_GLOB TEST_PREFIX )
|
|||||||
foreach( TEST_FILE ${FILENAMES} )
|
foreach( TEST_FILE ${FILENAMES} )
|
||||||
get_filename_component( TEST_NAME ${TEST_FILE} NAME_WE )
|
get_filename_component( TEST_NAME ${TEST_FILE} NAME_WE )
|
||||||
get_filename_component( TEST_EXT ${TEST_FILE} EXT )
|
get_filename_component( TEST_EXT ${TEST_FILE} EXT )
|
||||||
if( NOT ${TEST_EXT} STREQUAL ".fail.cpp" )
|
if( NOT ${TEST_EXT} STREQUAL ".fail.cpp" )
|
||||||
set( PREFIX "${TEST_PREFIX}_pass_${TEST_NAME}" )
|
set( PREFIX "${TEST_PREFIX}_pass_${TEST_NAME}" )
|
||||||
set( BIN_NAME ${PREFIX}_bin )
|
set( BIN_NAME ${PREFIX}_bin )
|
||||||
set( TST_NAME ${PREFIX}_test )
|
set( TST_NAME ${PREFIX}_test )
|
||||||
@@ -98,10 +106,10 @@ function( add_fail_tests TEST_GLOB TEST_PREFIX )
|
|||||||
|
|
||||||
#target_compile_definitions( ${BIN_NAME} PRIVATE ${TST_NAME} )
|
#target_compile_definitions( ${BIN_NAME} PRIVATE ${TST_NAME} )
|
||||||
set( TEST_BIN_NAME ${CMAKE_BINARY_DIR}/${BIN_NAME} )
|
set( TEST_BIN_NAME ${CMAKE_BINARY_DIR}/${BIN_NAME} )
|
||||||
add_custom_target( ${BIN_NAME}
|
add_custom_target( ${BIN_NAME}
|
||||||
COMMAND ${PROJECT_SOURCE_DIR}/compile_fail.sh ${TEST_BIN_NAME} ${CMAKE_CXX_COMPILER} -std=c++14 -L${CMAKE_BINARY_DIR}/ -ltz -I${PROJECT_SOURCE_DIR}/${HEADER_FOLDER}/date -o ${BIN_NAME} ${TEST_FILE}
|
COMMAND ${PROJECT_SOURCE_DIR}/compile_fail.sh ${TEST_BIN_NAME} ${CMAKE_CXX_COMPILER} -std=c++14 -L${CMAKE_BINARY_DIR}/ -ltz -I${PROJECT_SOURCE_DIR}/${HEADER_FOLDER}/date -o ${BIN_NAME} ${TEST_FILE}
|
||||||
WORKING_DIRECTORY ${CMAKE_BINARY_DIR}
|
WORKING_DIRECTORY ${CMAKE_BINARY_DIR}
|
||||||
COMMENT ${TST_NAME}
|
COMMENT ${TST_NAME}
|
||||||
)
|
)
|
||||||
add_test( ${TST_NAME} "${PROJECT_SOURCE_DIR}/test_fail.sh" ${CMAKE_BINARY_DIR}/${BIN_NAME} WORKING_DIRECTORY "${PROJECT_SOURCE_DIR}/" )
|
add_test( ${TST_NAME} "${PROJECT_SOURCE_DIR}/test_fail.sh" ${CMAKE_BINARY_DIR}/${BIN_NAME} WORKING_DIRECTORY "${PROJECT_SOURCE_DIR}/" )
|
||||||
#set_tests_properties( ${TST_NAME} PROPERTIES WILL_FAIL TRUE)
|
#set_tests_properties( ${TST_NAME} PROPERTIES WILL_FAIL TRUE)
|
||||||
@@ -114,7 +122,7 @@ foreach( child ${children} )
|
|||||||
if( IS_DIRECTORY "${PROJECT_SOURCE_DIR}/${TEST_FOLDER}/${child}" )
|
if( IS_DIRECTORY "${PROJECT_SOURCE_DIR}/${TEST_FOLDER}/${child}" )
|
||||||
set( CUR_FOLDER "${PROJECT_SOURCE_DIR}/${TEST_FOLDER}/${child}" )
|
set( CUR_FOLDER "${PROJECT_SOURCE_DIR}/${TEST_FOLDER}/${child}" )
|
||||||
add_pass_tests( "${CUR_FOLDER}/*.cpp" ${child} )
|
add_pass_tests( "${CUR_FOLDER}/*.cpp" ${child} )
|
||||||
if( NOT WIN32 )
|
if( NOT WIN32 )
|
||||||
add_fail_tests( "${CUR_FOLDER}/*.fail.cpp" ${child} )
|
add_fail_tests( "${CUR_FOLDER}/*.fail.cpp" ${child} )
|
||||||
endif( )
|
endif( )
|
||||||
endif( )
|
endif( )
|
||||||
|
Reference in New Issue
Block a user