build and libname

This commit is contained in:
Erik Frojdh 2020-09-07 09:14:47 +02:00
parent a1b88d3a62
commit fb8842e048
11 changed files with 50 additions and 53 deletions

View File

@ -241,7 +241,7 @@ if(SLS_MASTER_PROJECT)
# Set install dir CMake packages # Set install dir CMake packages
set(CMAKE_INSTALL_DIR "share/cmake/${PROJECT_NAME}") set(CMAKE_INSTALL_DIR "share/cmake/${PROJECT_NAME}")
# Set the list of exported targets # Set the list of exported targets
set(PROJECT_LIBRARIES slsSupportLib slsDetectorShared slsReceiverShared) set(PROJECT_LIBRARIES slsSupportShared slsDetectorShared slsReceiverShared)
# Generate and install package config file and version # Generate and install package config file and version
include(cmake/package_config.cmake) include(cmake/package_config.cmake)
endif() endif()

View File

@ -33,6 +33,7 @@ requirements:
- {{ cdt('libselinux') }} # [linux] - {{ cdt('libselinux') }} # [linux]
- {{ cdt('libxdamage') }} # [linux] - {{ cdt('libxdamage') }} # [linux]
- {{ cdt('libxxf86vm') }} # [linux] - {{ cdt('libxxf86vm') }} # [linux]
- expat
host: host:
- libstdcxx-ng - libstdcxx-ng
@ -45,6 +46,7 @@ requirements:
- xorg-libxau - xorg-libxau
- xorg-libxrender - xorg-libxrender
- xorg-libxfixes - xorg-libxfixes
- expat
run: run:
- zeromq - zeromq
@ -96,3 +98,4 @@ outputs:
- {{ pin_subpackage('slsdetlib', exact=True) }} - {{ pin_subpackage('slsdetlib', exact=True) }}
- qwt 6.* - qwt 6.*
- qt 4.8.* - qt 4.8.*
- expat

View File

