From befc92b9c0b1837266e42c74c0fb7fc8f878b919 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Pierre=20T=C3=A9choueyres?= Date: Wed, 28 Mar 2018 01:35:22 +0200 Subject: [PATCH] org-agenda: Call `recenter' only if buffer has a window * lisp/org-agenda.el (org-agenda-list): Condition the call to `recenter` only when the buffer has a window associated. This permit to call `org-agenda-list` in a `with-temp-buffer` like below: (with-temp-buffer (let ((org-agenda-sticky nil) (org-agenda-buffer-tmp-name (buffer-name))) (org-agenda-list 1) (buffer-string)) --- lisp/org-agenda.el | 5 +++-- 1 file changed, 3 insertions(+), 2 deletions(-) diff --git a/lisp/org-agenda.el b/lisp/org-agenda.el index 5bbf5e34e..78f67cccf 100644 --- a/lisp/org-agenda.el +++ b/lisp/org-agenda.el @@ -4261,8 +4261,9 @@ items if they have an hour specification like [h]h:mm." (insert tbl))) (goto-char (point-min)) (or org-agenda-multi (org-agenda-fit-window-to-buffer)) - (unless (and (pos-visible-in-window-p (point-min)) - (pos-visible-in-window-p (point-max))) + (unless (or (not (get-buffer-window)) + (and (pos-visible-in-window-p (point-min)) + (pos-visible-in-window-p (point-max)))) (goto-char (1- (point-max))) (recenter -1) (if (not (pos-visible-in-window-p (or start-pos 1))) -- 2.11.4.GIT