X-Git-Url: http://review.tizen.org/git/?p=platform%2Fupstream%2Flibzypp.git;a=blobdiff_plain;f=CMakeLists.txt;h=1c018ec499b613e0500c28415fce9999bd4930de;hp=ee0d7bda26c7b13a43757978d8ddc2dbeb76282c;hb=HEAD;hpb=be7c9cc1085dce83848112175614b3e322d4fbd4 diff --git a/CMakeLists.txt b/CMakeLists.txt index ee0d7bd..1245837 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -1,118 +1,151 @@ -PROJECT(libzypp) - -# Library -IF ( DEFINED LIB ) - SET ( LIB_INSTALL_DIR "${CMAKE_INSTALL_PREFIX}/${LIB}" ) -ELSE ( DEFINED LIB ) - IF (CMAKE_SIZEOF_VOID_P MATCHES "8") - SET( LIB_SUFFIX "64" ) - ENDIF(CMAKE_SIZEOF_VOID_P MATCHES "8") - SET ( LIB_INSTALL_DIR "${CMAKE_INSTALL_PREFIX}/lib${LIB_SUFFIX}" ) -ENDIF ( DEFINED LIB ) -MESSAGE(STATUS "Libraries will be installed in ${LIB_INSTALL_DIR}" ) - -# system configuration dir (etc) - -IF( NOT DEFINED SYSCONFDIR ) - SET( SYSCONFDIR /etc ) -ENDIF( NOT DEFINED SYSCONFDIR ) -MESSAGE(STATUS "Config files will be installed in ${SYSCONFDIR}" ) - -#################################################################### -# CONFIGURATION # -#################################################################### - +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 ${CMAKE_SOURCE_DIR}/cmake/modules ) - -INCLUDE( ${CMAKE_SOURCE_DIR}/VERSION.cmake ) +SET( CMAKE_MODULE_PATH ${LIBZYPP_SOURCE_DIR}/cmake/modules ) +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) + +IF (DEBIAN) + MESSAGE (STATUS "Building for Debian") + SET (ENABLE_BUILD_DOCS ON) + SET (ENABLE_BUILD_TRANS ON) + SET (ENABLE_BUILD_TESTS ON) + SET (have_system ${have_system}x) +ENDIF (DEBIAN) + +IF (${have_system} STREQUAL x) + MESSAGE (STATUS "Building for SUSE") +ENDIF (${have_system} STREQUAL x) + +IF (${have_system} STRGREATER xx) + MESSAGE (FATAL_ERROR "Can only build for one system type.") +ENDIF (${have_system} STRGREATER xx) +#-------------------------------------------------------------------------------- + +# allow name libraries by name mixed with full +# paths +if(COMMAND cmake_policy) + cmake_policy(SET CMP0003 NEW) +endif(COMMAND cmake_policy) + +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( PACKAGE "libzypp" ) 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 -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} -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" ) + +IF(${CC_FORMAT_SECURITY}) + SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -Werror=format-security") +ENDIF(${CC_FORMAT_SECURITY}) + +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}) + ADD_DEFINITIONS(-DHAVE_PIPE2) +ENDIF(${PIPE2_FOUND}) -SET( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -g -O3 -Wall -Woverloaded-virtual" ) -SET( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -g -O3 -Wall" ) 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}" ) -SET(CPACK_PACKAGE_DESCRIPTION_SUMMARY "Novell's package management core engine.") -SET(CPACK_PACKAGE_VENDOR "Novell Inc.") -#SET(CPACK_PACKAGE_DESCRIPTION_FILE "${CMAKE_CURRENT_SOURCE_DIR}/ReadMe.txt") -#SET(CPACK_RESOURCE_FILE_LICENSE "${CMAKE_CURRENT_SOURCE_DIR}/Copyright.txt") -SET(CPACK_PACKAGE_VERSION_MAJOR ${LIBZYPP_MAJOR}) -SET(CPACK_PACKAGE_VERSION_MINOR ${LIBZYPP_MINOR}) -SET(CPACK_PACKAGE_VERSION_PATCH ${LIBZYPP_PATCH}) -SET( CPACK_GENERATOR "TBZ2") -SET( CPACK_SOURCE_GENERATOR "TBZ2") -SET( CPACK_SOURCE_PACKAGE_FILE_NAME "${PACKAGE}-${VERSION}" ) - -# The following components are regex's to match anywhere (unless anchored) -# in absolute path + filename to find files or directories to be excluded -# from source tarball. -SET (CPACK_SOURCE_IGNORE_FILES -#svn files -"\\\\.svn/" -"\\\\.cvsignore$" -# temporary files -"\\\\.swp$" -# backup files -"~$" -# eclipse files -"\\\\.cdtproject$" -"\\\\.cproject$" -"\\\\.project$" -"\\\\.settings/" -# others -"\\\\.#" -"/#" -"/build/" -"/_build/" -"/\\\\.git/" -# used before -"/CVS/" -"/\\\\.libs/" -"/\\\\.deps/" -"\\\\.o$" -"\\\\.lo$" -"\\\\.la$" -"Makefile\\\\.in$" -) +GENERATE_PACKAGING(${PACKAGE} ${VERSION}) INCLUDE(CPack) -#################################################################### - -SET( DOC_INSTALL_DIR - "${CMAKE_INSTALL_PREFIX}/share/doc/packages/${PACKAGE}" - CACHE PATH "The install dir for documentation (default prefix/share/doc/packages/${PACKAGE})" - FORCE -) +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 ) -#################################################################### -# INCLUDES # -#################################################################### + 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() -#SET (CMAKE_INCLUDE_DIRECTORIES_BEFORE ON) -INCLUDE_DIRECTORIES( ${CMAKE_CURRENT_SOURCE_DIR} ${CMAKE_SOURCE_DIR} ${CMAKE_CURRENT_BINARY_DIR} SYSTEM ) + 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) #################################################################### - +IF ( ENABLE_USE_THREADS ) + SET( CMAKE_THREAD_PREFER_PTHREAD TRUE ) + FIND_PACKAGE( Threads REQUIRED ) + IF ( CMAKE_USE_PTHREADS_INIT ) + MESSAGE( STATUS "May use threads." ) + SET( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -pthread -DZYPP_USE_THREADS" ) + SET( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -pthread -DZYPP_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 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) + + # 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) + endif ( RPM_SUSPECT_VERSION STREQUAL "5.x" ) ENDIF( NOT RPM_FOUND) -FIND_PACKAGE(Boost REQUIRED) +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}) @@ -127,55 +160,19 @@ 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) - -#IF (DBUS_GLIB_FOUND) -# MESSAGE( STATUS "dbus-glib found" ) -# INCLUDE_DIRECTORIES(${DBUS_GLIB_INCLUDE_DIR}) -# LINK_DIRECTORIES(${DBUS_GLIB_LINK_DIR}) -#ELSE(DBUS_GLIB_FOUND) -# MESSAGE( ERROR "dbus-glib not found" ) -#ENDIF(DBUS_GLIB_FOUND) - -FIND_PACKAGE(Curl REQUIRED) +FIND_PACKAGE(CURL REQUIRED) IF ( NOT CURL_FOUND) MESSAGE( FATAL_ERROR " curl not found" ) ELSE ( NOT CURL_FOUND) - INCLUDE_DIRECTORIES(${CURL_INCLUDE_DIR}) + INCLUDE_DIRECTORIES(${CURL_INCLUDE_DIRS}) ENDIF( NOT CURL_FOUND) -FIND_PACKAGE(Libxml REQUIRED) -IF ( NOT LIBXML_FOUND) +FIND_PACKAGE(LibXml2 REQUIRED) +IF ( NOT LIBXML2_FOUND) MESSAGE( FATAL_ERROR " libxml not found" ) -ELSE ( NOT LIBXML_FOUND) - INCLUDE_DIRECTORIES(${LIBXML_INCLUDE_DIR}) -ENDIF( NOT LIBXML_FOUND) - -FIND_PACKAGE(Sqlite REQUIRED) +ELSE ( NOT LIBXML2_FOUND) + INCLUDE_DIRECTORIES(${LIBXML2_INCLUDE_DIR}) +ENDIF( NOT LIBXML2_FOUND) FIND_PACKAGE(ZLIB REQUIRED) IF ( NOT ZLIB_FOUND) @@ -184,84 +181,135 @@ ELSE ( NOT ZLIB_FOUND) INCLUDE_DIRECTORIES(${ZLIB_INCLUDE_DIR}) ENDIF( NOT ZLIB_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() + 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() + +FIND_PACKAGE(OpenSSL REQUIRED) + +FIND_PACKAGE(Udev) +IF ( NOT UDEV_FOUND ) + MESSAGE(WARNING "No udev found. CD device detection will be poor") +ELSE ( NOT UDEV_FOUND ) + ADD_DEFINITIONS(-DHAVE_UDEV) +ENDIF ( NOT UDEV_FOUND ) + +IF( DISABLE_LIBPROXY ) + MESSAGE( STATUS "libproxy support disabled" ) +ELSE( DISABLE_LIBPROXY ) + FIND_PACKAGE(libproxy) + IF ( NOT LIBPROXY_FOUND ) + MESSAGE( STATUS "libproxy not found" ) + ELSE ( NOT LIBPROXY_FOUND ) + INCLUDE_DIRECTORIES( ${LIBPROXY_INCLUDE_DIR} ) + ADD_DEFINITIONS(-DWITH_LIBPROXY_SUPPORT) + ENDIF( NOT LIBPROXY_FOUND ) +ENDIF( DISABLE_LIBPROXY ) + FIND_PROGRAM( DOXYGEN doxygen ) IF ( NOT DOXYGEN ) - MESSAGE( FATAL_ERROR "doxygen not found: install doxygen to build the documentation." ) + IF ( DISABLE_AUTODOCS ) + MESSAGE( STATUS "doxygen is not available. Can't build the documentation." ) + ELSE ( DISABLE_AUTODOCS ) + MESSAGE( FATAL_ERROR "doxygen not found: install doxygen to build the documentation!" ) + ENDIF ( DISABLE_AUTODOCS ) ELSE ( NOT DOXYGEN ) MESSAGE( STATUS "doxygen found: ${DOXYGEN}" ) ENDIF ( NOT DOXYGEN ) -MESSAGE(STATUS "soname: ${LIBZYPP_VERSION_INFO}") -MESSAGE(STATUS "version: ${VERSION}") +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) -#################################################################### -# RPM SPEC # -#################################################################### +pkg_check_modules ( SIGCPP REQUIRED sigc++-2.0 ) +INCLUDE_DIRECTORIES( ${SIGCPP_INCLUDE_DIRS} ) -MACRO(SPECFILE) - MESSAGE(STATUS "Writing spec file...") - CONFIGURE_FILE(${CMAKE_SOURCE_DIR}/libzypp.spec.cmake ${CMAKE_BINARY_DIR}/package/libzypp.spec @ONLY) - MESSAGE(STATUS "I hate you rpm-lint...!!!") - CONFIGURE_FILE(${CMAKE_SOURCE_DIR}/package/libzypp-rpmlint.cmake ${CMAKE_BINARY_DIR}/package/libzypp-rpmlintrc @ONLY) -ENDMACRO(SPECFILE) +pkg_check_modules ( LIBGLIB REQUIRED glib-2.0 ) +INCLUDE_DIRECTORIES( ${LIBGLIB_INCLUDE_DIRS} ) -SPECFILE() +MESSAGE(STATUS "soname: ${LIBZYPP_VERSION_INFO}") +MESSAGE(STATUS "version: ${VERSION}") MESSAGE(STATUS "Writing pkg-config file...") -CONFIGURE_FILE(${CMAKE_SOURCE_DIR}/libzypp.pc.cmake ${CMAKE_BINARY_DIR}/libzypp.pc @ONLY) -INSTALL( FILES ${CMAKE_BINARY_DIR}/libzypp.pc DESTINATION ${LIB_INSTALL_DIR}/pkgconfig ) +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 ${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 ) + +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 ) + +# logrotate config file +INSTALL( FILES ${LIBZYPP_SOURCE_DIR}/zypp-history.lr DESTINATION ${SYSCONFDIR}/logrotate.d ) #################################################################### # SUBDIRECTORIES # #################################################################### ADD_SUBDIRECTORY( zypp ) -#ADD_SUBDIRECTORY( zypp2 ) # do not build devel by default ADD_SUBDIRECTORY( devel EXCLUDE_FROM_ALL ) ADD_SUBDIRECTORY( tools ) -#ADD_SUBDIRECTORY( examples ) -ADD_SUBDIRECTORY( po EXCLUDE_FROM_ALL ) -ADD_SUBDIRECTORY( doc EXCLUDE_FROM_ALL ) -ADD_SUBDIRECTORY( tests EXCLUDE_FROM_ALL ) - -#################################################################### -# OTHERS # -#################################################################### - -#configure_file(${CMAKE_CURRENT_SOURCE_DIR}/config.h.cmake ${CMAKE_CURRENT_BINARY_DIR}/config.h ) -#yumschemadir=${zyppdir}/schema/yum -#xmlstoreschemadir=${zyppdir}/schema/xmlstore - -#################################################################### -# INSTALL # -#################################################################### - -#INSTALL_FILES( FILES libzypp.pc ) - -ADD_CUSTOM_TARGET( svncheck - COMMAND cd $(CMAKE_SOURCE_DIR) && ! LC_ALL=C svn status --show-updates --quiet | grep -v '^Status against revision' -) - -SET( AUTOBUILD_COMMAND - COMMAND ${CMAKE_COMMAND} -E remove ${CMAKE_BINARY_DIR}/package/*.tar.bz2 - COMMAND ${CMAKE_MAKE_PROGRAM} package_source - COMMAND ${CMAKE_COMMAND} -E copy ${CPACK_SOURCE_PACKAGE_FILE_NAME}.tar.bz2 ${CMAKE_BINARY_DIR}/package - COMMAND ${CMAKE_COMMAND} -E remove ${CPACK_SOURCE_PACKAGE_FILE_NAME}.tar.bz2 - COMMAND ${CMAKE_COMMAND} -E copy "${CMAKE_SOURCE_DIR}/package/${PACKAGE}.changes" "${CMAKE_BINARY_DIR}/package/${PACKAGE}.changes" -) - -ADD_CUSTOM_TARGET( srcpackage_local - ${AUTOBUILD_COMMAND} -) - -ADD_CUSTOM_TARGET( srcpackage - COMMAND ${CMAKE_MAKE_PROGRAM} svncheck - ${AUTOBUILD_COMMAND} -) +ADD_SUBDIRECTORY( doc ) + +IF ( ENABLE_BUILD_TRANS ) + ADD_SUBDIRECTORY( po ) +ELSE ( ENABLE_BUILD_TRANS ) + ADD_SUBDIRECTORY( po EXCLUDE_FROM_ALL ) +ENDIF ( ENABLE_BUILD_TRANS ) + +IF ( ENABLE_BUILD_TESTS ) + ADD_SUBDIRECTORY( tests ) +ELSE ( ENABLE_BUILD_TESTS ) + ADD_SUBDIRECTORY( tests EXCLUDE_FROM_ALL ) +ENDIF ( ENABLE_BUILD_TESTS ) +INCLUDE(CTest) +ENABLE_TESTING()