Merge branch 'internal-link-exact-headline-match'
This commit is contained in:
commit
d593bae0ff
24
doc/org.texi
24
doc/org.texi
|
@ -2806,23 +2806,13 @@ text before the first headline is usually not exported, so the first such
|
||||||
target should be after the first headline, or in the line directly before the
|
target should be after the first headline, or in the line directly before the
|
||||||
first headline.}.
|
first headline.}.
|
||||||
|
|
||||||
If no dedicated target exists, Org will search for the words in the link. In
|
If no dedicated target exists, Org will search for a headline that is exactly
|
||||||
the above example the search would be for @samp{my target}. Links starting
|
the link text but may also include a TODO keyword and tags@footnote{To insert
|
||||||
with a star like @samp{*My Target} restrict the search to
|
a link targeting a headline, in-buffer completion can be used. Just type a
|
||||||
headlines@footnote{To insert a link targeting a headline, in-buffer
|
star followed by a few optional letters into the buffer and press
|
||||||
completion can be used. Just type a star followed by a few optional letters
|
@kbd{M-@key{TAB}}. All headlines in the current buffer will be offered as
|
||||||
into the buffer and press @kbd{M-@key{TAB}}. All headlines in the current
|
completions.}. In non-Org files, the search will look for the words in the
|
||||||
buffer will be offered as completions. @xref{Handling links}, for more
|
link text, in the above example the search would be for @samp{my target}.
|
||||||
commands creating links.}. When searching, Org-mode will first try an
|
|
||||||
exact match, but then move on to more and more lenient searches. For
|
|
||||||
example, the link @samp{[[*My Targets]]} will find any of the following:
|
|
||||||
|
|
||||||
@example
|
|
||||||
** My targets
|
|
||||||
** TODO my targets are bright
|
|
||||||
** my 20 targets are
|
|
||||||
@end example
|
|
||||||
|
|
||||||
|
|
||||||
Following a link pushes a mark onto Org's own mark ring. You can
|
Following a link pushes a mark onto Org's own mark ring. You can
|
||||||
return to the previous position with @kbd{C-c &}. Using this command
|
return to the previous position with @kbd{C-c &}. Using this command
|
||||||
|
|
|
@ -1289,18 +1289,19 @@ the current file."
|
||||||
(string-match "^\\." link))
|
(string-match "^\\." link))
|
||||||
nil)
|
nil)
|
||||||
(t
|
(t
|
||||||
(save-excursion
|
(let ((org-link-search-inhibit-query t))
|
||||||
(setq found (condition-case nil (org-link-search link)
|
(save-excursion
|
||||||
(error nil)))
|
(setq found (condition-case nil (org-link-search link)
|
||||||
(when (and found
|
(error nil)))
|
||||||
(or (org-on-heading-p)
|
(when (and found
|
||||||
(not (eq found 'dedicated))))
|
(or (org-on-heading-p)
|
||||||
(or (get-text-property (point) 'target)
|
(not (eq found 'dedicated))))
|
||||||
(get-text-property
|
(or (get-text-property (point) 'target)
|
||||||
(max (point-min)
|
(get-text-property
|
||||||
(1- (or (previous-single-property-change
|
(max (point-min)
|
||||||
(point) 'target) 0)))
|
(1- (or (previous-single-property-change
|
||||||
'target))))))))
|
(point) 'target) 0)))
|
||||||
|
'target)))))))))
|
||||||
(when target
|
(when target
|
||||||
(set-match-data md)
|
(set-match-data md)
|
||||||
(goto-char (match-beginning 1))
|
(goto-char (match-beginning 1))
|
||||||
|
|
44
lisp/org.el
44
lisp/org.el
|
@ -1439,6 +1439,17 @@ Changing this requires a restart of Emacs to work correctly."
|
||||||
:group 'org-link-follow
|
:group 'org-link-follow
|
||||||
:type 'integer)
|
:type 'integer)
|
||||||
|
|
||||||
|
(defcustom org-link-search-must-match-exact-headline 'query-to-create
|
||||||
|
"Non-nil means internal links in Org files must exactly match a headline.
|
||||||
|
When nil, the link search tries to match a phrase will all words
|
||||||
|
in the search text."
|
||||||
|
:group 'org-link-follow
|
||||||
|
:type '(choice
|
||||||
|
(const :tag "Use fuzy text search" nil)
|
||||||
|
(const :tag "Match only exact headline" t)
|
||||||
|
(const :tag "Match extact headline or query to create it"
|
||||||
|
query-to-create)))
|
||||||
|
|
||||||
(defcustom org-link-frame-setup
|
(defcustom org-link-frame-setup
|
||||||
'((vm . vm-visit-folder-other-frame)
|
'((vm . vm-visit-folder-other-frame)
|
||||||
(gnus . org-gnus-no-new-news)
|
(gnus . org-gnus-no-new-news)
|
||||||
|
@ -9306,6 +9317,7 @@ the window configuration before `org-open-at-point' was called using:
|
||||||
|
|
||||||
(set-window-configuration org-window-config-before-follow-link)")
|
(set-window-configuration org-window-config-before-follow-link)")
|
||||||
|
|
||||||
|
(defvar org-link-search-inhibit-query nil) ;; dynamically scoped
|
||||||
(defun org-link-search (s &optional type avoid-pos)
|
(defun org-link-search (s &optional type avoid-pos)
|
||||||
"Search for a link search option.
|
"Search for a link search option.
|
||||||
If S is surrounded by forward slashes, it is interpreted as a
|
If S is surrounded by forward slashes, it is interpreted as a
|
||||||
|
@ -9323,7 +9335,7 @@ in all files. If AVOID-POS is given, ignore matches near that position."
|
||||||
(pre nil) (post nil)
|
(pre nil) (post nil)
|
||||||
words re0 re1 re2 re3 re4_ re4 re5 re2a re2a_ reall)
|
words re0 re1 re2 re3 re4_ re4 re5 re2a re2a_ reall)
|
||||||
(cond
|
(cond
|
||||||
;; First check if there are any special
|
;; First check if there are any special search functions
|
||||||
((run-hook-with-args-until-success 'org-execute-file-search-functions s))
|
((run-hook-with-args-until-success 'org-execute-file-search-functions s))
|
||||||
;; Now try the builtin stuff
|
;; Now try the builtin stuff
|
||||||
((and (equal (string-to-char s0) ?#)
|
((and (equal (string-to-char s0) ?#)
|
||||||
|
@ -9368,8 +9380,28 @@ in all files. If AVOID-POS is given, ignore matches near that position."
|
||||||
;;((eq major-mode 'dired-mode)
|
;;((eq major-mode 'dired-mode)
|
||||||
;; (grep (concat "grep -n -e '" (match-string 1 s) "' *")))
|
;; (grep (concat "grep -n -e '" (match-string 1 s) "' *")))
|
||||||
(t (org-do-occur (match-string 1 s)))))
|
(t (org-do-occur (match-string 1 s)))))
|
||||||
|
((and (org-mode-p) org-link-search-must-match-exact-headline)
|
||||||
|
(and (equal (string-to-char s) ?*) (setq s (substring s 1)))
|
||||||
|
(goto-char (point-min))
|
||||||
|
(cond
|
||||||
|
((let (case-fold-search)
|
||||||
|
(re-search-forward (format org-complex-heading-regexp-format
|
||||||
|
(regexp-quote s))
|
||||||
|
nil t))
|
||||||
|
;; OK, found a match
|
||||||
|
(goto-char (match-beginning 0)))
|
||||||
|
((and (not org-link-search-inhibit-query)
|
||||||
|
(eq org-link-search-must-match-exact-headline 'query-to-create)
|
||||||
|
(y-or-n-p "No match - create this as a new heading? "))
|
||||||
|
(goto-char (point-max))
|
||||||
|
(or (bolp) (newline))
|
||||||
|
(insert "* " s "\n")
|
||||||
|
(beginning-of-line 0))
|
||||||
|
(t
|
||||||
|
(goto-char pos)
|
||||||
|
(error "No match"))))
|
||||||
(t
|
(t
|
||||||
;; A normal search strings
|
;; A normal search string
|
||||||
(when (equal (string-to-char s) ?*)
|
(when (equal (string-to-char s) ?*)
|
||||||
;; Anchor on headlines, post may include tags.
|
;; Anchor on headlines, post may include tags.
|
||||||
(setq pre "^\\*+[ \t]+\\(?:\\sw+\\)?[ \t]*"
|
(setq pre "^\\*+[ \t]+\\(?:\\sw+\\)?[ \t]*"
|
||||||
|
@ -9414,13 +9446,7 @@ in all files. If AVOID-POS is given, ignore matches near that position."
|
||||||
)
|
)
|
||||||
(goto-char (match-beginning 1))
|
(goto-char (match-beginning 1))
|
||||||
(goto-char pos)
|
(goto-char pos)
|
||||||
(error "No match")))))
|
(error "No match"))))))
|
||||||
(t
|
|
||||||
;; Normal string-search
|
|
||||||
(goto-char (point-min))
|
|
||||||
(if (search-forward s nil t)
|
|
||||||
(goto-char (match-beginning 0))
|
|
||||||
(error "No match"))))
|
|
||||||
(and (org-mode-p) (org-show-context 'link-search))
|
(and (org-mode-p) (org-show-context 'link-search))
|
||||||
type))
|
type))
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue