emacs-diffs
[Top][All Lists]
Advanced

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

[Emacs-diffs] master f291864: * lisp/ecomplete.el: Add completion-table;


From: Stefan Monnier
Subject: [Emacs-diffs] master f291864: * lisp/ecomplete.el: Add completion-table; use lexical-binding and cl-lib
Date: Tue, 23 Jan 2018 12:14:58 -0500 (EST)

branch: master
commit f2918640bf35d6bb0130f854b2ea8ed4b4fd89d4
Author: Stefan Monnier <address@hidden>
Commit: Stefan Monnier <address@hidden>

    * lisp/ecomplete.el: Add completion-table; use lexical-binding and cl-lib
    
    Also remove redundant :group args.
    (ecomplete-database-file): Use locate-user-emacs-file.
    (ecomplete-completion-table): New completion table.
    (completion-category-defaults): Set default behavior for that table.
---
 etc/NEWS          | 10 ++++++---
 lisp/ecomplete.el | 64 ++++++++++++++++++++++++++++++++++++-------------------
 2 files changed, 49 insertions(+), 25 deletions(-)

diff --git a/etc/NEWS b/etc/NEWS
index d30f0b0..bb84396 100644
--- a/etc/NEWS
+++ b/etc/NEWS
@@ -94,6 +94,13 @@ non-text modes.
 
 * Changes in Specialized Modes and Packages in Emacs 27.1
 
+** Ecomplete
+*** The ecomplete sorting has changed to a decay-based algorithm.
+This can be controlled by the new `ecomplete-sort-predicate' variable.
+
+*** The 'ecompleterc' file is now placed in ~/.emacs.d/ecompleterc by default
+Of course it will still find it if you have it in ~/.ecompleterc
+
 ** Smtpmail
 Authentication mechanisms can be added via external packages, by
 defining new cl-defmethod of smtpmail-try-auth-method.
@@ -237,9 +244,6 @@ It's a simple convenience function for looking up MIME 
types based on
 file name extensions.
 
 +++
-** The ecomplete sorting has changed to a decay-based algorithm.  This
-can be controlled by the new `ecomplete-sort-predicate' variable.
-
 ** The new function 'read-answer' accepts either long or short answers
 depending on the new customizable variable 'read-answer-short'.
 
diff --git a/lisp/ecomplete.el b/lisp/ecomplete.el
index 3f0d21c..3bfab47 100644
--- a/lisp/ecomplete.el
+++ b/lisp/ecomplete.el
@@ -1,4 +1,4 @@
-;;; ecomplete.el --- electric completion of addresses and the like
+;;; ecomplete.el --- electric completion of addresses and the like  -*- 
lexical-binding:t -*-
 
 ;; Copyright (C) 2006-2018 Free Software Foundation, Inc.
 
@@ -53,22 +53,20 @@
 
 ;;; Code:
 
-(eval-when-compile
-  (require 'cl))
+(eval-when-compile (require 'cl-lib))
 
 (defgroup ecomplete nil
   "Electric completion of email addresses and the like."
   :group 'mail)
 
-(defcustom ecomplete-database-file "~/.ecompleterc"
+(defcustom ecomplete-database-file
+  (locate-user-emacs-file "ecompleterc" "~/.ecompleterc")
   "The name of the file to store the ecomplete data."
-  :group 'ecomplete
   :type 'file)
 
 (defcustom ecomplete-database-file-coding-system 'iso-2022-7bit
   "Coding system used for writing the ecomplete database file."
-  :type '(symbol :tag "Coding system")
-  :group 'ecomplete)
+  :type '(symbol :tag "Coding system"))
 
 (defcustom ecomplete-sort-predicate 'ecomplete-decay
   "Predicate to use when sorting matched.
@@ -80,8 +78,7 @@ string that was matched."
   :type '(radio (function-item :tag "Sort by usage and newness" 
ecomplete-decay)
                (function-item :tag "Sort by times used" ecomplete-usage)
                (function-item :tag "Sort by newness" ecomplete-newness)
-               (function :tag "Other"))
-  :group 'ecomplete)
+               (function :tag "Other")))
 
 ;;; Internal variables.
 
@@ -116,13 +113,13 @@ string that was matched."
   (with-temp-buffer
     (let ((coding-system-for-write ecomplete-database-file-coding-system))
       (insert "(")
-      (loop for (type . elems) in ecomplete-database
-           do
-           (insert (format "(%s\n" type))
-           (dolist (entry elems)
-             (prin1 entry (current-buffer))
-             (insert "\n"))
-           (insert ")\n"))
+      (cl-loop for (type . elems) in ecomplete-database
+              do
+              (insert (format "(%s\n" type))
+              (dolist (entry elems)
+                (prin1 entry (current-buffer))
+                (insert "\n"))
+              (insert ")\n"))
       (insert ")")
       (write-region (point-min) (point-max)
                    ecomplete-database-file nil 'silent))))
@@ -132,9 +129,9 @@ string that was matched."
         (match (regexp-quote match))
         (candidates
          (sort
-          (loop for (key count time text) in elems
-                when (string-match match text)
-                collect (list count time text))
+          (cl-loop for (_key count time text) in elems
+                   when (string-match match text)
+                   collect (list count time text))
            ecomplete-sort-predicate)))
     (when (> (length candidates) 10)
       (setcdr (nthcdr 10 candidates) nil))
@@ -183,9 +180,7 @@ matches."
                        (lookup-key local-map command))
              (apply (key-binding command) nil)
              (setq highlight (ecomplete-highlight-match-line matches line))))
-         (if selected
-             (message selected)
-           (message "Abort"))
+         (message (or selected "Abort"))
          selected)))))
 
 (defun ecomplete-highlight-match-line (matches line)
@@ -218,6 +213,31 @@ matches."
      (expt 1.05 (/ (- (float-time) (cadr elem))
                    (* 7 24 60 60)))))
 
+;; `ecomplete-get-matches' uses substring matching, so also use the `substring'
+;; style by default.
+(add-to-list 'completion-category-defaults
+             '(ecomplete (styles basic substring)))
+
+(defun ecomplete-completion-table (type)
+  "Return a completion-table suitable for TYPE."
+  (lambda (string pred action)
+    (pcase action
+      (`(boundaries . ,_) nil)
+      ('metadata `(metadata (category . ecomplete)
+                            (display-sort-function . ,#'identity)
+                            (cycle-sort-function . ,#'identity)))
+      (_
+       (let* ((elems (cdr (assq type ecomplete-database)))
+             (candidates
+              (mapcar (lambda (x) (nth 2 x))
+                       (sort
+                       (cl-loop for x in elems
+                                when (string-prefix-p string (nth 3 x)
+                                                       completion-ignore-case)
+                                collect (cdr x))
+                        ecomplete-sort-predicate))))
+         (complete-with-action action candidates string pred))))))
+
 (provide 'ecomplete)
 
 ;;; ecomplete.el ends here



reply via email to

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