1 ;;; GNU Guix --- Functional package management for GNU
2 ;;; Copyright © 2013, 2017, 2018, 2019, 2020 Ludovic Courtès <ludo@gnu.org>
3 ;;; Copyright © 2014 Ian Denhardt <ian@zenhack.net>
4 ;;; Copyright © 2015, 2016 Alex Kost <alezost@gmail.com>
5 ;;; Copyright © 2016, 2017, 2018, 2019 Efraim Flashner <efraim@flashner.co.il>
6 ;;; Copyright © 2017 Alex Griffin <a@ajgrf.com>
7 ;;; Copyright © 2017 ng0 <ng0@n0.is>
8 ;;; Copyright © 2017 Mathieu Othacehe <m.othacehe@gmail.com>
9 ;;; Copyright © 2017 nee <nee-git@hidamari.blue>
10 ;;; Copyright © 2018, 2019, 2020 Tobias Geerinckx-Rice <me@tobias.gr>
11 ;;; Copyright © 2018, 2019 Ricardo Wurmus <rekado@elephly.net>
12 ;;; Copyright © 2019 Nicolas Goaziou <mail@nicolasgoaziou.fr>
13 ;;; Copyright © 2019 Guy Fleury Iteriteka <hoonandon@gmail.com>
14 ;;; Copyright © 2019 Pierre Langlois <pierre.langlois@gmx.com>
15 ;;; Copyright © 2020 Peng Mei Yu <pengmeiyu@riseup.net>
16 ;;; Copyright © 2020 R Veera Kumar <vkor@vkten.in>
17 ;;; Copyright © 2020 Pierre Neidhardt <mail@ambrevar.xyz>
19 ;;; This file is part of GNU Guix.
21 ;;; GNU Guix is free software; you can redistribute it and/or modify it
22 ;;; under the terms of the GNU General Public License as published by
23 ;;; the Free Software Foundation; either version 3 of the License, or (at
24 ;;; your option) any later version.
26 ;;; GNU Guix is distributed in the hope that it will be useful, but
27 ;;; WITHOUT ANY WARRANTY; without even the implied warranty of
28 ;;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
29 ;;; GNU General Public License for more details.
31 ;;; You should have received a copy of the GNU General Public License
32 ;;; along with GNU Guix. If not, see <http://www.gnu.org/licenses/>.
34 (define-module (gnu packages image-viewers)
35 #:use-module ((guix licenses) #:prefix license:)
36 #:use-module (guix download)
37 #:use-module (guix git-download)
38 #:use-module (guix packages)
39 #:use-module (guix utils)
40 #:use-module (guix build-system gnu)
41 #:use-module (guix build-system cmake)
42 #:use-module (guix build-system meson)
43 #:use-module (guix build-system python)
44 #:use-module (gnu packages autotools)
45 #:use-module (gnu packages algebra)
46 #:use-module (gnu packages boost)
47 #:use-module (gnu packages check)
48 #:use-module (gnu packages compression)
49 #:use-module (gnu packages curl)
50 #:use-module (gnu packages documentation)
51 #:use-module (gnu packages fontutils)
52 #:use-module (gnu packages freedesktop)
53 #:use-module (gnu packages gettext)
54 #:use-module (gnu packages ghostscript)
55 #:use-module (gnu packages gl)
56 #:use-module (gnu packages glib)
57 #:use-module (gnu packages gnome)
58 #:use-module (gnu packages gtk)
59 #:use-module (gnu packages graphics)
60 #:use-module (gnu packages image)
61 #:use-module (gnu packages imagemagick)
62 #:use-module (gnu packages maths)
63 #:use-module (gnu packages perl)
64 #:use-module (gnu packages perl-check)
65 #:use-module (gnu packages photo)
66 #:use-module (gnu packages pkg-config)
67 #:use-module (gnu packages python)
68 #:use-module (gnu packages python-xyz)
69 #:use-module (gnu packages qt)
70 #:use-module (gnu packages xdisorg)
71 #:use-module (gnu packages xorg)
72 #:use-module (gnu packages))
78 (home-page "https://feh.finalrewind.org/")
81 (uri (string-append home-page
82 name "-" version ".tar.bz2"))
85 "0r83zincbfnk8g13xwm2qaccml9srnwlsmpc1f0nhwjkqyjmqm0q"))))
86 (build-system gnu-build-system)
88 '(#:phases (modify-phases %standard-phases (delete 'configure))
91 (list "CC=gcc" (string-append "PREFIX=" (assoc-ref %outputs "out"))
95 ("perl-test-command" ,perl-test-command)))
96 (inputs `(("imlib2" ,imlib2)
102 ("libxinerama" ,libxinerama)))
104 ;; Feh allows overriding the libcurl builtin CA path (unset in Guix)
105 ;; with the same variable as the `curl` command line HTTP tool.
106 (package-native-search-paths curl))
107 (synopsis "Fast and light imlib2-based image viewer")
109 "feh is an X11 image viewer aimed mostly at console users.
110 Unlike most other viewers, it does not have a fancy GUI, but simply
111 displays images. It can also be used to set the desktop wallpaper.
112 It is controlled via commandline arguments and configurable key/mouse
115 ;; The license is really the Expat license, with additional wording in the
116 ;; 2nd paragraph: "acknowledgment shall be given in the documentation and
117 ;; software packages that this Software was used."
118 (license (license:x11-style
120 "See 'COPYING' in the distribution."))))
122 (define-public geeqie
123 ;; The latest release, 1.4, fails to build with Exiv2 0.27.1. The upstream
124 ;; repo has several fixes for that, so take a snapshot.
125 (let ((commit "c220ddefb1b6b11b54f7598f0d44dd0723325ed4")
129 (version (git-version "1.4" revision commit))
133 (url "https://github.com/BestImageViewer/geeqie")
137 "07424nzrnwbksgalgg1a6ig2snd986w79kca1cfnv1q9kc7x2h3x"))
138 (file-name (git-file-name name version))))
139 (build-system gnu-build-system)
141 `( ;; Enable support for a "map" pane using GPS data.
142 #:configure-flags '("--enable-map")
144 ;; Parallel builds fail with something like:
145 ;; image-load.c:143:9: error: ‘gq_marshal_VOID__INT_INT_INT_INT’ undeclared
146 ;; due to unexpressed makefile dependencies.
150 (modify-phases %standard-phases
151 (add-before 'bootstrap 'pre-bootstrap
153 (define (write-dummy-changelog port)
154 (display "See Git history for a change log.\n" port))
155 ;; Create ChangeLog{,.html} to placate the makefile, which would
156 ;; otherwise require access to the Git repo.
157 (call-with-output-file "ChangeLog"
158 write-dummy-changelog)
159 (call-with-output-file "ChangeLog.html"
160 write-dummy-changelog)
162 ;; Don't try to run 'git' for the version number.
163 (substitute* "configure.ac"
164 (("m4_esyscmd_s\\([^)]+\\)")
165 (string-append "[" ,version "]")))
167 ;; Remove references to non-existent files.
168 (substitute* "po/POTFILES.in"
169 (("^plugins/import/.*") ""))
172 `(("clutter" ,clutter)
173 ("libchamplain" ,libchamplain)
179 `(("autoconf" ,autoconf)
180 ("automake" ,automake)
181 ("glib" ,glib "bin") ; glib-gettextize
182 ("intltool" ,intltool)
183 ("pkg-config" ,pkg-config)))
184 (home-page "http://www.geeqie.org/")
185 (synopsis "Lightweight GTK+ based image viewer")
187 "Geeqie is a lightweight GTK+ based image viewer for Unix like operating
188 systems. It features: EXIF, IPTC and XMP metadata browsing and editing
189 interoperability; easy integration with other software; geeqie works on files
190 and directories, there is no need to import images; fast preview for many raw
191 image formats; tools for image comparison, sorting and managing photo
192 collection. Geeqie was initially based on GQview.")
193 (license license:gpl2+))))
195 (define-public gpicview
201 (uri (string-append "mirror://sourceforge/lxde/"
202 "GPicView%20%28image%20Viewer%29/0.2.x/"
203 name "-" version ".tar.xz"))
206 "0hi9v0rdx47nys0wvm9xasdrafa34r5kq6crb074a0ipwmc60iiq"))))
207 (build-system gnu-build-system)
208 (inputs `(("gtk+" ,gtk+-2)
209 ("libjpeg" ,libjpeg-turbo)))
210 (native-inputs `(("intltool" ,intltool)
211 ("pkg-config" ,pkg-config)))
212 (synopsis "Simple and fast image viewer for X")
213 (description "gpicview is a lightweight GTK+ 2.x based image viewer.
214 It is the default image viewer on LXDE desktop environment.")
215 (home-page "http://lxde.sourceforge.net/gpicview/")
216 (license license:gpl2+)))
225 (url "https://github.com/muennich/sxiv.git")
226 (commit (string-append "v" version))))
227 (file-name (git-file-name name version))
230 "0xaawlfdy7b277m38mgg4423kd7p1ffn0dq4hciqs6ivbb3q9c4f"))))
231 (build-system gnu-build-system)
233 `(#:tests? #f ; no check target
235 (list (string-append "PREFIX=" %output)
237 ;; Xft.h #includes <ft2build.h> without ‘freetype2/’. The Makefile
238 ;; works around this by hard-coding /usr/include & $PREFIX.
239 (string-append "CPPFLAGS=-I"
240 (assoc-ref %build-inputs "freetype")
241 "/include/freetype2")
244 (modify-phases %standard-phases
245 (delete 'configure)))) ; no configure script
247 `(("freetype" ,freetype)
253 (home-page "https://github.com/muennich/sxiv")
254 (synopsis "Simple X Image Viewer")
256 "sxiv is an alternative to feh and qiv. Its primary goal is to
257 provide the most basic features required for fast image viewing. It has
258 vi key bindings and works nicely with tiling window managers. Its code
259 base should be kept small and clean to make it easy for you to dig into
260 it and customize it for your needs.")
261 (license license:gpl2+)))
263 (define-public viewnior
271 (url "https://github.com/hellosiyan/Viewnior.git")
272 (commit (string-append name "-" version))))
273 (file-name (git-file-name name version))
276 "0y4hk3vq8psba5k615w18qj0kbdfp5w0lm98nv5apy6hmcpwfyig"))))
277 (build-system meson-build-system)
280 (modify-phases %standard-phases
281 (add-after 'unpack 'patch-source
283 ;; Don't create 'icon-theme.cache'
284 (substitute* "meson.build"
285 (("meson.add_install_script*") ""))
287 #:tests? #f)) ; no tests
289 `(("gettext" ,gettext-minimal)
290 ("glib" ,glib "bin") ; glib-genmarshal
291 ("pkg-config" ,pkg-config)
292 ("shared-mime-info" ,shared-mime-info)))
295 ("gdk-pixbuf" ,gdk-pixbuf)
297 (home-page "http://siyanpanayotov.com/project/viewnior")
298 (synopsis "Simple, fast and elegant image viewer")
299 (description "Viewnior is an image viewer program. Created to be simple,
300 fast and elegant. Its minimalistic interface provides more screenspace for
301 your images. Among its features are:
303 @item Fullscreen & Slideshow
304 @item Rotate, flip, crop, save, delete images
305 @item Animation support
306 @item Browse only selected images
307 @item Navigation window
308 @item Set image as wallpaper (Gnome 2, Gnome 3, XFCE, LXDE, FluxBox, Nitrogen)
309 @item Simple interface
310 @item EXIF and IPTC metadata
311 @item Configurable mouse actions
313 (license license:gpl3+)))
315 (define-public catimg
323 (url "https://github.com/posva/catimg.git")
325 (file-name (git-file-name name version))
327 (base32 "0g9ywbgy162wiam9hc3yqpq5q4gyxa8fj4jskr3fdz8z8jjaabzz"))))
328 (build-system cmake-build-system)
330 `(#:tests? #f ; no tests
332 (modify-phases %standard-phases
333 (add-after 'unpack 'patch-convert
335 (substitute* "catimg"
336 ;; By replacing "convert", we also replace the "convert"
337 ;; in the message 'The version of convert is too old, don't
338 ;; expect good results :('. This should not happen, but in
339 ;; practice this error message should not affect us.
340 (("convert") (which "convert")))
342 (add-after 'install 'install-script
343 (lambda* (#:key outputs #:allow-other-keys)
344 ;; The bash script lacks an file extension. We have to rename
345 ;; it so that the C program and the bash script can be happy
347 (copy-file "../source/catimg"
348 (string-append (assoc-ref outputs "out")
352 `(("imagemagick" ,imagemagick))) ; for the bash script version
353 (home-page "https://github.com/posva/catimg")
354 (synopsis "Render images in the terminal")
356 "Catimg is a little program that prints images in the terminal.
357 It supports JPEG, PNG and GIF formats.")
358 (license license:expat)))
360 (define-public luminance-hdr
362 (name "luminance-hdr")
367 "mirror://sourceforge/qtpfsgui/luminance/"
368 version "/luminance-hdr-" version ".tar.bz2"))
371 "00fldbcizrx8jcnjgq74n3zmbm27dxzl96fxa7q49689mfnlw08l"))
372 (patches (search-patches "luminance-hdr-qt-printer.patch"))))
373 (build-system cmake-build-system)
375 `(("pkg-config" ,pkg-config)
376 ("qttools" ,qttools)))
379 ("qtdeclarative" ,qtdeclarative)
380 ("qtwebkit" ,qtwebkit)
387 ("libjpeg" ,libjpeg-turbo)
392 ("libtiff" ,libtiff)))
395 (modify-phases %standard-phases
396 (add-after 'set-paths 'add-ilmbase-include-path
397 (lambda* (#:key inputs #:allow-other-keys)
398 ;; 'OpenEXR.pc' has a -I for IlmBase but 'FindOpenEXR.cmake' does
399 ;; not use 'OpenEXR.pc'. Thus, we need to add
400 ;; "$ilmbase/include/OpenEXR/" to the CPATH.
402 (string-append (assoc-ref inputs "ilmbase")
404 ":" (or (getenv "CPATH") "")))
406 (home-page "http://qtpfsgui.sourceforge.net")
407 (synopsis "High dynamic range (HDR) imaging application")
409 "Luminance HDR (formerly QtPFSGui) is a graphical user interface
410 application that aims to provide a workflow for high dynamic range (HDR)
411 imaging. It supports several HDR and LDR image formats, and it can:
414 @item Create an HDR file from a set of images (formats: JPEG, TIFF 8bit and
415 16bit, RAW) of the same scene taken at different exposure setting;
416 @item Save load HDR images;
417 @item Rotate, resize and crop HDR images;
418 @item Tone-map HDR images;
419 @item Copy EXIF data between sets of images.
421 (license license:gpl2+)))
423 ;; CBR and RAR are currently unsupported, due to non-free dependencies.
424 (define-public mcomix
425 ;; Official mcomix hasn't been updated since 2016, it's broken with
426 ;; python-pillow 6+ and only supports Python 2. We use fork instead.
427 (let ((commit "fea55a7a9369569eefed72209eed830409c4af98"))
430 (version (git-version "1.2.1" "1" commit))
435 (url "https://github.com/multiSnow/mcomix3")
437 (file-name (git-file-name name version))
440 "05zl0dkjwbdcm2zlk4nz9w33amlqj8pbf32a8ymshc2356fqhhi5"))))
441 (build-system python-build-system)
444 ("python-pillow" ,python-pillow)
445 ("python-pygobject" ,python-pygobject)
446 ("python-pycairo" ,python-pycairo)))
448 `(#:tests? #f ; FIXME: How do we run tests?
450 (modify-phases %standard-phases
451 (add-after 'unpack 'configure
452 (lambda* (#:key inputs #:allow-other-keys)
453 (let ((p7zip (assoc-ref inputs "p7zip")))
454 ;; insert absolute path to 7z executable
455 (substitute* "mcomix/mcomix/archive/sevenzip_external.py"
456 (("_7z_executable = -1")
457 (string-append "_7z_executable = u'" p7zip "/bin/7z'"))))
460 (lambda* (#:key outputs #:allow-other-keys)
461 (let* ((out (assoc-ref outputs "out"))
462 (pyver ,(version-major+minor (package-version python)))
463 (lib (string-append out "/lib/python" pyver)))
464 (invoke (which "python") "installer.py" "--srcdir=mcomix"
465 (string-append "--target=" lib))
466 (rename-file (string-append lib "/mcomix")
467 (string-append lib "/site-packages"))
470 (lambda* (#:key outputs #:allow-other-keys)
471 (let* ((out (assoc-ref outputs "out"))
472 (share (string-append out "/share"))
473 (bin (string-append out "/bin"))
474 (pyver ,(version-major+minor (package-version python)))
475 (lib (string-append out "/lib/python" pyver "/site-packages")))
477 (rename-file (string-append lib "/mcomixstarter.py")
478 (string-append bin "/mcomix"))
479 (rename-file (string-append lib "/comicthumb.py")
480 (string-append bin "/comicthumb"))
481 (install-file "mime/mcomix.desktop"
482 (string-append share "/applications"))
483 (install-file "mime/mcomix.appdata.xml"
484 (string-append share "/metainfo"))
485 (install-file "mime/mcomix.xml"
486 (string-append share "/mime/packages"))
487 (install-file "mime/comicthumb.thumbnailer"
488 (string-append share "/thumbnailers"))
489 (install-file "man/mcomix.1" (string-append share "/man/man1"))
490 (install-file "man/comicthumb.1" (string-append share "/man/man1"))
494 (format #f "mcomix/mcomix/images/~sx~s/mcomix.png" size size)
495 (format #f "~a/icons/hicolor/~sx~s/apps/" share size size))
499 (format #f "mime/icons/~sx~s/application-x-~a.png" size size ext)
500 (format #f "~a/icons/hicolor/~sx~s/mimetypes/"
502 '("cb7" "cbr" "cbt" "cbz")))
505 (home-page "https://sourceforge.net/p/mcomix/wiki/Home/")
506 (synopsis "Image viewer for comics")
507 (description "MComix is a customizable image viewer that specializes as
508 a comic and manga reader. It supports a variety of container formats
509 including CBZ, CB7, CBT, LHA.
511 For PDF support, install the @emph{mupdf} package.")
512 (license license:gpl2+))))
522 (url "https://github.com/jurplel/qView.git")
524 (file-name (git-file-name name version))
526 (base32 "15a91bs3wcqhgf76wzigbn10hayg628j84pq4j2vaxar94ak0vk7"))))
527 (build-system gnu-build-system)
530 (modify-phases %standard-phases
534 ;; Installation process hard-codes "/usr/bin", possibly
536 (add-after 'configure 'fix-install-directory
537 (lambda* (#:key outputs #:allow-other-keys)
538 (let ((out (assoc-ref outputs "out")))
539 (substitute* "Makefile"
540 (("\\$\\(INSTALL_ROOT\\)/usr") out))
542 ;; Don't phone home or show "Checking for updates..." in the
544 (add-before 'build 'disable-auto-update
546 (substitute* "src/qvaboutdialog.cpp"
547 (("ui->updateLabel->setText\\(updateText\\);") "")
548 (("requestUpdates\\(\\);") ""))
553 ("qtimageformats" ,qtimageformats)))
554 (home-page "https://interversehq.com/qview/")
555 (synopsis "Convenient and minimal image viewer")
556 (description "qView is a Qt image viewer designed with visually
557 minimalism and usability in mind. Its features include animated GIF
558 controls, file history, rotation/mirroring, and multithreaded
560 (license license:gpl3+)))
568 (uri (string-append "https://hpjansson.org/chafa/releases/chafa-"
572 "0aa7119514rhsak5i0kgvwllb9z74lnfzfn7dzfhs27fc8cvx1dg"))))
573 (build-system gnu-build-system)
575 `(("pkg-config" ,pkg-config)))
578 ("imagemagick" ,imagemagick)))
579 (synopsis "Convert images to ANSI/Unicode characters")
581 "Chafa is a command-line utility that converts all kinds of images,
582 including animated GIFs, into ANSI/Unicode character output that can be
583 displayed in a terminal.")
584 (home-page "https://hpjansson.org/chafa/")
585 (license license:lgpl3+)))
594 (url "https://github.com/eXeC64/imv")
595 (commit (string-append "v" version))))
598 "0gk8g178i961nn3bls75a8qpv6wvfvav6hd9lxca1skaikd33zdx"))
599 (file-name (git-file-name name version))))
600 (build-system gnu-build-system)
603 (modify-phases %standard-phases
605 (add-after 'install 'record-absolute-file-names
606 (lambda* (#:key outputs #:allow-other-keys)
607 ;; 'imv' is a script that execs 'imv-x11' or 'imv-wayland'.
608 ;; Record their absolute file name.
609 (let* ((out (assoc-ref outputs "out"))
610 (bin (string-append out "/bin")))
611 (substitute* (string-append bin "/imv")
613 (string-append bin "/imv-")))
617 (string-append "PREFIX=" (assoc-ref %outputs "out"))
618 (string-append "CONFIGPREFIX="
619 (assoc-ref %outputs "out") "/etc"))))
621 `(("asciidoc" ,asciidoc)
622 ("freeimage" ,freeimage)
625 ("libxkbcommon" ,libxkbcommon)
627 ("wayland" ,wayland)))
630 ("pkg-config" ,pkg-config)))
631 (synopsis "Image viewer for tiling window managers")
632 (description "@code{imv} is a command line image viewer intended for use
633 with tiling window managers. Features include:
636 @item Native Wayland and X11 support.
637 @item Support for dozens of image formats including:
644 @item Various RAW formats
645 @item Photoshop PSD files
647 @item Configurable key bindings and behavior.
648 @item Highly scriptable with IPC via imv-msg.
650 (home-page "https://github.com/eXeC64/imv")
651 (license license:expat)))
660 (uri (string-append "http://spiegl.de/qiv/download/qiv-"
663 (base32 "1rlf5h67vhj7n1y7jqkm9k115nfnzpwngj3kzqsi2lg676srclv7"))))
664 (build-system gnu-build-system)
666 `(("pkg-config" ,pkg-config)
667 ;; That is required for testing.
668 ("xorg-server" ,xorg-server-for-tests)))
674 ("libjpeg" ,libjpeg-turbo)
678 ("libxext" ,libxext)))
681 (modify-phases %standard-phases
682 (delete 'configure) ; no configure script
683 (add-before 'install 'patch-file-start-xserver
684 (lambda* (#:key inputs #:allow-other-keys)
685 ;; patch the file so that qiv runs and exits by itself
686 (substitute* "Makefile"
687 (("./qiv -f ./intro.jpg") "./qiv -f -C -s ./intro.jpg")
688 ;; Fail the build when test fails.
689 (("echo \"-- Test Failed --\"")
690 "(echo \"-- Test Failed --\" ; false)"))
691 ;; There must be a running X server and make install doesn't start one.
692 ;; Therefore we must do it.
694 (setenv "DISPLAY" ":1")
696 #:tests? #f ; there is no check target
699 (string-append "PREFIX=" (assoc-ref %outputs "out")))))
700 (home-page "http://spiegl.de/qiv/")
701 (synopsis "Graphical image viewer for X")
703 "Quick Image Viewer is a small and fast GDK/Imlib2 image viewer.
704 Features include zoom, maxpect, scale down, fullscreen, slideshow, delete,
705 brightness/contrast/gamma correction, pan with keyboard and mouse, flip,
706 rotate left/right, jump/forward/backward images, filename filter and use it
707 to set X desktop background.")
708 (license license:gpl2)))