# HG changeset patch # User Stefan Monnier # Date 1207366310 0 # Node ID 5dee8473f368a159c37761d7e8822f30c2060b9d # Parent 3636fd479ab3dea4792757153aebb875bef5c425 Fix problem with completion for buffer-local tables. Reported by Radey Shouman . (tags-complete-tag): Remove. (tags-lazy-completion-table): New function to replace it. (find-tag-tag, complete-tag): Update users. diff -r 3636fd479ab3 -r 5dee8473f368 lisp/progmodes/etags.el --- a/lisp/progmodes/etags.el Sat Apr 05 00:56:31 2008 +0000 +++ b/lisp/progmodes/etags.el Sat Apr 05 03:31:50 2008 +0000 @@ -780,17 +780,15 @@ (quit (message "Tags completion table construction aborted.") (setq tags-completion-table nil))))) -(defun tags-complete-tag (string predicate what) - "Completion function for tags. -Does normal `try-completion', but builds `tags-completion-table' on -demand." - (save-excursion - ;; If we need to ask for the tag table, allow that. - (let ((enable-recursive-minibuffers t)) - (visit-tags-table-buffer)) - (if (eq what t) - (all-completions string (tags-completion-table) predicate) - (try-completion string (tags-completion-table) predicate)))) +(defun tags-lazy-completion-table () + (lexical-let ((buf (current-buffer))) + (lambda (string pred action) + (with-current-buffer buf + (save-excursion + ;; If we need to ask for the tag table, allow that. + (let ((enable-recursive-minibuffers t)) + (visit-tags-table-buffer)) + (complete-with-action action (tags-completion-table) string pred)))))) (defun find-tag-tag (string) "Read a tag name, with defaulting and completion." @@ -805,7 +803,7 @@ (substring string 0 (string-match "[ :]+\\'" string)) default) string) - 'tags-complete-tag + (tags-lazy-completion-table) nil nil nil nil default))) (if (equal spec "") (or default (error "There is no default tag")) @@ -2053,6 +2051,7 @@ (pattern (funcall (or find-tag-default-function (get major-mode 'find-tag-default-function) 'find-tag-default))) + (comp-table (tags-lazy-completion-table)) beg completion) (or pattern @@ -2060,7 +2059,7 @@ (search-backward pattern) (setq beg (point)) (forward-char (length pattern)) - (setq completion (tags-complete-tag pattern nil nil)) + (setq completion (try-completion pattern comp-table)) (cond ((eq completion t)) ((null completion) (message "Can't find completion for \"%s\"" pattern) @@ -2072,7 +2071,7 @@ (message "Making completion list...") (with-output-to-temp-buffer "*Completions*" (display-completion-list - (all-completions pattern 'tags-complete-tag nil) + (all-completions pattern comp-table nil) pattern)) (message "Making completion list...%s" "done")))))