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 "04c8cgwzkax481sz7lbzy23mk79bqmjy3qpvr7vxa4c14mc9k5gk"))))
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)
161 (setenv "NOCONFIGURE" "true")
163 ;; Don't try to run 'git' for the version number.
164 (substitute* "configure.ac"
165 (("m4_esyscmd_s\\([^)]+\\)")
166 (string-append "[" ,version "]")))
168 ;; Remove references to non-existent files.
169 (substitute* "po/POTFILES.in"
170 (("^plugins/import/.*") ""))
173 `(("clutter" ,clutter)
174 ("libchamplain" ,libchamplain)
180 `(("autoconf" ,autoconf)
181 ("automake" ,automake)
182 ("glib" ,glib "bin") ; glib-gettextize
183 ("intltool" ,intltool)
184 ("pkg-config" ,pkg-config)))
185 (home-page "http://www.geeqie.org/")
186 (synopsis "Lightweight GTK+ based image viewer")
188 "Geeqie is a lightweight GTK+ based image viewer for Unix like operating
189 systems. It features: EXIF, IPTC and XMP metadata browsing and editing
190 interoperability; easy integration with other software; geeqie works on files
191 and directories, there is no need to import images; fast preview for many raw
192 image formats; tools for image comparison, sorting and managing photo
193 collection. Geeqie was initially based on GQview.")
194 (license license:gpl2+))))
196 (define-public gpicview
202 (uri (string-append "mirror://sourceforge/lxde/"
203 "GPicView%20%28image%20Viewer%29/0.2.x/"
204 name "-" version ".tar.xz"))
207 "0hi9v0rdx47nys0wvm9xasdrafa34r5kq6crb074a0ipwmc60iiq"))))
208 (build-system gnu-build-system)
209 (inputs `(("gtk+" ,gtk+-2)
210 ("libjpeg" ,libjpeg)))
211 (native-inputs `(("intltool" ,intltool)
212 ("pkg-config" ,pkg-config)))
213 (synopsis "Simple and fast image viewer for X")
214 (description "gpicview is a lightweight GTK+ 2.x based image viewer.
215 It is the default image viewer on LXDE desktop environment.")
216 (home-page "http://lxde.sourceforge.net/gpicview/")
217 (license license:gpl2+)))
226 (url "https://github.com/muennich/sxiv.git")
227 (commit (string-append "v" version))))
228 (file-name (git-file-name name version))
231 "0xaawlfdy7b277m38mgg4423kd7p1ffn0dq4hciqs6ivbb3q9c4f"))))
232 (build-system gnu-build-system)
234 `(#:tests? #f ; no check target
236 (list (string-append "PREFIX=" %output)
238 ;; Xft.h #includes <ft2build.h> without ‘freetype2/’. The Makefile
239 ;; works around this by hard-coding /usr/include & $PREFIX.
240 (string-append "CPPFLAGS=-I"
241 (assoc-ref %build-inputs "freetype")
242 "/include/freetype2")
245 (modify-phases %standard-phases
246 (delete 'configure)))) ; no configure script
248 `(("freetype" ,freetype)
254 (home-page "https://github.com/muennich/sxiv")
255 (synopsis "Simple X Image Viewer")
257 "sxiv is an alternative to feh and qiv. Its primary goal is to
258 provide the most basic features required for fast image viewing. It has
259 vi key bindings and works nicely with tiling window managers. Its code
260 base should be kept small and clean to make it easy for you to dig into
261 it and customize it for your needs.")
262 (license license:gpl2+)))
264 (define-public viewnior
272 (url "https://github.com/hellosiyan/Viewnior.git")
273 (commit (string-append name "-" version))))
274 (file-name (git-file-name name version))
277 "0y4hk3vq8psba5k615w18qj0kbdfp5w0lm98nv5apy6hmcpwfyig"))))
278 (build-system meson-build-system)
281 (modify-phases %standard-phases
282 (add-after 'unpack 'patch-source
284 ;; Don't create 'icon-theme.cache'
285 (substitute* "meson.build"
286 (("meson.add_install_script*") ""))
288 #:tests? #f)) ; no tests
290 `(("gettext" ,gettext-minimal)
291 ("glib" ,glib "bin") ; glib-genmarshal
292 ("pkg-config" ,pkg-config)
293 ("shared-mime-info" ,shared-mime-info)))
296 ("gdk-pixbuf" ,gdk-pixbuf)
298 (home-page "http://siyanpanayotov.com/project/viewnior")
299 (synopsis "Simple, fast and elegant image viewer")
300 (description "Viewnior is an image viewer program. Created to be simple,
301 fast and elegant. Its minimalistic interface provides more screenspace for
302 your images. Among its features are:
304 @item Fullscreen & Slideshow
305 @item Rotate, flip, crop, save, delete images
306 @item Animation support
307 @item Browse only selected images
308 @item Navigation window
309 @item Set image as wallpaper (Gnome 2, Gnome 3, XFCE, LXDE, FluxBox, Nitrogen)
310 @item Simple interface
311 @item EXIF and IPTC metadata
312 @item Configurable mouse actions
314 (license license:gpl3+)))
316 (define-public catimg
324 (url "https://github.com/posva/catimg.git")
326 (file-name (git-file-name name version))
328 (base32 "0g9ywbgy162wiam9hc3yqpq5q4gyxa8fj4jskr3fdz8z8jjaabzz"))))
329 (build-system cmake-build-system)
331 `(#:tests? #f ; no tests
333 (modify-phases %standard-phases
334 (add-after 'unpack 'patch-convert
336 (substitute* "catimg"
337 ;; By replacing "convert", we also replace the "convert"
338 ;; in the message 'The version of convert is too old, don't
339 ;; expect good results :('. This should not happen, but in
340 ;; practice this error message should not affect us.
341 (("convert") (which "convert")))
343 (add-after 'install 'install-script
344 (lambda* (#:key outputs #:allow-other-keys)
345 ;; The bash script lacks an file extension. We have to rename
346 ;; it so that the C program and the bash script can be happy
348 (copy-file "../source/catimg"
349 (string-append (assoc-ref outputs "out")
353 `(("imagemagick" ,imagemagick))) ; for the bash script version
354 (home-page "https://github.com/posva/catimg")
355 (synopsis "Render images in the terminal")
357 "Catimg is a little program that prints images in the terminal.
358 It supports JPEG, PNG and GIF formats.")
359 (license license:expat)))
361 (define-public luminance-hdr
363 (name "luminance-hdr")
368 "mirror://sourceforge/qtpfsgui/luminance/"
369 version "/luminance-hdr-" version ".tar.bz2"))
372 "00fldbcizrx8jcnjgq74n3zmbm27dxzl96fxa7q49689mfnlw08l"))
373 (patches (search-patches "luminance-hdr-qt-printer.patch"))))
374 (build-system cmake-build-system)
376 `(("pkg-config" ,pkg-config)
377 ("qttools" ,qttools)))
380 ("qtdeclarative" ,qtdeclarative)
381 ("qtwebkit" ,qtwebkit)
393 ("libtiff" ,libtiff)))
396 (modify-phases %standard-phases
397 (add-after 'set-paths 'add-ilmbase-include-path
398 (lambda* (#:key inputs #:allow-other-keys)
399 ;; 'OpenEXR.pc' has a -I for IlmBase but 'FindOpenEXR.cmake' does
400 ;; not use 'OpenEXR.pc'. Thus, we need to add
401 ;; "$ilmbase/include/OpenEXR/" to the CPATH.
403 (string-append (assoc-ref inputs "ilmbase")
405 ":" (or (getenv "CPATH") "")))
407 (home-page "http://qtpfsgui.sourceforge.net")
408 (synopsis "High dynamic range (HDR) imaging application")
410 "Luminance HDR (formerly QtPFSGui) is a graphical user interface
411 application that aims to provide a workflow for high dynamic range (HDR)
412 imaging. It supports several HDR and LDR image formats, and it can:
415 @item Create an HDR file from a set of images (formats: JPEG, TIFF 8bit and
416 16bit, RAW) of the same scene taken at different exposure setting;
417 @item Save load HDR images;
418 @item Rotate, resize and crop HDR images;
419 @item Tone-map HDR images;
420 @item Copy EXIF data between sets of images.
422 (license license:gpl2+)))
424 ;; CBR and RAR are currently unsupported, due to non-free dependencies.
425 (define-public mcomix
426 ;; Official mcomix hasn't been updated since 2016, it's broken with
427 ;; python-pillow 6+ and only supports Python 2. We use fork instead.
428 (let ((commit "fea55a7a9369569eefed72209eed830409c4af98"))
431 (version (git-version "1.2.1" "1" commit))
436 (url "https://github.com/multiSnow/mcomix3")
438 (file-name (git-file-name name version))
441 "05zl0dkjwbdcm2zlk4nz9w33amlqj8pbf32a8ymshc2356fqhhi5"))))
442 (build-system python-build-system)
445 ("python-pillow" ,python-pillow)
446 ("python-pygobject" ,python-pygobject)
447 ("python-pycairo" ,python-pycairo)))
449 `(#:tests? #f ; FIXME: How do we run tests?
451 (modify-phases %standard-phases
452 (add-after 'unpack 'configure
453 (lambda* (#:key inputs #:allow-other-keys)
454 (let ((p7zip (assoc-ref inputs "p7zip")))
455 ;; insert absolute path to 7z executable
456 (substitute* "mcomix/mcomix/archive/sevenzip_external.py"
457 (("_7z_executable = -1")
458 (string-append "_7z_executable = u'" p7zip "/bin/7z'"))))
461 (lambda* (#:key outputs #:allow-other-keys)
462 (let* ((out (assoc-ref outputs "out"))
463 (pyver ,(version-major+minor (package-version python)))
464 (lib (string-append out "/lib/python" pyver)))
465 (invoke (which "python") "installer.py" "--srcdir=mcomix"
466 (string-append "--target=" lib))
467 (rename-file (string-append lib "/mcomix")
468 (string-append lib "/site-packages"))
471 (lambda* (#:key outputs #:allow-other-keys)
472 (let* ((out (assoc-ref outputs "out"))
473 (share (string-append out "/share"))
474 (bin (string-append out "/bin"))
475 (pyver ,(version-major+minor (package-version python)))
476 (lib (string-append out "/lib/python" pyver "/site-packages")))
478 (rename-file (string-append lib "/mcomixstarter.py")
479 (string-append bin "/mcomix"))
480 (rename-file (string-append lib "/comicthumb.py")
481 (string-append bin "/comicthumb"))
482 (install-file "mime/mcomix.desktop"
483 (string-append share "/applications"))
484 (install-file "mime/mcomix.appdata.xml"
485 (string-append share "/metainfo"))
486 (install-file "mime/mcomix.xml"
487 (string-append share "/mime/packages"))
488 (install-file "mime/comicthumb.thumbnailer"
489 (string-append share "/thumbnailers"))
490 (install-file "man/mcomix.1" (string-append share "/man/man1"))
491 (install-file "man/comicthumb.1" (string-append share "/man/man1"))
495 (format #f "mcomix/mcomix/images/~sx~s/mcomix.png" size size)
496 (format #f "~a/icons/hicolor/~sx~s/apps/" share size size))
500 (format #f "mime/icons/~sx~s/application-x-~a.png" size size ext)
501 (format #f "~a/icons/hicolor/~sx~s/mimetypes/"
503 '("cb7" "cbr" "cbt" "cbz")))
506 (home-page "https://sourceforge.net/p/mcomix/wiki/Home/")
507 (synopsis "Image viewer for comics")
508 (description "MComix is a customizable image viewer that specializes as
509 a comic and manga reader. It supports a variety of container formats
510 including CBZ, CB7, CBT, LHA.
512 For PDF support, install the @emph{mupdf} package.")
513 (license license:gpl2+))))
523 (url "https://github.com/jurplel/qView.git")
525 (file-name (git-file-name name version))
527 (base32 "15a91bs3wcqhgf76wzigbn10hayg628j84pq4j2vaxar94ak0vk7"))))
528 (build-system gnu-build-system)
531 (modify-phases %standard-phases
535 ;; Installation process hard-codes "/usr/bin", possibly
537 (add-after 'configure 'fix-install-directory
538 (lambda* (#:key outputs #:allow-other-keys)
539 (let ((out (assoc-ref outputs "out")))
540 (substitute* "Makefile"
541 (("\\$\\(INSTALL_ROOT\\)/usr") out))
543 ;; Don't phone home or show "Checking for updates..." in the
545 (add-before 'build 'disable-auto-update
547 (substitute* "src/qvaboutdialog.cpp"
548 (("ui->updateLabel->setText\\(updateText\\);") "")
549 (("requestUpdates\\(\\);") ""))
554 ("qtimageformats" ,qtimageformats)))
555 (home-page "https://interversehq.com/qview/")
556 (synopsis "Convenient and minimal image viewer")
557 (description "qView is a Qt image viewer designed with visually
558 minimalism and usability in mind. Its features include animated GIF
559 controls, file history, rotation/mirroring, and multithreaded
561 (license license:gpl3+)))
569 (uri (string-append "https://hpjansson.org/chafa/releases/chafa-"
573 "0aa7119514rhsak5i0kgvwllb9z74lnfzfn7dzfhs27fc8cvx1dg"))))
574 (build-system gnu-build-system)
576 `(("pkg-config" ,pkg-config)))
579 ("imagemagick" ,imagemagick)))
580 (synopsis "Convert images to ANSI/Unicode characters")
582 "Chafa is a command-line utility that converts all kinds of images,
583 including animated GIFs, into ANSI/Unicode character output that can be
584 displayed in a terminal.")
585 (home-page "https://hpjansson.org/chafa/")
586 (license license:lgpl3+)))
595 (url "https://github.com/eXeC64/imv")
596 (commit (string-append "v" version))))
599 "0gk8g178i961nn3bls75a8qpv6wvfvav6hd9lxca1skaikd33zdx"))
600 (file-name (git-file-name name version))))
601 (build-system gnu-build-system)
604 (modify-phases %standard-phases
606 (add-after 'install 'record-absolute-file-names
607 (lambda* (#:key outputs #:allow-other-keys)
608 ;; 'imv' is a script that execs 'imv-x11' or 'imv-wayland'.
609 ;; Record their absolute file name.
610 (let* ((out (assoc-ref outputs "out"))
611 (bin (string-append out "/bin")))
612 (substitute* (string-append bin "/imv")
614 (string-append bin "/imv-")))
618 (string-append "PREFIX=" (assoc-ref %outputs "out"))
619 (string-append "CONFIGPREFIX="
620 (assoc-ref %outputs "out") "/etc"))))
622 `(("asciidoc" ,asciidoc)
623 ("freeimage" ,freeimage)
626 ("libxkbcommon" ,libxkbcommon)
628 ("wayland" ,wayland)))
631 ("pkg-config" ,pkg-config)))
632 (synopsis "Image viewer for tiling window managers")
633 (description "@code{imv} is a command line image viewer intended for use
634 with tiling window managers. Features include:
637 @item Native Wayland and X11 support.
638 @item Support for dozens of image formats including:
645 @item Various RAW formats
646 @item Photoshop PSD files
648 @item Configurable key bindings and behavior.
649 @item Highly scriptable with IPC via imv-msg.
651 (home-page "https://github.com/eXeC64/imv")
652 (license license:expat)))
661 (uri (string-append "http://spiegl.de/qiv/download/qiv-"
664 (base32 "1rlf5h67vhj7n1y7jqkm9k115nfnzpwngj3kzqsi2lg676srclv7"))))
665 (build-system gnu-build-system)
667 `(("pkg-config" ,pkg-config)
668 ;; That is required for testing.
669 ("xorg-server" ,xorg-server-for-tests)))
679 ("libxext" ,libxext)))
682 (modify-phases %standard-phases
683 (delete 'configure) ; no configure script
684 (add-before 'install 'patch-file-start-xserver
685 (lambda* (#:key inputs #:allow-other-keys)
686 ;; patch the file so that qiv runs and exits by itself
687 (substitute* "Makefile"
688 (("./qiv -f ./intro.jpg") "./qiv -f -C -s ./intro.jpg")
689 ;; Fail the build when test fails.
690 (("echo \"-- Test Failed --\"")
691 "(echo \"-- Test Failed --\" ; false)"))
692 ;; There must be a running X server and make install doesn't start one.
693 ;; Therefore we must do it.
695 (setenv "DISPLAY" ":1")
697 #:tests? #f ; there is no check target
700 (string-append "PREFIX=" (assoc-ref %outputs "out")))))
701 (home-page "http://spiegl.de/qiv/")
702 (synopsis "Graphical image viewer for X")
704 "Quick Image Viewer is a small and fast GDK/Imlib2 image viewer.
705 Features include zoom, maxpect, scale down, fullscreen, slideshow, delete,
706 brightness/contrast/gamma correction, pan with keyboard and mouse, flip,
707 rotate left/right, jump/forward/backward images, filename filter and use it
708 to set X desktop background.")
709 (license license:gpl2)))