]> git.eshelyaron.com Git - emacs.git/commitdiff
Allow shortening filenames in recentf-mode menu
authorStefan Kangas <stefan@marxist.se>
Tue, 21 Jun 2022 12:27:51 +0000 (14:27 +0200)
committerStefan Kangas <stefan@marxist.se>
Tue, 21 Jun 2022 12:38:45 +0000 (14:38 +0200)
* lisp/recentf.el (recentf-show-abbreviated): New function.
(recentf--filter-names): New helper function.
(recentf-show-basenames): Use above new helper function.
(recentf-menu-filter): Allow setting user option to new value
'recentf-show-abbreviated'.

etc/NEWS
lisp/recentf.el

index c54a1cc42a26670bcdf7f04d708c448498c0325d..fdc2e99ca46883d803fdfc3912669dc2db536036 100644 (file)
--- a/etc/NEWS
+++ b/etc/NEWS
@@ -1840,6 +1840,11 @@ Enabling this minor mode turns on hiding header material, like
 If non-nil, files untracked by a VCS are considered to be part of
 the project by a VC project based on that VCS.
 
+---
+*** The 'recentf-mode' menu can now use shortened filenames.
+Set the user option 'recentf-menu-filter' to
+'recentf-show-abbreviated' to enable it.
+
 ---
 ** The autoarg.el library is now marked obsolete.
 This library provides the 'autoarg-mode' and 'autoarg-kp-mode' minor
index 2de9831154023cbfd157c9c4fe3be2adba8970e8..28aee0f17fd9991fa4099dfa624ed8bcec80ddc7 100644 (file)
@@ -186,6 +186,8 @@ A nil value means no filter.  The following functions are predefined:
     Sort menu items by directories in ascending order.
 - `recentf-sort-directories-descending'
     Sort menu items by directories in descending order.
+- `recentf-show-abbreviated'
+    Show shortened filenames.
 - `recentf-show-basenames'
     Show filenames sans directory in menu items.
 - `recentf-show-basenames-ascending'
@@ -214,6 +216,7 @@ elements (see `recentf-make-menu-element' for menu element form)."
                 (function-item recentf-sort-basenames-descending)
                 (function-item recentf-sort-directories-ascending)
                 (function-item recentf-sort-directories-descending)
+                (function-item recentf-show-abbreviated)
                 (function-item recentf-show-basenames)
                 (function-item recentf-show-basenames-ascending)
                 (function-item recentf-show-basenames-descending)
@@ -724,14 +727,11 @@ Compares directories then filenames to order the list."
            (recentf-menu-element-value e2)
            (recentf-menu-element-value e1)))))
 
-(defun recentf-show-basenames (l &optional no-dir)
-  "Filter the list of menu elements L to show filenames sans directory.
-When a filename is duplicated, it is appended a sequence number if
-optional argument NO-DIR is non-nil, or its directory otherwise."
+(defun recentf--filter-names (l no-dir fun)
   (let (filtered-names filtered-list full name counters sufx)
     (dolist (elt l (nreverse filtered-list))
       (setq full (recentf-menu-element-value elt)
-            name (file-name-nondirectory full))
+            name (funcall fun full))
       (if (not (member name filtered-names))
           (push name filtered-names)
         (if no-dir
@@ -743,6 +743,18 @@ optional argument NO-DIR is non-nil, or its directory otherwise."
         (setq name (format "%s(%s)" name sufx)))
       (push (recentf-make-menu-element name full) filtered-list))))
 
+(defun recentf-show-abbreviated (l &optional no-dir)
+  "Filter the list of menu elements L to show shortened filenames.
+When a filename is duplicated, it is appended a sequence number if
+optional argument NO-DIR is non-nil, or its directory otherwise."
+  (recentf--filter-names l no-dir #'abbreviate-file-name))
+
+(defun recentf-show-basenames (l &optional no-dir)
+  "Filter the list of menu elements L to show filenames sans directory.
+When a filename is duplicated, it is appended a sequence number if
+optional argument NO-DIR is non-nil, or its directory otherwise."
+  (recentf--filter-names l no-dir #'file-name-nondirectory))
+
 (defsubst recentf-show-basenames-ascending (l)
   "Filter the list of menu elements L to show filenames sans directory.
 Filenames are sorted in ascending order.