emacs-orgmode
[Top][All Lists]
Advanced

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

Re: org-goto and org-store-link/org-id-get-create


From: Ihor Radchenko
Subject: Re: org-goto and org-store-link/org-id-get-create
Date: Wed, 28 Apr 2021 22:58:37 +0800

Bastien <bzg@gnu.org> writes:

> Can you provide a patch for this?

Sure. Attached.

>From d914acea52d251e2099681ac9541e4cb42e0953f Mon Sep 17 00:00:00 2001
Message-Id: 
<d914acea52d251e2099681ac9541e4cb42e0953f.1619621773.git.yantar92@gmail.com>
From: Ihor Radchenko <yantar92@gmail.com>
Date: Wed, 28 Apr 2021 22:51:53 +0800
Subject: [PATCH] Bypass read-only state in org-entry-put

* lisp/org.el (org-entry-put): Ignore read-only state of the buffer.

Fixes bug when ID property is not insered when creating ID in an
indirect read-only org-goto buffer. [1]

[1] https://orgmode.org/list/8ffe2da5-e2cb-f44c-0a46-b19873c0bdf2@gmx.de/
---
 lisp/org.el | 113 ++++++++++++++++++++++++++--------------------------
 1 file changed, 57 insertions(+), 56 deletions(-)

diff --git a/lisp/org.el b/lisp/org.el
index eb4b2db88..dbc245534 100644
--- a/lisp/org.el
+++ b/lisp/org.el
@@ -12340,62 +12340,63 @@ (defun org-entry-put (pom property value)
        ((not (stringp value)) (error "Properties values should be strings"))
        ((not (org--valid-property-p property))
         (user-error "Invalid property name: \"%s\"" property)))
-  (org-with-point-at pom
-    (if (or (not (featurep 'org-inlinetask)) (org-inlinetask-in-task-p))
-       (org-back-to-heading-or-point-min t)
-      (org-with-limited-levels (org-back-to-heading-or-point-min t)))
-    (let ((beg (point)))
-      (cond
-       ((equal property "TODO")
-       (cond ((not (org-string-nw-p value)) (setq value 'none))
-             ((not (member value org-todo-keywords-1))
-              (user-error "\"%s\" is not a valid TODO state" value)))
-       (org-todo value)
-       (org-align-tags))
-       ((equal property "PRIORITY")
-       (org-priority (if (org-string-nw-p value) (string-to-char value) ?\s))
-       (org-align-tags))
-       ((equal property "SCHEDULED")
-       (forward-line)
-       (if (and (looking-at-p org-planning-line-re)
-                (re-search-forward
-                 org-scheduled-time-regexp (line-end-position) t))
-           (cond ((string= value "earlier") (org-timestamp-change -1 'day))
-                 ((string= value "later") (org-timestamp-change 1 'day))
-                 ((string= value "") (org-schedule '(4)))
-                 (t (org-schedule nil value)))
-         (if (member value '("earlier" "later" ""))
-             (call-interactively #'org-schedule)
-           (org-schedule nil value))))
-       ((equal property "DEADLINE")
-       (forward-line)
-       (if (and (looking-at-p org-planning-line-re)
-                (re-search-forward
-                 org-deadline-time-regexp (line-end-position) t))
-           (cond ((string= value "earlier") (org-timestamp-change -1 'day))
-                 ((string= value "later") (org-timestamp-change 1 'day))
-                 ((string= value "") (org-deadline '(4)))
-                 (t (org-deadline nil value)))
-         (if (member value '("earlier" "later" ""))
-             (call-interactively #'org-deadline)
-           (org-deadline nil value))))
-       ((member property org-special-properties)
-       (error "The %s property cannot be set with `org-entry-put'" property))
-       (t
-       (let* ((range (org-get-property-block beg 'force))
-              (end (cdr range))
-              (case-fold-search t))
-         (goto-char (car range))
-         (if (re-search-forward (org-re-property property nil t) end t)
-             (progn (delete-region (match-beginning 0) (match-end 0))
-                    (goto-char (match-beginning 0)))
-           (goto-char end)
-           (insert "\n")
-           (backward-char))
-         (insert ":" property ":")
-         (when value (insert " " value))
-         (org-indent-line)))))
-    (run-hook-with-args 'org-property-changed-functions property value)))
+  (org-no-read-only
+   (org-with-point-at pom
+     (if (or (not (featurep 'org-inlinetask)) (org-inlinetask-in-task-p))
+        (org-back-to-heading-or-point-min t)
+       (org-with-limited-levels (org-back-to-heading-or-point-min t)))
+     (let ((beg (point)))
+       (cond
+        ((equal property "TODO")
+        (cond ((not (org-string-nw-p value)) (setq value 'none))
+              ((not (member value org-todo-keywords-1))
+               (user-error "\"%s\" is not a valid TODO state" value)))
+        (org-todo value)
+        (org-align-tags))
+        ((equal property "PRIORITY")
+        (org-priority (if (org-string-nw-p value) (string-to-char value) ?\s))
+        (org-align-tags))
+        ((equal property "SCHEDULED")
+        (forward-line)
+        (if (and (looking-at-p org-planning-line-re)
+                 (re-search-forward
+                  org-scheduled-time-regexp (line-end-position) t))
+            (cond ((string= value "earlier") (org-timestamp-change -1 'day))
+                  ((string= value "later") (org-timestamp-change 1 'day))
+                  ((string= value "") (org-schedule '(4)))
+                  (t (org-schedule nil value)))
+          (if (member value '("earlier" "later" ""))
+              (call-interactively #'org-schedule)
+            (org-schedule nil value))))
+        ((equal property "DEADLINE")
+        (forward-line)
+        (if (and (looking-at-p org-planning-line-re)
+                 (re-search-forward
+                  org-deadline-time-regexp (line-end-position) t))
+            (cond ((string= value "earlier") (org-timestamp-change -1 'day))
+                  ((string= value "later") (org-timestamp-change 1 'day))
+                  ((string= value "") (org-deadline '(4)))
+                  (t (org-deadline nil value)))
+          (if (member value '("earlier" "later" ""))
+              (call-interactively #'org-deadline)
+            (org-deadline nil value))))
+        ((member property org-special-properties)
+        (error "The %s property cannot be set with `org-entry-put'" property))
+        (t
+        (let* ((range (org-get-property-block beg 'force))
+               (end (cdr range))
+               (case-fold-search t))
+          (goto-char (car range))
+          (if (re-search-forward (org-re-property property nil t) end t)
+              (progn (delete-region (match-beginning 0) (match-end 0))
+                     (goto-char (match-beginning 0)))
+            (goto-char end)
+            (insert "\n")
+            (backward-char))
+          (insert ":" property ":")
+          (when value (insert " " value))
+          (org-indent-line)))))
+     (run-hook-with-args 'org-property-changed-functions property value))))
 
 (defun org-buffer-property-keys (&optional specials defaults columns)
   "Get all property keys in the current buffer.
-- 
2.26.3


reply via email to

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