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 Nikita <nikita@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, 2020 Guy Fleury Iteriteka <gfleury@disroot.org>
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 "0yvvj1s7ayn0lwils582smwkmckdk0gij5c58g45n4xh981n693q"))))
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
129 (url "https://github.com/BestImageViewer/geeqie")
130 (commit (string-append "v" version))))
133 "0nf45sh3pwsv98sppcrqj81b6mdi31n1sbc7gn88m8mhpfp1qq6k"))
134 (file-name (git-file-name name version))))
135 (build-system gnu-build-system)
137 `( ;; Enable support for a "map" pane using GPS data.
138 #:configure-flags '("--enable-map"
141 `(("clutter" ,clutter)
142 ("libchamplain" ,libchamplain)
148 `(("autoconf" ,autoconf)
149 ("automake" ,automake)
150 ("glib" ,glib "bin") ; glib-gettextize
151 ("intltool" ,intltool)
152 ("pkg-config" ,pkg-config)))
153 (home-page "http://www.geeqie.org/")
154 (synopsis "Lightweight GTK+ based image viewer")
156 "Geeqie is a lightweight GTK+ based image viewer for Unix like operating
157 systems. It features: EXIF, IPTC and XMP metadata browsing and editing
158 interoperability; easy integration with other software; geeqie works on files
159 and directories, there is no need to import images; fast preview for many raw
160 image formats; tools for image comparison, sorting and managing photo
161 collection. Geeqie was initially based on GQview.")
162 (license license:gpl2+)))
164 (define-public gpicview
170 (uri (string-append "mirror://sourceforge/lxde/"
171 "GPicView%20%28image%20Viewer%29/0.2.x/"
172 name "-" version ".tar.xz"))
175 "0hi9v0rdx47nys0wvm9xasdrafa34r5kq6crb074a0ipwmc60iiq"))))
176 (build-system gnu-build-system)
177 (inputs `(("gtk+" ,gtk+-2)
178 ("libjpeg" ,libjpeg-turbo)))
179 (native-inputs `(("intltool" ,intltool)
180 ("pkg-config" ,pkg-config)))
181 (synopsis "Simple and fast image viewer for X")
182 (description "gpicview is a lightweight GTK+ 2.x based image viewer.
183 It is the default image viewer on LXDE desktop environment.")
184 (home-page "http://lxde.sourceforge.net/gpicview/")
185 (license license:gpl2+)))
194 (url "https://github.com/muennich/sxiv")
195 (commit (string-append "v" version))))
196 (file-name (git-file-name name version))
199 "0xaawlfdy7b277m38mgg4423kd7p1ffn0dq4hciqs6ivbb3q9c4f"))))
200 (build-system gnu-build-system)
202 `(#:tests? #f ; no check target
204 (list (string-append "PREFIX=" %output)
206 ;; Xft.h #includes <ft2build.h> without ‘freetype2/’. The Makefile
207 ;; works around this by hard-coding /usr/include & $PREFIX.
208 (string-append "CPPFLAGS=-I"
209 (assoc-ref %build-inputs "freetype")
210 "/include/freetype2")
213 (modify-phases %standard-phases
214 (delete 'configure)))) ; no configure script
216 `(("freetype" ,freetype)
222 (home-page "https://github.com/muennich/sxiv")
223 (synopsis "Simple X Image Viewer")
225 "sxiv is an alternative to feh and qiv. Its primary goal is to
226 provide the most basic features required for fast image viewing. It has
227 vi key bindings and works nicely with tiling window managers. Its code
228 base should be kept small and clean to make it easy for you to dig into
229 it and customize it for your needs.")
230 (license license:gpl2+)))
232 (define-public viewnior
240 (url "https://github.com/hellosiyan/Viewnior")
241 (commit (string-append name "-" version))))
242 (file-name (git-file-name name version))
245 "0y4hk3vq8psba5k615w18qj0kbdfp5w0lm98nv5apy6hmcpwfyig"))))
246 (build-system meson-build-system)
249 (modify-phases %standard-phases
250 (add-after 'unpack 'patch-source
252 ;; Don't create 'icon-theme.cache'
253 (substitute* "meson.build"
254 (("meson.add_install_script*") ""))
256 #:tests? #f)) ; no tests
258 `(("gettext" ,gettext-minimal)
259 ("glib" ,glib "bin") ; glib-genmarshal
260 ("pkg-config" ,pkg-config)
261 ("shared-mime-info" ,shared-mime-info)))
264 ("gdk-pixbuf" ,gdk-pixbuf)
266 (home-page "http://siyanpanayotov.com/project/viewnior")
267 (synopsis "Simple, fast and elegant image viewer")
268 (description "Viewnior is an image viewer program. Created to be simple,
269 fast and elegant. Its minimalistic interface provides more screenspace for
270 your images. Among its features are:
272 @item Fullscreen & Slideshow
273 @item Rotate, flip, crop, save, delete images
274 @item Animation support
275 @item Browse only selected images
276 @item Navigation window
277 @item Set image as wallpaper (Gnome 2, Gnome 3, XFCE, LXDE, FluxBox, Nitrogen)
278 @item Simple interface
279 @item EXIF and IPTC metadata
280 @item Configurable mouse actions
282 (license license:gpl3+)))
284 (define-public catimg
292 (url "https://github.com/posva/catimg")
294 (file-name (git-file-name name version))
296 (base32 "0g9ywbgy162wiam9hc3yqpq5q4gyxa8fj4jskr3fdz8z8jjaabzz"))))
297 (build-system cmake-build-system)
299 `(#:tests? #f ; no tests
301 (modify-phases %standard-phases
302 (add-after 'unpack 'patch-convert
304 (substitute* "catimg"
305 ;; By replacing "convert", we also replace the "convert"
306 ;; in the message 'The version of convert is too old, don't
307 ;; expect good results :('. This should not happen, but in
308 ;; practice this error message should not affect us.
309 (("convert") (which "convert")))
311 (add-after 'install 'install-script
312 (lambda* (#:key outputs #:allow-other-keys)
313 ;; The bash script lacks an file extension. We have to rename
314 ;; it so that the C program and the bash script can be happy
316 (copy-file "../source/catimg"
317 (string-append (assoc-ref outputs "out")
321 `(("imagemagick" ,imagemagick))) ; for the bash script version
322 (home-page "https://github.com/posva/catimg")
323 (synopsis "Render images in the terminal")
325 "Catimg is a little program that prints images in the terminal.
326 It supports JPEG, PNG and GIF formats.")
327 (license license:expat)))
329 (define-public luminance-hdr
331 (name "luminance-hdr")
336 "mirror://sourceforge/qtpfsgui/luminance/"
337 version "/luminance-hdr-" version ".tar.bz2"))
340 "188q0l63nfasqfvwbq4mwx2vh7wsfi2bq9n5nksddspl1qz01lnp"))))
341 (build-system cmake-build-system)
343 `(("pkg-config" ,pkg-config)
344 ("qttools" ,qttools)))
347 ("qtdeclarative" ,qtdeclarative)
349 ("qtwebkit" ,qtwebkit)
357 ("libjpeg" ,libjpeg-turbo)
362 ("libtiff" ,libtiff)))
364 '(#:tests? #f ;XXX: some tests fail to compile
366 (modify-phases %standard-phases
367 (add-after 'set-paths 'add-ilmbase-include-path
368 (lambda* (#:key inputs #:allow-other-keys)
369 ;; 'OpenEXR.pc' has a -I for IlmBase but 'FindOpenEXR.cmake' does
370 ;; not use 'OpenEXR.pc'. Thus, we need to add
371 ;; "$ilmbase/include/OpenEXR/" to the CPATH.
373 (string-append (assoc-ref inputs "ilmbase")
375 ":" (or (getenv "CPATH") "")))
377 (home-page "http://qtpfsgui.sourceforge.net")
378 (synopsis "High dynamic range (HDR) imaging application")
380 "Luminance HDR (formerly QtPFSGui) is a graphical user interface
381 application that aims to provide a workflow for high dynamic range (HDR)
382 imaging. It supports several HDR and LDR image formats, and it can:
385 @item Create an HDR file from a set of images (formats: JPEG, TIFF 8bit and
386 16bit, RAW) of the same scene taken at different exposure setting;
387 @item Save load HDR images;
388 @item Rotate, resize and crop HDR images;
389 @item Tone-map HDR images;
390 @item Copy EXIF data between sets of images.
392 (license license:gpl2+)))
394 ;; CBR and RAR are currently unsupported, due to non-free dependencies.
395 (define-public mcomix
396 ;; Official mcomix hasn't been updated since 2016, it's broken with
397 ;; python-pillow 6+ and only supports Python 2. We use fork instead.
398 (let ((commit "fea55a7a9369569eefed72209eed830409c4af98"))
401 (version (git-version "1.2.1" "1" commit))
406 (url "https://github.com/multiSnow/mcomix3")
408 (file-name (git-file-name name version))
411 "05zl0dkjwbdcm2zlk4nz9w33amlqj8pbf32a8ymshc2356fqhhi5"))))
412 (build-system python-build-system)
415 ("python-pillow" ,python-pillow)
416 ("python-pygobject" ,python-pygobject)
417 ("python-pycairo" ,python-pycairo)))
419 `(#:tests? #f ; FIXME: How do we run tests?
421 (modify-phases %standard-phases
422 (add-after 'unpack 'configure
423 (lambda* (#:key inputs #:allow-other-keys)
424 (let ((p7zip (assoc-ref inputs "p7zip")))
425 ;; insert absolute path to 7z executable
426 (substitute* "mcomix/mcomix/archive/sevenzip_external.py"
427 (("_7z_executable = -1")
428 (string-append "_7z_executable = u'" p7zip "/bin/7z'"))))
431 (lambda* (#:key outputs #:allow-other-keys)
432 (let* ((out (assoc-ref outputs "out"))
433 (pyver ,(version-major+minor (package-version python)))
434 (lib (string-append out "/lib/python" pyver)))
435 (invoke (which "python") "installer.py" "--srcdir=mcomix"
436 (string-append "--target=" lib))
437 (rename-file (string-append lib "/mcomix")
438 (string-append lib "/site-packages"))
441 (lambda* (#:key outputs #:allow-other-keys)
442 (let* ((out (assoc-ref outputs "out"))
443 (share (string-append out "/share"))
444 (bin (string-append out "/bin"))
445 (pyver ,(version-major+minor (package-version python)))
446 (lib (string-append out "/lib/python" pyver "/site-packages")))
448 (rename-file (string-append lib "/mcomixstarter.py")
449 (string-append bin "/mcomix"))
450 (rename-file (string-append lib "/comicthumb.py")
451 (string-append bin "/comicthumb"))
452 (install-file "mime/mcomix.desktop"
453 (string-append share "/applications"))
454 (install-file "mime/mcomix.appdata.xml"
455 (string-append share "/metainfo"))
456 (install-file "mime/mcomix.xml"
457 (string-append share "/mime/packages"))
458 (install-file "mime/comicthumb.thumbnailer"
459 (string-append share "/thumbnailers"))
460 (install-file "man/mcomix.1" (string-append share "/man/man1"))
461 (install-file "man/comicthumb.1" (string-append share "/man/man1"))
465 (format #f "mcomix/mcomix/images/~sx~s/mcomix.png" size size)
466 (format #f "~a/icons/hicolor/~sx~s/apps/" share size size))
470 (format #f "mime/icons/~sx~s/application-x-~a.png" size size ext)
471 (format #f "~a/icons/hicolor/~sx~s/mimetypes/"
473 '("cb7" "cbr" "cbt" "cbz")))
476 (home-page "https://sourceforge.net/p/mcomix/wiki/Home/")
477 (synopsis "Image viewer for comics")
478 (description "MComix is a customizable image viewer that specializes as
479 a comic and manga reader. It supports a variety of container formats
480 including CBZ, CB7, CBT, LHA.
482 For PDF support, install the @emph{mupdf} package.")
483 (license license:gpl2+))))
493 (url "https://github.com/jurplel/qView")
495 (file-name (git-file-name name version))
497 (base32 "15a91bs3wcqhgf76wzigbn10hayg628j84pq4j2vaxar94ak0vk7"))))
498 (build-system gnu-build-system)
501 (modify-phases %standard-phases
505 ;; Installation process hard-codes "/usr/bin", possibly
507 (add-after 'configure 'fix-install-directory
508 (lambda* (#:key outputs #:allow-other-keys)
509 (let ((out (assoc-ref outputs "out")))
510 (substitute* "Makefile"
511 (("\\$\\(INSTALL_ROOT\\)/usr") out))
513 ;; Don't phone home or show "Checking for updates..." in the
515 (add-before 'build 'disable-auto-update
517 (substitute* "src/qvaboutdialog.cpp"
518 (("ui->updateLabel->setText\\(updateText\\);") "")
519 (("requestUpdates\\(\\);") ""))
524 ("qtimageformats" ,qtimageformats)))
525 (home-page "https://interversehq.com/qview/")
526 (synopsis "Convenient and minimal image viewer")
527 (description "qView is a Qt image viewer designed with visually
528 minimalism and usability in mind. Its features include animated GIF
529 controls, file history, rotation/mirroring, and multithreaded
531 (license license:gpl3+)))
539 (uri (string-append "https://hpjansson.org/chafa/releases/chafa-"
543 "18rb82bfqj1sj2g4irazx4lwq9q4b4k7my1r0q714vf9yhs41ls6"))))
544 (build-system gnu-build-system)
546 `(("pkg-config" ,pkg-config)))
548 `(("freetype" ,freetype)
549 ("libjpeg" ,libjpeg-turbo)
551 ("imagemagick" ,imagemagick)))
552 (synopsis "Convert images to ANSI/Unicode characters")
554 "Chafa is a command-line utility that converts all kinds of images,
555 including animated GIFs, into ANSI/Unicode character output that can be
556 displayed in a terminal.")
557 (home-page "https://hpjansson.org/chafa/")
558 (license license:lgpl3+)))
567 (url "https://github.com/eXeC64/imv")
568 (commit (string-append "v" version))))
571 "0gk8g178i961nn3bls75a8qpv6wvfvav6hd9lxca1skaikd33zdx"))
572 (file-name (git-file-name name version))))
573 (build-system gnu-build-system)
576 (modify-phases %standard-phases
578 (add-after 'install 'record-absolute-file-names
579 (lambda* (#:key outputs #:allow-other-keys)
580 ;; 'imv' is a script that execs 'imv-x11' or 'imv-wayland'.
581 ;; Record their absolute file name.
582 (let* ((out (assoc-ref outputs "out"))
583 (bin (string-append out "/bin")))
584 (substitute* (string-append bin "/imv")
586 (string-append bin "/imv-")))
590 (string-append "PREFIX=" (assoc-ref %outputs "out"))
591 (string-append "CONFIGPREFIX="
592 (assoc-ref %outputs "out") "/etc"))))
594 `(("asciidoc" ,asciidoc)
595 ("freeimage" ,freeimage)
598 ("libxkbcommon" ,libxkbcommon)
600 ("wayland" ,wayland)))
603 ("pkg-config" ,pkg-config)))
604 (synopsis "Image viewer for tiling window managers")
605 (description "@code{imv} is a command line image viewer intended for use
606 with tiling window managers. Features include:
609 @item Native Wayland and X11 support.
610 @item Support for dozens of image formats including:
617 @item Various RAW formats
618 @item Photoshop PSD files
620 @item Configurable key bindings and behavior.
621 @item Highly scriptable with IPC via imv-msg.
623 (home-page "https://github.com/eXeC64/imv")
624 (license license:expat)))
633 (uri (string-append "http://spiegl.de/qiv/download/qiv-"
636 (base32 "1rlf5h67vhj7n1y7jqkm9k115nfnzpwngj3kzqsi2lg676srclv7"))))
637 (build-system gnu-build-system)
639 `(("pkg-config" ,pkg-config)
640 ;; That is required for testing.
641 ("xorg-server" ,xorg-server-for-tests)))
647 ("libjpeg" ,libjpeg-turbo)
651 ("libxext" ,libxext)))
654 (modify-phases %standard-phases
655 (delete 'configure) ; no configure script
656 (add-before 'install 'patch-file-start-xserver
657 (lambda* (#:key inputs #:allow-other-keys)
658 ;; patch the file so that qiv runs and exits by itself
659 (substitute* "Makefile"
660 (("./qiv -f ./intro.jpg") "./qiv -f -C -s ./intro.jpg")
661 ;; Fail the build when test fails.
662 (("echo \"-- Test Failed --\"")
663 "(echo \"-- Test Failed --\" ; false)"))
664 ;; There must be a running X server and make install doesn't start one.
665 ;; Therefore we must do it.
667 (setenv "DISPLAY" ":1")
669 #:tests? #f ; there is no check target
672 (string-append "PREFIX=" (assoc-ref %outputs "out")))))
673 (home-page "http://spiegl.de/qiv/")
674 (synopsis "Graphical image viewer for X")
676 "Quick Image Viewer is a small and fast GDK/Imlib2 image viewer.
677 Features include zoom, maxpect, scale down, fullscreen, slideshow, delete,
678 brightness/contrast/gamma correction, pan with keyboard and mouse, flip,
679 rotate left/right, jump/forward/backward images, filename filter and use it
680 to set X desktop background.")
681 (license license:gpl2)))