525 lines
22 KiB
Scheme
525 lines
22 KiB
Scheme
;;; GNU Guix --- Functional package management for GNU
|
||
;;; Copyright © 2014, 2018 Eric Bavier <bavier@member.fsf.org>
|
||
;;; Copyright © 2015, 2018 Leo Famulari <leo@famulari.name>
|
||
;;; Copyright © 2018–2021 Tobias Geerinckx-Rice <me@tobias.gr>
|
||
;;; Copyright © 2019 Christopher Baines <mail@cbaines.net>
|
||
;;;
|
||
;;; 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/>.
|
||
|
||
(define-module (gnu packages patchutils)
|
||
#:use-module (guix utils)
|
||
#:use-module (guix packages)
|
||
#:use-module (guix licenses)
|
||
#:use-module (guix download)
|
||
#:use-module (guix git-download)
|
||
#:use-module (guix build-system gnu)
|
||
#:use-module (guix build-system python)
|
||
#:use-module (gnu packages)
|
||
#:use-module (gnu packages ed)
|
||
#:use-module (gnu packages base)
|
||
#:use-module (gnu packages bash)
|
||
#:use-module (gnu packages check)
|
||
#:use-module (gnu packages databases)
|
||
#:use-module (gnu packages django)
|
||
#:use-module (gnu packages file)
|
||
#:use-module (gnu packages gawk)
|
||
#:use-module (gnu packages gettext)
|
||
#:use-module (gnu packages glib)
|
||
#:use-module (gnu packages gnome)
|
||
#:use-module (gnu packages gtk)
|
||
#:use-module (gnu packages less)
|
||
#:use-module (gnu packages mail)
|
||
#:use-module (gnu packages ncurses)
|
||
#:use-module (gnu packages perl)
|
||
#:use-module (gnu packages python)
|
||
#:use-module (gnu packages python-xyz)
|
||
#:use-module (gnu packages version-control)
|
||
#:use-module (gnu packages xml))
|
||
|
||
(define-public patchutils
|
||
(package
|
||
(name "patchutils")
|
||
(version "0.3.4")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append "http://cyberelk.net/tim/data/patchutils/stable/"
|
||
name "-" version ".tar.xz"))
|
||
(sha256
|
||
(base32
|
||
"0xp8mcfyi5nmb5a2zi5ibmyshxkb1zv1dgmnyn413m7ahgdx8mfg"))
|
||
(patches (search-patches "patchutils-test-perms.patch"))))
|
||
(build-system gnu-build-system)
|
||
(inputs `(("perl" ,perl)))
|
||
(arguments
|
||
'(#:parallel-tests? #f
|
||
#:phases
|
||
(modify-phases %standard-phases
|
||
(add-before 'check 'patch-test-scripts
|
||
(lambda _
|
||
(substitute* (find-files "tests" "^run-test$")
|
||
(("/bin/echo") (which "echo")))
|
||
#t))
|
||
(add-after 'install 'wrap-program
|
||
;; Point installed scripts to the utilities they need.
|
||
(lambda* (#:key inputs outputs #:allow-other-keys)
|
||
(let* ((out (assoc-ref outputs "out"))
|
||
(diffutils (assoc-ref inputs "diffutils"))
|
||
(sed (assoc-ref inputs "sed"))
|
||
(gawk (assoc-ref inputs "gawk")))
|
||
(for-each
|
||
(lambda (prog)
|
||
(wrap-program (string-append out "/bin/" prog)
|
||
`("PATH" ":" prefix
|
||
,(map (lambda (dir)
|
||
(string-append dir "/bin"))
|
||
(list diffutils sed gawk)))))
|
||
'("dehtmldiff" "editdiff" "espdiff")))
|
||
#t)))))
|
||
(home-page "http://cyberelk.net/tim/software/patchutils")
|
||
(synopsis "Collection of tools for manipulating patch files")
|
||
(description
|
||
"Patchutils is a collection of programs that can manipulate patch files
|
||
in useful ways such as interpolating between two pre-patches, combining two
|
||
incremental patches, fixing line numbers in hand-edited patches, and simply
|
||
listing the files modified by a patch.")
|
||
(license gpl2+)))
|
||
|
||
(define-public quilt
|
||
(package
|
||
(name "quilt")
|
||
(version "0.66")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append "mirror://savannah/quilt/"
|
||
"quilt-" version ".tar.gz"))
|
||
(sha256
|
||
(base32 "01vfvk4pqigahx82fhaaffg921ivd3k7rylz1yfvy4zbdyd32jri"))))
|
||
(build-system gnu-build-system)
|
||
(native-inputs
|
||
`(("gettext" ,gettext-minimal)))
|
||
(inputs `(("perl" ,perl)
|
||
("less" ,less)
|
||
("file" ,file)
|
||
("ed" ,ed)
|
||
("diffstat" ,diffstat)))
|
||
(arguments
|
||
'(#:parallel-tests? #f
|
||
#:phases
|
||
(modify-phases %standard-phases
|
||
(add-before 'check 'patch-tests
|
||
(lambda _
|
||
(substitute*
|
||
'("test/run"
|
||
"test/edit.test")
|
||
(("/bin/sh") (which "sh")))
|
||
#t))
|
||
(add-after 'install 'wrap-program
|
||
;; quilt's configure checks for the absolute path to the utilities it
|
||
;; needs, but uses only the name when invoking them, so we need to
|
||
;; make sure the quilt script can find those utilities when run.
|
||
(lambda* (#:key inputs outputs #:allow-other-keys)
|
||
(let* ((out (assoc-ref outputs "out"))
|
||
(coreutils (assoc-ref inputs "coreutils"))
|
||
(diffutils (assoc-ref inputs "diffutils"))
|
||
(findutils (assoc-ref inputs "findutils"))
|
||
(diffstat (assoc-ref inputs "diffstat"))
|
||
(less (assoc-ref inputs "less"))
|
||
(file (assoc-ref inputs "file"))
|
||
(ed (assoc-ref inputs "ed"))
|
||
(sed (assoc-ref inputs "sed"))
|
||
(bash (assoc-ref inputs "bash"))
|
||
(grep (assoc-ref inputs "grep")))
|
||
(wrap-program (string-append out "/bin/quilt")
|
||
`("PATH" ":" prefix
|
||
,(map (lambda (dir)
|
||
(string-append dir "/bin"))
|
||
(list coreutils diffutils findutils
|
||
less file ed sed bash grep
|
||
diffstat)))))
|
||
#t)))))
|
||
(home-page "https://savannah.nongnu.org/projects/quilt/")
|
||
(synopsis "Script for managing patches to software")
|
||
(description
|
||
"Quilt allows you to easily manage large numbers of patches by keeping
|
||
track of the changes each patch makes. Patches can be applied, un-applied,
|
||
refreshed, and more.")
|
||
(license gpl2)))
|
||
|
||
(define-public colordiff
|
||
(package
|
||
(name "colordiff")
|
||
(version "1.0.19")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (list (string-append "https://www.colordiff.org/colordiff-"
|
||
version ".tar.gz")
|
||
(string-append "http://www.colordiff.org/archive/colordiff-"
|
||
version ".tar.gz")))
|
||
(sha256
|
||
(base32 "069vzzgs7b44bmfh3ks2psrdb26s1w19gp9w4xxbgi7nhx6w3s26"))))
|
||
(build-system gnu-build-system)
|
||
(arguments
|
||
`(#:tests? #f ; no tests
|
||
#:make-flags (list (string-append "DESTDIR=" (assoc-ref %outputs "out"))
|
||
"INSTALL_DIR=/bin" "MAN_DIR=/share/man/man1")
|
||
#:phases
|
||
(modify-phases %standard-phases
|
||
(delete 'configure) ; no configure script
|
||
(delete 'build)))) ; nothing to build
|
||
(inputs
|
||
`(("perl" ,perl)
|
||
("xmlto" ,xmlto)))
|
||
(home-page "https://www.colordiff.org")
|
||
(synopsis "Display diff output with colors")
|
||
(description
|
||
"Colordiff is Perl script wrapper on top of diff command which provides
|
||
'syntax highlighting' for various patch formats.")
|
||
(license gpl2+)))
|
||
|
||
(define-public patches
|
||
(let ((commit "ef1b8a7d954b82ed4af3a08fd63d2085d19090ef"))
|
||
(package
|
||
(name "patches")
|
||
(home-page "https://github.com/stefanha/patches")
|
||
(version (string-append "0.0-1." (string-take commit 7)))
|
||
(source (origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url home-page)
|
||
(commit commit)))
|
||
(sha256
|
||
(base32
|
||
"11rdmhv0l1s8nqb20ywmw2zqizczch2p62qf9apyx5wqgxlnjshk"))
|
||
(file-name (string-append name "-"version "-checkout"))))
|
||
(build-system python-build-system)
|
||
(inputs `(("python-notmuch" ,python2-notmuch)))
|
||
(arguments
|
||
`(#:tests? #f ;no "test" target
|
||
#:python ,python-2)) ;not compatible with Python 3
|
||
(synopsis "Patch tracking tool")
|
||
(description
|
||
"@code{Patches} is a patch-tracking tool initially written for the QEMU
|
||
project. It provides commands that build a database of patches from a mailing
|
||
list, and commands that can search that database. It allows users to track
|
||
the status of a patch, apply patches, and search for patches---all that from
|
||
the command-line or from Emacs via its Notmuch integration.")
|
||
(license gpl2+))))
|
||
|
||
(define-public vbindiff
|
||
(package
|
||
(name "vbindiff")
|
||
(version "3.0_beta5")
|
||
(source (origin
|
||
(method url-fetch)
|
||
(uri (string-append "https://www.cjmweb.net/vbindiff/vbindiff-"
|
||
version ".tar.gz"))
|
||
(sha256
|
||
(base32
|
||
"1f1kj4jki08bnrwpzi663mjfkrx4wnfpzdfwd2qgijlkx5ysjkgh"))))
|
||
(build-system gnu-build-system)
|
||
(inputs
|
||
`(("ncurses" ,ncurses)))
|
||
(home-page "https://www.cjmweb.net/vbindiff/")
|
||
(synopsis "Console-based tool for comparing binary data")
|
||
(description "Visual Binary Diff (@command{vbindiff}) displays files in
|
||
hexadecimal and ASCII (or EBCDIC). It can also display two files at once, and
|
||
highlight the differences between them. It works well with large files (up to 4
|
||
GiB).")
|
||
(license gpl2+)))
|
||
|
||
(define-public meld
|
||
(package
|
||
(name "meld")
|
||
(version "3.20.3")
|
||
(source
|
||
(origin
|
||
(method url-fetch)
|
||
(uri (string-append "mirror://gnome/sources/meld/"
|
||
(version-major+minor version)
|
||
"/meld-" version ".tar.xz"))
|
||
(sha256
|
||
(base32 "06h52vaghvj5n507mj0hhk9yrca16pyl4l16c00b3bmkplljpqzh"))))
|
||
(build-system python-build-system)
|
||
(native-inputs
|
||
`(("intltool" ,intltool)
|
||
("xmllint" ,libxml2)
|
||
("glib-compile-schemas" ,glib "bin")
|
||
("python-pytest" ,python-pytest)))
|
||
(inputs
|
||
`(("python-cairo" ,python-pycairo)
|
||
("python-gobject" ,python-pygobject)
|
||
("gsettings-desktop-schemas" ,gsettings-desktop-schemas)
|
||
("gtksourceview" ,gtksourceview-3)))
|
||
(propagated-inputs
|
||
`(("dconf" ,dconf)))
|
||
(arguments
|
||
`(#:imported-modules ((guix build glib-or-gtk-build-system)
|
||
,@%python-build-system-modules)
|
||
#:modules ((guix build python-build-system)
|
||
((guix build glib-or-gtk-build-system) #:prefix glib-or-gtk:)
|
||
(guix build utils))
|
||
#:phases
|
||
(modify-phases %standard-phases
|
||
;; This setup.py script does not support one of the Python build
|
||
;; system's default flags, "--single-version-externally-managed".
|
||
(replace 'install
|
||
(lambda* (#:key outputs #:allow-other-keys)
|
||
(invoke "python" "setup.py"
|
||
;; This setup.py runs gtk-update-icon-cache which we don't want.
|
||
"--no-update-icon-cache"
|
||
;; "--no-compile-schemas"
|
||
"install"
|
||
(string-append "--prefix=" (assoc-ref outputs "out"))
|
||
"--root=/")))
|
||
;; The tests need to be run after installation.
|
||
(delete 'check)
|
||
(add-after 'install 'check
|
||
(lambda* (#:key inputs outputs #:allow-other-keys)
|
||
;; Tests look for installed package
|
||
(add-installed-pythonpath inputs outputs)
|
||
;; The tests fail when HOME=/homeless-shelter.
|
||
(setenv "HOME" "/tmp")
|
||
(invoke "py.test" "-v" "-k"
|
||
;; TODO: Those tests fail, why?
|
||
"not test_classify_change_actions")))
|
||
(add-after 'wrap 'glib-or-gtk-wrap
|
||
(assoc-ref glib-or-gtk:%standard-phases 'glib-or-gtk-wrap))
|
||
(add-after 'wrap 'wrap-typelib
|
||
(lambda* (#:key inputs outputs #:allow-other-keys)
|
||
(let ((out (assoc-ref outputs "out")))
|
||
(wrap-program (string-append out "/bin/meld")
|
||
`("GI_TYPELIB_PATH" prefix
|
||
,(search-path-as-string->list (getenv "GI_TYPELIB_PATH"))))
|
||
#t))))))
|
||
(home-page "https://meldmerge.org/")
|
||
(synopsis "Compare files, directories and working copies")
|
||
(description "Meld is a visual diff and merge tool targeted at
|
||
developers. Meld helps you compare files, directories, and version controlled
|
||
projects. It provides two- and three-way comparison of both files and
|
||
directories, and has support for many popular version control systems.
|
||
|
||
Meld helps you review code changes and understand patches. It might even help
|
||
you to figure out what is going on in that merge you keep avoiding.")
|
||
(license gpl2)))
|
||
|
||
(define-public patchwork
|
||
(package
|
||
(name "patchwork")
|
||
(version "3.0.1")
|
||
(source (origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://github.com/getpatchwork/patchwork")
|
||
(commit (string-append "v" version))))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32
|
||
"049ih1fbbbmj11v5m9ilahifl8x7gi6wyba58552y9n9djzs8csc"))))
|
||
(build-system python-build-system)
|
||
(arguments
|
||
`(;; TODO: Tests require a running database
|
||
#:tests? #f
|
||
#:phases
|
||
(modify-phases %standard-phases
|
||
(delete 'configure)
|
||
(delete 'build)
|
||
(add-after 'unpack 'replace-wsgi.py
|
||
(lambda* (#:key inputs outputs #:allow-other-keys)
|
||
(delete-file "patchwork/wsgi.py")
|
||
(call-with-output-file "patchwork/wsgi.py"
|
||
(lambda (port)
|
||
;; Embed the PYTHONPATH containing the dependencies, as well
|
||
;; as the python modules in this package in the wsgi.py file,
|
||
;; as this will ensure they are available at runtime.
|
||
(define pythonpath
|
||
(string-append (getenv "GUIX_PYTHONPATH")
|
||
":"
|
||
(site-packages inputs outputs)))
|
||
(display
|
||
(string-append "
|
||
import os, sys
|
||
|
||
sys.path.extend('" pythonpath "'.split(':'))
|
||
|
||
from django.core.wsgi import get_wsgi_application
|
||
|
||
# By default, assume that patchwork is running as a Guix service, which
|
||
# provides the settings as the 'guix.patchwork.settings' Python module.
|
||
#
|
||
# When using httpd, it's hard to set environment variables, so rely on the
|
||
# default set here.
|
||
os.environ['DJANGO_SETTINGS_MODULE'] = os.getenv(
|
||
'DJANGO_SETTINGS_MODULE',
|
||
'guix.patchwork.settings' # default
|
||
)
|
||
|
||
application = get_wsgi_application()\n") port)))))
|
||
(replace 'check
|
||
(lambda* (#:key tests? #:allow-other-keys)
|
||
(when tests?
|
||
(setenv "DJANGO_SETTINGS_MODULE" "patchwork.settings.dev")
|
||
(invoke "python" "-Wonce" "./manage.py" "test" "--noinput"))
|
||
#t))
|
||
(replace 'install
|
||
(lambda* (#:key inputs outputs #:allow-other-keys)
|
||
(let ((out (assoc-ref outputs "out"))
|
||
(out-site-packages (site-packages inputs outputs)))
|
||
(for-each (lambda (directory)
|
||
(copy-recursively
|
||
directory
|
||
(string-append out-site-packages directory)))
|
||
'(;; Contains the python code
|
||
"patchwork"
|
||
;; Contains the templates for the generated HTML
|
||
"templates"))
|
||
(delete-file-recursively
|
||
(string-append out-site-packages "patchwork/tests"))
|
||
|
||
;; Install patchwork related tools
|
||
(for-each (lambda (file)
|
||
(install-file file (string-append out "/bin")))
|
||
(list
|
||
(string-append out-site-packages
|
||
"patchwork/bin/parsemail.sh")
|
||
(string-append out-site-packages
|
||
"patchwork/bin/parsemail-batch.sh")))
|
||
|
||
;; Collect the static assets, this includes JavaScript, CSS and
|
||
;; fonts. This is a standard Django process when running a
|
||
;; Django application for regular use, and includes assets for
|
||
;; dependencies like the admin site from Django.
|
||
;;
|
||
;; The intent here is that you can serve files from this
|
||
;; directory through a webserver, which is recommended when
|
||
;; running Django applications.
|
||
(let ((static-root
|
||
(string-append out "/share/patchwork/htdocs")))
|
||
(mkdir-p static-root)
|
||
(copy-file "patchwork/settings/production.example.py"
|
||
"patchwork/settings/assets.py")
|
||
(setenv "DJANGO_SECRET_KEY" "dummyvalue")
|
||
(setenv "DJANGO_SETTINGS_MODULE" "patchwork.settings.assets")
|
||
(setenv "STATIC_ROOT" static-root)
|
||
(invoke "./manage.py" "collectstatic" "--no-input"))
|
||
|
||
;; The lib directory includes example configuration files that
|
||
;; may be useful when deploying patchwork.
|
||
(copy-recursively "lib"
|
||
(string-append
|
||
out "/share/doc/" ,name "-" ,version)))
|
||
#t))
|
||
;; The hasher script is used from the post-receive.hook
|
||
(add-after 'install 'install-hasher
|
||
(lambda* (#:key inputs outputs #:allow-other-keys)
|
||
(let* ((out (assoc-ref outputs "out"))
|
||
(out-site-packages (site-packages inputs outputs))
|
||
(out-hasher.py (string-append out-site-packages
|
||
"/patchwork/hasher.py")))
|
||
(chmod out-hasher.py #o555)
|
||
(symlink out-hasher.py (string-append out "/bin/hasher")))
|
||
#t))
|
||
;; Create a patchwork specific version of Django's command line admin
|
||
;; utility.
|
||
(add-after 'install 'install-patchwork-admin
|
||
(lambda* (#:key inputs outputs #:allow-other-keys)
|
||
(let* ((out (assoc-ref outputs "out")))
|
||
(mkdir-p (string-append out "/bin"))
|
||
(call-with-output-file (string-append out "/bin/patchwork-admin")
|
||
(lambda (port)
|
||
(simple-format port "#!~A
|
||
import os, sys
|
||
|
||
if __name__ == \"__main__\":
|
||
from django.core.management import execute_from_command_line
|
||
|
||
execute_from_command_line(sys.argv)" (which "python"))))
|
||
(chmod (string-append out "/bin/patchwork-admin") #o555))
|
||
#t)))))
|
||
(inputs
|
||
`(("python-wrapper" ,python-wrapper)))
|
||
(propagated-inputs
|
||
`(("python-django" ,python-django-2.2)
|
||
;; TODO: Make this configurable
|
||
("python-psycopg2" ,python-psycopg2)
|
||
("python-mysqlclient" ,python-mysqlclient)
|
||
("python-django-filter" ,python-django-filter)
|
||
("python-djangorestframework" ,python-djangorestframework)
|
||
("python-django-debug-toolbar" ,python-django-debug-toolbar)))
|
||
(synopsis "Web based patch tracking system")
|
||
(description
|
||
"Patchwork is a patch tracking system. It takes in emails containing
|
||
patches, and displays the patches along with comments and state information.
|
||
Users can login allowing them to change the state of patches.")
|
||
(home-page "http://jk.ozlabs.org/projects/patchwork/")
|
||
(license gpl2+)))
|
||
|
||
(define-public pwclient
|
||
(package
|
||
(name "pwclient")
|
||
(version "1.3.0")
|
||
(source (origin
|
||
(method git-fetch)
|
||
(uri (git-reference
|
||
(url "https://github.com/getpatchwork/pwclient")
|
||
(commit version)))
|
||
(file-name (git-file-name name version))
|
||
(sha256
|
||
(base32
|
||
"1xckwvcqklzpyh3xs4k2zm40ifp0q5fdkj2vmgb8vhfvl1ivs6jv"))))
|
||
(build-system python-build-system)
|
||
(arguments
|
||
`(#:phases
|
||
(modify-phases %standard-phases
|
||
(add-after 'unpack 'patch-requirements
|
||
(lambda _
|
||
(substitute* "test-requirements.txt"
|
||
;; The pytest requirement is unnecessarily strict
|
||
(("pytest>=3.0,<5.0;")
|
||
"pytest>=3.0,<6.0;"))
|
||
#t))
|
||
(add-before 'build 'set-PBR_VERSION
|
||
(lambda _
|
||
(setenv "PBR_VERSION"
|
||
,version)
|
||
#t))
|
||
(replace 'check
|
||
(lambda* (#:key tests? #:allow-other-keys)
|
||
(when tests?
|
||
(invoke "pytest"))
|
||
#t))
|
||
(add-after 'install 'install-man-page
|
||
(lambda* (#:key outputs #:allow-other-keys)
|
||
(install-file "man/pwclient.1"
|
||
(string-append
|
||
(assoc-ref outputs "out")
|
||
"/share/man/man1"))
|
||
#t)))))
|
||
(native-inputs
|
||
`(("python-pbr" ,python-pbr)
|
||
("python-pytest" ,python-pytest)
|
||
("python-pytest-cov" ,python-pytest-cov)
|
||
("python-mock" ,python-mock)))
|
||
(home-page
|
||
"https://github.com/getpatchwork/pwclient")
|
||
(synopsis "Command-line client for the Patchwork patch tracking tool")
|
||
(description
|
||
"pwclient is a VCS-agnostic tool for interacting with Patchwork, the
|
||
web-based patch tracking system.")
|
||
(license gpl2+)))
|