Hello, Ah! At last I've got the concern.
You said about the situation where we want to save the manually inserted TBLFM when regenerating the table? Best Regards, Slava Barinov Ihor Radchenko <yanta...@posteo.net> writes: > Slava Barinov <raysl...@gmail.com> writes: > >> Oh, right, I messed the scopes. > > Is your new patch version correct? > I still see #+TBLFM stripped unconditionally even when :tblfm parameter > is not specified.
>From 8b03e527a0a31ce966ddea5e14addb8d11c9af02 Mon Sep 17 00:00:00 2001 From: Slava Barinov <raysl...@gmail.com> Date: Fri, 21 Feb 2025 20:45:41 +0900 Subject: [PATCH] lisp/org-collector.el (org-dblock-write:propview): Add support for the :tblfm keyword. --- lisp/org-collector.el | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/lisp/org-collector.el b/lisp/org-collector.el index b645d3a..cea0708 100644 --- a/lisp/org-collector.el +++ b/lisp/org-collector.el @@ -122,6 +122,7 @@ preceding the dblock, then update the contents of the dblock." (noquote (plist-get params :noquote)) (colnames (plist-get params :colnames)) (defaultval (plist-get params :defaultval)) + (tblfm (plist-get params :tblfm)) (content-lines (org-split-string (plist-get params :content) "\n")) id table line pos idpos stringformat) (save-excursion @@ -147,7 +148,13 @@ preceding the dblock, then update the contents of the dblock." (message (format "point-%d" pos)) (while (setq line (pop content-lines)) (when (string-match "^#" line) - (insert "\n" line))) + (unless (and tblfm + (string-match "^#\\+TBLFM:" line)) + (insert "\n" line)))) + (when tblfm + (unless (looking-back "\n" 1) + (insert "\n")) + (insert (concat "#+TBLFM:" tblfm))) (goto-char pos) (org-table-recalculate 'all)) (org-collector-error (widen) (error "%s" er)) -- 2.48.1