X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=CMakeLists.txt;h=fffec8f5de48b6d8d5fb6fda3c621edc0a00d34b;hb=920f56c87430fd547bd2faf0f26c36677b7f9854;hp=b4d97dcb35d199fe912df84a7579487ef8d08043;hpb=1c6a381922c8a1e4d0ef9fb480edb35b38484252;p=platform%2Fupstream%2Flibzypp.git diff --git a/CMakeLists.txt b/CMakeLists.txt index b4d97dc..fffec8f 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,10 +1,17 @@ -PROJECT(libzypp) +PROJECT(LIBZYPP) SET( PACKAGE "libzypp" ) # where to look first for cmake modules, before ${CMAKE_ROOT}/Modules/ is checked -SET( CMAKE_MODULE_PATH ${CMAKE_SOURCE_DIR}/cmake/modules ) +SET( CMAKE_MODULE_PATH ${LIBZYPP_SOURCE_DIR}/cmake/modules ) +cmake_minimum_required(VERSION 2.6) + +# allow name libraries by name mixed with full +# paths +if(COMMAND cmake_policy) + cmake_policy(SET CMP0003 NEW) +endif(COMMAND cmake_policy) INCLUDE(ZyppCommon) -INCLUDE( ${CMAKE_SOURCE_DIR}/VERSION.cmake ) +INCLUDE( ${LIBZYPP_SOURCE_DIR}/VERSION.cmake ) MATH( EXPR LIBZYPP_CURRENT "${LIBZYPP_MAJOR} * 100 + ${LIBZYPP_MINOR}" ) MATH( EXPR LIBZYPP_AGE "${LIBZYPP_MINOR} - ${LIBZYPP_COMPATMINOR}" ) @@ -13,10 +20,13 @@ MATH( EXPR LIBZYPP_AGE "${LIBZYPP_MINOR} - ${LIBZYPP_COMPATMINOR}" ) MATH( EXPR LIBZYPP_SO_FIRST "${LIBZYPP_CURRENT}-${LIBZYPP_AGE}" ) SET( VERSION "${LIBZYPP_MAJOR}.${LIBZYPP_MINOR}.${LIBZYPP_PATCH}" ) -SET( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -g -O3 -Wall -Woverloaded-virtual" ) -SET( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -g -O3 -Wall" ) +SET( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -fno-strict-aliasing -fPIC -g -Wall -Werror=format-security -Woverloaded-virtual -Wnon-virtual-dtor -Wl,-as-needed" ) +SET( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fno-strict-aliasing -fPIC -g -Wall -Werror=format-security -Wl,-as-needed" ) +set( CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS} -O3" ) +set( CMAKE_CXX_FLAGS_RELEASE "${CMAKE_CXX_FLAGS} -O3" ) + ADD_DEFINITIONS( -D_FILE_OFFSET_BITS=64 ) -ADD_DEFINITIONS( -DVERSION=\\\"${VERSION}\\\" ) +ADD_DEFINITIONS( -DVERSION="${VERSION}" ) SET( LIBZYPP_VERSION_INFO "${LIBZYPP_SO_FIRST}.${LIBZYPP_AGE}.${LIBZYPP_PATCH}" ) SET( LIBZYPP_SOVERSION_INFO "${LIBZYPP_SO_FIRST}" ) @@ -24,13 +34,31 @@ GENERATE_PACKAGING(${PACKAGE} ${VERSION}) INCLUDE(CPack) +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 zypp_test_utils) + ADD_TEST( ${loop_var}_test ${CMAKE_CURRENT_BINARY_DIR}/${loop_var}_test --catch_system_errors=no) + ENDFOREACH( loop_var ) +ENDMACRO(ADD_TESTS) + #################################################################### FIND_PACKAGE(Rpm REQUIRED) IF ( NOT RPM_FOUND) - MESSAGE( FATAL_ERROR " rpm not found" ) + MESSAGE( FATAL_ERROR " rpm-devel not found" ) ELSE ( NOT RPM_FOUND) INCLUDE_DIRECTORIES(${RPM_INCLUDE_DIR}) + # fix includes not relative to rpm + INCLUDE_DIRECTORIES(${RPM_INCLUDE_DIR}/rpm) + 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: enable rpm-4.4 legacy interface." ) + ADD_DEFINITIONS(-D_RPM_4_4_COMPAT) + endif ( RPM_SUSPECT_VERSION STREQUAL "5.x" ) ENDIF( NOT RPM_FOUND) FIND_PACKAGE(Boost REQUIRED) @@ -48,32 +76,6 @@ ELSE (GETTEXT_FOUND) MESSAGE( FATAL_ERROR "Gettext not found" ) ENDIF (GETTEXT_FOUND) -FIND_PACKAGE(Hal REQUIRED) -IF ( NOT HAL_FOUND) - MESSAGE( FATAL_ERROR " Hal not found" ) -ELSE ( NOT HAL_FOUND) - INCLUDE_DIRECTORIES(${HAL_INCLUDE_DIR}) -# hal/libhal-storage.h is broken grrr - INCLUDE_DIRECTORIES(${HAL_INCLUDE_DIR}/hal) -ENDIF( NOT HAL_FOUND) - -FIND_PACKAGE(Dbus REQUIRED) -IF ( NOT DBUS_FOUND) - MESSAGE( FATAL_ERROR " dbus not found" ) -ELSE ( NOT DBUS_FOUND) - INCLUDE_DIRECTORIES(${DBUS_INCLUDE_DIR}) - INCLUDE_DIRECTORIES(${DBUS_ARCH_INCLUDE_DIR}) -ENDIF( NOT DBUS_FOUND) - -FIND_PACKAGE(Glib REQUIRED) -IF (GLIB_FOUND) - MESSAGE( STATUS "glib found: includes in ${GLIB_INCLUDE_DIR}, library in ${GLIB_LIBRARY}") - INCLUDE_DIRECTORIES(${GLIB_INCLUDE_DIR}) - INCLUDE_DIRECTORIES(${GLIB_CONFIG_INCLUDE_DIR}) -ELSE(GLIB_FOUND) - MESSAGE( FATAL_ERROR "glib not found" ) -ENDIF(GLIB_FOUND) - FIND_PACKAGE(Curl REQUIRED) IF ( NOT CURL_FOUND) MESSAGE( FATAL_ERROR " curl not found" ) @@ -88,8 +90,6 @@ ELSE ( NOT LIBXML_FOUND) INCLUDE_DIRECTORIES(${LIBXML_INCLUDE_DIR}) ENDIF( NOT LIBXML_FOUND) -FIND_PACKAGE(Sqlite REQUIRED) - FIND_PACKAGE(ZLIB REQUIRED) IF ( NOT ZLIB_FOUND) MESSAGE( FATAL_ERROR " zlib not found" ) @@ -104,6 +104,20 @@ ELSE ( NOT SATSOLVER_FOUND ) INCLUDE_DIRECTORIES( ${SATSOLVER_INCLUDE_DIR} ) ENDIF( NOT SATSOLVER_FOUND ) +# satsolver uses expat and has open references to it: +FIND_PACKAGE(EXPAT REQUIRED) + +FIND_PACKAGE(OpenSSL REQUIRED) +FIND_PACKAGE(Udev REQUIRED) + +FIND_PACKAGE(libproxy) +IF ( NOT LIBPROXY_FOUND ) + MESSAGE( FATAL_ERROR " libproxy not found" ) +ELSE ( NOT LIBPROXY_FOUND ) + INCLUDE_DIRECTORIES( ${LIBPROXY_INCLUDE_DIR} ) + ADD_DEFINITIONS(-D_WITH_LIBPROXY_SUPPORT_) +ENDIF( NOT LIBPROXY_FOUND ) + FIND_PROGRAM( DOXYGEN doxygen ) IF ( NOT DOXYGEN ) MESSAGE( FATAL_ERROR "doxygen not found: install doxygen to build the documentation." ) @@ -114,13 +128,28 @@ ENDIF ( NOT DOXYGEN ) MESSAGE(STATUS "soname: ${LIBZYPP_VERSION_INFO}") MESSAGE(STATUS "version: ${VERSION}") +MESSAGE(STATUS "Writing pkg-config file...") +CONFIGURE_FILE(${LIBZYPP_SOURCE_DIR}/libzypp.pc.cmake ${LIBZYPP_BINARY_DIR}/libzypp.pc @ONLY) +INSTALL( FILES ${LIBZYPP_BINARY_DIR}/libzypp.pc DESTINATION ${LIB_INSTALL_DIR}/pkgconfig ) MESSAGE(STATUS "FindZypp.cmake will be installed in ${CMAKE_INSTALL_PREFIX}/share/cmake/Modules") -INSTALL( FILES ${CMAKE_SOURCE_DIR}/cmake/modules/FindZypp.cmake DESTINATION ${CMAKE_INSTALL_PREFIX}/share/cmake/Modules ) -INSTALL( FILES ${CMAKE_SOURCE_DIR}/cmake/modules/ZyppCommon.cmake DESTINATION ${CMAKE_INSTALL_PREFIX}/share/cmake/Modules ) +INSTALL( FILES ${LIBZYPP_SOURCE_DIR}/cmake/modules/FindZypp.cmake DESTINATION ${CMAKE_INSTALL_PREFIX}/share/cmake/Modules ) +INSTALL( FILES ${LIBZYPP_SOURCE_DIR}/cmake/modules/ZyppCommon.cmake DESTINATION ${CMAKE_INSTALL_PREFIX}/share/cmake/Modules ) + +#################################################################### +# config templates +# (don't forget to mention them in the .spec file) +#################################################################### MESSAGE(STATUS "zypp.conf will be installed in ${SYSCONFDIR}/zypp") -INSTALL( FILES ${CMAKE_SOURCE_DIR}/zypp.conf DESTINATION ${SYSCONFDIR}/zypp ) +INSTALL( FILES ${LIBZYPP_SOURCE_DIR}/zypp.conf DESTINATION ${SYSCONFDIR}/zypp ) + +#install systemCheck +MESSAGE(STATUS "systemCheck will be installed in ${SYSCONFDIR}/zypp") +INSTALL( FILES ${LIBZYPP_SOURCE_DIR}/systemCheck DESTINATION ${SYSCONFDIR}/zypp ) + +# logrotate config file +INSTALL( FILES ${LIBZYPP_SOURCE_DIR}/zypp-history.lr DESTINATION ${SYSCONFDIR}/logrotate.d ) #################################################################### # SUBDIRECTORIES # @@ -131,8 +160,11 @@ ADD_SUBDIRECTORY( zypp ) # do not build devel by default ADD_SUBDIRECTORY( devel EXCLUDE_FROM_ALL ) ADD_SUBDIRECTORY( tools ) -#ADD_SUBDIRECTORY( examples ) +ADD_SUBDIRECTORY( examples ) ADD_SUBDIRECTORY( po EXCLUDE_FROM_ALL ) -ADD_SUBDIRECTORY( doc EXCLUDE_FROM_ALL ) +ADD_SUBDIRECTORY( doc ) +ADD_SUBDIRECTORY( vendor ) ADD_SUBDIRECTORY( tests EXCLUDE_FROM_ALL ) +INCLUDE(CTest) +ENABLE_TESTING()