mirror of
https://github.com/pocoproject/poco.git
synced 2024-12-16 19:54:38 +01:00
Improve CMake handling of MD and MT
- Some other minor improvements Contributed-by: Torndeco <torndeco.di@gmail.com>
This commit is contained in:
parent
2d5b37232b
commit
6fb5ecca03
@ -6,10 +6,10 @@
|
|||||||
# ENABLE_{COMPONENT}
|
# ENABLE_{COMPONENT}
|
||||||
# ENABLE_TESTS
|
# ENABLE_TESTS
|
||||||
|
|
||||||
project(Poco)
|
|
||||||
|
|
||||||
cmake_minimum_required(VERSION 3.0.0)
|
cmake_minimum_required(VERSION 3.0.0)
|
||||||
|
|
||||||
|
project(Poco)
|
||||||
|
|
||||||
file(STRINGS "${PROJECT_SOURCE_DIR}/libversion" SHARED_LIBRARY_VERSION)
|
file(STRINGS "${PROJECT_SOURCE_DIR}/libversion" SHARED_LIBRARY_VERSION)
|
||||||
|
|
||||||
# Read the version information from the VERSION file
|
# Read the version information from the VERSION file
|
||||||
@ -53,19 +53,6 @@ if (CMAKE_BUILD_TYPE STREQUAL "")
|
|||||||
set( CMAKE_BUILD_TYPE "RelWithDebInfo" )
|
set( CMAKE_BUILD_TYPE "RelWithDebInfo" )
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# http://www.cmake.org/Wiki/CMake_Useful_Variables :
|
|
||||||
# CMAKE_BUILD_TYPE
|
|
||||||
# Choose the type of build. CMake has default flags for these:
|
|
||||||
#
|
|
||||||
# * None (CMAKE_C_FLAGS or CMAKE_CXX_FLAGS used)
|
|
||||||
# * Debug (CMAKE_C_FLAGS_DEBUG or CMAKE_CXX_FLAGS_DEBUG)
|
|
||||||
# * Release (CMAKE_C_FLAGS_RELEASE or CMAKE_CXX_FLAGS_RELEASE)
|
|
||||||
# * RelWithDebInfo (CMAKE_C_FLAGS_RELWITHDEBINFO or CMAKE_CXX_FLAGS_RELWITHDEBINFO
|
|
||||||
# * MinSizeRel (CMAKE_C_FLAGS_MINSIZEREL or CMAKE_CXX_FLAGS_MINSIZEREL)
|
|
||||||
|
|
||||||
# For Debug build types, append a "d" to the library names.
|
|
||||||
set(CMAKE_DEBUG_POSTFIX "d" CACHE STRING "Set debug library postfix" FORCE)
|
|
||||||
|
|
||||||
# Include some common macros to simpilfy the Poco CMake files
|
# Include some common macros to simpilfy the Poco CMake files
|
||||||
include(PocoMacros)
|
include(PocoMacros)
|
||||||
|
|
||||||
@ -102,7 +89,12 @@ option(POCO_STATIC
|
|||||||
option(POCO_UNBUNDLED
|
option(POCO_UNBUNDLED
|
||||||
"Set to OFF|ON (default is OFF) to control linking dependencies as external" OFF)
|
"Set to OFF|ON (default is OFF) to control linking dependencies as external" OFF)
|
||||||
|
|
||||||
# Uncomment from next two lines to force statitc or dynamic library, default is autodetection
|
if(MSVC)
|
||||||
|
option(POCO_MT
|
||||||
|
"Set to OFF|ON (default is OFF) to control build of POCO as /MT instead of /MD" OFF)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# Uncomment from next two lines to force static or dynamic library, default is autodetection
|
||||||
if(POCO_STATIC)
|
if(POCO_STATIC)
|
||||||
add_definitions( -DPOCO_STATIC -DPOCO_NO_AUTOMATIC_LIBS)
|
add_definitions( -DPOCO_STATIC -DPOCO_NO_AUTOMATIC_LIBS)
|
||||||
set( LIB_MODE STATIC )
|
set( LIB_MODE STATIC )
|
||||||
@ -127,58 +119,7 @@ else ()
|
|||||||
message(STATUS "Build with using internal copy of sqlite, libz, pcre, expat, ...")
|
message(STATUS "Build with using internal copy of sqlite, libz, pcre, expat, ...")
|
||||||
endif ()
|
endif ()
|
||||||
|
|
||||||
include(CheckTypeSize)
|
include(DefinePlatformSpecifc)
|
||||||
find_package(Cygwin)
|
|
||||||
|
|
||||||
# OS Detection
|
|
||||||
if(WIN32)
|
|
||||||
add_definitions( -DPOCO_OS_FAMILY_WINDOWS -DUNICODE -D_UNICODE)
|
|
||||||
#set(SYSLIBS iphlpapi gdi32 odbc32)
|
|
||||||
endif(WIN32)
|
|
||||||
|
|
||||||
if (UNIX AND NOT ANDROID )
|
|
||||||
add_definitions( -DPOCO_OS_FAMILY_UNIX )
|
|
||||||
# Standard 'must be' defines
|
|
||||||
if (APPLE)
|
|
||||||
add_definitions( -DPOCO_HAVE_IPv6 -DPOCO_NO_STAT64)
|
|
||||||
set(SYSLIBS dl)
|
|
||||||
else (APPLE)
|
|
||||||
add_definitions( -D_XOPEN_SOURCE=500 -D_REENTRANT -D_THREAD_SAFE -D_LARGEFILE64_SOURCE -D_FILE_OFFSET_BITS=64)
|
|
||||||
set(SYSLIBS pthread dl rt)
|
|
||||||
endif (APPLE)
|
|
||||||
endif(UNIX AND NOT ANDROID )
|
|
||||||
|
|
||||||
if (CMAKE_SYSTEM MATCHES "SunOS")
|
|
||||||
add_definitions( -DPOCO_OS_FAMILY_UNIX )
|
|
||||||
# Standard 'must be' defines
|
|
||||||
add_definitions( -D_XOPEN_SOURCE=500 -D_REENTRANT -D_THREAD_SAFE -D_LARGEFILE64_SOURCE -D_FILE_OFFSET_BITS=64 )
|
|
||||||
set(SYSLIBS pthread socket xnet nsl resolv rt dl)
|
|
||||||
endif(CMAKE_SYSTEM MATCHES "SunOS")
|
|
||||||
|
|
||||||
if (CMAKE_COMPILER_IS_MINGW)
|
|
||||||
add_definitions(-DWC_NO_BEST_FIT_CHARS=0x400 -DPOCO_WIN32_UTF8)
|
|
||||||
add_definitions(-D_WIN32 -DMINGW32 -DWINVER=0x500 -DODBCVER=0x0300 -DPOCO_THREAD_STACK_SIZE)
|
|
||||||
endif (CMAKE_COMPILER_IS_MINGW)
|
|
||||||
|
|
||||||
if (CYGWIN)
|
|
||||||
# add_definitions(-DWC_NO_BEST_FIT_CHARS=0x400 -DPOCO_WIN32_UTF8)
|
|
||||||
endif (CYGWIN)
|
|
||||||
|
|
||||||
# SunPro C++
|
|
||||||
if (${CMAKE_CXX_COMPILER_ID} MATCHES "SunPro")
|
|
||||||
add_definitions( -D_BSD_SOURCE -library=stlport4)
|
|
||||||
endif (${CMAKE_CXX_COMPILER_ID} MATCHES "SunPro")
|
|
||||||
|
|
||||||
# iOS
|
|
||||||
if (IOS)
|
|
||||||
add_definitions( -DPOCO_HAVE_IPv6 -DPOCO_NO_FPENVIRONMENT -DPOCO_NO_STAT64 -DPOCO_NO_SHAREDLIBS -DPOCO_NO_NET_IFTYPES )
|
|
||||||
endif(IOS)
|
|
||||||
|
|
||||||
#Android
|
|
||||||
if (ANDROID)
|
|
||||||
add_definitions( -DPOCO_ANDROID -DPOCO_NO_FPENVIRONMENT -DPOCO_NO_WSTRING -DPOCO_NO_SHAREDMEMORY )
|
|
||||||
endif(ANDROID)
|
|
||||||
|
|
||||||
|
|
||||||
# Collect the built libraries and include dirs, the will be used to create the PocoConfig.cmake file
|
# Collect the built libraries and include dirs, the will be used to create the PocoConfig.cmake file
|
||||||
set(Poco_COMPONENTS "")
|
set(Poco_COMPONENTS "")
|
||||||
@ -330,7 +271,17 @@ message(STATUS "CMake ${CMAKE_VERSION} successfully configured ${PROJECT_NAME} u
|
|||||||
message(STATUS "Installation target path: ${CMAKE_INSTALL_PREFIX}")
|
message(STATUS "Installation target path: ${CMAKE_INSTALL_PREFIX}")
|
||||||
|
|
||||||
message(STATUS "C_FLAGS: =${CMAKE_C_FLAGS}")
|
message(STATUS "C_FLAGS: =${CMAKE_C_FLAGS}")
|
||||||
|
message(STATUS "CMAKE_C_FLAGS_DEBUG:=${CMAKE_C_FLAGS_DEBUG}")
|
||||||
|
message(STATUS "CMAKE_C_FLAGS_RELEASE:=${CMAKE_C_FLAGS_RELEASE}")
|
||||||
|
message(STATUS "CMAKE_C_FLAGS_MINSIZEREL:=${CMAKE_C_FLAGS_MINSIZEREL}")
|
||||||
|
message(STATUS "CMAKE_C_FLAGS_RELWITHDEBINFO:=${CMAKE_C_FLAGS_RELWITHDEBINFO}")
|
||||||
|
message(STATUS "")
|
||||||
|
message(STATUS "")
|
||||||
message(STATUS "CXX_FLAGS:=${CMAKE_CXX_FLAGS}")
|
message(STATUS "CXX_FLAGS:=${CMAKE_CXX_FLAGS}")
|
||||||
|
message(STATUS "CMAKE_CXX_FLAGS_DEBUG:=${CMAKE_CXX_FLAGS_DEBUG}")
|
||||||
|
message(STATUS "CMAKE_CXX_FLAGS_RELEASE:=${CMAKE_CXX_FLAGS_RELEASE}")
|
||||||
|
message(STATUS "CMAKE_CXX_FLAGS_MINSIZEREL:=${CMAKE_CXX_FLAGS_MINSIZEREL}")
|
||||||
|
message(STATUS "CMAKE_CXX_FLAGS_RELWITHDEBINFO:=${CMAKE_CXX_FLAGS_RELWITHDEBINFO}")
|
||||||
|
|
||||||
foreach(component ${Poco_COMPONENTS})
|
foreach(component ${Poco_COMPONENTS})
|
||||||
message(STATUS "Building: ${component}")
|
message(STATUS "Building: ${component}")
|
||||||
|
111
cmake/DefinePlatformSpecifc.cmake
Normal file
111
cmake/DefinePlatformSpecifc.cmake
Normal file
@ -0,0 +1,111 @@
|
|||||||
|
# http://www.cmake.org/Wiki/CMake_Useful_Variables :
|
||||||
|
# CMAKE_BUILD_TYPE
|
||||||
|
# Choose the type of build. CMake has default flags for these:
|
||||||
|
#
|
||||||
|
# * None (CMAKE_C_FLAGS or CMAKE_CXX_FLAGS used)
|
||||||
|
# * Debug (CMAKE_C_FLAGS_DEBUG or CMAKE_CXX_FLAGS_DEBUG)
|
||||||
|
# * Release (CMAKE_C_FLAGS_RELEASE or CMAKE_CXX_FLAGS_RELEASE)
|
||||||
|
# * RelWithDebInfo (CMAKE_C_FLAGS_RELWITHDEBINFO or CMAKE_CXX_FLAGS_RELWITHDEBINFO
|
||||||
|
# * MinSizeRel (CMAKE_C_FLAGS_MINSIZEREL or CMAKE_CXX_FLAGS_MINSIZEREL)
|
||||||
|
|
||||||
|
# Setting CXX Flag /MD or /MT and POSTFIX values i.e MDd / MD / MTd / MT / d
|
||||||
|
#
|
||||||
|
# For visual studio the library naming is as following:
|
||||||
|
# Dynamic libraries:
|
||||||
|
# - PocoX.dll for release library
|
||||||
|
# - PocoXd.dll for debug library
|
||||||
|
#
|
||||||
|
# Static libraries:
|
||||||
|
# - PocoXmd.lib for /MD release build
|
||||||
|
# - PocoXtmt.lib for /MT release build
|
||||||
|
#
|
||||||
|
# - PocoXmdd.lib for /MD debug build
|
||||||
|
# - PocoXmtd.lib for /MT debug build
|
||||||
|
|
||||||
|
if(MSVC)
|
||||||
|
if(POCO_MT)
|
||||||
|
set(CompilerFlags
|
||||||
|
CMAKE_CXX_FLAGS
|
||||||
|
CMAKE_CXX_FLAGS_DEBUG
|
||||||
|
CMAKE_CXX_FLAGS_RELEASE
|
||||||
|
CMAKE_C_FLAGS
|
||||||
|
CMAKE_C_FLAGS_DEBUG
|
||||||
|
CMAKE_C_FLAGS_RELEASE
|
||||||
|
)
|
||||||
|
foreach(CompilerFlag ${CompilerFlags})
|
||||||
|
string(REPLACE "/MD" "/MT" ${CompilerFlag} "${${CompilerFlag}}")
|
||||||
|
endforeach()
|
||||||
|
|
||||||
|
set(STATIC_POSTFIX "mt" CACHE STRING "Set static library postfix" FORCE)
|
||||||
|
else(POCO_MT)
|
||||||
|
set(STATIC_POSTFIX "md" CACHE STRING "Set static library postfix" FORCE)
|
||||||
|
endif(POCO_MT)
|
||||||
|
|
||||||
|
if(POCO_STATIC)
|
||||||
|
set(CMAKE_DEBUG_POSTFIX "${STATIC_POSTFIX}d" CACHE STRING "Set Debug library postfix" FORCE)
|
||||||
|
set(CMAKE_RELEASE_POSTFIX "${STATIC_POSTFIX}" CACHE STRING "Set Release library postfix" FORCE)
|
||||||
|
set(CMAKE_MINSIZEREL_POSTFIX "${STATIC_POSTFIX}" CACHE STRING "Set MinSizeRel library postfix" FORCE)
|
||||||
|
set(CMAKE_RELWITHDEBINFO_POSTFIX "${STATIC_POSTFIX}d" CACHE STRING "Set RelWithDebInfo library postfix" FORCE)
|
||||||
|
else(POCO_STATIC)
|
||||||
|
set(CMAKE_DEBUG_POSTFIX "d" CACHE STRING "Set Debug library postfix" FORCE)
|
||||||
|
set(CMAKE_RELEASE_POSTFIX "" CACHE STRING "Set Release library postfix" FORCE)
|
||||||
|
set(CMAKE_MINSIZEREL_POSTFIX "" CACHE STRING "Set MinSizeRel library postfix" FORCE)
|
||||||
|
set(CMAKE_RELWITHDEBINFO_POSTFIX "d" CACHE STRING "Set RelWithDebInfo library postfix" FORCE)
|
||||||
|
endif()
|
||||||
|
endif(MSVC)
|
||||||
|
|
||||||
|
|
||||||
|
# OS Detection
|
||||||
|
include(CheckTypeSize)
|
||||||
|
find_package(Cygwin)
|
||||||
|
|
||||||
|
if(WIN32)
|
||||||
|
add_definitions( -DPOCO_OS_FAMILY_WINDOWS -DUNICODE -D_UNICODE -D__LCC__) #__LCC__ define used by MySQL.h
|
||||||
|
set(SYSLIBS ${SYSLIBS} gdi32)
|
||||||
|
if(ENABLE_DATA_ODBC)
|
||||||
|
set(SYSLIBS ${SYSLIBS} odbc32)
|
||||||
|
endif(ENABLE_DATA_ODBC)
|
||||||
|
endif(WIN32)
|
||||||
|
|
||||||
|
if (UNIX AND NOT ANDROID )
|
||||||
|
add_definitions( -DPOCO_OS_FAMILY_UNIX )
|
||||||
|
# Standard 'must be' defines
|
||||||
|
if (APPLE)
|
||||||
|
add_definitions( -DPOCO_HAVE_IPv6 -DPOCO_NO_STAT64)
|
||||||
|
set(SYSLIBS dl)
|
||||||
|
else (APPLE)
|
||||||
|
add_definitions( -D_XOPEN_SOURCE=500 -D_REENTRANT -D_THREAD_SAFE -D_LARGEFILE64_SOURCE -D_FILE_OFFSET_BITS=64)
|
||||||
|
set(SYSLIBS pthread dl rt)
|
||||||
|
endif (APPLE)
|
||||||
|
endif(UNIX AND NOT ANDROID )
|
||||||
|
|
||||||
|
if (CMAKE_SYSTEM MATCHES "SunOS")
|
||||||
|
add_definitions( -DPOCO_OS_FAMILY_UNIX )
|
||||||
|
# Standard 'must be' defines
|
||||||
|
add_definitions( -D_XOPEN_SOURCE=500 -D_REENTRANT -D_THREAD_SAFE -D_LARGEFILE64_SOURCE -D_FILE_OFFSET_BITS=64 )
|
||||||
|
set(SYSLIBS pthread socket xnet nsl resolv rt dl)
|
||||||
|
endif(CMAKE_SYSTEM MATCHES "SunOS")
|
||||||
|
|
||||||
|
if (CMAKE_COMPILER_IS_MINGW)
|
||||||
|
add_definitions(-DWC_NO_BEST_FIT_CHARS=0x400 -DPOCO_WIN32_UTF8)
|
||||||
|
add_definitions(-D_WIN32 -DMINGW32 -DWINVER=0x500 -DODBCVER=0x0300 -DPOCO_THREAD_STACK_SIZE)
|
||||||
|
endif (CMAKE_COMPILER_IS_MINGW)
|
||||||
|
|
||||||
|
if (CYGWIN)
|
||||||
|
# add_definitions(-DWC_NO_BEST_FIT_CHARS=0x400 -DPOCO_WIN32_UTF8)
|
||||||
|
endif (CYGWIN)
|
||||||
|
|
||||||
|
# SunPro C++
|
||||||
|
if (${CMAKE_CXX_COMPILER_ID} MATCHES "SunPro")
|
||||||
|
add_definitions( -D_BSD_SOURCE -library=stlport4)
|
||||||
|
endif (${CMAKE_CXX_COMPILER_ID} MATCHES "SunPro")
|
||||||
|
|
||||||
|
# iOS
|
||||||
|
if (IOS)
|
||||||
|
add_definitions( -DPOCO_HAVE_IPv6 -DPOCO_NO_FPENVIRONMENT -DPOCO_NO_STAT64 -DPOCO_NO_SHAREDLIBS -DPOCO_NO_NET_IFTYPES )
|
||||||
|
endif(IOS)
|
||||||
|
|
||||||
|
#Android
|
||||||
|
if (ANDROID)
|
||||||
|
add_definitions( -DPOCO_ANDROID -DPOCO_NO_FPENVIRONMENT -DPOCO_NO_WSTRING -DPOCO_NO_SHAREDMEMORY )
|
||||||
|
endif(ANDROID)
|
Loading…
Reference in New Issue
Block a user