X-Git-Url: https://code.delx.au/gnu-emacs-elpa/blobdiff_plain/9e2de34d6c42dc54148303b334dea23e630be2ba..b7974385f6c7b5836e0fdb022ed22df55464a7ec:/packages/company/company-template.el diff --git a/packages/company/company-template.el b/packages/company/company-template.el index ea1db86bc..bc1055cde 100644 --- a/packages/company/company-template.el +++ b/packages/company/company-template.el @@ -1,6 +1,6 @@ ;;; company-template.el -;; Copyright (C) 2009, 2010, 2013 Free Software Foundation, Inc. +;; Copyright (C) 2009, 2010, 2014 Free Software Foundation, Inc. ;; Author: Nikolaj Schumacher @@ -21,7 +21,7 @@ ;;; Code: -(eval-when-compile (require 'cl)) +(require 'cl-lib) (defface company-template-field '((((background dark)) (:background "yellow" :foreground "black")) @@ -32,10 +32,10 @@ (defvar company-template-nav-map (let ((keymap (make-sparse-keymap))) (define-key keymap [tab] 'company-template-forward-field) + (define-key keymap (kbd "TAB") 'company-template-forward-field) keymap)) -(defvar company-template--buffer-templates nil) -(make-variable-buffer-local 'company-template--buffer-templates) +(defvar-local company-template--buffer-templates nil) ;; interactive ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; @@ -58,8 +58,8 @@ (let* ((start (point)) (templates (company-template-templates-at (point))) (minimum (apply 'max (mapcar 'overlay-end templates))) - (fields (loop for templ in templates - append (overlay-get templ 'company-template-fields)))) + (fields (cl-loop for templ in templates + append (overlay-get templ 'company-template-fields)))) (dolist (pos (mapcar 'overlay-start fields)) (and pos (> pos (point)) @@ -70,9 +70,9 @@ (company-template-remove-field (company-template-field-at start)))) (defun company-template-field-at (&optional point) - (loop for ovl in (overlays-at (or point (point))) - when (overlay-get ovl 'company-template-parent) - return ovl)) + (cl-loop for ovl in (overlays-at (or point (point))) + when (overlay-get ovl 'company-template-parent) + return ovl)) ;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;; @@ -97,7 +97,7 @@ "Add new field to template TEMPL at POS, inserting TEXT. When DISPLAY is non-nil, set the respective property on the overlay. Leave point at the end of the field." - (assert templ) + (cl-assert templ) (goto-char pos) (insert text) (when (> (point) (overlay-end templ)) @@ -149,22 +149,49 @@ Leave point at the end of the field." (defun company-template-c-like-templatify (call) (let* ((end (point-marker)) (beg (- (point) (length call))) - (cnt 0)) - (when (re-search-backward ")" beg t) - (delete-region (match-end 0) end)) - (goto-char beg) - (when (search-forward "(" end 'move) - (if (eq (char-after) ?\)) + (cnt 0) + (templ (company-template-declare-template beg end)) + paren-open paren-close) + (with-syntax-table (make-char-table 'syntax-table nil) + (modify-syntax-entry ?\( "(") + (modify-syntax-entry ?\) ")") + (modify-syntax-entry ?< "(") + (modify-syntax-entry ?> ")") + (when (search-backward ")" beg t) + (setq paren-close (point-marker)) + (forward-char 1) + (delete-region (point) end) + (backward-sexp) + (forward-char 1) + (setq paren-open (point-marker))) + (when (search-backward ">" beg t) + (let ((angle-close (point-marker))) (forward-char 1) - (let ((templ (company-template-declare-template beg end))) - (while (re-search-forward (concat " *\\([^,)]*\\)[,)]") end t) - (let ((sig (match-string 1))) - (delete-region (match-beginning 1) (match-end 1)) - (save-excursion - (company-template-add-field templ (match-beginning 1) - (format "arg%d" cnt) sig)) - (incf cnt))) - (company-template-move-to-first templ)))))) + (backward-sexp) + (forward-char) + (setq cnt (company-template--c-like-args templ angle-close + cnt)))) + (when paren-open + (goto-char paren-open) + (company-template--c-like-args templ paren-close cnt))) + (if (overlay-get templ 'company-template-fields) + (company-template-move-to-first templ) + (company-template-remove-template templ) + (goto-char end)))) + +(defun company-template--c-like-args (templ end counter) + (let ((last-pos (point))) + (while (re-search-forward "\\([^,]+\\),?" end 'move) + (when (zerop (car (parse-partial-sexp last-pos (point)))) + (let ((sig (buffer-substring-no-properties last-pos (match-end 1)))) + (save-excursion + (company-template-add-field templ last-pos + (format "arg%d" counter) sig) + (delete-region (point) (+ (point) (length sig)))) + (skip-chars-forward " ") + (setq last-pos (point)) + (cl-incf counter))))) + counter) (provide 'company-template) ;;; company-template.el ends here