emacs-elpa-diffs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[elpa] master 1c36f7c 091/173: company-dabbrev--search-buffer: Use use f


From: Dmitry Gutov
Subject: [elpa] master 1c36f7c 091/173: company-dabbrev--search-buffer: Use use forward search (#433)
Date: Thu, 23 Jun 2016 00:28:40 +0000 (UTC)

branch: master
commit 1c36f7cdaf745f445c154fd5e1509703659a857b
Author: Dmitry Gutov <address@hidden>
Commit: Dmitry Gutov <address@hidden>

    company-dabbrev--search-buffer: Use use forward search (#433)
---
 company-dabbrev.el |   24 +++++++++++++++++-------
 1 file changed, 17 insertions(+), 7 deletions(-)

diff --git a/company-dabbrev.el b/company-dabbrev.el
index 337943d..37dcecc 100644
--- a/company-dabbrev.el
+++ b/company-dabbrev.el
@@ -108,14 +108,24 @@ This variable affects both `company-dabbrev' and 
`company-dabbrev-code'."
                                         (invisible-p (match-beginning 0)))))
                      (push match symbols)))))
       (goto-char (if pos (1- pos) (point-min)))
-      ;; search before pos
-      (company-dabrev--time-limit-while (re-search-backward regexp nil t)
-          start limit
-        (if (and ignore-comments (save-match-data 
(company-in-string-or-comment)))
-            (goto-char (nth 8 (syntax-ppss)))
-          (maybe-collect-match)))
+      ;; Search before pos.
+      (let ((tmp-end (point)))
+        (company-dabrev--time-limit-while (not (bobp))
+            start limit
+          (ignore-errors
+            (forward-char -10000))
+          (forward-line 0)
+          (save-excursion
+            ;; Before, we used backward search, but it matches non-greedily, 
and
+            ;; that forced us to use the "beginning/end of word" anchors in
+            ;; `company-dabbrev--make-regexp'.
+            (while (re-search-forward regexp tmp-end t)
+              (if (and ignore-comments (save-match-data 
(company-in-string-or-comment)))
+                  (re-search-forward "\\s>\\|\\s!\\|\\s\"" tmp-end t)
+                (maybe-collect-match))))
+          (setq tmp-end (point))))
       (goto-char (or pos (point-min)))
-      ;; search after pos
+      ;; Search after pos.
       (company-dabrev--time-limit-while (re-search-forward regexp nil t)
           start limit
         (if (and ignore-comments (save-match-data 
(company-in-string-or-comment)))



reply via email to

[Prev in Thread] Current Thread [Next in Thread]