X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=CPack.txt;h=1a4d77dc9433f6ac4a3b5071ade4d5f18c8340ab;hb=refs%2Fheads%2Ftest%2Fpoll_timeout;hp=386bb131a6ece1ecde3141757c121075e8a5668b;hpb=8ba89beac798e2b3d1f96b46471e3b58d8c61d1d;p=awesomized%2Flibmemcached diff --git a/CPack.txt b/CPack.txt index 386bb131..1a4d77dc 100644 --- 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() @@ -35,23 +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_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}) -set(CMAKE_INSTALL_DEFAULT_COMPONENT_NAME lib) +set(CPACK_PACKAGE_DIRECTORY "${CMAKE_BINARY_DIR}") + +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) @@ -64,28 +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() - +# WIN if(WIN32) cpack_include_if(NSIS) endif() -# BSDs -if(CMAKE_SYSTEM_NAME MATCHES BSD) - cpack_include_if(BSD) -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} + ) +