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