gnu: syncthing-gtk: Switch source to use Debian's Python 3 port.

* gnu/packages/syncthing.scm (syncthing-gtk)[source]: Adjust to use the Debian
Python 3 port.
[phases]{remove-windows.py}: New phase.
This commit is contained in:
Maxim Cournoyer 2021-01-29 10:49:29 -05:00
parent aa0d1e3306
commit de8dc9039b
No known key found for this signature in database
GPG key ID: 1260E46482E63562

View file

@ -4,6 +4,7 @@
;;; Copyright © 2020 Tobias Geerinckx-Rice <me@tobias.gr>
;;; Copyright © 2020 Efraim Flashner <efraim@flashner.co.il>
;;; Copyright © 2020 Giacomo Leidi <goodoldpaul@autistici.org>
;;; Copyright © 2021 Maxim Cournoyer <maxim.cournoyer@gmail.com>
;;;
;;; This file is part of GNU Guix.
;;;
@ -189,22 +190,27 @@ (define-public syncthing
(license mpl2.0)))
(define-public syncthing-gtk
;; The commit used below corresponds to the latest commit of the
;; python3-port branch maintained by Debian. Upstream hasn't bothered
;; porting to Python 3 (see:
;; https://github.com/kozec/syncthing-gtk/issues/487).
(let ((revision "1")
(commit "c46fbd8ad1d12d409da8942702a2f119cf45514a"))
(package
(name "syncthing-gtk")
(version "0.9.4.4")
(version (git-version "0.9.4.4" revision commit))
(source (origin
(method git-fetch)
(uri (git-reference
(url "https://github.com/syncthing/syncthing-gtk")
(commit (string-append "v" version))))
(url "https://salsa.debian.org/debian/syncthing-gtk.git")
(commit commit)))
(file-name (git-file-name name version))
(sha256
(base32
"0nc0wd7qvyri7841c3dd9in5d7367hys0isyw8znv5fj4c0a6v1f"))))
"1x1c8snf0jpgjmyyidjw0015ksk5ishqn817wx8vs9i0lfgnnbbg"))))
(build-system python-build-system)
(arguments
`(#:python ,python-2
#:phases
`(#:phases
(modify-phases %standard-phases
(add-after 'unpack 'hardcode-dependencies
(lambda* (#:key inputs #:allow-other-keys)
@ -215,29 +221,32 @@ (define-public syncthing-gtk
(("killall") (string-append psmisc "/bin/killall")))
(substitute* "syncthing_gtk/configuration.py"
(("/usr/bin/syncthing") (string-append syncthing
"/bin/syncthing"))))
#t))
"/bin/syncthing"))))))
(add-after 'unpack 'remove-windows.py
(lambda _
;; A Windows-specific module that fails to load with
;; "ModuleNotFoundError: No module named 'msvcrt'.
(delete-file "syncthing_gtk/windows.py")))
(add-after 'wrap 'wrap-libs
(lambda* (#:key outputs #:allow-other-keys)
(let ((out (assoc-ref outputs "out")))
(wrap-program (string-append out "/bin/syncthing-gtk")
`("GI_TYPELIB_PATH" ":" prefix
(,(getenv "GI_TYPELIB_PATH"))))
#t))))))
(,(getenv "GI_TYPELIB_PATH"))))))))))
(inputs
`(("gtk+" ,gtk+)
("libappindicator" ,libappindicator)
("libnotify" ,libnotify)
("librsvg" ,librsvg)
("python2-bcrypt" ,python2-bcrypt)
("python2-dateutil" ,python2-dateutil)
("python2-pycairo" ,python2-pycairo)
("python2-pygobject" ,python2-pygobject)
("python-bcrypt" ,python-bcrypt)
("python-dateutil" ,python-dateutil)
("python-pycairo" ,python-pycairo)
("python-pygobject" ,python-pygobject)
("python-nautilus" ,python-nautilus)
("psmisc" ,psmisc)
("syncthing" ,syncthing)))
(native-inputs
`(("python2-setuptools" ,python2-setuptools)))
;; (native-inputs
;; `(("python2-setuptools" ,python2-setuptools)))
(home-page "https://github.com/syncthing/syncthing-gtk")
(synopsis "GTK3 based GUI and notification area icon for Syncthing")
(description "@code{syncthing-gtk} is a GTK3 Python based GUI and
@ -250,7 +259,7 @@ (define-public syncthing-gtk
@item Restart, shutdown server
@item Editing daemon settings
@end itemize\n")
(license gpl2)))
(license gpl2))))
(define-public go-github-com-jackpal-go-nat-pmp
(package