Some command line options are not GNU/POSIX compliant (3)
[geeqie.git] / README.md
index 1cf935f..6d37e30 100644 (file)
--- a/README.md
+++ b/README.md
@@ -1,48 +1,45 @@
-      ###################################################################
-      ##                          Geeqie x.x                           ##
-      ##                                                               ##
-      ##              Copyright (C) 2008 - 2017 The Geeqie Team        ##
-      ##              Copyright (C) 1999 - 2006 John Ellis.            ##
-      ##                                                               ##
-      ##                      Use at your own risk!                    ##
-      ##                                                               ##
-      ##  This software released under the GNU General Public License. ##
-      ##       Please read the COPYING file for more information.      ##
-      ###################################################################
+# Geeqie Readme
 
-This is Geeqie, a successor of GQview.
+Code Status:  
+![Build Status](https://github.com/BestImageViewer/geeqie/actions/workflows/check-build-actions.yml/badge.svg)
+
+Package Status:  
+[![Packaging status](https://repology.org/badge/tiny-repos/geeqie.svg)](https://repology.org/project/geeqie/versions)
+[![latest packaged version(s)](https://repology.org/badge/latest-versions/geeqie.svg)](https://repology.org/project/geeqie/versions)
 
-[![Build Status](https://api.travis-ci.org/BestImageViewer/geeqie.svg?branch=master)](https://travis-ci.org/BestImageViewer/geeqie)
+## ![][image_ref_geeqie_png] Geeqie - an image viewer
 
-Geeqie has been forked from GQview project, because it was not possible to
-contact the GQview author and only maintainer.
+This is Geeqie, a successor of GQview.
 
-The Geeqie project will continue the development forward and maintain the existing code.
+Geeqie is a free open software image viewer and organiser program for Linux, FreeBSD and other Unix-like operating systems
 
-Geeqie is currently considered stable.
+It can be used as a simple database-free image viewer but it also has extensive capabilities.
 
 Please send any questions, problems or suggestions to the [mailing list](mailto:geeqie@freelists.org) or
 open an issue on [Geeqie at GitHub](https://github.com/BestImageViewer/geeqie/issues).
 
+(NB Unless you first subscribe to the mailing list, you will not receive automated responses)
+
 Subscribe to the mailing list [here](https://www.freelists.org/list/geeqie).
 
-The project website is <http://www.geeqie.org/> and you will find the latest sources in the
+The project website is <https://www.geeqie.org/> and you will find the latest sources in the
 [Geeqie repository](http://geeqie.org/cgi-bin/gitweb.cgi?p=geeqie.git).
 
-# README contents:
-
-* Description / Features
-* Downloading
-* Installation
-* Notes and changes for this release
-* Requirements
+## Contents
 
+* [Features](#features)
+* [Downloading](#downloading)
+* [AppImages](#appimages)
+* [Installation Scripts](#installation-scripts)
+* [Compiling and Installing](#compiling-and-installing)
+* [Notes and changes for the latest release](#notes-and-changes-for-the-latest-release)
+* [Requirements](#requirements)
+* [Required libraries](#required-libraries)
 
-## Description / Features
+### Features
 
 Geeqie is a graphics file viewer. Basic features:
 
-
 * Single click image viewing / navigation.
 
 * Zoom functions.
@@ -59,18 +56,19 @@ Geeqie is a graphics file viewer. Basic features:
 
 * Selectable exif auto-rotation of images.
 
-
 * Single click file copy or move to pre-defined folders - with undo feature.
 * Drag and drop.
 
 * Collections.
 
-* support for stereoscopic images
+* Support for stereoscopic images
     * input: side-by-side (JPS) and MPO format
     * output: single image, anaglyph, SBS, mirror, SBS half size (3DTV)
 
-*   Viewing raster and vector images, in the following formats:
-3FR, ANI, APM, ARW, BMP, CR2, CRW, CUR, DNG, ERF, GIF, ICNS, ICO, JPE/JPEG/JPG, JPS, KDC, MEF, MPO, MOS, MRW, NEF, ORF, PEF, PTX, PBM/PGM/PNM/PPM, PNG, QIF/QTIF (QuickTime Image Format), RAF, RAW, RW2, SR2, SRF, SVG/SVGZ, TGA/TARGA, TIF/TIFF, WMF, XBM, XPM. Animated GIFs are supported.
+* Viewing raster and vector images, in the following formats:
+    * 3FR, ANI, ARW, AVIF, BMP, CR2, CR3, CRW, CUR, DDS, DjVu, DNG, ERF, GIF, HEIC, HEIF, ICO, JP2. JPE/JPEG/JPG, JPEG XL, JPS, KDC, MEF, MOS, MPO, MRW, NEF, ORF (including OM-1), PBM/PGM/PNM/PPM, PEF, PNG, PSD, QIF/QTIF (QuickTime Image Format), RAF, RAW, RW2, SCR (ZX Spectrum), SR2, SRF, SVG/SVGZ, TGA/TARGA, TIF/TIFF, WEBP, XBM, XPM.
+    * Display images in archive files (.ZIP, .RAR etc.).
+    * Animated GIF and WEBP files are supported.
 
 * Preview and thumbnails of video clips can be displayed. Clips can be run via a defined external program.
 
@@ -96,145 +94,160 @@ Geeqie is a graphics file viewer. Basic features:
 * Geeqie includes a 'find duplicates' tool which can compare images using a variety of criteria (filename, file size, visual similarity, dimensions, image content), either within a single folder or between two folders. Finding duplicates ignoring the rotation of images is also supported.
 * Images may be given a rating value (also known as a "star rating").
 
-* Maps from [OpenStreetMap](http://www.openstreetmap.org) may be displayed in a side panel. If an image has GPS coordinates embedded, its position will be displayed on the map - if Image Direction is encoded, that will be displayed also. If an image does not have embedded GPS coordinates, it may be dragged-and-dropped onto the map to encode its position.
+* Maps from [OpenStreetMap](https://www.openstreetmap.org) may be displayed in a side panel. If an image has GPS coordinates embedded, its position will be displayed on the map - if Image Direction is encoded, that will be displayed also. If an image does not have embedded GPS coordinates, it may be dragged-and-dropped onto the map to encode its position.
+
+* Speed of operation can be increased by caching thumbnails and similarity data of images. When Geeqie is run as a stand-alone command line program (`geeqie --cache-maintenance <path>`) these data will be recursively created from the defined start point. This program can be called from `cron` or `anacron` so that cache updating is automatically done at specified intervals.
+
+* Extensible via plugins
+
+### Downloading
+
+Geeqie is available:  
+
+* as a package for Linux and BSD systems (See the [project web page](https://www.geeqie.org#download)).
+
+* as a [flatpak](https://flathub.org/apps/details/org.geeqie.Geeqie) from the [Flathub site](https://flathub.org/home).
+
+* as an [AppImage](https://github.com/BestImageViewer/geeqie/releases) - x86_64 and arm64 (Generated from the latest sources).
+
+* as a [Homebrew](https://formulae.brew.sh/formula/geeqie) or [MacPorts](https://ports.macports.org/port/geeqie) package for macOS.
+
+* via WSL2 on Windows 11 - see notes below.
+
+### AppImages
+
+The Continuous Build release version has AppImages that are automatically generated each time the source code is updated. There are two versions - the full version is about 120MB and the minimal version is about 10MB and will therefore load much faster.
+
+The minimal version can display jpegs, pngs and some other formats, but does not have the range of the full version.
+
+This script file will download to $HOME/bin the latest Continuous Build AppImages for you:
+
+```sh
+wget https://raw.githubusercontent.com/BestImageViewer/geeqie/master/scripts/geeqie-download-appimage.sh
+chmod +x geeqie-download-appimage.sh
+```
 
-## Downloading
+The script can download either the full size or the minimal version of the AppIamge, and sets a symbolic link to the executable file. The ```--help``` option lists all options.
 
-Geeqie is available as a package with some distributions.
+The full version takes a noticeable time to load, and runs slightly slower than a normal packaged release.
+The above script has the option ```--extract``` which extracts the contents of either AppImage to a sub-directory under $HOME/bin.
+With this option the loading and run time is the same as for a packaged release.
 
-The source tar of the latest formal release may be downloaded: <http://geeqie.org/geeqie-1.3.tar.xz>
+There are also options to install desktop icons, menu items, and to revert to earlier downloaded versions.
 
-However Geeqie is stable, and you may download the latest version (if you have installed git) from here:
+AppImages have a "portable mode" which is described [here](https://docs.appimage.org/user-guide/portable-mode.html).
 
-Either: `git clone git://www.geeqie.org/geeqie.git`
+**Note:**
 
-Or: `git clone http://www.geeqie.org/git/geeqie.git`
+Command line auto-completion does not work with AppImages. If you are using the AppImage `--extract` option, this is a work-around.
 
+Assuming you have extracted the AppImage to `$HOME/bin/Geeqie-latest-x86_64-AppImage/`, create a symbolic link as follows:
 
-## Installation
+```sh
+mkdir --parents $HOME/.local/share/bash-completion/completions/
+ln --symbolic $HOME/bin/Geeqie-latest-x86_64-AppImage/squashfs-root/usr/local/share/bash-completion/completions/geeqie $HOME/.local/share/bash-completion/completions/geeqie
+```
 
-List compile options: `./autogen.sh --help`
+### Installation scripts
 
-Common options:
-`./autogen.sh --disable-gtk3`,
+Geeqie is stable and you may compile the latest version from sources.
 
-Compilation: `./autogen.sh [options]; make -j<no. of cpu cores> `
+There are two scripts which will download and compile the sources for you.
 
-Install: `[sudo] make install`
+The first script will install Geeqie to a defined location, and will run under any system. However, it is left to you to make sure dependencies are fulfilled.
+To get the script, from the command line type:
 
-Removal: `[sudo] make uninstall`
+```sh
+wget https://raw.githubusercontent.com/pixlsus/Scripts/master/build-geeqie
+chmod +x build-geeqie
+```
 
-#### Note:
-The zip and gzip files at geeqie.org and GitHub contain only the sources - they cannot, by themselves, be used to install Geeqie.
+The second script will run only on Debian-based system, but will fulfil all dependencies and also give you the opportunity to include additional pixbuf loaders and other useful programs.
+To get the script, from the command line type:
 
-It is recommended to always use `git clone  git://www.geeqie.org/geeqie.git` to download Geeqie. After installing Geeqie you may delete the folder you have cloned Geeqie into.
+```sh
+wget https://raw.githubusercontent.com/BestImageViewer/geeqie/master/geeqie-install-debian.sh
+chmod +x geeqie-install-debian.sh
+```
+
+If you wish to compile the sources yourself you may download the latest version (if you have installed git) from here:
+
+`git clone http://git.geeqie.org/git/geeqie.git`
+
+### Compiling and Installing
+
+`meson setup build`  
+`ninja -C build install`
+
+List compile options:  
+`meson configure build`
+
+Apply options e.g.:  
+`sudo ninja -C build uninstall`  
+`meson configure build -Dpdf=enabled -Dwebp=disabled`  
+`ninja -C build install`
+
+Re-display configuration data:  
+`ninja -C build reconfigure`
+
+Meaning of options:  
+`auto` If the library is not found, continue the installation  
+`enabled` If the library is not found, stop the installation  
+`disabled` Do not look for the library  
+
+Uninstall:  
+`sudo ninja -C build uninstall`
+
+Install new version:  
+`sudo ninja -C build uninstall`  
+`git pull`  
+`ninja -C build install`
+
+#### Note
+
+It is recommended to always use `git clone  git://git.geeqie.org/geeqie.git` to download Geeqie. After installing Geeqie you may delete the folder you have cloned Geeqie into.
 
 However if you leave the folder intact, whenever new features or patches are available, execute:
 
-`git pull; sudo make uninstall; sudo make maintainer-clean; ./autogen.sh; make -j<no. of cpu cores>; sudo make install`
+`sudo ninja -C build uninstall; git pull; ninja -C build install`
 
 Only the changed sources are downloaded, which makes this a quick operation.
 
 Your configuration file, history file and desktop files are not affected by this process.
 
-
-
-## Notes and changes for the latest release
+### Notes and changes for the latest release
 
 See the NEWS file in the installation folder, or [Geeqie News at GitHub](https://github.com/BestImageViewer/geeqie/blob/master/NEWS)
 
 And either the ChangeLog file or [Geeqie ChangeLog](http://geeqie.org/cgi-bin/gitweb.cgi?p=geeqie.git;a=shortlog)
 
+### Required libraries
+
+Required libraries for a Debian installation may be listed by:
+
+```sh
+wget https://raw.githubusercontent.com/BestImageViewer/geeqie/master/geeqie-install-debian.sh
+chmod +x geeqie-install-debian.sh
+./geeqie-install-debian.sh --list
+```
 
-## Requirements
-
-### Required libraries:
-    GTK+ 3.00
-        www.gtk.org
-        enabled by default
-        disable with configure option: --disable-gtk3
-    or
-    GTK+ 2.20
-        disabled by default when GTK+3 libraries are found.
-        enable with configure option: --disable-gtk3
-        optional items map display and GPU acceleration are not available
-        with GTK2
-
-        Note: GTK+3 is still somehow experimental. It is needed for some
-        features but we have several complains about the GTK+3 usability.
-
-        So if you need a stable version, you are advised to compile it
-        with GTK+2. If you want to play with the cool new features, use
-        GTK+3.
-
-### Optional libraries:
-    lcms2 2.0
-    or
-    lcms 1.14
-        www.littlecms.com
-        for color management support
-        enabled by default
-        disable with configure option: --disable-lcms
-
-    exiv2 0.11
-        www.exiv2.org
-        for enhanced exif support
-        enabled by default
-        disable with configure option: --disable-exiv2
-
-    lirc
-        www.lirc.org
-        for remote control support
-        enabled by default
-        disable with configure option: --disable-lirc
-
-    libchamplain-gtk 0.12
-    libchamplain 0.12
-    libclutter 1.0
-        wiki.gnome.org/Projects/libchamplain
-        for map display
-        enabled by default
-        disable with configure option: --disable-map
-
-    libclutter 1.0
-        www.clutter-project.org
-        for GPU acceleration (a check-box on Preferences/Image must also be ticked)
-        enabled by default
-        disable with configure option: --disable-gpu-accel
-        explicitly disabling will also disable the map feature
-
-    lua 5.1
-        www.lua.org
-        support for lua scripting
-        enabled by default
-        disable with configure option: --disable-lua
-
-    librsvg2-common
-        for displaying .svg images
-
-    libwmf0.2-7-gtk
-        for displaying .wmf images
-
-    (see also "Additional pixbuf loaders" in the References section of the Help file)
-
-    awk
-        when running Geeqie, to use the geo-decode function
-
-    markdown
-        when compiling Geeqie, to create this file in html format
-
-    libffmpegthumbnailer 2.0.0
-        https://github.com/dirkvdb/ffmpegthumbnailer
-        for thumbnailing camera video clips
-        disable with configure option: --disable-ffmpegthumbnailer
-
-### Code hackers:
+### Code hackers
 
 If you plan on making any major changes to the code that will be offered for
 inclusion to the main source, please contact us first - so that we can avoid
 duplication of effort.
-                                                         The Geeqie Team
 
-### Known bugs:
+### Known bugs
 
 See the Geeqie Bug Tracker at <https://github.com/BestImageViewer/geeqie/issues>
+
+### Windows
+
+Geeqie can be run on Windows 11 (and possibly Windows 10) via Windows Subsystem for Linux (WSL2).
+
+If the Ubuntu distribution is loaded by WSL, Geeqie can be run as an Ubuntu package or as an extracted AppImage. Geeqie can also be compiled from sources.
+
+Note that some icons are not displayed correctly, and Help and Print do not work. However the Help manual is available [on-line](https://www.geeqie.org/help/GuideIndex.html)
+
+[image_ref_geeqie_png]:
+