]> git.eshelyaron.com Git - emacs.git/commitdiff
Fix broken completion in sh-mode
authorLeo Liu <sdl.web@gmail.com>
Mon, 27 Aug 2012 12:33:05 +0000 (20:33 +0800)
committerLeo Liu <sdl.web@gmail.com>
Mon, 27 Aug 2012 12:33:05 +0000 (20:33 +0800)
See: http://debbugs.gnu.org/12220

lisp/ChangeLog
lisp/progmodes/sh-script.el

index 456eca53a820ca23424fbfb30b63a6b68eea8294..4ef437213a0e86859abbaedf0b70587d9d9fb4c5 100644 (file)
@@ -1,5 +1,8 @@
 2012-08-27  Leo Liu  <sdl.web@gmail.com>
 
+       * progmodes/sh-script.el (sh-dynamic-complete-functions): Adapt to
+       completion-at-point.  (Bug#12220)
+
        * skeleton.el (skeleton-untabify): Change to nil (bug#12223).
 
        * progmodes/sh-script.el (sh-indent-comment): Change to t (bug#12267).
index 90f9ce3a52f2c608ae7802859bb35c92cfb35def..2d0cdeaeeaeeaed29f9317125042fbdac69ebfd9 100644 (file)
   (require 'comint))
 (require 'executable)
 
+(autoload 'comint-completion-at-point "comint")
+(autoload 'comint-filename-completion "comint")
+(autoload 'shell-command-completion "shell")
+(autoload 'shell-environment-variable-completion "shell")
+
 (defvar font-lock-comment-face)
 (defvar font-lock-set-defaults)
 (defvar font-lock-string-face)
@@ -469,7 +474,6 @@ This is buffer-local in every such buffer.")
     (define-key map "`" 'skeleton-pair-insert-maybe)
     (define-key map "\"" 'skeleton-pair-insert-maybe)
 
-    (define-key map [remap complete-tag] 'comint-dynamic-complete)
     (define-key map [remap delete-backward-char]
       'backward-delete-char-untabify)
     (define-key map "\C-c:" 'sh-set-shell)
@@ -556,9 +560,9 @@ This is buffer-local in every such buffer.")
   "Value to use for `skeleton-pair-default-alist' in Shell-Script mode.")
 
 (defcustom sh-dynamic-complete-functions
-  '(shell-dynamic-complete-environment-variable
-    shell-dynamic-complete-command
-    comint-dynamic-complete-filename)
+  '(shell-environment-variable-completion
+    shell-command-completion
+    comint-filename-completion)
   "Functions for doing TAB dynamic completion."
   :type '(repeat function)
   :group 'sh-script)
@@ -1490,6 +1494,7 @@ with your script for an edit-interpret-debug cycle."
   (set (make-local-variable 'local-abbrev-table) sh-mode-abbrev-table)
   (set (make-local-variable 'comint-dynamic-complete-functions)
        sh-dynamic-complete-functions)
+  (add-hook 'completion-at-point-functions 'comint-completion-at-point nil t)
   ;; we can't look if previous line ended with `\'
   (set (make-local-variable 'comint-prompt-regexp) "^[ \t]*")
   (set (make-local-variable 'imenu-case-fold-search) nil)
@@ -3682,20 +3687,6 @@ The document is bounded by `sh-here-document-word'."
 \f
 ;; various other commands
 
-(autoload 'comint-dynamic-complete "comint"
-  "Dynamically perform completion at point." t)
-
-(autoload 'shell-dynamic-complete-command "shell"
-  "Dynamically complete the command at point." t)
-
-(autoload 'comint-dynamic-complete-filename "comint"
-  "Dynamically complete the filename at point." t)
-
-(autoload 'shell-dynamic-complete-environment-variable "shell"
-  "Dynamically complete the environment variable at point." t)
-
-
-
 (defun sh-beginning-of-command ()
   "Move point to successive beginnings of commands."
   (interactive)