mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-11 13:49:23 -05:00
cmake: Generate documentation.
To prevent complicating the dependencies of a core tool, a new variant, CMAKE-MINIMAL is introduced and the CMake build system is configured to use it by default. The regular CMAKE package gains a manpage, info manual as well as HTML documentation. Fixes issue #33497 (https://bugs.gnu.org/33497). * gnu/packages/cmake.scm (gnu): Use modules (gnu packages python-xyz), (gnu packages texinfo) and (srfi srfi-1). (cmake-minimal): Rename the original cmake variable to this. [phases]{configure}: Extract the configure script arguments to... [configure-flags]: here. [properties]: Set the HIDDEN? property to #t. (cmake): New variable, which inherits from CMAKE-MINIMAL. [phases]{move-html-doc}: Add phase. [native-inputs]: Add PYTHON-SPHINX and TEXINFO. [outputs]: Add the "doc" output. [properties]: Clear the inherited HIDDEN? property. * guix/build-system/cmake.scm (default-cmake): Use CMAKE-MINIMAL instead of CMAKE.
This commit is contained in:
parent
e16cf2666f
commit
2f33a7321e
2 changed files with 70 additions and 26 deletions
|
@ -8,6 +8,8 @@
|
||||||
;;; Copyright © 2017, 2018 Marius Bakke <mbakke@fastmail.com>
|
;;; Copyright © 2017, 2018 Marius Bakke <mbakke@fastmail.com>
|
||||||
;;; Copyright © 2018 Arun Isaac <arunisaac@systemreboot.net>
|
;;; Copyright © 2018 Arun Isaac <arunisaac@systemreboot.net>
|
||||||
;;; Copyright © 2018 Tobias Geerinckx-Rice <me@tobias.gr>
|
;;; Copyright © 2018 Tobias Geerinckx-Rice <me@tobias.gr>
|
||||||
|
;;; Copyright © 2019 Maxim Cournoyer <maxim.cournoyer@gmail.com>
|
||||||
|
|
||||||
;;;
|
;;;
|
||||||
;;; This file is part of GNU Guix.
|
;;; This file is part of GNU Guix.
|
||||||
;;;
|
;;;
|
||||||
|
@ -39,11 +41,16 @@ (define-module (gnu packages cmake)
|
||||||
#:use-module (gnu packages file)
|
#:use-module (gnu packages file)
|
||||||
#:use-module (gnu packages libevent)
|
#:use-module (gnu packages libevent)
|
||||||
#:use-module (gnu packages ncurses)
|
#:use-module (gnu packages ncurses)
|
||||||
#:use-module (gnu packages xml))
|
#:use-module (gnu packages python-xyz)
|
||||||
|
#:use-module (gnu packages texinfo)
|
||||||
|
#:use-module (gnu packages xml)
|
||||||
|
#:use-module (srfi srfi-1))
|
||||||
|
|
||||||
(define-public cmake
|
;;; This minimal variant of CMake does not include the documentation. It is
|
||||||
|
;;; used by the cmake-build-system.
|
||||||
|
(define-public cmake-minimal
|
||||||
(package
|
(package
|
||||||
(name "cmake")
|
(name "cmake-minimal")
|
||||||
(version "3.14.0")
|
(version "3.14.0")
|
||||||
(source (origin
|
(source (origin
|
||||||
(method url-fetch)
|
(method url-fetch)
|
||||||
|
@ -72,6 +79,23 @@ (define-public cmake
|
||||||
(build-system gnu-build-system)
|
(build-system gnu-build-system)
|
||||||
(arguments
|
(arguments
|
||||||
`(#:test-target "test"
|
`(#:test-target "test"
|
||||||
|
#:configure-flags
|
||||||
|
(let ((out (assoc-ref %outputs "out"))
|
||||||
|
(parallel-job-count (number->string (parallel-job-count))))
|
||||||
|
(list "--verbose"
|
||||||
|
(string-append "--parallel=" parallel-job-count)
|
||||||
|
(string-append "--prefix=" out)
|
||||||
|
"--system-libs"
|
||||||
|
"--no-system-jsoncpp" ; FIXME: Circular dependency.
|
||||||
|
;; By default, the man pages and other docs land
|
||||||
|
;; in PREFIX/man and PREFIX/doc, but we want them
|
||||||
|
;; in share/{man,doc}. Note that unlike
|
||||||
|
;; autoconf-generated configure scripts, cmake's
|
||||||
|
;; configure prepends "PREFIX/" to what we pass
|
||||||
|
;; to --mandir and --docdir.
|
||||||
|
"--mandir=share/man"
|
||||||
|
,(string-append "--docdir=share/doc/cmake-"
|
||||||
|
(version-major+minor version))))
|
||||||
#:make-flags
|
#:make-flags
|
||||||
(let ((skipped-tests
|
(let ((skipped-tests
|
||||||
(list "BundleUtilities" ; This test fails on Guix.
|
(list "BundleUtilities" ; This test fails on Guix.
|
||||||
|
@ -119,25 +143,10 @@ (define-public cmake
|
||||||
(setenv "CMAKE_INCLUDE_PATH" (or (getenv "CPATH")
|
(setenv "CMAKE_INCLUDE_PATH" (or (getenv "CPATH")
|
||||||
(getenv "C_INCLUDE_PATH")))
|
(getenv "C_INCLUDE_PATH")))
|
||||||
#t)))
|
#t)))
|
||||||
|
;; CMake uses its own configure script.
|
||||||
(replace 'configure
|
(replace 'configure
|
||||||
(lambda* (#:key outputs #:allow-other-keys)
|
(lambda* (#:key (configure-flags '()) #:allow-other-keys)
|
||||||
(let ((out (assoc-ref outputs "out")))
|
(apply invoke "./configure" configure-flags))))))
|
||||||
(invoke
|
|
||||||
"./configure" "--verbose"
|
|
||||||
(string-append "--parallel=" (number->string (parallel-job-count)))
|
|
||||||
(string-append "--prefix=" out)
|
|
||||||
"--system-libs"
|
|
||||||
"--no-system-jsoncpp" ; FIXME: Circular dependency.
|
|
||||||
;; By default, the man pages and other docs land
|
|
||||||
;; in PREFIX/man and PREFIX/doc, but we want them
|
|
||||||
;; in share/{man,doc}. Note that unlike
|
|
||||||
;; autoconf-generated configure scripts, cmake's
|
|
||||||
;; configure prepends "PREFIX/" to what we pass
|
|
||||||
;; to --mandir and --docdir.
|
|
||||||
"--mandir=share/man"
|
|
||||||
,(string-append
|
|
||||||
"--docdir=share/doc/cmake-"
|
|
||||||
(version-major+minor version)))))))))
|
|
||||||
(inputs
|
(inputs
|
||||||
`(("bzip2" ,bzip2)
|
`(("bzip2" ,bzip2)
|
||||||
("curl" ,curl)
|
("curl" ,curl)
|
||||||
|
@ -159,12 +168,47 @@ (define-public cmake
|
||||||
CMake is used to control the software compilation process using simple platform
|
CMake is used to control the software compilation process using simple platform
|
||||||
and compiler independent configuration files. CMake generates native makefiles
|
and compiler independent configuration files. CMake generates native makefiles
|
||||||
and workspaces that can be used in the compiler environment of your choice.")
|
and workspaces that can be used in the compiler environment of your choice.")
|
||||||
(license (list license:bsd-3 ; cmake
|
(properties '((hidden? . #t)))
|
||||||
license:bsd-4 ; cmcompress
|
(license (list license:bsd-3 ; cmake
|
||||||
license:bsd-2 ; cmlibarchive
|
license:bsd-4 ; cmcompress
|
||||||
license:expat ; cmjsoncpp is dual MIT/public domain
|
license:bsd-2 ; cmlibarchive
|
||||||
|
license:expat ; cmjsoncpp is dual MIT/public domain
|
||||||
license:public-domain)))) ; cmlibarchive/archive_getdate.c
|
license:public-domain)))) ; cmlibarchive/archive_getdate.c
|
||||||
|
|
||||||
|
(define-public cmake
|
||||||
|
(package
|
||||||
|
(inherit cmake-minimal)
|
||||||
|
(name "cmake")
|
||||||
|
(arguments
|
||||||
|
(substitute-keyword-arguments (package-arguments cmake-minimal)
|
||||||
|
((#:configure-flags configure-flags ''())
|
||||||
|
`(append ,configure-flags
|
||||||
|
;; Extra configure flags used to generate the documentation.
|
||||||
|
'("--sphinx-info"
|
||||||
|
"--sphinx-man"
|
||||||
|
"--sphinx-html")))
|
||||||
|
((#:phases phases)
|
||||||
|
`(modify-phases ,phases
|
||||||
|
(add-after 'install 'move-html-doc
|
||||||
|
(lambda* (#:key outputs #:allow-other-keys)
|
||||||
|
(let ((out (assoc-ref outputs "out"))
|
||||||
|
(doc (assoc-ref outputs "doc"))
|
||||||
|
(html (string-append "/share/doc/cmake-"
|
||||||
|
,(version-major+minor
|
||||||
|
(package-version cmake-minimal))
|
||||||
|
"/html")))
|
||||||
|
(copy-recursively (string-append out html)
|
||||||
|
(string-append doc html))
|
||||||
|
(delete-file-recursively (string-append out html))
|
||||||
|
#t)))))))
|
||||||
|
;; Extra inputs required to build the documentation.
|
||||||
|
(native-inputs
|
||||||
|
`(,@(package-native-inputs cmake-minimal)
|
||||||
|
("python-sphinx" ,python-sphinx)
|
||||||
|
("texinfo" ,texinfo)))
|
||||||
|
(outputs '("out" "doc"))
|
||||||
|
(properties (alist-delete 'hidden? (package-properties cmake-minimal)))))
|
||||||
|
|
||||||
(define-public emacs-cmake-mode
|
(define-public emacs-cmake-mode
|
||||||
(package
|
(package
|
||||||
(inherit cmake)
|
(inherit cmake)
|
||||||
|
|
|
@ -48,7 +48,7 @@ (define (default-cmake)
|
||||||
|
|
||||||
;; Do not use `@' to avoid introducing circular dependencies.
|
;; Do not use `@' to avoid introducing circular dependencies.
|
||||||
(let ((module (resolve-interface '(gnu packages cmake))))
|
(let ((module (resolve-interface '(gnu packages cmake))))
|
||||||
(module-ref module 'cmake)))
|
(module-ref module 'cmake-minimal)))
|
||||||
|
|
||||||
(define* (lower name
|
(define* (lower name
|
||||||
#:key source inputs native-inputs outputs system target
|
#:key source inputs native-inputs outputs system target
|
||||||
|
|
Loading…
Reference in a new issue