Merge pull request #140 from hussainnaqvee/patch-1
[awesomized/libmemcached] / CPack.txt
index 97221b621a8ee4c981e28d480394550f318b9f29..1a4d77dc9433f6ac4a3b5071ade4d5f18c8340ab 100644 (file)
--- a/CPack.txt
+++ b/CPack.txt
@@ -1,13 +1,12 @@
 # default options
 
+set(CPACK_ARCHIVE_COMPONENT_INSTALL ${CPACK_COMPONENT_INSTALL})
+set(CPACK_SOURCE_IGNORE_FILES "/[.]git/;/[.](idea|settings|c?project);~$;[.]log$;[.]bak$")
+
 macro(cpack_include_if GENERATOR)
     message(STATUS "Checking ${GENERATOR} package configuration ...")
-    if(EXISTS ${CMAKE_SOURCE_DIR}/CPack${GENERATOR}.txt)
-        message(STATUS "  Sourcing ${CMAKE_SOURCE_DIR}/CPack${GENERATOR}.txt")
-        include(${CMAKE_SOURCE_DIR}/CPack${GENERATOR}.txt)
-    elseif(EXISTS ${CMAKE_BINARY_DIR}/CPack${GENERATOR}.txt)
-        message(STATUS "  Sourcing ${CMAKE_BINARY_DIR}/CPack${GENERATOR}.txt")
-        include(${CMAKE_BINARY_DIR}/CPack${GENERATOR}.txt)
+    if(EXISTS ${CMAKE_SOURCE_DIR}/CPack/${GENERATOR}.txt)
+        include(${CMAKE_SOURCE_DIR}/CPack/${GENERATOR}.txt)
     endif()
 endmacro()
 
@@ -21,7 +20,7 @@ set(CPACK_BINARY_TXZ 0)
 set(CPACK_BINARY_TZ 0)
 set(CPACK_BINARY_ZIP ${WIN32})
 set(CPACK_BINARY_NSIS ${WIN32})
-set(CPACK_BINARY_NUGET ${WIN32})
+set(CPACK_BINARY_NUGET 0)
 
 # source archive
 set(CPACK_SOURCE_TBZ2 0)
@@ -35,22 +34,37 @@ set(CPACK_PACKAGE_LICENSE "BSD-3-Clause")
 set(CPACK_PACKAGE_CONTACT "${PROJECT_CONTACT}")
 set(CPACK_PACKAGE_VENDOR "${PROJECT_CONTACT}")
 set(CPACK_PACKAGE_DESCRIPTION
-       "libmemcached is an open source C/C++ client library and tools for the
-memcached server (http://memcached.org/). It has been designed to be
-light on memory usage, thread safe, and provide full access to server
-side methods.")
-set(CPACK_PACKAGE_INSTALL_DIRECTORY "${CPACK_PACKAGE_NAME}/${CPACK_PACKAGE_VERSION}")
-#set(CPACK_PACKAGE_CHECKSUM SHA1)
+       "libmemcached-awesome is an open source C/C++ client library and tools
+for the memcached server (http://memcached.org/). It has been designed
+to be light on memory usage, thread safe, and provide full access to
+server side methods.")
+set(CPACK_PROJECT_CONFIG ${PROJECT_CONFIG})
+set(CPACK_PROJECT_CONFIG_FILE "${CMAKE_SOURCE_DIR}/CPack/ProjectConfig.txt")
+set(CPACK_PACKAGE_DESCRIPTION_FILE "${CMAKE_SOURCE_DIR}/README.md")
+set(CPACK_PACKAGE_INSTALL_DIRECTORY "${PROJECT_NAME}/${PROJECT_VERSION}")
+set(CPACK_PACKAGE_CHECKSUM SHA1)
 set(CPACK_RESOURCE_FILE_LICENSE "${CMAKE_SOURCE_DIR}/LICENSE")
 set(CPACK_RESOURCE_FILE_README "${CMAKE_SOURCE_DIR}/README.md")
 set(CPACK_CHANGELOG_FILE "${CMAKE_SOURCE_DIR}/ChangeLog-1.1.md")
+set(CPACK_PACKAGE_DIRECTORY "${CMAKE_BINARY_DIR}")
 
-set(CPACK_SOURCE_IGNORE_FILES "/[.]git/;/[.](idea|settings|c?project);~$;[.]log$;[.]bak$")
-
-set(CPACK_PACKAGE_FILE_NAME
-        "${CMAKE_PROJECT_NAME}-${CMAKE_PROJECT_VERSION}-${CMAKE_SYSTEM_NAME}-${CMAKE_SYSTEM_PROCESSOR}")
-
-set(CPACK_ARCHIVE_COMPONENT_INSTALL ${CPACK_COMPONENT_INSTALL})
+execute_process(
+        COMMAND git describe --tags --match [0-9]*.*
+        WORKING_DIRECTORY ${CMAKE_SOURCE_DIR}
+        OUTPUT_VARIABLE PROJECT_TAG
+        ERROR_VARIABLE GIT_ERROR_OUTPUT
+)
+if(GIT_ERROR_OUTPUT)
+    message(NOTICE "git describe: ${GIT_ERROR_OUTPUT}")
+endif()
+string(STRIP "${PROJECT_TAG}" PROJECT_TAG)
+if(PROJECT_TAG)
+    set(CPACK_PACKAGE_FILE_NAME ${PROJECT_NAME}-${PROJECT_TAG})
+    set(CPACK_PACKAGE_VERSION ${PROJECT_TAG})
+else()
+    set(CPACK_PACKAGE_FILE_NAME ${PROJECT_NAME}-${PROJECT_VERSION})
+    set(CPACK_PACKAGE_VERSION ${PROJECT_VERSION})
+endif()
 
 # dependencies
 if(HAVE_LIBSASL)
@@ -63,24 +77,35 @@ if(HAVE_LIBEVENT)
     string(APPEND CPACK_PACKAGE_DEPENDS " libevent")
 endif()
 
-
 # DEBs
-if(EXISTS /usr/bin/dpkg)
+find_program(DPKG dpkg)
+if(DPKG)
     cpack_include_if(DEB)
 endif()
 
-if(APPLE)
-endif()
-
-# BSDs
-if(CMAKE_SYSTEM_NAME MATCHES BSD)
-    cpack_include_if(BSD)
+# WIN
+if(WIN32)
+    cpack_include_if(NSIS)
 endif()
 
 # RPMs
-if(EXISTS /usr/bin/dnf OR EXISTS /usr/bin/yum OR EXISTS /usr/bin/rpmbuild)
+find_program(RPMBUILD rpmbuild)
+if(RPMBUILD)
     cpack_include_if(RPM)
 endif()
 
 # keep last
 include(CPack)
+
+set(PUSH_ARTIFACTS_SH "${CMAKE_SOURCE_DIR}/scripts/push-artifacts.sh")
+if(WIN32)
+    set(PUSH_ARTIFACTS_CMD msys2 -c '${PUSH_ARTIFACTS_SH} ${CPACK_PACKAGE_VERSION}')
+else()
+    set(PUSH_ARTIFACTS_CMD ${PUSH_ARTIFACTS_SH} ${CPACK_PACKAGE_VERSION})
+endif()
+
+add_custom_target(push-artifacts
+        COMMAND ${PUSH_ARTIFACTS_CMD}
+        WORKING_DIRECTORY ${CPACK_PACKAGE_DIRECTORY}
+        )
+