X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;f=src%2FCMakeLists.txt;h=76ea9f16d0aef2b8dff961c4084c9c0dc7508cb7;hb=refs%2Ftags%2Fupstream%2F0.6.28;hp=e14537028ba4d41bede65e5eb3809ffe8999bc79;hpb=e50636a98e3f1dbeaa0fa24222736279c159c468;p=platform%2Fupstream%2Flibsolv.git diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index e145370..76ea9f1 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -1,8 +1,54 @@ -SET(libsatsolver_SRCS bitmap.c poolarch.c poolid.c solver.c source_solv.c -evr.c pool.c queue.c source.c util.c) +INCLUDE (CheckFunctionExists) +CHECK_FUNCTION_EXISTS (qsort_r HAVE_QSORT_R) +CHECK_FUNCTION_EXISTS (__qsort_r HAVE___QSORT_R) -ADD_LIBRARY(satsolver STATIC ${libsatsolver_SRCS}) +IF (HAVE_QSORT_R) + ADD_DEFINITIONS (-DHAVE_QSORT_R=1) +ENDIF (HAVE_QSORT_R) -#SET(libsatsolver_HEADERS bitmap.h evr.h hash.h poolarch.h pool.h poolid.h pooltypes.h queue.h solvable.h solver.h source.h source_solv.h util.h ) -#INSTALL( FILES ${libsatsolver_HEADERS} DESTINATION "${CMAKE_INSTALL_PREFIX}/include/satsolver" ) +IF (HAVE___QSORT_R) + ADD_DEFINITIONS (-DHAVE___QSORT_R=1) +ENDIF (HAVE___QSORT_R) + +ADD_DEFINITIONS (-DLIBSOLV_INTERNAL=1) + +SET (libsolv_SRCS + bitmap.c poolarch.c poolvendor.c poolid.c strpool.c dirpool.c + solver.c solverdebug.c repo_solv.c repo_write.c evr.c pool.c + queue.c repo.c repodata.c repopage.c util.c policy.c solvable.c + transaction.c order.c rules.c problems.c linkedpkg.c cplxdeps.c + chksum.c md5.c sha1.c sha2.c solvversion.c selection.c + fileprovides.c diskusage.c suse.c) + +SET (libsolv_HEADERS + bitmap.h evr.h hash.h policy.h poolarch.h poolvendor.h pool.h + poolid.h pooltypes.h queue.h solvable.h solver.h solverdebug.h + repo.h repodata.h repo_solv.h repo_write.h util.h selection.h + strpool.h dirpool.h knownid.h transaction.h rules.h problems.h + chksum.h dataiterator.h ${CMAKE_BINARY_DIR}/src/solvversion.h) + +SET (CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fPIC") +IF (HAVE_LINKER_VERSION_SCRIPT) +SET (CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} ${LINK_FLAGS} -Wl,--version-script=${CMAKE_SOURCE_DIR}/src/libsolv.ver") +ENDIF (HAVE_LINKER_VERSION_SCRIPT) + +IF (DISABLE_SHARED) +ADD_LIBRARY (libsolv STATIC ${libsolv_SRCS}) +ELSE (DISABLE_SHARED) +ADD_LIBRARY (libsolv SHARED ${libsolv_SRCS}) +ENDIF (DISABLE_SHARED) + +SET_TARGET_PROPERTIES(libsolv PROPERTIES OUTPUT_NAME "solv") +SET_TARGET_PROPERTIES(libsolv PROPERTIES SOVERSION ${LIBSOLV_SOVERSION}) +SET_TARGET_PROPERTIES(libsolv PROPERTIES INSTALL_NAME_DIR ${LIB_INSTALL_DIR}) + +INSTALL (FILES ${libsolv_HEADERS} DESTINATION "${INCLUDE_INSTALL_DIR}/solv") +INSTALL (TARGETS libsolv LIBRARY DESTINATION ${LIB_INSTALL_DIR} ARCHIVE DESTINATION ${LIB_INSTALL_DIR} RUNTIME DESTINATION bin) + +IF (ENABLE_STATIC AND NOT DISABLE_SHARED) +ADD_LIBRARY (libsolv_static STATIC ${libsolv_SRCS}) +SET_TARGET_PROPERTIES(libsolv_static PROPERTIES OUTPUT_NAME "solv") +SET_TARGET_PROPERTIES(libsolv_static PROPERTIES SOVERSION ${LIBSOLV_SOVERSION}) +INSTALL (TARGETS libsolv_static LIBRARY DESTINATION ${LIB_INSTALL_DIR} ARCHIVE DESTINATION ${LIB_INSTALL_DIR}) +ENDIF (ENABLE_STATIC AND NOT DISABLE_SHARED)