X-Git-Url: https://git.m6w6.name/?a=blobdiff_plain;f=CPack.txt;h=1a4d77dc9433f6ac4a3b5071ade4d5f18c8340ab;hb=refs%2Fheads%2Fv1.x;hp=97221b621a8ee4c981e28d480394550f318b9f29;hpb=c0f50dec5334f54cf060b1f9c4250c72649b4ff2;p=awesomized%2Flibmemcached diff --git a/CPack.txt b/CPack.txt index 97221b62..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() @@ -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} + ) +