diff options
author | Daniel Schürmann <daschuer@mixxx.org> | 2020-12-09 01:57:43 +0100 |
---|---|---|
committer | Daniel Schürmann <daschuer@mixxx.org> | 2020-12-09 23:20:12 +0100 |
commit | 6f92dbffd2cf8c4ec4a08f5117b53864814304ce (patch) | |
tree | 068cbdee13456b99525aa3ad3056e7e7dec52142 /packaging/CPackDebUploadPPA.cmake | |
parent | 67ebbe0ddb632432747887f4b809acffc25961b5 (diff) |
Added CPack files for uploading PPA packages
Diffstat (limited to 'packaging/CPackDebUploadPPA.cmake')
-rw-r--r-- | packaging/CPackDebUploadPPA.cmake | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/packaging/CPackDebUploadPPA.cmake b/packaging/CPackDebUploadPPA.cmake new file mode 100644 index 0000000000..4e28eb24c3 --- /dev/null +++ b/packaging/CPackDebUploadPPA.cmake @@ -0,0 +1,62 @@ +# This file is executed during cpack time. +# The command is +# cpack -G External -D DEB_UPLOAD_PPA=true + +find_program(CPACK_DEBIAN_DEBUILD debuild) +if(NOT CPACK_DEBIAN_DEBUILD) + message(FATAL_ERROR "debuild not found, required for cpack -G External -D DEB_UPLOAD_PPA=true" ) +endif() + +find_program(CPACK_DEBIAN_DPUT dput) +if(NOT CPACK_DEBIAN_DPUT ) + message(FATAL_ERROR "dput not found, required for cpack -G External -D DEB_UPLOAD_PPA=true" ) +endif() + +find_program(CPACK_DEBIAN_DEBCHANGE debchange) +if(NOT CPACK_DEBIAN_DEBCHANGE) + message(FATAL_ERROR "debchange not found, required for cpack -G External -D DEB_UPLOAD_PPA=true" ) +endif() + +find_program(CPACK_DEBIAN_MARKDOWN markdown) +if(NOT CPACK_DEBIAN_MARKDOWN) + message(FATAL_ERROR "debchange not found, required for cpack -G External -D DEB_UPLOAD_PPA=true" ) +endif() + + +message( NOTICE "Creating mixxx_${CPACK_DEBIAN_UPSTREAM_VERSION}.orig.tar.gz" ) +execute_process( + COMMAND tar -czf "mixxx_${CPACK_DEBIAN_UPSTREAM_VERSION}.orig.tar.gz" ${CPACK_PACKAGE_FILE_NAME} + WORKING_DIRECTORY ${CPACK_TOPLEVEL_DIRECTORY} +) + +message( NOTICE "Creating debian folder" ) +file(COPY ${CPACK_TOPLEVEL_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME}/packaging/debian + DESTINATION ${CPACK_TOPLEVEL_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME}) + +execute_process( + COMMAND ${CPACK_DEBIAN_MARKDOWN} ${CPACK_TOPLEVEL_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME}/CHANGELOG.md -o NEWS.html + WORKING_DIRECTORY ${CPACK_TOPLEVEL_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME}/debian +) + +configure_file(${CPACK_TOPLEVEL_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME}/debian/control.in + ${CPACK_TOPLEVEL_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME}/debian/control + @ONLY) +file(REMOVE ${CPACK_TOPLEVEL_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME}/debian/control.in) + + +foreach(RELEASE ${CPACK_DEBIAN_DISTRIBUTION_RELEASES}) + + file(COPY ${CPACK_TOPLEVEL_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME}/packaging/debian/changelog + DESTINATION ${CPACK_TOPLEVEL_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME}/debian) + execute_process(COMMAND ${CPACK_DEBIAN_DEBCHANGE} -v "${CPACK_DEBIAN_UPSTREAM_VERSION}-${CPACK_DEBIAN_DEBIAN_VERSION}~${CPACK_DEBIAN_DEBIAN_VERSION_EXTRA}~${RELEASE}" -M "Build of ${CPACK_DEBIAN_UPSTREAM_VERSION}" + WORKING_DIRECTORY ${CPACK_TOPLEVEL_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME}) + execute_process(COMMAND ${CPACK_DEBIAN_DEBCHANGE} -r -D ${RELEASE} -M "Build of ${CPACK_DEBIAN_UPSTREAM_VERSION}" + WORKING_DIRECTORY ${CPACK_TOPLEVEL_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME}) + + execute_process(COMMAND ${CPACK_DEBIAN_DEBUILD} -S -sa + WORKING_DIRECTORY ${CPACK_TOPLEVEL_DIRECTORY}/${CPACK_PACKAGE_FILE_NAME} + RESULT_VARIABLE CPACK_DEBIAN_DEBUILD_RET) + if(NOT CPACK_DEBIAN_DEBUILD_RET EQUAL "0") + message(FATAL_ERROR "${CPACK_DEBIAN_DEBUILD} retuned exit code ${CPACK_DEBIAN_DEBUILD_RET}") + endif() +endforeach(RELEASE ${CPACK_DEBIAN_DISTRIBUTION_RELEASES}) |