X-Git-Url: http://review.tizen.org/git/?a=blobdiff_plain;ds=sidebyside;f=src%2FCMakeLists.txt;h=ca04b3911710950638cdce5983eee612c76b610b;hb=1aac48dff40ef592968a18058bad270da65ed847;hp=9bd0fde74a4e62d3517676930d314cc81ef50370;hpb=180a7cc50ba32c83e6a05d3560850ba228d2afcb;p=platform%2Fupstream%2Flibsolv.git diff --git a/src/CMakeLists.txt b/src/CMakeLists.txt index 9bd0fde..ca04b39 100644 --- a/src/CMakeLists.txt +++ b/src/CMakeLists.txt @@ -1,21 +1,75 @@ -SET(libsatsolver_SRCS +INCLUDE (CheckFunctionExists) +CHECK_FUNCTION_EXISTS (qsort_r HAVE_QSORT_R) +CHECK_FUNCTION_EXISTS (__qsort_r HAVE___QSORT_R) + +IF (HAVE_QSORT_R) + ADD_DEFINITIONS (-DHAVE_QSORT_R=1) +ENDIF (HAVE_QSORT_R) + +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 evr.c pool.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 rules.c problems.c - chksum.c md5.c sha1.c sha2.c satversion.c) - -ADD_LIBRARY(satsolver STATIC ${libsatsolver_SRCS}) + 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 solver_util.c cleandeps.c + userinstalled.c filelistfilter.c decision.c) -SET(libsatsolver_HEADERS +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 repopage.h repo_solv.h util.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 md5.h sha1.h sha2.h ${CMAKE_BINARY_DIR}/src/satversion.h) + chksum.h dataiterator.h ${CMAKE_BINARY_DIR}/src/solvversion.h) + +IF (ENABLE_CONDA) + SET (libsolv_SRCS ${libsolv_SRCS} conda.c) + SET (libsolv_HEADERS ${libsolv_HEADERS} conda.h) +ENDIF (ENABLE_CONDA) + +IF (NOT MSVC) + SET (CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fPIC") +ENDIF (NOT MSVC) + +IF (WIN32) + INCLUDE (${PROJECT_SOURCE_DIR}/win32/CMakeLists.txt) + LIST (APPEND libsolv_SRCS ${WIN32_COMPAT_SOURCES}) +ENDIF (WIN32) + +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) + +IF (WIN32) + IF (DISABLE_SHARED) + TARGET_COMPILE_DEFINITIONS(libsolv PUBLIC SOLV_STATIC_LIB) + ELSE (DISABLE_SHARED) + TARGET_COMPILE_DEFINITIONS(libsolv PRIVATE SOLV_EXPORTS) + ENDIF (DISABLE_SHARED) +ENDIF (WIN32) + +SET_TARGET_PROPERTIES(libsolv PROPERTIES OUTPUT_NAME "solv") +SET_TARGET_PROPERTIES(libsolv PROPERTIES SOVERSION ${LIBSOLV_SOVERSION}) -SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -fPIC") +INSTALL (FILES ${libsolv_HEADERS} DESTINATION "${CMAKE_INSTALL_INCLUDEDIR}/solv") +INSTALL (TARGETS libsolv LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR} RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR}) -INSTALL(FILES ${libsatsolver_HEADERS} DESTINATION "${CMAKE_INSTALL_PREFIX}/include/satsolver") -INSTALL(TARGETS satsolver LIBRARY DESTINATION ${LIB_INSTALL_DIR} ARCHIVE DESTINATION ${LIB_INSTALL_DIR}) +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 ${CMAKE_INSTALL_LIBDIR} ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}) +ENDIF (ENABLE_STATIC AND NOT DISABLE_SHARED)