Fix open-at-point in example blocks and diary-sexps
* lisp/org.el (org-open-at-point): Also open links in example blocks and diary-sexps. * testing/lisp/test-org.el (test-org/open-at-point/keyword): (test-org/open-at-point/property): (test-org/open-at-point/comment): Add tests. Reported-by: Dieter Faulbaum <Dieter.Faulbaum@helmholtz-berlin.de> <http://lists.gnu.org/archive/html/emacs-orgmode/2017-06/msg00277.html>
This commit is contained in:
parent
521734d51f
commit
5d99560ddf
59
lisp/org.el
59
lisp/org.el
|
@ -10780,9 +10780,10 @@ When optional argument REFERENCE-BUFFER is non-nil, it should
|
||||||
specify a buffer from where the link search should happen. This
|
specify a buffer from where the link search should happen. This
|
||||||
is used internally by `org-open-link-from-string'.
|
is used internally by `org-open-link-from-string'.
|
||||||
|
|
||||||
On top of syntactically correct links, this function will open
|
On top of syntactically correct links, this function will also
|
||||||
the link at point in comments or comment blocks and the first
|
try to open links and time-stamps in comments, example
|
||||||
link in a property drawer line."
|
blocks... i.e., whenever point is on something looking like
|
||||||
|
a timestamp or a link."
|
||||||
(interactive "P")
|
(interactive "P")
|
||||||
;; On a code block, open block's results.
|
;; On a code block, open block's results.
|
||||||
(unless (call-interactively 'org-babel-open-src-block-result)
|
(unless (call-interactively 'org-babel-open-src-block-result)
|
||||||
|
@ -10795,28 +10796,20 @@ link in a property drawer line."
|
||||||
;; the closest one.
|
;; the closest one.
|
||||||
(org-element-lineage
|
(org-element-lineage
|
||||||
(org-element-context)
|
(org-element-context)
|
||||||
'(clock comment comment-block footnote-definition
|
'(clock footnote-definition footnote-reference headline
|
||||||
footnote-reference headline inlinetask keyword link
|
inlinetask link timestamp)
|
||||||
node-property timestamp)
|
|
||||||
t))
|
t))
|
||||||
(type (org-element-type context))
|
(type (org-element-type context))
|
||||||
(value (org-element-property :value context)))
|
(value (org-element-property :value context)))
|
||||||
(cond
|
(cond
|
||||||
((not context) (user-error "No link found"))
|
|
||||||
;; Exception: open timestamps and links in properties
|
|
||||||
;; drawers, keywords and comments.
|
|
||||||
((memq type '(comment comment-block keyword node-property))
|
|
||||||
(call-interactively #'org-open-at-point-global))
|
|
||||||
;; On a headline or an inlinetask, but not on a timestamp,
|
;; On a headline or an inlinetask, but not on a timestamp,
|
||||||
;; a link, a footnote reference or on tags.
|
;; a link, a footnote reference or on tags.
|
||||||
((and (memq type '(headline inlinetask))
|
((and (memq type '(headline inlinetask))
|
||||||
;; Not on tags.
|
;; Not on tags.
|
||||||
(let ((case-fold-search nil))
|
(let ((case-fold-search nil))
|
||||||
(save-excursion
|
(and (org-match-line org-complex-heading-regexp)
|
||||||
(beginning-of-line)
|
(or (not (match-beginning 5))
|
||||||
(looking-at org-complex-heading-regexp))
|
(< (point) (match-beginning 5))))))
|
||||||
(or (not (match-beginning 5))
|
|
||||||
(< (point) (match-beginning 5)))))
|
|
||||||
(let* ((data (org-offer-links-in-entry (current-buffer) (point) arg))
|
(let* ((data (org-offer-links-in-entry (current-buffer) (point) arg))
|
||||||
(links (car data))
|
(links (car data))
|
||||||
(links-end (cdr data)))
|
(links-end (cdr data)))
|
||||||
|
@ -10827,6 +10820,26 @@ link in a property drawer line."
|
||||||
(org-open-at-point))
|
(org-open-at-point))
|
||||||
(require 'org-attach)
|
(require 'org-attach)
|
||||||
(org-attach-reveal 'if-exists))))
|
(org-attach-reveal 'if-exists))))
|
||||||
|
;; On a footnote reference or at definition's label.
|
||||||
|
((or (eq type 'footnote-reference)
|
||||||
|
(and (eq type 'footnote-definition)
|
||||||
|
(save-excursion
|
||||||
|
;; Do not validate action when point is on the
|
||||||
|
;; spaces right after the footnote label, in
|
||||||
|
;; order to be on par with behaviour on links.
|
||||||
|
(skip-chars-forward " \t")
|
||||||
|
(let ((begin
|
||||||
|
(org-element-property :contents-begin context)))
|
||||||
|
(if begin (< (point) begin)
|
||||||
|
(= (org-element-property :post-affiliated context)
|
||||||
|
(line-beginning-position)))))))
|
||||||
|
(org-footnote-action))
|
||||||
|
;; No valid context. Ignore catch-all types like `headline'.
|
||||||
|
;; If point is on something looking like a link or
|
||||||
|
;; a time-stamp, try opening it. It may be useful in
|
||||||
|
;; comments, example blocks...
|
||||||
|
((memq type '(footnote-definition headline inlinetask nil))
|
||||||
|
(call-interactively #'org-open-at-point-global))
|
||||||
;; On a clock line, make sure point is on the timestamp
|
;; On a clock line, make sure point is on the timestamp
|
||||||
;; before opening it.
|
;; before opening it.
|
||||||
((and (eq type 'clock)
|
((and (eq type 'clock)
|
||||||
|
@ -10919,20 +10932,6 @@ link in a property drawer line."
|
||||||
(widen))
|
(widen))
|
||||||
(goto-char destination))))
|
(goto-char destination))))
|
||||||
(t (browse-url-at-point))))))
|
(t (browse-url-at-point))))))
|
||||||
;; On a footnote reference or at a footnote definition's label.
|
|
||||||
((or (eq type 'footnote-reference)
|
|
||||||
(and (eq type 'footnote-definition)
|
|
||||||
(save-excursion
|
|
||||||
;; Do not validate action when point is on the
|
|
||||||
;; spaces right after the footnote label, in
|
|
||||||
;; order to be on par with behaviour on links.
|
|
||||||
(skip-chars-forward " \t")
|
|
||||||
(let ((begin
|
|
||||||
(org-element-property :contents-begin context)))
|
|
||||||
(if begin (< (point) begin)
|
|
||||||
(= (org-element-property :post-affiliated context)
|
|
||||||
(line-beginning-position)))))))
|
|
||||||
(org-footnote-action))
|
|
||||||
(t (user-error "No link found")))))
|
(t (user-error "No link found")))))
|
||||||
(run-hook-with-args 'org-follow-link-hook)))
|
(run-hook-with-args 'org-follow-link-hook)))
|
||||||
|
|
||||||
|
|
|
@ -2319,14 +2319,18 @@ http://article.gmane.org/gmane.emacs.orgmode/21459/"
|
||||||
|
|
||||||
;;;; Open at point
|
;;;; Open at point
|
||||||
|
|
||||||
(ert-deftest test-org/open-at-point-in-keyword ()
|
(ert-deftest test-org/open-at-point/keyword ()
|
||||||
"Does `org-open-at-point' open link in a keyword line?"
|
"Does `org-open-at-point' open link in a keyword line?"
|
||||||
(should
|
(should
|
||||||
(org-test-with-temp-text
|
(org-test-with-temp-text
|
||||||
"<<top>>\n#+KEYWORD: <point>[[top]]"
|
"<<top>>\n#+KEYWORD: <point>[[top]]"
|
||||||
|
(org-open-at-point) t))
|
||||||
|
(should
|
||||||
|
(org-test-with-temp-text
|
||||||
|
"* H\n<<top>>\n#+KEYWORD: <point>[[top]]"
|
||||||
(org-open-at-point) t)))
|
(org-open-at-point) t)))
|
||||||
|
|
||||||
(ert-deftest test-org/open-at-point-in-property ()
|
(ert-deftest test-org/open-at-point/property ()
|
||||||
"Does `org-open-at-point' open link in property drawer?"
|
"Does `org-open-at-point' open link in property drawer?"
|
||||||
(should
|
(should
|
||||||
(org-test-with-temp-text
|
(org-test-with-temp-text
|
||||||
|
@ -2336,11 +2340,15 @@ http://article.gmane.org/gmane.emacs.orgmode/21459/"
|
||||||
:END:"
|
:END:"
|
||||||
(org-open-at-point) t)))
|
(org-open-at-point) t)))
|
||||||
|
|
||||||
(ert-deftest test-org/open-at-point-in-comment ()
|
(ert-deftest test-org/open-at-point/comment ()
|
||||||
"Does `org-open-at-point' open link in a commented line?"
|
"Does `org-open-at-point' open link in a commented line?"
|
||||||
(should
|
(should
|
||||||
(org-test-with-temp-text
|
(org-test-with-temp-text
|
||||||
"<<top>>\n# <point>[[top]]"
|
"<<top>>\n# <point>[[top]]"
|
||||||
|
(org-open-at-point) t))
|
||||||
|
(should
|
||||||
|
(org-test-with-temp-text
|
||||||
|
"* H\n<<top>>\n# <point>[[top]]"
|
||||||
(org-open-at-point) t)))
|
(org-open-at-point) t)))
|
||||||
|
|
||||||
(ert-deftest test-org/open-at-point/inline-image ()
|
(ert-deftest test-org/open-at-point/inline-image ()
|
||||||
|
|
Loading…
Reference in New Issue