diff --git a/lisp/org-footnote.el b/lisp/org-footnote.el index 729a4a930..c8c4dae80 100644 --- a/lisp/org-footnote.el +++ b/lisp/org-footnote.el @@ -291,7 +291,8 @@ otherwise." ((eq type 'table-cell) ;; :contents-begin is not reliable on empty cells, so special ;; case it. - (<= (point) (org-element-property :contents-end context))) + (<= (save-excursion (skip-chars-backward " \t") (point)) + (org-element-property :contents-end context))) ((let ((cbeg (org-element-property :contents-begin context)) (cend (org-element-property :contents-end context))) (and cbeg (>= (point) cbeg) (<= (point) cend)))))))) diff --git a/testing/lisp/test-org-footnote.el b/testing/lisp/test-org-footnote.el index 4ce5b3458..6d8ba2f44 100644 --- a/testing/lisp/test-org-footnote.el +++ b/testing/lisp/test-org-footnote.el @@ -90,7 +90,7 @@ (org-test-with-temp-text " *bold*" (let ((org-footnote-auto-label t)) (org-footnote-new)) (buffer-string)))) - ;; Arrow new footnotes in empty cells. + ;; Arrow new footnotes in table cells. (should (string-match-p " \\[fn:1\\]" @@ -109,6 +109,12 @@ (org-test-with-temp-text "| |" (let ((org-footnote-auto-label t)) (org-footnote-new)) (buffer-string)))) + (should + (string-match-p + " \\[fn:1\\]" + (org-test-with-temp-text "| contents |" + (let ((org-footnote-auto-label t)) (org-footnote-new)) + (buffer-string)))) ;; When creating a new footnote, move to its definition. (should (string=