]> git.eshelyaron.com Git - emacs.git/commitdiff
; * lisp/image-dired.el: Add some basic sections.
authorStefan Kangas <stefan@marxist.se>
Mon, 8 Nov 2021 05:42:44 +0000 (06:42 +0100)
committerStefan Kangas <stefan@marxist.se>
Mon, 8 Nov 2021 06:37:48 +0000 (07:37 +0100)
This file is currently rather hard to follow due to things just being
thrown in at random by many different contributors, with seemingly no
overall plan or idea.  This is the first step towards giving it some
kind of organization.

lisp/image-dired.el

index b67e1e7888f9ba08c93de629d550320aa27eda9c..a2c37f00f23ec11f27b403b8b5bd32e428f40dce 100644 (file)
   (require 'cl-lib)
   (require 'wid-edit))
 
+\f
+;;; Customizable variables
+
 (defgroup image-dired nil
   "Use Dired to browse your images as thumbnails, and more."
   :prefix "image-dired-"
@@ -216,8 +219,6 @@ https://specifications.freedesktop.org/thumbnail-spec/thumbnail-spec-latest.html
   "Database file where file names and their associated tags are stored."
   :type 'file)
 
-
-
 (defcustom image-dired-cmd-create-thumbnail-program
   (if (executable-find "gm") "gm" "convert")
   "Executable used to create thumbnail.
@@ -498,6 +499,9 @@ variable is nil, it will never ask."
                  (const :tag "Disable warning" nil))
   :version "29.1")
 
+\f
+;;; Util functions
+
 (defvar image-dired-debug nil
   "Non-nil means enable debug messages.")
 
@@ -622,6 +626,9 @@ See also `image-dired-thumbnail-storage'."
   (unless (executable-find (symbol-value executable))
     (error "Executable %S not found" executable)))
 
+\f
+;;; Creating thumbnails
+
 (defun image-dired-thumb-size (dimension)
   "Return thumb size depending on `image-dired-thumbnail-storage'.
 DIMENSION should be either the symbol `width' or `height'."
@@ -651,8 +658,6 @@ consider setting `image-dired-debug' to a non-nil value to see
 the time spent on generating thumbnails.  Run `image-clear-cache'
 and remove the cached thumbnail files between each trial run.")
 
-(defvar image-dired-tag-history nil "Variable holding the tag history.")
-
 (defun image-dired-pngnq-thumb (spec)
   "Quantize thumbnail described by format SPEC with pngnq(1)."
   (let ((process
@@ -1064,6 +1069,9 @@ never ask for confirmation."
 ;;;###autoload
 (defalias 'image-dired 'image-dired-show-all-from-dir)
 
+\f
+;;; Tags
+
 (defun image-dired-sane-db-file ()
   "Check if `image-dired-db-file' exists.
 If not, try to create it (including any parent directories).
@@ -1082,6 +1090,8 @@ Signal error if there are problems creating it."
         (file-exists-p image-dired-db-file))
       (error "Could not create %s" image-dired-db-file)))
 
+(defvar image-dired-tag-history nil "Variable holding the tag history.")
+
 (defun image-dired-write-tags (file-tags)
   "Write file tags to database.
 Write each file and tag in FILE-TAGS to the database.
@@ -1202,6 +1212,9 @@ With prefix argument ARG, remove tag from file at point."
      (image-dired-update-property
       'tags (image-dired-list-tags (image-dired-original-file-name))))))
 
+\f
+;;; Thumbnail mode (cont.)
+
 (defun image-dired-original-file-name ()
   "Get original file name for thumbnail or display image at point."
   (get-text-property (point) 'original-file-name))
@@ -1654,6 +1667,9 @@ Use `image-dired-minor-mode' to get a nice setup."
   ;; Use approximately as much vertical spacing as horizontal.
   (setq-local line-spacing (frame-char-width)))
 
+\f
+;;; Display image mode
+
 (define-derived-mode image-dired-display-image-mode
   image-mode "image-dired-image-display"
   "Mode for displaying and manipulating original image.
@@ -1741,6 +1757,9 @@ With prefix argument ARG, create thumbnails even if they already exist
                 arg)
         (image-dired-create-thumb curr-file thumb-name)))))
 
+\f
+;;; Slideshow.
+
 (defvar image-dired-slideshow-timer nil
   "Slideshow timer.")
 
@@ -1778,6 +1797,9 @@ Ask user for number of images to show and the delay in between."
   (interactive)
   (cancel-timer image-dired-slideshow-timer))
 
+\f
+;;; Thumbnail mode (cont. 3)
+
 (defun image-dired-delete-char ()
   "Remove current thumbnail from thumbnail buffer and line up."
   (interactive nil image-dired-thumbnail-mode)
@@ -2008,6 +2030,9 @@ overwritten.  This confirmation can be turned off using
   (interactive)
   (image-dired-rotate-original "90"))
 
+\f
+;;; EXIF support
+
 (defun image-dired-get-exif-file-name (file)
   "Use the image's EXIF information to return a unique file name.
 The file name should be unique as long as you do not take more than
@@ -2088,6 +2113,8 @@ function.  The result is a couple of new files in
        (copy-file curr-file new-name))
      files)))
 
+;;; Thumbnail mode (cont.)
+
 (defun image-dired-display-next-thumbnail-original (&optional arg)
   "In thumbnail buffer, move to next thumbnail and display the image.
 With prefix ARG, move that many thumbnails."
@@ -2101,6 +2128,9 @@ With prefix ARG, move that many thumbnails."
   (interactive "p" image-dired-thumbnail-mode)
   (image-dired-display-next-thumbnail-original (- arg)))
 
+\f
+;;; Image Comments
+
 (defun image-dired-write-comments (file-comments)
   "Write file comments to database.
 Write file comments to one or more files.
@@ -2227,6 +2257,10 @@ matching tag will be marked in the Dired buffer."
          (dired-mark 1))))
     (message "%d files with matching tag marked." hits)))
 
+
+\f
+;;; Mouse support
+
 (defun image-dired-mouse-display-image (event)
   "Use mouse EVENT, call `image-dired-display-image' to display image.
 Track this in associated Dired buffer if `image-dired-track-movement' is
@@ -2255,6 +2289,10 @@ non-nil."
       (image-dired-track-original-file))
   (image-dired-display-thumb-properties))
 
+
+\f
+;;; Dired marks and tags
+
 (defun image-dired-thumb-file-marked-p (&optional flagged)
   "Check if file is marked in associated Dired buffer.
 If optional argument FLAGGED is non-nil, check if file is flagged
@@ -2347,7 +2385,8 @@ Track this in associated Dired buffer if
           comment)))))
 
 \f
-;;;; Gallery support
+\f
+;;; Gallery support
 
 ;; TODO:
 ;; * Support gallery creation when using per-directory thumbnail
@@ -2581,7 +2620,7 @@ when using per-directory thumbnail file storage"))
       (insert "</html>"))))
 
 \f
-;;;; Tag support
+;;; Tag support
 
 (defvar image-dired-widget-list nil
   "List to keep track of meta data in edit buffer.")
@@ -2685,7 +2724,7 @@ tags to their respective image file.  Internal function used by
          (push (cons file tag) lst))))))
 
 \f
-;;;; bookmark.el support
+;;; bookmark.el support
 
 (declare-function bookmark-make-record-default
                   "bookmark" (&optional no-file no-context posn))
@@ -2716,7 +2755,7 @@ tags to their respective image file.  Internal function used by
     (goto-char (point-min))))
 
 \f
-;;;; Obsolete
+;;; Obsolete
 
 ;;;###autoload
 (define-obsolete-function-alias 'tumme #'image-dired "24.4")