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

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

[elpa] externals/company-ebdb 6afcd29 1/9: Add external/contrib packages


From: Stefan Monnier
Subject: [elpa] externals/company-ebdb 6afcd29 1/9: Add external/contrib packages for EBDB
Date: Tue, 1 Dec 2020 15:31:18 -0500 (EST)

branch: externals/company-ebdb
commit 6afcd291a379d098e0489f126acbdf1e67a69f83
Author: Eric Abrahamsen <eric@ericabrahamsen.net>
Commit: Eric Abrahamsen <eric@ericabrahamsen.net>

    Add external/contrib packages for EBDB
---
 company-ebdb.el | 73 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 file changed, 73 insertions(+)

diff --git a/company-ebdb.el b/company-ebdb.el
new file mode 100644
index 0000000..c7791c5
--- /dev/null
+++ b/company-ebdb.el
@@ -0,0 +1,73 @@
+;;; company-ebdb.el --- company-mode completion backend for EBDB in 
message-mode
+
+;; Copyright (C) 2013-2014, 2016  Free Software Foundation, Inc.
+
+;; Author: Jan Tatarik <jan.tatarik@gmail.com>
+;; Maintainer: Eric Abrahamsen <eric@ericabrahamsen.net>
+;; Version: 1
+;; Package-Requires: ((company "0.9.4") (ebdb "0.2"))
+
+;; This file is part of GNU Emacs.
+
+;; GNU Emacs is free software: you can redistribute it and/or modify
+;; it under the terms of the GNU General Public License as published by
+;; the Free Software Foundation, either version 3 of the License, or
+;; (at your option) any later version.
+
+;; GNU Emacs is distributed in the hope that it will be useful,
+;; but WITHOUT ANY WARRANTY; without even the implied warranty of
+;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+;; GNU General Public License for more details.
+
+;; You should have received a copy of the GNU General Public License
+;; along with GNU Emacs.  If not, see <http://www.gnu.org/licenses/>.
+
+(require 'company)
+(require 'cl-lib)
+
+(declare-function ebdb-record-mail "ebdb")
+(declare-function ebdb-records "ebdb")
+(declare-function ebdb-dwim-mail "ebdb-com")
+(declare-function ebdb-search "ebdb-com")
+
+(defgroup company-ebdb nil
+  "Completion backend for EBDB."
+  :group 'company)
+
+(defcustom company-ebdb-modes '(message-mode mail-mode notmuch-message-mode)
+  "Major modes in which `company-ebdb' may complete."
+  :type '(repeat (symbol :tag "Major mode"))
+  :package-version '(company . "0.8.8"))
+
+(defun company-ebdb--candidates (arg)
+  (cl-mapcan (lambda (record)
+               (mapcar (lambda (mail) (ebdb-dwim-mail record mail))
+                       (ebdb-record-mail record t)))
+             (eval '(ebdb-search (ebdb-records) `((ebdb-field-name ,arg)
+                                                 (ebdb-field-mail ,arg))))))
+
+(defun company-ebdb--post-complete (arg)
+  (when (memq major-mode company-ebdb-modes)
+   (let* ((bits (ebdb-decompose-ebdb-address arg))
+         (recs (ebdb-message-search (car bits) (nth 1 bits))))
+     (when recs
+       (ebdb-display-records recs nil nil nil (ebdb-popup-window))))))
+
+;;;###autoload
+(defun company-ebdb (command &optional arg &rest ignore)
+  "`company-mode' completion backend for EBDB."
+  (interactive (list 'interactive))
+  (cl-case command
+    (interactive (company-begin-backend 'company-ebdb))
+    (prefix (and (memq major-mode company-ebdb-modes)
+                 (featurep 'ebdb-com)
+                 (looking-back "^\\(To\\|Cc\\|Bcc\\): *.*? *\\([^,;]*\\)"
+                               (line-beginning-position))
+                 (match-string-no-properties 2)))
+    (candidates (company-ebdb--candidates arg))
+    (post-completion (company-ebdb--post-complete arg))
+    (sorted t)
+    (no-cache t)))
+
+(provide 'company-ebdb)
+;;; company-ebdb.el ends here



reply via email to

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