diff options
author | Stefan Kangas <stefan@marxist.se> | 2022-06-25 12:55:15 +0200 |
---|---|---|
committer | Stefan Kangas <stefan@marxist.se> | 2022-06-25 12:55:18 +0200 |
commit | 3d3029353b95360e374fc673339b7c8cd5568db1 (patch) | |
tree | e3c20a72b455b38d91fed3e9e26cc667b6ce16a0 /lisp/recentf.el | |
parent | a2c25d5b2f34522d14fd9dc105d942b74698078a (diff) | |
download | emacs-3d3029353b95360e374fc673339b7c8cd5568db1.tar.gz emacs-3d3029353b95360e374fc673339b7c8cd5568db1.tar.bz2 emacs-3d3029353b95360e374fc673339b7c8cd5568db1.zip |
New command recentf-open
* lisp/recentf.el (recentf-open): New command. (Bug#56148)
(recentf): New alias.
(recentf, recentf-mode): Update documentation to focus more on the
list of recently opened files and ways of accessing it, instead of
focusing on the menu bar only.
(recentf-list, recentf-enabled-p): Minor doc fixes.
* doc/emacs/files.texi (File Conveniences): Update documentation.
Diffstat (limited to 'lisp/recentf.el')
-rw-r--r-- | lisp/recentf.el | 53 |
1 files changed, 44 insertions, 9 deletions
diff --git a/lisp/recentf.el b/lisp/recentf.el index d8016077ebd..601b2642f76 100644 --- a/lisp/recentf.el +++ b/lisp/recentf.el @@ -1,4 +1,4 @@ -;;; recentf.el --- setup a menu of recently opened files -*- lexical-binding: t -*- +;;; recentf.el --- keep track of recently opened files -*- lexical-binding: t -*- ;; Copyright (C) 1999-2022 Free Software Foundation, Inc. @@ -23,10 +23,19 @@ ;;; Commentary: -;; This package maintains a menu for visiting files that were operated -;; on recently. When enabled a new "Open Recent" submenu is -;; displayed in the "File" menu. The recent files list is -;; automatically saved across Emacs sessions. +;; This package maintains a list of recently opened files and makes it +;; easy to visit them. The recent files list is automatically saved +;; across Emacs sessions. + +;; There are three ways to access recent files: +;; +;; (1) `M-x recentf-open' prompts for a recently opened file. +;; +;; (2) When this mode is enabled, a new "Open Recent" submenu is +;; displayed in the "File" menu. +;; +;; (3) `M-x recentf-open-files' lists recently visited files in a +;; buffer. ;; You can customize the number of recent files displayed, the ;; location of the menu and other options. Type: @@ -45,17 +54,17 @@ ;;; Internal data ;; (defvar recentf-list nil - "List of recently opened files.") + "List of recently opened files for `recentf-mode'.") (defun recentf-enabled-p () - "Return non-nil if recentf mode is currently enabled." + "Return non-nil if `recentf-mode' is currently enabled." (memq 'recentf-save-list kill-emacs-hook)) ;;; Customization ;; (defgroup recentf nil - "Maintain a menu of recently opened files." + "Maintain a list of recently opened files." :version "21.1" :group 'files) @@ -465,6 +474,26 @@ Return non-nil if F1 is less than F2." (recentf-string-lessp (file-name-nondirectory f1) (file-name-nondirectory f2)) (recentf-string-lessp d1 d2)))) + + +;;; Open files +;; + +;;;###autoload +(defun recentf-open (file) + "Prompt for FILE in `recentf-list' and visit it. +Enable `recentf-mode' if it isn't already." + (interactive + (list + (progn (unless recentf-mode (recentf-mode 1)) + (completing-read (format-prompt "Open recent file" nil) + recentf-list nil t)))) + (when file + (funcall recentf-menu-action file))) + +;;;###autoload +(defalias 'recentf 'recentf-open) + ;;; Menu building ;; @@ -1344,7 +1373,13 @@ That is, remove duplicates, non-kept, and excluded files." ;;;###autoload (define-minor-mode recentf-mode - "Toggle \"Open Recent\" menu (Recentf mode). + "Toggle keeping track of opened files (Recentf mode). +This mode maintains a list of recently opened files and makes it +easy to visit them. The recent files list is automatically saved +across Emacs sessions. + +You can use `recentf-open' or `recentf-open-files' to visit +files. When Recentf mode is enabled, a \"Open Recent\" submenu is displayed in the \"File\" menu, containing a list of files that |