X-Git-Url: http://review.tizen.org/git/?p=platform%2Fupstream%2Flibzypp.git;a=blobdiff_plain;f=CMakeLists.txt;h=1c018ec499b613e0500c28415fce9999bd4930de;hp=7711a9bdd021c2985a145a90dbfc79e33e4ab406;hb=HEAD;hpb=42b5d038414cf4a4a050e816b471f890b24e8032 diff --git a/CMakeLists.txt b/CMakeLists.txt index 7711a9b..1245837 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,16 +1,20 @@ +cmake_minimum_required(VERSION 3.1) PROJECT(LIBZYPP) SET( PACKAGE "libzypp" ) # where to look first for cmake modules, before ${CMAKE_ROOT}/Modules/ is checked SET( CMAKE_MODULE_PATH ${LIBZYPP_SOURCE_DIR}/cmake/modules ) -cmake_minimum_required(VERSION 2.6) +INCLUDE(ZyppCommon) OPTION (ENABLE_BUILD_DOCS "Build documentation by default?" OFF) OPTION (ENABLE_BUILD_TRANS "Build translation files by default?" OFF) OPTION (ENABLE_BUILD_TESTS "Build and run test suite by default?" OFF) OPTION (ENABLE_USE_THREADS "Enable using threads (NOT being used by threads!)?" OFF) +OPTION (ENABLE_ZCHUNK_COMPRESSION "Build with zchunk compression support?" OFF) +OPTION (DISABLE_MEDIABACKEND_TESTS "Disable Tests depending on Nginx and libfcgi?" OFF) OPTION (DISABLE_LIBPROXY "Build without libproxy support even if package is installed?" OFF) OPTION (DISABLE_AUTODOCS "Do not require doxygen being installed (required to build autodocs)?" OFF) +OPTION (EXPORT_NG_API "Export experimental libzypp API" OFF) #-------------------------------------------------------------------------------- SET (have_system x) @@ -37,25 +41,28 @@ if(COMMAND cmake_policy) cmake_policy(SET CMP0003 NEW) endif(COMMAND cmake_policy) -INCLUDE(ZyppCommon) +find_package(FindPkgConfig) INCLUDE( ${LIBZYPP_SOURCE_DIR}/VERSION.cmake ) +MATH( EXPR LIBZYPP_NUMVERSION "${LIBZYPP_MAJOR} * 10000 + ${LIBZYPP_MINOR} * 100 + ${LIBZYPP_PATCH}" ) MATH( EXPR LIBZYPP_CURRENT "${LIBZYPP_MAJOR} * 100 + ${LIBZYPP_MINOR}" ) MATH( EXPR LIBZYPP_AGE "${LIBZYPP_MINOR} - ${LIBZYPP_COMPATMINOR}" ) # Libtool wanted current:patch:age # But cmake is not libtool, it wants the verbatim suffix to libzypp.so MATH( EXPR LIBZYPP_SO_FIRST "${LIBZYPP_CURRENT}-${LIBZYPP_AGE}" ) SET( VERSION "${LIBZYPP_MAJOR}.${LIBZYPP_MINOR}.${LIBZYPP_PATCH}" ) +CONFIGURE_FILE ( zypp/APIConfig.h.in zypp/APIConfig.h ) +SET (CMAKE_CXX_STANDARD ${ZYPPCOMMON_CXX_STANDARD}) include(CheckCCompilerFlag) include(CheckCXXCompilerFlag) CHECK_C_COMPILER_FLAG("-Werror=format-security" CC_FORMAT_SECURITY) CHECK_CXX_COMPILER_FLAG("-Werror=format-security" CXX_FORMAT_SECURITY) -SET( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fno-strict-aliasing -fPIC -g -rdynamic -Wall -Wl,-as-needed" ) -SET( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fno-strict-aliasing -fPIC -g -rdynamic -Wall -Wl,-as-needed" ) +SET( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fno-strict-aliasing -fPIC -g -Wall -Wp,-D_GLIBCXX_ASSERTIONS" ) +SET( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fno-strict-aliasing -fPIC -g -Wall -Wp,-D_GLIBCXX_ASSERTIONS" ) -SET( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -std=c++11 -fvisibility-inlines-hidden -Woverloaded-virtual -Wnon-virtual-dtor" ) +SET( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fvisibility-inlines-hidden -Woverloaded-virtual -Wnon-virtual-dtor" ) set( CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS} -O3 -DZYPP_NDEBUG" ) set( CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS} -O3 -DZYPP_NDEBUG" ) @@ -68,6 +75,12 @@ IF(${CXX_FORMAT_SECURITY}) SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Werror=format-security") ENDIF(${CXX_FORMAT_SECURITY}) +if ( NOT "${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang") + #cli args ignored by clang, it still prints a noisy warning though + SET( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -rdynamic -Wl,-as-needed" ) + SET( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -rdynamic -Wl,-as-needed" ) +endif() + INCLUDE(CheckFunctionExists) CHECK_FUNCTION_EXISTS(pipe2 PIPE2_FOUND) IF(${PIPE2_FOUND}) @@ -75,7 +88,6 @@ IF(${PIPE2_FOUND}) ENDIF(${PIPE2_FOUND}) ADD_DEFINITIONS( -D_FILE_OFFSET_BITS=64 ) -ADD_DEFINITIONS( -DVERSION="${VERSION}" ) SET( LIBZYPP_VERSION_INFO "${LIBZYPP_SO_FIRST}.${LIBZYPP_AGE}.${LIBZYPP_PATCH}" ) SET( LIBZYPP_SOVERSION_INFO "${LIBZYPP_SO_FIRST}" ) @@ -87,14 +99,18 @@ MACRO(ADD_TESTS) FOREACH( loop_var ${ARGV} ) SET_SOURCE_FILES_PROPERTIES( ${loop_var}_test.cc COMPILE_FLAGS "-DBOOST_TEST_DYN_LINK -DBOOST_TEST_MAIN -DBOOST_AUTO_TEST_MAIN=\"\" " ) ADD_EXECUTABLE( ${loop_var}_test ${loop_var}_test.cc ) - TARGET_LINK_LIBRARIES( ${loop_var}_test zypp ${Boost_UNIT_TEST_FRAMEWORK_LIBRARY} zypp_test_utils) + + SET(TEST_REQ_LIBS zypp-allsym ${Boost_UNIT_TEST_FRAMEWORK_LIBRARY} ) + IF(NOT DISABLE_MEDIABACKEND_TESTS) + LIST( APPEND TEST_REQ_LIBS zypp_test_utils) + ENDIF() + + TARGET_LINK_LIBRARIES( ${loop_var}_test ${TEST_REQ_LIBS} ) ADD_TEST( ${loop_var}_test ${CMAKE_CURRENT_BINARY_DIR}/${loop_var}_test --catch_system_errors=no) ENDFOREACH( loop_var ) ENDMACRO(ADD_TESTS) #################################################################### -# prefer packages using the same install prefix as we do -SET(CMAKE_PREFIX_PATH ${CMAKE_INSTALL_PREFIX} usr/localX /usr/local /usr) IF ( ENABLE_USE_THREADS ) SET( CMAKE_THREAD_PREFER_PTHREAD TRUE ) @@ -106,6 +122,7 @@ IF ( ENABLE_USE_THREADS ) ENDIF ( CMAKE_USE_PTHREADS_INIT ) ENDIF ( ENABLE_USE_THREADS ) +INCLUDE(CheckSymbolExists) FIND_PACKAGE(Rpm REQUIRED) IF ( NOT RPM_FOUND) MESSAGE( FATAL_ERROR " rpm-devel not found" ) @@ -113,19 +130,22 @@ ELSE ( NOT RPM_FOUND) INCLUDE_DIRECTORIES(${RPM_INCLUDE_DIR}) # fix includes not relative to rpm INCLUDE_DIRECTORIES(${RPM_INCLUDE_DIR}/rpm) + + # rpmtsSetVfyFlags were introduced in rpm-4.15 + UNSET( RPMTSSETVFYFLAGS_FOUND CACHE ) + SET( CMAKE_REQUIRED_LIBRARIES "-lrpm" ) + CHECK_SYMBOL_EXISTS( rpmtsSetVfyFlags rpm/rpmts.h RPMTSSETVFYFLAGS_FOUND ) + IF ( NOT RPMTSSETVFYFLAGS_FOUND ) + ADD_DEFINITIONS( -DHAVE_NO_RPMTSSETVFYFLAGS ) + ENDIF () + if ( RPM_SUSPECT_VERSION STREQUAL "5.x" ) MESSAGE( STATUS "rpm found: enable rpm-4 compat interface." ) ADD_DEFINITIONS(-D_RPM_5) - elseif ( RPM_SUSPECT_VERSION STREQUAL "4.x" ) - MESSAGE( STATUS "rpm found: use rpm-4.x interface." ) - ADD_DEFINITIONS(-D_RPM_4_X) - elseif ( RPM_SUSPECT_VERSION STREQUAL "4.4" ) - MESSAGE( STATUS "rpm found: enable rpm-4.4 legacy interface." ) - ADD_DEFINITIONS(-D_RPM_4_4) endif ( RPM_SUSPECT_VERSION STREQUAL "5.x" ) ENDIF( NOT RPM_FOUND) -FIND_PACKAGE(Boost REQUIRED COMPONENTS program_options unit_test_framework) +FIND_PACKAGE(Boost REQUIRED COMPONENTS program_options unit_test_framework thread) IF (Boost_FOUND) MESSAGE( STATUS "boost found: includes in ${Boost_INCLUDE_DIRS}, library in ${Boost_LIBRARY_DIRS}") INCLUDE_DIRECTORIES(${Boost_INCLUDE_DIRS}) @@ -161,35 +181,45 @@ ELSE ( NOT ZLIB_FOUND) INCLUDE_DIRECTORIES(${ZLIB_INCLUDE_DIR}) ENDIF( NOT ZLIB_FOUND) -#SET(LibSolv_USE_STATIC_LIBS ON) -FIND_PACKAGE(LibSolv REQUIRED ext) -IF ( NOT LibSolv_FOUND ) - MESSAGE( FATAL_ERROR " libsolv not found" ) + +#Allow to override the libsolv install location +IF( LIBSOLV_SRCDIR AND LIBSOLV_BUILDDIR ) + execute_process( + COMMAND ${CMAKE_COMMAND} -E make_directory ${CMAKE_BINARY_DIR}/libsolv + COMMAND ${CMAKE_COMMAND} -E make_directory ${CMAKE_BINARY_DIR}/libsolv/include + COMMAND ${CMAKE_COMMAND} -E make_directory ${CMAKE_BINARY_DIR}/libsolv/ext + COMMAND ${CMAKE_COMMAND} -E make_directory ${CMAKE_BINARY_DIR}/libsolv/solvversion + COMMAND ${CMAKE_COMMAND} -E create_symlink ${LIBSOLV_SRCDIR}/src ${CMAKE_BINARY_DIR}/libsolv/include/solv + COMMAND ${CMAKE_COMMAND} -E create_symlink ${LIBSOLV_SRCDIR}/ext ${CMAKE_BINARY_DIR}/libsolv/ext/solv + COMMAND ${CMAKE_COMMAND} -E create_symlink ${LIBSOLV_BUILDDIR}/src ${CMAKE_BINARY_DIR}/libsolv/solvversion/solv + ) + + INCLUDE_DIRECTORIES( ${CMAKE_BINARY_DIR}/libsolv/include ${CMAKE_BINARY_DIR}/libsolv/ext ${CMAKE_BINARY_DIR}/libsolv/solvversion ${CMAKE_BINARY_DIR}/libsolv/solvversion/solv ${CMAKE_BINARY_DIR}/libsolv/ext/solv ${CMAKE_BINARY_DIR}/libsolv/include/solv ) + SET( LibSolv_LIBRARIES ${LIBSOLV_BUILDDIR}/src/libsolv.a ${LIBSOLV_BUILDDIR}/ext/libsolvext.a ) + ELSE() - INCLUDE_DIRECTORIES( ${LibSolv_INCLUDE_DIRS} ) + FIND_PACKAGE(LibSolv REQUIRED ext) + #SET(LibSolv_USE_STATIC_LIBS ON) + IF ( NOT LibSolv_FOUND ) + MESSAGE( FATAL_ERROR " libsolv not found" ) + ELSE() + INCLUDE_DIRECTORIES( ${LibSolv_INCLUDE_DIRS} ) + ENDIF() +ENDIF( LIBSOLV_SRCDIR AND LIBSOLV_BUILDDIR ) + +FIND_PACKAGE(Gpgme REQUIRED) +IF ( NOT GPGME_PTHREAD_FOUND ) + MESSAGE( FATAL_ERROR " gpgme not found" ) +ELSE() + INCLUDE_DIRECTORIES( ${GPGME_INCLUDES} ) + LINK_DIRECTORIES(${GPGME_LIBRARY_DIR}) ENDIF() -# libsolv uses expat and has open references to it: -FIND_PACKAGE(EXPAT REQUIRED) - FIND_PACKAGE(OpenSSL REQUIRED) FIND_PACKAGE(Udev) IF ( NOT UDEV_FOUND ) - FIND_PACKAGE(Hal) - IF ( NOT HAL_FOUND ) - MESSAGE(WARNING "No udev or HAL. CD device detection will be poor") - ELSE ( NOT HAL_FOUND ) - ADD_DEFINITIONS(-DHAVE_HAL) - INCLUDE_DIRECTORIES(${HAL_INCLUDE_DIR}) - INCLUDE_DIRECTORIES(${HAL_INCLUDE_DIR}/hal) - # HAL requires working dbus - FIND_PACKAGE(Dbus REQUIRED) - IF(DBUS_FOUND) - INCLUDE_DIRECTORIES(${DBUS_INCLUDE_DIR}) - INCLUDE_DIRECTORIES(${DBUS_ARCH_INCLUDE_DIR}) - ENDIF(DBUS_FOUND) - ENDIF ( NOT HAL_FOUND ) + MESSAGE(WARNING "No udev found. CD device detection will be poor") ELSE ( NOT UDEV_FOUND ) ADD_DEFINITIONS(-DHAVE_UDEV) ENDIF ( NOT UDEV_FOUND ) @@ -217,6 +247,20 @@ ELSE ( NOT DOXYGEN ) MESSAGE( STATUS "doxygen found: ${DOXYGEN}" ) ENDIF ( NOT DOXYGEN ) +IF (ENABLE_ZCHUNK_COMPRESSION) + MESSAGE("Building with zchunk support enabled.") + PKG_CHECK_MODULES (ZCHUNK zck REQUIRED) + SET( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${ZCHUNK_CFLAGS}" ) + SET( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${ZCHUNK_CFLAGS}" ) + ADD_DEFINITIONS (-DENABLE_ZCHUNK_COMPRESSION=1) +ENDIF(ENABLE_ZCHUNK_COMPRESSION) + +pkg_check_modules ( SIGCPP REQUIRED sigc++-2.0 ) +INCLUDE_DIRECTORIES( ${SIGCPP_INCLUDE_DIRS} ) + +pkg_check_modules ( LIBGLIB REQUIRED glib-2.0 ) +INCLUDE_DIRECTORIES( ${LIBGLIB_INCLUDE_DIRS} ) + MESSAGE(STATUS "soname: ${LIBZYPP_VERSION_INFO}") MESSAGE(STATUS "version: ${VERSION}") @@ -236,6 +280,9 @@ INSTALL( FILES ${LIBZYPP_SOURCE_DIR}/cmake/modules/ZyppCommon.cmake DESTINATION MESSAGE(STATUS "zypp.conf will be installed in ${SYSCONFDIR}/zypp") INSTALL( FILES ${LIBZYPP_SOURCE_DIR}/zypp.conf DESTINATION ${SYSCONFDIR}/zypp ) +MESSAGE(STATUS "needreboot will be installed in ${SYSCONFDIR}/zypp/") +INSTALL( FILES ${LIBZYPP_SOURCE_DIR}/needreboot DESTINATION ${SYSCONFDIR}/zypp ) + #install systemCheck MESSAGE(STATUS "systemCheck will be installed in ${SYSCONFDIR}/zypp") INSTALL( FILES ${LIBZYPP_SOURCE_DIR}/systemCheck DESTINATION ${SYSCONFDIR}/zypp ) @@ -252,7 +299,6 @@ ADD_SUBDIRECTORY( zypp ) ADD_SUBDIRECTORY( devel EXCLUDE_FROM_ALL ) ADD_SUBDIRECTORY( tools ) ADD_SUBDIRECTORY( doc ) -ADD_SUBDIRECTORY( vendor ) IF ( ENABLE_BUILD_TRANS ) ADD_SUBDIRECTORY( po )