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

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

[elpa] externals/denote 2ab74c1d47 6/6: Merge pull request #495 from jea


From: ELPA Syncer
Subject: [elpa] externals/denote 2ab74c1d47 6/6: Merge pull request #495 from jeanphilippegg/denote--date-convert
Date: Sat, 14 Dec 2024 03:57:58 -0500 (EST)

branch: externals/denote
commit 2ab74c1d47927685fe1c5b2c1ffbb00b51c1690b
Merge: 5d4b9f9089 165ef38a9b
Author: Protesilaos Stavrou <info@protesilaos.com>
Commit: GitHub <noreply@github.com>

    Merge pull request #495 from jeanphilippegg/denote--date-convert
    
    Small adjustments for notes without identifier
---
 README.org           |  9 +++---
 denote.el            | 82 +++++++++++++++++++++++++---------------------------
 tests/denote-test.el | 12 ++++----
 3 files changed, 48 insertions(+), 55 deletions(-)

diff --git a/README.org b/README.org
index d295150799..4aa0893a2d 100644
--- a/README.org
+++ b/README.org
@@ -5949,11 +5949,10 @@ might change them without further notice.
   ([[#h:e7ef08d6-af1b-4ab3-bb00-494a653e6d63][The 
denote-date-prompt-use-org-read-date option]]). With optional
   =INITIAL-DATE= use it as the initial minibuffer text. With optional
   =PROMPT-TEXT= use it in the minibuffer instead of the default
-  prompt. When ~denote-date-prompt-use-org-read-date~ is non-nil, the
-  value of =INITIAL-DATE= is of the format understood by
-  ~org-read-date~. Otherwise, it is a string that can be processed by
-  ~denote-valid-date-p~. [ The =INITIAL-DATE= and =PROMPT-TEXT= are
-  part of {{{development-version}}}. ]
+  prompt. =INITIAL-DATE= is a string that can be processed by
+  ~denote-valid-date-p~, a value that can be parsed by ~decode-time~
+  or nil. [ The =INITIAL-DATE= and =PROMPT-TEXT= are part of
+  {{{development-version}}}. ]
 
 #+findex: denote-command-prompt
 + Function ~denote-command-prompt~ ::  Prompt for command among
