2014-04-24 18:03:36 -04:00
|
|
|
;;; GNU Guix --- Functional package management for GNU
|
2018-03-11 16:46:30 -04:00
|
|
|
;;; Copyright © 2014, 2018 Ludovic Courtès <ludo@gnu.org>
|
2016-01-20 07:09:53 -05:00
|
|
|
;;; Copyright © 2014, 2016 Andreas Enge <andreas@enge.fr>
|
2016-03-16 11:18:21 -04:00
|
|
|
;;; Copyright © 2016 Eric Bavier <bavier@member.fsf.org>
|
2016-07-04 15:32:31 -04:00
|
|
|
;;; Copyright © 2016 Roel Janssen <roel@gnu.org>
|
2017-01-03 06:58:28 -05:00
|
|
|
;;; Copyright © 2016 Thomas Danckaert <post@thomasdanckaert.be>
|
2017-08-27 22:27:56 -04:00
|
|
|
;;; Copyright © 2017 Kei Kebreau <kkebreau@posteo.net>
|
2020-07-26 15:19:12 -04:00
|
|
|
;;; Copyright © 2017, 2020 Efraim Flashner <efraim@flashner.co.il>
|
2018-02-06 09:53:15 -05:00
|
|
|
;;; Copyright © 2018 Tobias Geerinckx-Rice <me@tobias.gr>
|
2019-08-02 05:35:37 -04:00
|
|
|
;;; Copyright © 2019 Mathieu Othacehe <m.othacehe@gmail.com>
|
2020-03-03 06:52:46 -05:00
|
|
|
;;; Copyright © 2020 Ricardo Wurmus <rekado@elephly.net>
|
2020-07-30 01:39:45 -04:00
|
|
|
;;; Copyright © 2020 Michael Rohleder <mike@rohleder.de>
|
2014-04-24 18:03:36 -04:00
|
|
|
;;;
|
|
|
|
;;; This file is part of GNU Guix.
|
|
|
|
;;;
|
|
|
|
;;; GNU Guix is free software; you can redistribute it and/or modify it
|
|
|
|
;;; under the terms of the GNU General Public License as published by
|
|
|
|
;;; the Free Software Foundation; either version 3 of the License, or (at
|
|
|
|
;;; your option) any later version.
|
|
|
|
;;;
|
|
|
|
;;; GNU Guix is distributed in the hope that it will be useful, but
|
|
|
|
;;; WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
;;; GNU General Public License for more details.
|
|
|
|
;;;
|
|
|
|
;;; You should have received a copy of the GNU General Public License
|
|
|
|
;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
2016-03-16 11:12:47 -04:00
|
|
|
(define-module (gnu packages documentation)
|
|
|
|
#:use-module (guix licenses)
|
2014-04-24 18:03:36 -04:00
|
|
|
#:use-module (guix packages)
|
|
|
|
#:use-module (guix download)
|
2020-03-03 06:52:46 -05:00
|
|
|
#:use-module (guix git-download)
|
2016-03-16 11:12:47 -04:00
|
|
|
#:use-module (guix build-system gnu)
|
2016-01-20 07:09:53 -05:00
|
|
|
#:use-module (guix build-system cmake)
|
2020-07-30 01:39:45 -04:00
|
|
|
#:use-module (guix build-system qt)
|
2014-04-24 18:03:36 -04:00
|
|
|
#:use-module (gnu packages)
|
2018-02-06 09:53:15 -05:00
|
|
|
#:use-module (gnu packages autotools)
|
2020-07-30 01:39:45 -04:00
|
|
|
#:use-module (gnu packages backup)
|
2019-08-02 05:35:37 -04:00
|
|
|
#:use-module (gnu packages base)
|
2017-01-03 06:58:28 -05:00
|
|
|
#:use-module (gnu packages bash)
|
2016-03-16 11:12:47 -04:00
|
|
|
#:use-module (gnu packages python)
|
2014-04-24 18:03:36 -04:00
|
|
|
#:use-module (gnu packages bison)
|
2020-07-30 01:39:45 -04:00
|
|
|
#:use-module (gnu packages kde-frameworks)
|
2016-07-04 15:32:31 -04:00
|
|
|
#:use-module (gnu packages docbook)
|
2014-04-24 18:03:36 -04:00
|
|
|
#:use-module (gnu packages flex)
|
2014-04-24 18:31:41 -04:00
|
|
|
#:use-module (gnu packages graphviz)
|
2016-03-16 11:18:21 -04:00
|
|
|
#:use-module (gnu packages gettext)
|
2016-07-04 15:32:31 -04:00
|
|
|
#:use-module (gnu packages glib)
|
2014-04-24 18:03:36 -04:00
|
|
|
#:use-module (gnu packages perl)
|
2020-07-30 01:39:45 -04:00
|
|
|
#:use-module (gnu packages pkg-config)
|
|
|
|
#:use-module (gnu packages qt)
|
|
|
|
#:use-module (gnu packages sqlite)
|
|
|
|
#:use-module (gnu packages xml)
|
|
|
|
#:use-module (gnu packages xorg))
|
2016-03-16 11:12:47 -04:00
|
|
|
|
|
|
|
(define-public asciidoc
|
|
|
|
(package
|
|
|
|
(name "asciidoc")
|
2018-02-06 09:53:15 -05:00
|
|
|
(version "8.6.10")
|
2016-03-16 11:12:47 -04:00
|
|
|
(source (origin
|
2020-07-26 15:19:12 -04:00
|
|
|
(method git-fetch)
|
|
|
|
(uri (git-reference
|
|
|
|
(url "https://github.com/asciidoc/asciidoc")
|
|
|
|
(commit version)))
|
|
|
|
(file-name (git-file-name name version))
|
2016-03-16 11:12:47 -04:00
|
|
|
(sha256
|
|
|
|
(base32
|
2020-07-26 15:19:12 -04:00
|
|
|
"1hrqkgjmp1gq3f9rkbr8l0y62fzvwb9n8ys35s25bg2ld04y4g4y"))))
|
2016-03-16 11:12:47 -04:00
|
|
|
(build-system gnu-build-system)
|
2016-08-19 15:08:43 -04:00
|
|
|
(arguments
|
|
|
|
`(#:tests? #f ; no 'check' target
|
|
|
|
#:phases
|
|
|
|
(modify-phases %standard-phases
|
2018-03-25 00:23:44 -04:00
|
|
|
(replace 'bootstrap
|
|
|
|
(lambda _
|
|
|
|
(invoke "autoconf")))
|
2017-03-12 17:46:28 -04:00
|
|
|
;; Some XML-related binaries are required for asciidoc's proper usage.
|
|
|
|
;; Without these, asciidoc fails when parsing XML documents, either
|
|
|
|
;; reporting a missing "xmllint" binary or, when passed the
|
|
|
|
;; "--no-xmllint" option, a missing "xsltproc" binary.
|
|
|
|
;; The following phase enables asciidoc to find some of them.
|
|
|
|
(add-before 'configure 'set-xml-binary-paths
|
|
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
|
|
(let* ((libxml2 (assoc-ref inputs "libxml2"))
|
|
|
|
(xmllint (string-append libxml2 "/bin/xmllint"))
|
|
|
|
(libxslt (assoc-ref inputs "libxslt"))
|
|
|
|
(xsltproc (string-append libxslt "/bin/xsltproc")))
|
|
|
|
(substitute* "a2x.py"
|
|
|
|
(("XMLLINT = 'xmllint'")
|
|
|
|
(string-append "XMLLINT = '" xmllint "'"))
|
|
|
|
(("XSLTPROC = 'xsltproc'")
|
|
|
|
(string-append "XSLTPROC = '" xsltproc "'")))
|
|
|
|
#t)))
|
2016-08-19 15:08:43 -04:00
|
|
|
;; Make asciidoc use the local docbook-xsl package instead of fetching
|
|
|
|
;; it from the internet at run-time.
|
|
|
|
(add-before 'install 'make-local-docbook-xsl
|
|
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
|
|
(substitute* (find-files "docbook-xsl" ".*\\.xsl$")
|
|
|
|
(("xsl:import href=\"http://docbook.sourceforge.net/\
|
|
|
|
release/xsl/current")
|
|
|
|
(string-append
|
|
|
|
"xsl:import href=\""
|
|
|
|
(string-append (assoc-ref inputs "docbook-xsl")
|
|
|
|
"/xml/xsl/docbook-xsl-"
|
|
|
|
,(package-version docbook-xsl)))))
|
2017-03-16 01:37:42 -04:00
|
|
|
#t))
|
|
|
|
;; Do the same for docbook-xml.
|
|
|
|
(add-before 'install 'make-local-docbook-xml
|
|
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
|
|
(substitute* "docbook45.conf"
|
|
|
|
(("http://www.oasis-open.org/docbook/xml/4.5/docbookx.dtd")
|
|
|
|
(string-append (assoc-ref inputs "docbook-xml")
|
|
|
|
"/xml/dtd/docbook/docbookx.dtd")))
|
2016-08-19 15:08:43 -04:00
|
|
|
#t)))))
|
2018-02-06 09:53:15 -05:00
|
|
|
(native-inputs
|
|
|
|
`(("autoconf" ,autoconf)))
|
2016-08-19 15:08:43 -04:00
|
|
|
(inputs `(("python" ,python-2)
|
2017-03-16 01:37:42 -04:00
|
|
|
("docbook-xml" ,docbook-xml)
|
2017-03-12 17:46:28 -04:00
|
|
|
("docbook-xsl" ,docbook-xsl)
|
|
|
|
("libxml2" ,libxml2)
|
|
|
|
("libxslt" ,libxslt)))
|
2020-06-10 11:19:02 -04:00
|
|
|
(home-page "https://asciidoc.org/")
|
2016-03-16 11:12:47 -04:00
|
|
|
(synopsis "Text-based document generation system")
|
|
|
|
(description
|
|
|
|
"AsciiDoc is a text document format for writing notes, documentation,
|
|
|
|
articles, books, ebooks, slideshows, web pages, man pages and blogs.
|
|
|
|
AsciiDoc files can be translated to many formats including HTML, PDF,
|
|
|
|
EPUB, man page.
|
|
|
|
|
|
|
|
AsciiDoc is highly configurable: both the AsciiDoc source file syntax and
|
|
|
|
the backend output markups (which can be almost any type of SGML/XML
|
|
|
|
markup) can be customized and extended by the user.")
|
|
|
|
(license gpl2+)))
|
2014-04-24 18:03:36 -04:00
|
|
|
|
2020-03-03 06:52:46 -05:00
|
|
|
(define-public asciidoc-py3
|
|
|
|
(package (inherit asciidoc)
|
|
|
|
(name "asciidoc-py3")
|
2020-06-28 08:13:09 -04:00
|
|
|
(version "9.0.1")
|
2020-03-03 06:52:46 -05:00
|
|
|
(source (origin
|
|
|
|
(method git-fetch)
|
|
|
|
(uri (git-reference
|
|
|
|
(url "https://github.com/asciidoc/asciidoc-py3/")
|
|
|
|
(commit version)))
|
|
|
|
(file-name (git-file-name name version))
|
|
|
|
(sha256
|
|
|
|
(base32
|
2020-06-28 08:13:09 -04:00
|
|
|
"1xpws5lgzaqwgbc7sq6bp8adjxy8qb4qb9nj4vvpxamjgx3pny54"))))
|
2020-03-03 06:52:46 -05:00
|
|
|
(build-system gnu-build-system)
|
|
|
|
(native-inputs
|
|
|
|
`(("autoconf" ,autoconf)))
|
|
|
|
(inputs
|
|
|
|
`(("python" ,python)
|
|
|
|
("docbook-xml" ,docbook-xml)
|
|
|
|
("docbook-xsl" ,docbook-xsl)
|
|
|
|
("libxml2" ,libxml2)
|
|
|
|
("libxslt" ,libxslt)))))
|
|
|
|
|
2014-04-24 18:03:36 -04:00
|
|
|
(define-public doxygen
|
|
|
|
(package
|
|
|
|
(name "doxygen")
|
2020-01-08 11:10:47 -05:00
|
|
|
(version "1.8.17")
|
2019-02-13 14:24:06 -05:00
|
|
|
(home-page "http://www.doxygen.nl/")
|
2014-04-24 18:03:36 -04:00
|
|
|
(source (origin
|
|
|
|
(method url-fetch)
|
2019-02-13 14:24:06 -05:00
|
|
|
(uri (list (string-append home-page "files/doxygen-"
|
|
|
|
version ".src.tar.gz")
|
|
|
|
(string-append "mirror://sourceforge/doxygen/rel-"
|
|
|
|
version "/doxygen-" version
|
|
|
|
".src.tar.gz")))
|
2014-04-24 18:03:36 -04:00
|
|
|
(sha256
|
|
|
|
(base32
|
2020-01-08 11:10:47 -05:00
|
|
|
"16dmv0gm1x8rvbm82fmjvi213q8fxqxinm75pcf595flya59ific"))
|
|
|
|
(patches (search-patches "doxygen-test.patch"
|
|
|
|
"doxygen-1.8.17-runtests.patch"))))
|
2016-01-20 07:09:53 -05:00
|
|
|
(build-system cmake-build-system)
|
2014-04-24 18:03:36 -04:00
|
|
|
(native-inputs
|
|
|
|
`(("bison" ,bison)
|
2019-07-07 14:00:21 -04:00
|
|
|
("flex" ,flex)
|
2019-07-07 14:07:22 -04:00
|
|
|
("libxml2" ,libxml2) ;provides xmllint for the tests
|
|
|
|
("python" ,python))) ;for creating the documentation
|
2017-01-03 06:58:28 -05:00
|
|
|
(inputs
|
2018-08-22 10:45:17 -04:00
|
|
|
`(("bash" ,bash-minimal)))
|
2014-04-24 18:03:36 -04:00
|
|
|
(arguments
|
2019-08-02 05:35:37 -04:00
|
|
|
;; Force cmake to use iconv header from cross-libc instead of the one
|
|
|
|
;; from native libc.
|
|
|
|
`(,@(if (%current-target-system)
|
|
|
|
'(#:configure-flags
|
|
|
|
(list (string-append "-DICONV_INCLUDE_DIR="
|
|
|
|
(assoc-ref %build-inputs "cross-libc")
|
|
|
|
"/include")))
|
|
|
|
'())
|
|
|
|
#:test-target "tests"
|
2017-01-03 06:58:28 -05:00
|
|
|
#:phases (modify-phases %standard-phases
|
|
|
|
(add-before 'configure 'patch-sh
|
|
|
|
(lambda* (#:key inputs #:allow-other-keys)
|
|
|
|
(substitute* "src/portable.cpp"
|
|
|
|
(("/bin/sh")
|
|
|
|
(string-append
|
|
|
|
(assoc-ref inputs "bash") "/bin/sh")))
|
|
|
|
#t)))))
|
gnu: Some cleanup based on lint checkers.
* gnu/packages/admin.scm, gnu/packages/aidc.scm, gnu/packages/algebra.scm,
gnu/packages/apr.scm, gnu/packages/avahi.scm, gnu/packages/backup.scm,
gnu/packages/base.scm, gnu/packages/calcurse.scm, gnu/packages/cdrom.scm,
gnu/packages/check.scm, gnu/packages/compression.scm, gnu/packages/cook.scm,
gnu/packages/crypto.scm, gnu/packages/cryptsetup.scm, gnu/packages/curl.scm,
gnu/packages/cyrus-sasl.scm, gnu/packages/databases.scm,
gnu/packages/doxygen.scm, gnu/packages/dwm.scm, gnu/packages/elf.scm,
gnu/packages/emacs.scm, gnu/packages/feh.scm, gnu/packages/file.scm,
gnu/packages/fish.scm, gnu/packages/flex.scm, gnu/packages/fltk.scm,
gnu/packages/fontutils.scm, gnu/packages/games.scm, gnu/packages/gcal.scm,
gnu/packages/gcc.scm, gnu/packages/geeqie.scm, gnu/packages/ghostscript.scm,
gnu/packages/gimp.scm, gnu/packages/gl.scm, gnu/packages/glib.scm,
gnu/packages/gnome.scm, gnu/packages/gnunet.scm, gnu/packages/gnupg.scm,
gnu/packages/gperf.scm, gnu/packages/grub.scm, gnu/packages/gsasl.scm,
gnu/packages/gtk.scm, gnu/packages/guile-wm.scm, gnu/packages/guile.scm,
gnu/packages/hurd.scm, gnu/packages/icu4c.scm, gnu/packages/image.scm,
gnu/packages/imagemagick.scm, gnu/packages/irssi.scm, gnu/packages/kde.scm,
gnu/packages/libdaemon.scm, gnu/packages/libevent.scm,
gnu/packages/libidn.scm, gnu/packages/libusb.scm, gnu/packages/linux.scm,
gnu/packages/lout.scm, gnu/packages/lsh.scm, gnu/packages/lsof.scm,
gnu/packages/lua.scm, gnu/packages/maths.scm, gnu/packages/mcrypt.scm,
gnu/packages/mp3.scm, gnu/packages/netpbm.scm, gnu/packages/noweb.scm,
gnu/packages/ocaml.scm, gnu/packages/openssl.scm, gnu/packages/pcre.scm,
gnu/packages/pdf.scm, gnu/packages/pkg-config.scm,
gnu/packages/pretty-print.scm, gnu/packages/python.scm, gnu/packages/qt.scm,
gnu/packages/rsync.scm, gnu/packages/scheme.scm, gnu/packages/scrot.scm,
gnu/packages/sdl.scm, gnu/packages/skribilo.scm, gnu/packages/ssh.scm,
gnu/packages/stalonetray.scm, gnu/packages/tcl.scm, gnu/packages/tcsh.scm,
gnu/packages/telephony.scm, gnu/packages/texlive.scm, gnu/packages/tor.scm,
gnu/packages/valgrind.scm, gnu/packages/version-control.scm,
gnu/packages/vim.scm, gnu/packages/vpn.scm, gnu/packages/w3m.scm,
gnu/packages/web.scm, gnu/packages/wordnet.scm, gnu/packages/xiph.scm,
gnu/packages/xml.scm, gnu/packages/xorg.scm, gnu/packages/zile.scm,
gnu/packages/zip.scm, gnu/packages/zsh.scm [synopsis, description]: Adjust
according to lint checkers.
* gnu/packages/fltk.scm (fltk)[source]: Wrap long line in uri.
* /gnu/packages/xiph.scm (libogg, libtheora, vorbis-tools)[source]: Same.
2014-10-24 00:46:59 -04:00
|
|
|
(synopsis "Generate documentation from annotated sources")
|
2014-04-24 18:03:36 -04:00
|
|
|
(description "Doxygen is the de facto standard tool for generating
|
|
|
|
documentation from annotated C++ sources, but it also supports other popular
|
|
|
|
programming languages such as C, Objective-C, C#, PHP, Java, Python,
|
|
|
|
IDL (Corba, Microsoft, and UNO/OpenOffice flavors), Fortran, VHDL, Tcl,
|
|
|
|
and to some extent D.")
|
|
|
|
(license gpl3+)))
|
2016-03-16 11:18:21 -04:00
|
|
|
|
|
|
|
(define-public doc++
|
|
|
|
(package
|
|
|
|
(name "doc++")
|
|
|
|
(version "3.4.10")
|
|
|
|
(source (origin
|
|
|
|
(method url-fetch)
|
|
|
|
(uri (string-append "https://sourceforge.net/projects/docpp/"
|
|
|
|
"files/doc++-" version ".tar.gz"))
|
|
|
|
(sha256
|
|
|
|
(base32
|
|
|
|
"0i37zlxl8g352s4hzpdx0657k5x3czh3xcsfr27irc708gb277pn"))
|
|
|
|
(patches (search-patches "doc++-include-directives.patch"
|
|
|
|
"doc++-segfault-fix.patch"))))
|
|
|
|
(build-system gnu-build-system)
|
|
|
|
(native-inputs
|
|
|
|
`(("flex" ,flex)
|
2016-09-25 03:33:02 -04:00
|
|
|
("gettext" ,gettext-minimal)))
|
2016-03-16 11:18:21 -04:00
|
|
|
(home-page "http://docpp.sourceforge.net/")
|
|
|
|
(synopsis "Documentation system for C, C++, IDL, and Java")
|
|
|
|
(description
|
|
|
|
"DOC++ is a documentation system for C, C++, IDL, and Java. It can
|
|
|
|
generate both TeX output for high-quality hardcopies or HTML output for online
|
|
|
|
brwosing. The documentation is extracted directly from the C/C++/IDL source
|
|
|
|
or Java class files.")
|
|
|
|
(license gpl2+)))
|
2016-07-04 15:32:31 -04:00
|
|
|
|
|
|
|
(define-public scrollkeeper
|
|
|
|
(package
|
|
|
|
(name "scrollkeeper")
|
|
|
|
(version "0.3.14")
|
|
|
|
(source
|
|
|
|
(origin
|
|
|
|
(method url-fetch)
|
2016-07-21 02:35:30 -04:00
|
|
|
(uri (string-append "mirror://sourceforge/scrollkeeper/scrollkeeper/"
|
|
|
|
version "/scrollkeeper-" version ".tar.gz"))
|
2016-07-04 15:32:31 -04:00
|
|
|
(sha256
|
|
|
|
(base32 "1bfxwxc1ngh11v36z899sz9qam366r050fhkyb5adv65lb1x62sa"))))
|
|
|
|
(build-system gnu-build-system)
|
|
|
|
(arguments
|
|
|
|
`(#:configure-flags
|
|
|
|
(list (string-append "--with-xml-catalog="
|
|
|
|
(assoc-ref %build-inputs "docbook-xml")
|
|
|
|
"/xml/dtd/docbook/catalog.xml"))))
|
|
|
|
(inputs
|
|
|
|
`(("perl" ,perl)
|
|
|
|
("libxml2" ,libxml2)
|
|
|
|
("libxslt" ,libxslt)
|
|
|
|
;; The configure script checks for either version 4.2 or 4.1.2.
|
|
|
|
("docbook-xml" ,docbook-xml-4.2)))
|
|
|
|
(native-inputs
|
|
|
|
`(("intltool" ,intltool)))
|
|
|
|
(home-page "http://scrollkeeper.sourceforge.net/")
|
|
|
|
(synopsis "Open Documentation Cataloging Project")
|
|
|
|
(description "ScrollKeeper is a cataloging system for documentation on open
|
|
|
|
systems. It manages documentation metadata as specified by the Open Source
|
|
|
|
Metadata Framework and provides a simple API to allow help browsers to find,
|
|
|
|
sort, and search the document catalog. It will also be able to communicate
|
|
|
|
with catalog servers on the Net to search for documents which are not on the
|
|
|
|
local system.")
|
|
|
|
(license lgpl2.1+)))
|
2020-07-30 01:39:45 -04:00
|
|
|
|
|
|
|
(define-public zeal
|
|
|
|
(package
|
|
|
|
(name "zeal")
|
|
|
|
(version "0.6.1")
|
|
|
|
(home-page "https://github.com/zealdocs/zeal")
|
|
|
|
(source
|
|
|
|
(origin
|
|
|
|
(method git-fetch)
|
|
|
|
(uri (git-reference
|
|
|
|
(url home-page)
|
|
|
|
(commit (string-append "v" version))))
|
|
|
|
(file-name (git-file-name name version))
|
|
|
|
(sha256
|
|
|
|
(base32 "05qcjpibakv4ibhxgl5ajbkby3w7bkxsv3nfv2a0kppi1z0f8n8v"))))
|
|
|
|
(build-system qt-build-system)
|
|
|
|
(arguments `(#:tests? #f)) ; no tests
|
|
|
|
(native-inputs
|
|
|
|
`(("extra-cmake-modules" ,extra-cmake-modules)
|
|
|
|
("pkg-config" ,pkg-config)))
|
|
|
|
(inputs
|
|
|
|
`(("libarchive" ,libarchive)
|
|
|
|
("sqlite" ,sqlite)
|
|
|
|
("qtbase" ,qtbase)
|
|
|
|
("qtwebkit" ,qtwebkit)
|
|
|
|
("qtx11extras" ,qtx11extras)
|
|
|
|
("xcb-util-keyms" ,xcb-util-keysyms)))
|
|
|
|
(synopsis "Offline documentation browser inspired by Dash")
|
|
|
|
(description "Zeal is a simple offline documentation browser
|
|
|
|
inspired by Dash.")
|
|
|
|
(license gpl3+)))
|