From 407a55c1c0e24994808b7fa098a14507a7a90755 Mon Sep 17 00:00:00 2001 From: Thierry Banel Date: Sat, 24 Feb 2024 17:31:46 +0100 Subject: [PATCH] org-table.el: Enhanced table parsing * lisp/org-table.el (org-table-to-lisp): Refactored. * etc/ORG-NEWS: Document changes. `org-table-to-lisp' is significantly faster. It no longer uses regexps, nor clobbers the global regexp state. --- etc/ORG-NEWS | 6 ++++++ lisp/org-table.el | 37 ++++++++++++++++++++++++------------- 2 files changed, 30 insertions(+), 13 deletions(-) diff --git a/etc/ORG-NEWS b/etc/ORG-NEWS index db0c604f2..dc0d9c0ad 100644 --- a/etc/ORG-NEWS +++ b/etc/ORG-NEWS @@ -1285,6 +1285,12 @@ For symmetry with =\S= and =\sect= for the section symbol, =\P= has been added as an another form for the pilcrow symbol currently available as =\para=. +*** ~org-table-to-lisp~ no longer clobbers the regexp global state + +It does no longer use regexps. + +It is also faster. Large tables can be read quickly. + * Version 9.6 ** Important announcements and breaking changes diff --git a/lisp/org-table.el b/lisp/org-table.el index c6e16c1fd..67fffc23e 100644 --- a/lisp/org-table.el +++ b/lisp/org-table.el @@ -5494,25 +5494,36 @@ for a horizontal separator line, or a list of field values as strings. The table is taken from the parameter TXT, or from the buffer at point." (if txt (with-temp-buffer + (buffer-disable-undo) (insert txt) (goto-char (point-min)) (org-table-to-lisp)) (save-excursion (goto-char (org-table-begin)) - (let ((table nil)) - (while (re-search-forward "\\=[ \t]*|" nil t) - (let ((row nil)) - (if (looking-at "-") - (push 'hline table) - (while (not (progn (skip-chars-forward " \t") (eolp))) - (push (buffer-substring - (point) - (progn (re-search-forward "[ \t]*\\(|\\|$\\)") - (match-beginning 0))) - row)) - (push (nreverse row) table))) + (let (table) + (while (progn (skip-chars-forward " \t") + (eq (following-char) ?|)) + (forward-char) + (push + (if (eq (following-char) ?-) + 'hline + (let (row) + (while (progn + (skip-chars-forward " \t") + (not (eolp))) + (let ((q (point))) + (skip-chars-forward "^|\n") + (goto-char + (prog1 + (let ((p (point))) + (unless (eolp) (setq p (1+ p))) + p) + (skip-chars-backward " \t" q) + (push (buffer-substring-no-properties q (point)) row))))) + (nreverse row))) + table) (forward-line)) - (nreverse table))))) + (nreverse table))))) (defun org-table-collapse-header (table &optional separator max-header-lines) "Collapse the lines before `hline' into a single header.