emacs-elpa-diffs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[elpa] externals/denote ef43b21e46 2/5: Merge pull request #177 from jea


From: ELPA Syncer
Subject: [elpa] externals/denote ef43b21e46 2/5: Merge pull request #177 from jeanphilippegg/refactor-denote-rename-buffer
Date: Mon, 16 Oct 2023 03:57:54 -0400 (EDT)

branch: externals/denote
commit ef43b21e46fe1ec2f3679039526dd9e16500d7ca
Merge: 58b9be3530 59788dec28
Author: Protesilaos Stavrou <info@protesilaos.com>
Commit: GitHub <noreply@github.com>

    Merge pull request #177 from jeanphilippegg/refactor-denote-rename-buffer
    
    Refactor denote-rename-buffer
---
 denote-rename-buffer.el | 72 ++++++++++++++++++++-----------------------------
 1 file changed, 29 insertions(+), 43 deletions(-)

diff --git a/denote-rename-buffer.el b/denote-rename-buffer.el
index c29e2aa2c5..afe4f944a0 100644
--- a/denote-rename-buffer.el
+++ b/denote-rename-buffer.el
@@ -88,59 +88,45 @@ buffer will be used, if available."
   :package-version '(denote . "2.1.0")
   :group 'denote-rename-buffer)
 
-(defun denote-rename-buffer--common-check (buffer)
-  "Determine if BUFFER shall be renamed.
-Return the file path and the type of it as a cons cell."
-  (when-let ((file (buffer-file-name buffer))
-             ((denote-file-has-identifier-p file))
-             (type (denote-filetype-heuristics file)))
-    (cons file type)))
-
-(defun denote-rename-buffer--get-title (buffer)
-  "Return Denote title of BUFFER."
-  (when-let ((file-and-type (denote-rename-buffer--common-check buffer)))
-    (denote-retrieve-title-value (car file-and-type) (cdr file-and-type))))
+(defun denote-rename-buffer--get-title (file type)
+  "Return Denote title of FILE, given TYPE."
+  (denote-retrieve-title-value file type))
 
-(defun denote-rename-buffer--get-identifier (buffer)
-  "Return Denote identifier of BUFFER."
-  (when-let ((file-and-type (denote-rename-buffer--common-check buffer)))
-    (denote-retrieve-filename-identifier (car file-and-type))))
+(defun denote-rename-buffer--get-identifier (file)
+  "Return Denote identifier of FILE."
+  (denote-retrieve-filename-identifier file))
 
-(defun denote-rename-buffer--get-signature (buffer)
-  "Return Denote signature of BUFFER."
-  (when-let ((file-and-type (denote-rename-buffer--common-check buffer)))
-    (denote-retrieve-filename-signature (car file-and-type))))
+(defun denote-rename-buffer--get-signature (file)
+  "Return Denote signature of FILE."
+  (denote-retrieve-filename-signature file))
 
-(defun denote-rename-buffer--get-keywords (buffer)
-  "Return Denote keywords of BUFFER."
-  (when-let ((file-and-type (denote-rename-buffer--common-check buffer)))
-    (denote--keywords-combine
-     (denote-retrieve-keywords-value (car file-and-type) (cdr 
file-and-type)))))
+(defun denote-rename-buffer--get-keywords (file type)
+  "Return Denote keywords of FILE, given TYPE."
+  (denote--keywords-combine
+   (denote-retrieve-keywords-value file type)))
 
 (defun denote-rename-buffer--format (buffer)
   "Parse the BUFFER through the `denote-rename-buffer-format'."
-  (format-spec denote-rename-buffer-format
-               (list (cons ?t (denote-rename-buffer--get-title buffer))
-                     (cons ?i (denote-rename-buffer--get-identifier buffer))
-                     (cons ?d (denote-rename-buffer--get-identifier buffer))
-                     (cons ?s (denote-rename-buffer--get-signature buffer))
-                     (cons ?k (denote-rename-buffer--get-keywords buffer))
-                     (cons ?% "%"))
-               'delete))
-
-(defun denote-rename-buffer--with-unique-name (name)
-  "Call `rename-buffer' with NAME and uniquify it."
-  (unless (or (string-empty-p name)
-              (string-blank-p name))
-    (rename-buffer name :unique)))
+  (when-let ((file (buffer-file-name buffer))
+             (type (denote-filetype-heuristics file)))
+    (format-spec denote-rename-buffer-format
+                 (list (cons ?t (denote-rename-buffer--get-title file type))
+                       (cons ?i (denote-rename-buffer--get-identifier file))
+                       (cons ?d (denote-rename-buffer--get-identifier file))
+                       (cons ?s (denote-rename-buffer--get-signature file))
+                       (cons ?k (denote-rename-buffer--get-keywords file type))
+                       (cons ?% "%"))
+                 'delete)))
 
 (defun denote-rename-buffer (&optional buffer)
   "Rename current buffer or optional BUFFER with `denote-rename-buffer-format'.
 The symbol of this function is the default value of the user
 option `denote-rename-buffer-function' and is thus used by the
 `denote-rename-buffer-mode'."
-  (denote-rename-buffer--with-unique-name
-   (denote-rename-buffer--format (or buffer (current-buffer)))))
+  (when-let (((denote-file-has-identifier-p (buffer-file-name buffer)))
+             (new-name (denote-rename-buffer--format (or buffer 
(current-buffer))))
+             ((not (string-blank-p new-name))))
+    (rename-buffer new-name :unique)))
 
 (make-obsolete
  'denote-rename-buffer-with-title
@@ -155,8 +141,8 @@ option `denote-rename-buffer-function' and is thus used by 
the
 (defun denote-rename-buffer--fallback (&optional buffer)
   "Fallback to rename BUFFER or `current-buffer'.
 This is called if `denote-rename-buffer-rename-function' is nil."
-  (denote-rename-buffer--with-unique-name
-   (denote-rename-buffer--get-title (or buffer (current-buffer)))))
+  (let ((denote-rename-buffer-format "%t"))
+    (denote-rename-buffer buffer)))
 
 (defun denote-rename-buffer-rename-function-or-fallback ()
   "Call `denote-rename-buffer-function' or its fallback to rename with title.



reply via email to

[Prev in Thread] Current Thread [Next in Thread]