|
| 1 | +--- libmariadb/CMakeLists.txt |
| 2 | ++++ libmariadb/CMakeLists.txt |
| 3 | +@@ -414,7 +414,7 @@ |
| 4 | + ENDIF() |
| 5 | + |
| 6 | + |
| 7 | +-IF(CMAKE_VERSION VERSION_GREATER 2.8.7) |
| 8 | ++IF(FALSE) |
| 9 | + # CREATE OBJECT LIBRARY |
| 10 | + ADD_LIBRARY(mariadb_obj OBJECT ${LIBMARIADB_SOURCES}) |
| 11 | + IF(UNIX) |
| 12 | +@@ -443,21 +443,24 @@ |
| 13 | + "FILE_DESCRIPTION:Dynamic lib for client/server communication") |
| 14 | + ENDIF() |
| 15 | + |
| 16 | ++IF(NOT BUILD_SHARED_LIBS) |
| 17 | + ADD_LIBRARY(mariadbclient STATIC ${MARIADB_OBJECTS} ${EMPTY_FILE}) |
| 18 | + TARGET_LINK_LIBRARIES(mariadbclient ${SYSTEM_LIBS} ${CRYPTO_LIBS}) |
| 19 | +- |
| 20 | ++ELSE() |
| 21 | + IF(UNIX) |
| 22 | + ADD_LIBRARY(libmariadb SHARED ${libmariadb_RC} ${MARIADB_OBJECTS} ${EMPTY_FILE}) |
| 23 | + SET_TARGET_PROPERTIES(libmariadb PROPERTIES COMPILE_FLAGS "${CMAKE_SHARED_LIBRARY_C_FLAGS}") |
| 24 | + ELSE() |
| 25 | +- ADD_LIBRARY(libmariadb SHARED ${libmariadb_RC} ${MARIADB_OBJECTS} mariadbclient.def) |
| 26 | ++ ADD_LIBRARY(libmariadb SHARED ${libmariadb_RC} ${MARIADB_OBJECTS} ${EMPTY_FILE} mariadbclient.def) |
| 27 | + SET_TARGET_PROPERTIES(libmariadb PROPERTIES LINKER_LANGUAGE C) |
| 28 | + ENDIF() |
| 29 | + |
| 30 | + TARGET_LINK_LIBRARIES(libmariadb LINK_PRIVATE ${SYSTEM_LIBS} ${CRYPTO_LIBS}) |
| 31 | + |
| 32 | + SIGN_TARGET(libmariadb) |
| 33 | +- |
| 34 | ++ENDIF() |
| 35 | ++ |
| 36 | ++IF(BUILD_SHARED_LIBS) |
| 37 | + IF(CMAKE_SYSTEM_NAME MATCHES "Linux" OR |
| 38 | + CMAKE_SYSTEM_NAME MATCHES "kFreeBSD" OR |
| 39 | + CMAKE_SYSTEM_NAME MATCHES "GNU") |
| 40 | +@@ -466,11 +469,14 @@ |
| 41 | + ENDIF() |
| 42 | + SET_TARGET_PROPERTIES(libmariadb PROPERTIES LINK_FLAGS "${CC_BINARY_DIR}/libmariadb/mariadbclient.def") |
| 43 | + ENDIF() |
| 44 | +- |
| 45 | ++ELSE() |
| 46 | + SET_TARGET_PROPERTIES(mariadbclient PROPERTIES IMPORTED_INTERFACE_LINK_LIBRARIES "${SYSTEM_LIBS}") |
| 47 | ++ENDIF() |
| 48 | ++IF(BUILD_SHARED_LIBS) |
| 49 | + SET_TARGET_PROPERTIES(libmariadb PROPERTIES IMPORTED_INTERFACE_LINK_LIBRARIES "${SYSTEM_LIBS}") |
| 50 | + |
| 51 | + SET_TARGET_PROPERTIES(libmariadb PROPERTIES PREFIX "") |
| 52 | ++ENDIF() |
| 53 | + |
| 54 | + # |
| 55 | + # Installation |
| 56 | +@@ -490,11 +496,15 @@ |
| 57 | + ENDIF() |
| 58 | + ENDIF() |
| 59 | + |
| 60 | ++IF(NOT BUILD_SHARED_LIBS) |
| 61 | + create_symlink(libmariadb${CMAKE_STATIC_LIBRARY_SUFFIX} mariadbclient ${INSTALL_LIBDIR}) |
| 62 | +- |
| 63 | ++ENDIF() |
| 64 | ++ |
| 65 | ++IF(BUILD_SHARED_LIBS) |
| 66 | + SET_TARGET_PROPERTIES(libmariadb PROPERTIES VERSION |
| 67 | + ${CPACK_PACKAGE_VERSION_MAJOR} |
| 68 | + SOVERSION ${CPACK_PACKAGE_VERSION_MAJOR}) |
| 69 | ++ELSE() |
| 70 | + |
| 71 | + IF(NOT WIN32) |
| 72 | + SET_TARGET_PROPERTIES(mariadbclient PROPERTIES OUTPUT_NAME "${LIBMARIADB_STATIC_NAME}") |
| 73 | +@@ -502,20 +512,33 @@ |
| 74 | + |
| 75 | + INSTALL(TARGETS mariadbclient |
| 76 | + COMPONENT Development |
| 77 | +- DESTINATION ${INSTALL_LIBDIR}) |
| 78 | ++ RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR} |
| 79 | ++ LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} |
| 80 | ++ ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}) |
| 81 | ++ENDIF() |
| 82 | ++ |
| 83 | ++IF(BUILD_SHARED_LIBS) |
| 84 | + IF(WIN32) |
| 85 | + INSTALL(TARGETS libmariadb |
| 86 | + COMPONENT SharedLibraries |
| 87 | +- DESTINATION ${INSTALL_LIBDIR}) |
| 88 | ++ RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR} |
| 89 | ++ LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} |
| 90 | ++ ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}) |
| 91 | + ELSE() |
| 92 | + # in cmake 3.12+ we can use |
| 93 | + #INSTALL(TARGETS libmariadb LIBRARY DESTINATION ${INSTALL_LIBDIR} |
| 94 | + # COMPONENT SharedLibraries NAMELINK_COMPONENT Development) |
| 95 | + # but as long as we build on CentOS 7 with its cmake 2.8.12.2 we have to use |
| 96 | +-INSTALL(TARGETS libmariadb LIBRARY DESTINATION ${INSTALL_LIBDIR} |
| 97 | +- COMPONENT SharedLibraries NAMELINK_SKIP) |
| 98 | +-INSTALL(TARGETS libmariadb LIBRARY DESTINATION ${INSTALL_LIBDIR} |
| 99 | +- COMPONENT Development NAMELINK_ONLY) |
| 100 | ++INSTALL(TARGETS libmariadb LIBRARY |
| 101 | ++ RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR} |
| 102 | ++ LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} |
| 103 | ++ ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR} |
| 104 | ++ COMPONENT SharedLibraries) |
| 105 | ++INSTALL(TARGETS libmariadb LIBRARY |
| 106 | ++ RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR} |
| 107 | ++ LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR} |
| 108 | ++ ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR} |
| 109 | ++ COMPONENT Development) |
| 110 | + ENDIF() |
| 111 | + |
| 112 | + IF(MSVC) |
| 113 | +@@ -524,3 +547,4 @@ |
| 114 | + CONFIGURATIONS Debug RelWithDebInfo |
| 115 | + COMPONENT Development) |
| 116 | + ENDIF() |
| 117 | ++ENDIF() |
0 commit comments