From cd83606cfd8a52e7222a0deeeddb3af29e9cbfce Mon Sep 17 00:00:00 2001 From: Ihor Radchenko Date: Sun, 16 Jan 2022 15:30:27 +0800 Subject: [PATCH] org-fold: Handle indirect buffer visibility --- lisp/org-capture.el | 5 ++++- lisp/org.el | 8 +++++++- 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/lisp/org-capture.el b/lisp/org-capture.el index 1324ffab4..068e3eda2 100644 --- a/lisp/org-capture.el +++ b/lisp/org-capture.el @@ -1171,7 +1171,10 @@ may have been stored before." (goto-char (point-min)) (unless (org-at-heading-p) (outline-next-heading))) ;; Otherwise, insert as a top-level entry at the end of the file. - (t (goto-char (point-max)))) + (t (goto-char (point-max)) + ;; Make sure that last point is not folded. + (org-fold-core-cycle-over-indirect-buffers + (org-fold-region (max 1 (1- (point-max))) (point-max) nil)))) (let ((origin (point))) (unless (bolp) (insert "\n")) (org-capture-empty-lines-before) diff --git a/lisp/org.el b/lisp/org.el index 9e9f1b412..4c8701195 100644 --- a/lisp/org.el +++ b/lisp/org.el @@ -5984,7 +5984,13 @@ frame is not changed." (number-to-string n)))))) (setq n (1+ n))) (condition-case nil - (make-indirect-buffer buffer bname 'clone) + (let ((indirect-buffer (make-indirect-buffer buffer bname 'clone))) + ;; Decouple folding state. We need to do it manually since + ;; `make-indirect-buffer' does not run + ;; `clone-indirect-buffer-hook'. + (org-fold-core-decouple-indirect-buffer-folds) + ;; Return the buffer. + indirect-buffer) (error (make-indirect-buffer buffer bname))))) (defun org-set-frame-title (title)