@ -59,14 +59,13 @@ set( HEADERS
#set(ROOT_INCLUDE_PATH ${CMAKE_CURRENT_SOURCE_DIR}) #set(ROOT_INCLUDE_PATH ${CMAKE_CURRENT_SOURCE_DIR})
# ROOT dictionary generation # ROOT dictionary generation
include("${ROOT_DIR}/modules/RootNewMacros.cmake") include("${ROOT_DIR}/RootMacros.cmake")
root_generate_dictionary(ctbDict ${HEADERS} LINKDEF ctbLinkDef.h) root_generate_dictionary(ctbDict ${HEADERS} LINKDEF ctbLinkDef.h)
add_library(ctbRootLib SHARED ctbDict.cxx) add_library(ctbRootLib SHARED ctbDict.cxx)
target_include_directories(ctbRootLib PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}) target_include_directories(ctbRootLib PUBLIC ${CMAKE_CURRENT_SOURCE_DIR})
target_link_libraries(ctbRootLib PUBLIC target_link_libraries(ctbRootLib PUBLIC
ROOT::Core ROOT::Core
slsDetectorShared slsDetectorShared
slsSupportLib
${ROOT_LIBRARIES} ${ROOT_LIBRARIES}
${ROOT_EXE_LINKER_FLAGS} ${ROOT_EXE_LINKER_FLAGS}
) )
@ -78,7 +77,6 @@ set_target_properties(
target_link_libraries(ctbGui PUBLIC target_link_libraries(ctbGui PUBLIC
slsDetectorShared slsDetectorShared
slsSupportLib
ctbRootLib ctbRootLib
${TIFF_LIBRARIES} ${TIFF_LIBRARIES}
) )

View File

@ -11,7 +11,7 @@ pybind11_add_module(_slsdet
target_link_libraries(_slsdet PUBLIC target_link_libraries(_slsdet PUBLIC
slsDetectorShared slsDetectorShared
slsReceiverShared slsReceiverShared
slsSupportLib slsSupportShared
${ZeroMQ_LIBRARIES} ${ZeroMQ_LIBRARIES}
) )

View File

@ -1,6 +1,6 @@
add_executable(using_logger using_logger.cpp) add_executable(using_logger using_logger.cpp)
target_link_libraries(using_logger target_link_libraries(using_logger
slsSupportLib slsSupportShared
pthread pthread
rt rt
) )
@ -22,7 +22,7 @@ set_target_properties(using_logger PROPERTIES
# add_executable(udp udp.cpp) # add_executable(udp udp.cpp)
# target_link_libraries(udp # target_link_libraries(udp
# slsDetectorShared # slsDetectorShared
# slsSupportLib # slsSupportShared
# pthread # pthread
# rt # rt
# fmt # fmt

View File

@ -23,7 +23,7 @@ foreach(exe ${MOENCH_EXECUTABLES})
target_link_libraries(${exe} target_link_libraries(${exe}
PUBLIC PUBLIC
slsSupportLib slsSupportShared
${ZeroMQ_LIBRARIES} ${ZeroMQ_LIBRARIES}
pthread pthread
tiff tiff

View File

@ -88,6 +88,7 @@ target_include_directories(slsDetectorGui PUBLIC
) )
target_link_libraries(slsDetectorGui PUBLIC target_link_libraries(slsDetectorGui PUBLIC
slsProjectOptions
slsProjectWarnings slsProjectWarnings
slsDetectorShared slsDetectorShared
${QT_QTCORE_LIBRARIES} ${QT_QTCORE_LIBRARIES}
@ -97,6 +98,7 @@ target_link_libraries(slsDetectorGui PUBLIC
ZLIB::ZLIB ZLIB::ZLIB
Qt4::QtOpenGL Qt4::QtOpenGL
Qt4::QtSvg Qt4::QtSvg
expat
) )
set_target_properties(slsDetectorGui PROPERTIES set_target_properties(slsDetectorGui PROPERTIES
@ -104,10 +106,10 @@ set_target_properties(slsDetectorGui PROPERTIES
) )
install(TARGETS slsDetectorGui install(TARGETS slsDetectorGui
# EXPORT "${TARGETS_EXPORT_NAME}" EXPORT "${TARGETS_EXPORT_NAME}"
RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR} RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}
# LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
# ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR} ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}
# PUBLIC_HEADER DESTINATION ${CMAKE_INSTALL_INCLUDEDIR} # PUBLIC_HEADER DESTINATION ${CMAKE_INSTALL_INCLUDEDIR}
) )

View File

@ -27,7 +27,7 @@ target_include_directories(slsDetectorShared PUBLIC
target_link_libraries(slsDetectorShared target_link_libraries(slsDetectorShared
PUBLIC PUBLIC
slsSupportLibStatic slsSupportStatic
pthread pthread
rt rt
slsProjectOptions slsProjectOptions

View File

@ -35,10 +35,10 @@ if((CMAKE_BUILD_TYPE STREQUAL "Release") AND SLS_LTO_AVAILABLE)
endif() endif()
target_link_libraries(slsReceiverShared target_link_libraries(slsReceiverShared
PUBLIC PUBLIC
slsProjectOptions slsProjectOptions
slsSupportLibStatic slsSupportStatic
PRIVATE PRIVATE
slsProjectWarnings #don't propagate warnigns slsProjectWarnings #don't propagate warnigns
) )
@ -80,13 +80,13 @@ set_target_properties(slsReceiver PROPERTIES
) )
target_link_libraries(slsReceiver PUBLIC target_link_libraries(slsReceiver PUBLIC
slsProjectOptions PUBLIC
slsProjectWarnings
slsSupportLib
slsReceiverShared slsReceiverShared
pthread pthread
${ZeroMQ_LIBRARIES} ${ZeroMQ_LIBRARIES}
rt rt
PRIVATE
slsProjectWarnings
) )
add_executable(slsMultiReceiver add_executable(slsMultiReceiver
@ -97,14 +97,14 @@ set_target_properties(slsMultiReceiver PROPERTIES
RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin
) )
target_link_libraries(slsMultiReceiver PUBLIC target_link_libraries(slsMultiReceiver
slsProjectOptions PUBLIC
slsProjectWarnings
slsSupportLib
slsReceiverShared slsReceiverShared
pthread pthread
${ZeroMQ_LIBRARIES} ${ZeroMQ_LIBRARIES}
rt rt
PRIVATE
slsProjectWarnings
) )
if (SLS_USE_TESTS) if (SLS_USE_TESTS)

View File

@ -12,6 +12,7 @@ set(SOURCES
src/sls_detector_exceptions.cpp src/sls_detector_exceptions.cpp
) )
# Header files to install as a part of the library
set(PUBLICHEADERS set(PUBLICHEADERS
include/sls_detector_defs.h include/sls_detector_defs.h
include/sls_detector_exceptions.h include/sls_detector_exceptions.h
@ -45,28 +46,27 @@ if(SLS_DEVEL_HEADERS)
) )
endif() endif()
# Create a Object library to avoidbuilding the library twice # Create an object library to avoid building the library twice
add_library(slsSupportObject OBJECT add_library(slsSupportObject OBJECT
${SOURCES} ${SOURCES}
${HEADERS} ${HEADERS}
) )
target_include_directories(slsSupportObject PUBLIC target_include_directories(slsSupportObject
PUBLIC
"$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>" "$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>"
"$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>" "$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>"
) PRIVATE
target_include_directories(slsSupportObject PRIVATE
${ZeroMQ_INCLUDE_DIRS} ${ZeroMQ_INCLUDE_DIRS}
) )
target_link_libraries(slsSupportObject target_link_libraries(slsSupportObject
PUBLIC PUBLIC
slsProjectOptions slsProjectOptions
zmq # zmq
${ZeroMQ_LIBRARIES}
rapidjson rapidjson
PRIVATE PRIVATE
slsProjectWarnings slsProjectWarnings
) )
@ -74,41 +74,35 @@ if (SLS_USE_TESTS)
add_subdirectory(tests) add_subdirectory(tests)
endif(SLS_USE_TESTS) endif(SLS_USE_TESTS)
add_library(slsSupportLib SHARED $<TARGET_OBJECTS:slsSupportObject>) # Add shared library version of the support lib
target_link_libraries(slsSupportLib PUBLIC slsSupportObject) add_library(slsSupportShared SHARED $<TARGET_OBJECTS:slsSupportObject>)
# target_include_directories(slsSupportLib PUBLIC
# "$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>"
# "$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>"
# )
set_target_properties(slsSupportLib PROPERTIES target_link_libraries(slsSupportShared PUBLIC slsSupportObject)
set_target_properties(slsSupportShared PROPERTIES
LIBRARY_OUTPUT_NAME SlsSupport LIBRARY_OUTPUT_NAME SlsSupport
LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin
PUBLIC_HEADER "${PUBLICHEADERS}" PUBLIC_HEADER "${PUBLICHEADERS}"
) )
add_library(slsSupportLibStatic STATIC $<TARGET_OBJECTS:slsSupportObject>) # Add static version of the support lib
target_link_libraries(slsSupportLibStatic PUBLIC slsSupportObject) add_library(slsSupportStatic STATIC $<TARGET_OBJECTS:slsSupportObject>)
set_target_properties(slsSupportLibStatic PROPERTIES target_link_libraries(slsSupportStatic PUBLIC slsSupportObject)
set_target_properties(slsSupportStatic PROPERTIES
ARCHIVE_OUTPUT_NAME SlsSupportStatic ARCHIVE_OUTPUT_NAME SlsSupportStatic
ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin ARCHIVE_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin
PUBLIC_HEADER "${PUBLICHEADERS}" PUBLIC_HEADER "${PUBLICHEADERS}"
) )
# target_include_directories(slsSupportLibStatic PUBLIC
# "$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>"
# "$<INSTALL_INTERFACE:${CMAKE_INSTALL_INCLUDEDIR}>"
# )
if((CMAKE_BUILD_TYPE STREQUAL "Release") AND SLS_LTO_AVAILABLE) if((CMAKE_BUILD_TYPE STREQUAL "Release") AND SLS_LTO_AVAILABLE)
set_property(TARGET slsSupportObject PROPERTY INTERPROCEDURAL_OPTIMIZATION True) set_property(TARGET slsSupportObject PROPERTY INTERPROCEDURAL_OPTIMIZATION True)
set_property(TARGET slsSupportLib PROPERTY INTERPROCEDURAL_OPTIMIZATION True) set_property(TARGET slsSupportShared PROPERTY INTERPROCEDURAL_OPTIMIZATION True)
set_property(TARGET slsSupportLibStatic PROPERTY INTERPROCEDURAL_OPTIMIZATION True) set_property(TARGET slsSupportStatic PROPERTY INTERPROCEDURAL_OPTIMIZATION True)
endif() endif()
# Install the library install(TARGETS slsSupportShared slsSupportStatic slsSupportObject
install(TARGETS slsSupportLib slsSupportLibStatic slsSupportObject
EXPORT "${TARGETS_EXPORT_NAME}" EXPORT "${TARGETS_EXPORT_NAME}"
LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR} ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}

View File

@ -8,12 +8,12 @@ set(SLS_TEST_SOURCES
) )
add_executable(testclient src/testclient.cpp) add_executable(testclient src/testclient.cpp)
target_link_libraries(testclient slsSupportLib) target_link_libraries(testclient slsSupportShared)
set_target_properties(testclient PROPERTIES set_target_properties(testclient PROPERTIES
RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin) RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin)
add_executable(testserver src/testserver.cpp) add_executable(testserver src/testserver.cpp)
target_link_libraries(testserver slsSupportLib) target_link_libraries(testserver slsSupportShared)
set_target_properties(testserver PROPERTIES set_target_properties(testserver PROPERTIES
RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin) RUNTIME_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}/bin)
@ -21,7 +21,7 @@ add_executable(tests ${SLS_TEST_SOURCES})
target_link_libraries(tests target_link_libraries(tests
slsProjectOptions slsProjectOptions
slsProjectWarnings slsProjectWarnings
slsSupportLib slsSupportShared
pthread pthread
rt rt
) )