]> git.eshelyaron.com Git - emacs.git/commitdiff
Cleanup cfengine3-mode so complete-symbol works again.
authorTed Zlatanov <tzz@lifelogs.com>
Mon, 16 Dec 2013 15:49:25 +0000 (10:49 -0500)
committerTed Zlatanov <tzz@lifelogs.com>
Mon, 16 Dec 2013 15:49:25 +0000 (10:49 -0500)
* progmodes/cfengine.el (cfengine3--current-word): Remove.
(cfengine3--current-function): Bring in the current-function
functionality from `cfengine3--current-word'.
(cfengine3-completion-function): Bring in the
bounds-of-current-word functionality from
`cfengine3--current-word'.

lisp/ChangeLog
lisp/progmodes/cfengine.el

index 5876dc37fbfd37c495333529cf51a5648a349289..9ccc510ce1a71bfb1860d8298ca2ca7eb595c693 100644 (file)
@@ -1,3 +1,12 @@
+2013-12-16  Teodor Zlatanov  <tzz@lifelogs.com>
+
+       * progmodes/cfengine.el (cfengine3--current-word): Remove.
+       (cfengine3--current-function): Bring in the current-function
+       functionality from `cfengine3--current-word'.
+       (cfengine3-completion-function): Bring in the
+       bounds-of-current-word functionality from
+       `cfengine3--current-word'.
+
 2013-12-16  Martin Rudalics  <rudalics@gmx.at>
 
        * window.el (display-buffer-below-selected): Bind
index 802561811872953a6fdd0a3f6b21b7f49004d3da..8d06041f919bd74c65ea2a11f8209d01ddb63bf1 100644 (file)
@@ -1165,24 +1165,18 @@ Intended as the value of `indent-line-function'."
 ;; CLASS: [.|&!()a-zA-Z0-9_\200-\377]+::
 ;; CATEGORY: [a-zA-Z_]+:
 
-(defun cfengine3--current-word (&optional bounds)
-  "Propose a word around point in the current CFEngine 3 buffer."
-  (save-excursion
-    (skip-syntax-forward "w_")
-    (when (search-backward-regexp
-           cfengine-mode-syntax-functions-regex
-           (point-at-bol)
-           t)
-      (if bounds
-          (list (point) (match-end 1))
-        (match-string 1)))))
-
 (defun cfengine3--current-function ()
   "Look up current CFEngine 3 function"
   (let* ((syntax (cfengine3-make-syntax-cache))
          (flist (assq 'functions syntax)))
     (when flist
-      (let ((w (cfengine3--current-word)))
+      (let ((w (save-excursion
+                 (skip-syntax-forward "w_")
+                 (when (search-backward-regexp
+                        cfengine-mode-syntax-functions-regex
+                        (point-at-bol)
+                        t)
+                   (match-string 1)))))
         (and w (assq (intern w) flist))))))
 
 ;; format from "cf-promises -s json", e.g. "sort" function:
@@ -1271,7 +1265,10 @@ see.  Use it by executing `turn-on-eldoc-mode'."
 (defun cfengine3-completion-function ()
   "Return completions for function name around or before point."
   (cfengine3-make-syntax-cache)
-  (let* ((bounds (cfengine3--current-word t))
+  (let* ((bounds (save-excursion
+                   (let ((p (point)))
+                     (skip-syntax-backward "w_" (point-at-bol))
+                     (list (point) p))))
          (syntax (cfengine3-make-syntax-cache))
          (flist (assq 'functions syntax)))
     (when bounds