diff --git a/denote.el b/denote.el
index 296e02de78..ac2368dfdf 100644
--- a/denote.el
+++ b/denote.el
@@ -2741,20 +2741,12 @@ here for clarity."
 
 (defun denote--date-convert (date prefer-type)
   "Determine how to convert DATE to PREFER-TYPE `:list' or `:string'."
-  (let ((parsed-date (denote-valid-date-p date)))
-    (unless (memq prefer-type '(:list :string))
-      (error "The PREFER-TYPE must be either `:list' or `:string'"))
-    (cond
-     ((listp date)
-      (if (eq prefer-type :list)
-          parsed-date
-        (format-time-string "%F %T" date)))
-     ((stringp date)
-      (if (eq prefer-type :string)
-          date
-        parsed-date))
-     (t
-      (error "The `%s' is neither a list nor a string" date)))))
+  (unless (memq prefer-type '(:list :string))
+    (error "The PREFER-TYPE must be either `:list' or `:string'"))
+  (cond ((eq prefer-type :list)
+         date)
+        ((eq prefer-type :string)
+         (if date (format-time-string "%F %T" date) ""))))
 
 (defun denote-date-prompt (&optional initial-date prompt-text)
   "Prompt for date, expecting YYYY-MM-DD or that plus HH:MM.
@@ -2765,25 +2757,25 @@ With optional INITIAL-DATE use it as the initial 
minibuffer
 text.  With optional PROMPT-TEXT use it in the minibuffer instead
 of the default prompt.
 
-When `denote-date-prompt-use-org-read-date' is non-nil, the value of
-INITIAL-DATE is of the format understood by `org-read-date'.  Otherwise,
-it is a string that can be processed by `denote-valid-date-p'."
-  (if (and denote-date-prompt-use-org-read-date
-           (require 'org nil :no-error))
-      (let* ((time (org-read-date nil t nil prompt-text (denote--date-convert 
initial-date :list)))
-             (org-time-seconds (format-time-string "%S" time))
-             (cur-time-seconds (format-time-string "%S" (current-time))))
-        ;; When the user does not input a time, org-read-date defaults to 00 
for seconds.
-        ;; When the seconds are 00, we add the current seconds to avoid 
identifier collisions.
-        (when (string-equal "00" org-time-seconds)
-          (setq time (time-add time (string-to-number cur-time-seconds))))
-        (format-time-string "%Y-%m-%d %H:%M:%S" time))
-    (read-string
-     (or
-      "DATE and TIME for note (e.g. 2022-06-16 14:30): "
-      prompt-text)
-     (denote--date-convert initial-date :string)
-     'denote-date-history)))
+INITIAL-DATE is a string that can be processed by `denote-valid-date-p',
+a value that can be parsed by `decode-time' or nil."
+  (let ((initial-date (denote-valid-date-p initial-date)))
+    (if (and denote-date-prompt-use-org-read-date
+             (require 'org nil :no-error))
+        (let* ((time (org-read-date nil t nil prompt-text 
(denote--date-convert initial-date :list)))
+               (org-time-seconds (format-time-string "%S" time))
+               (cur-time-seconds (format-time-string "%S" (current-time))))
+          ;; When the user does not input a time, org-read-date defaults to 00 
for seconds.
+          ;; When the seconds are 00, we add the current seconds to avoid 
identifier collisions.
+          (when (string-equal "00" org-time-seconds)
+            (setq time (time-add time (string-to-number cur-time-seconds))))
+          (format-time-string "%Y-%m-%d %H:%M:%S" time))
+      (read-string
+       (or
+        "DATE and TIME for note (e.g. 2022-06-16 14:30): "
+        prompt-text)
+       (denote--date-convert initial-date :string)
+       'denote-date-history))))
 
 (defun denote-prompt-for-date-return-id (&optional initial-date prompt-text)
   "Use `denote-date-prompt' and return it as `denote-id-format'.
@@ -2791,7 +2783,7 @@ Optional INITIAL-DATE and PROMPT-TEXT have the same 
meaning as
 `denote-date-prompt'."
   (denote-get-identifier
    (denote-valid-date-p
-    (denote-date-prompt initial-date prompt-text))))
+    (denote-date-prompt (denote-valid-date-p initial-date) prompt-text))))
 
 (defvar denote-subdirectory-history nil
   "Minibuffer history of `denote-subdirectory-prompt'.")
@@ -3424,6 +3416,16 @@ If `denote-rename-confirmations' does not contain
 (defvar denote-rename-max-mini-window-height 0.33
   "How much to enlarge `max-mini-window-height' for renaming operations.")
 
+(defun denote--generate-date-for-rename (file)
+  "Generate a date for FILE.
+
+Respect `denote-generate-identifier-automatically'."
+  (if (or (eq denote-generate-identifier-automatically t)
+          (eq denote-generate-identifier-automatically 'on-rename))
+      (or (file-attribute-modification-time (file-attributes file))
+          (current-time))
+    nil))
+
 (defun denote--rename-file (file title keywords signature date)
   "Rename FILE according to the other parameters.
 Parameters TITLE, KEYWORDS, SIGNATURE and DATE are as described
@@ -3443,12 +3445,7 @@ Respect `denote-rename-confirmations', 
`denote-save-buffers' and
          (keywords (denote-keywords-sort keywords))
          (directory (file-name-directory file))
          (extension (file-name-extension file :include-period))
-         ;; Handle nil date
-         (date (cond (date date)
-                     ((or (eq denote-generate-identifier-automatically t)
-                          (eq denote-generate-identifier-automatically 
'on-rename))
-                      (or (file-attribute-modification-time (file-attributes 
file))
-                          (current-time)))))
+         (date (or date (denote--generate-date-for-rename file)))
          (old-id (or (denote-retrieve-filename-identifier file) ""))
          (id (denote-get-identifier date))
          (id (cond ((or (string-empty-p id) (string= old-id id))
@@ -3485,9 +3482,8 @@ It is meant to be combined with `denote--rename-file' to 
create
 renaming commands."
   (let* ((file-in-prompt (propertize (file-relative-name file) 'face 
'denote-faces-prompt-current-name))
          (file-type (denote-filetype-heuristics file))
-         (date (denote-valid-date-p (or (denote-retrieve-filename-identifier 
file)
-                                        (file-attribute-modification-time 
(file-attributes file))
-                                        (current-time))))
+         (id (or (denote-retrieve-filename-identifier file) ""))
+         (date (or (denote-valid-date-p id) (denote--generate-date-for-rename 
file)))
          (title (or (denote-retrieve-title-or-filename file file-type) ""))
          (keywords (denote-extract-keywords-from-path file))
          (signature (or (denote-retrieve-filename-signature file) "")))
diff --git a/tests/denote-test.el b/tests/denote-test.el
index 3a083abfe5..0c6028b1b7 100644
--- a/tests/denote-test.el
+++ b/tests/denote-test.el
@@ -527,15 +527,13 @@ does not involve the time zone."
            (equal (denote--date-convert '(26454 45206 461174 657000) :string)
                   "2024-12-09 10:55:50")
 
-           (equal (denote--date-convert "2024-12-09 10:55:50" :list)
-                  '(26454 45206))
+           (equal (denote--date-convert nil :string)
+                  "")
 
-           (equal (denote--date-convert "2024-12-09 10:55:50" :string)
-                  "2024-12-09 10:55:50")))
+           (equal (denote--date-convert nil :list)
+                  nil)))
   (should-error (denote--date-convert '(26454 45206 461174 657000) 
:not-valid-type))
-  (should-error (denote--date-convert "2024-12-09 10:55:50" :not-valid-type))
-  (should-error (denote--date-convert "Not right date" :list))
-  (should-error (denote--date-convert "Not right date" :string)))
+  (should-error (denote--date-convert nil :not-valid-type)))
 
 ;;;; denote-journal-extras.el
 



reply via email to

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