;;; company-tempo.el --- company-mode completion back-end for tempo ;; 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 'tempo) (defsubst company-tempo-lookup (match) (cdr (assoc match (tempo-build-collection)))) (defun company-tempo-insert (match) "Replace MATCH with the expanded tempo template." (search-backward match) (goto-char (match-beginning 0)) (replace-match "") (call-interactively (company-tempo-lookup match))) (defsubst company-tempo-meta (match) (let ((templ (company-tempo-lookup match)) doc) (and templ (setq doc (documentation templ t)) (car (split-string doc "\n" t))))) ;;;###autoload (defun company-tempo (command &optional arg &rest ignored) "`company-mode' completion back-end for tempo." (interactive (list 'interactive)) (cl-case command (interactive (company-begin-backend 'company-tempo 'company-tempo-insert)) (prefix (or (car (tempo-find-match-string tempo-match-finder)) "")) (candidates (all-completions arg (tempo-build-collection))) (meta (company-tempo-meta arg)) (require-match t) (sorted t))) (provide 'company-tempo) ;;; company-tempo.el ends here