;;; company-ispell.el --- company-mode completion back-end using Ispell ;; Copyright (C) 2009-2011 Free Software Foundation, Inc. ;; Author: Nikolaj Schumacher ;; 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/>. ;;; Commentary: ;; ;;; Code: (require 'company) (require 'cl-lib) (require 'ispell) (defgroup company-ispell nil "Completion back-end using Ispell." :group 'company) (defcustom company-ispell-dictionary nil "Dictionary to use for `company-ispell'. If nil, use `ispell-complete-word-dict'." :type '(choice (const :tag "default (nil)" nil) (file :tag "dictionary" t))) (defvar company-ispell-available 'unknown) (defun company-ispell-available () (when (eq company-ispell-available 'unknown) (condition-case err (progn (lookup-words "WHATEVER") (setq company-ispell-available t)) (error (message "Company: ispell-look-command not found") (setq company-ispell-available nil)))) company-ispell-available) ;;;###autoload (defun company-ispell (command &optional arg &rest ignored) "`company-mode' completion back-end using Ispell." (interactive (list 'interactive)) (cl-case command (interactive (company-begin-backend 'company-ispell)) (prefix (when (company-ispell-available) (company-grab-word))) (candidates (lookup-words arg (or company-ispell-dictionary ispell-complete-word-dict))) (sorted t) (ignore-case 'keep-prefix))) (provide 'company-ispell) ;;; company-ispell.el ends here