Merge pull request #79 from akdor1154/versioningFix
Implement basic DEB/RPM packaging
This commit is contained in:
commit
e19f73c6bf
|
@ -391,4 +391,6 @@ endif()
|
||||||
add_custom_target(check DEPENDS ${CHECK_TARGETS})
|
add_custom_target(check DEPENDS ${CHECK_TARGETS})
|
||||||
# }}}
|
# }}}
|
||||||
|
|
||||||
|
INCLUDE(${CMAKE_SOURCE_DIR}/Packaging.cmake)
|
||||||
|
|
||||||
# vim: filetype=cmake:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80:foldmethod=marker
|
# vim: filetype=cmake:expandtab:shiftwidth=4:tabstop=8:softtabstop=4:textwidth=80:foldmethod=marker
|
||||||
|
|
|
@ -0,0 +1,62 @@
|
||||||
|
if(NOT VERSION)
|
||||||
|
set(VERSION "unknown")
|
||||||
|
endif()
|
||||||
|
|
||||||
|
string(REGEX REPLACE "^v?([0-9.]+)-?(.*)$"
|
||||||
|
"\\1;\\2" version_result ${VERSION})
|
||||||
|
|
||||||
|
list(LENGTH version_result version_result_list_length)
|
||||||
|
|
||||||
|
if(version_result_list_length EQUAL 2)
|
||||||
|
list(GET version_result 0 version_num)
|
||||||
|
list(GET version_result 1 version_gitstamp)
|
||||||
|
else(version_result_list_length EQUAL 2)
|
||||||
|
message("Unable to deduce a meaningful version number. \
|
||||||
|
Set OVERRIDE_VERSION when you run CMake (cmake .. -DOVERRIDE_VERSION=3.14.159), or \
|
||||||
|
just build from a git repository.")
|
||||||
|
set(version_num "0.0.0")
|
||||||
|
set(version_gitstamp "")
|
||||||
|
endif(version_result_list_length EQUAL 2)
|
||||||
|
|
||||||
|
if(version_gitstamp)
|
||||||
|
set(version_gitsuffix "~git${version_gitstamp}")
|
||||||
|
else(version_gitstamp)
|
||||||
|
set(version_gitsuffix "")
|
||||||
|
endif(version_gitstamp)
|
||||||
|
|
||||||
|
string(REGEX REPLACE "([0-9]+)\\.([0-9]+)\\.([0-9]+)"
|
||||||
|
"\\1;\\2;\\3" version_num_split ${version_num})
|
||||||
|
|
||||||
|
list(APPEND version_num_split 0 0 0) #ensure the list(GET )) commands below never fail
|
||||||
|
|
||||||
|
list(GET version_num_split 0 CPACK_PACKAGE_VERSION_MAJOR)
|
||||||
|
list(GET version_num_split 1 CPACK_PACKAGE_VERSION_MINOR)
|
||||||
|
list(GET version_num_split 2 CPACK_PACKAGE_VERSION_PATCH)
|
||||||
|
|
||||||
|
set(version_num "${CPACK_PACKAGE_VERSION_MAJOR}.${CPACK_PACKAGE_VERSION_MINOR}.${CPACK_PACKAGE_VERSION_PATCH}")
|
||||||
|
|
||||||
|
message(STATUS "Package version will be set to ${version_num}${version_gitsuffix}.")
|
||||||
|
|
||||||
|
set(CPACK_PACKAGE_VERSION "${version_num}${version_gitsuffix}")
|
||||||
|
|
||||||
|
if(NOT CPACK_GENERATOR)
|
||||||
|
find_program(rpmbuild_path "rpmbuild")
|
||||||
|
if(rpmbuild_path)
|
||||||
|
message(STATUS "rpmbuild found, enabling RPM for the 'package' target")
|
||||||
|
list(APPEND CPACK_GENERATOR RPM)
|
||||||
|
endif(rpmbuild_path)
|
||||||
|
|
||||||
|
find_program(dpkg_path "dpkg")
|
||||||
|
if (dpkg_path)
|
||||||
|
message(STATUS "dpkg found, enabling DEB for the 'package' target")
|
||||||
|
list(APPEND CPACK_GENERATOR DEB)
|
||||||
|
endif(dpkg_path)
|
||||||
|
endif(NOT CPACK_GENERATOR)
|
||||||
|
|
||||||
|
set(CPACK_PACKAGE_NAME "awesome")
|
||||||
|
set(CPACK_DEBIAN_PACKAGE_MAINTAINER "devnull@example.com")
|
||||||
|
set(CPACK_PACKAGE_DESCRIPTION_SUMMARY "A tiling window manager")
|
||||||
|
|
||||||
|
if(CPACK_GENERATOR)
|
||||||
|
include(CPack)
|
||||||
|
endif()
|
|
@ -12,10 +12,18 @@ After extracting the dist tarball, run:
|
||||||
|
|
||||||
This will create a build directory, run cmake in it and build awesome.
|
This will create a build directory, run cmake in it and build awesome.
|
||||||
|
|
||||||
After building is finished, you can install:
|
After building is finished, you can either install via `make install`:
|
||||||
|
|
||||||
make install # you might need root permissions
|
make install # you might need root permissions
|
||||||
|
|
||||||
|
or by auto-generating a .deb or .rpm package, for easy removal later on:
|
||||||
|
|
||||||
|
make package
|
||||||
|
|
||||||
|
sudo dpkg -i awesome-x.y.z.deb
|
||||||
|
# or
|
||||||
|
sudo rpm -Uvh awesome-x.y.z.rpm
|
||||||
|
|
||||||
## Running awesome
|
## Running awesome
|
||||||
|
|
||||||
You can directly select awesome from your display manager. If not, you can
|
You can directly select awesome from your display manager. If not, you can
|
||||||
|
|
Loading…
Reference in New Issue