From: Sam Steingold Date: Tue, 18 Nov 2008 14:14:37 +0000 (+0000) Subject: (compilation-start-hook): New hook. X-Git-Tag: emacs-pretest-23.0.90~1722 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=dd93e6daf75d71797fa6f03719d5890d269b2cb4;p=emacs.git (compilation-start-hook): New hook. (compilation-start): Run it on the compilation process. --- diff --git a/lisp/ChangeLog b/lisp/ChangeLog index 4010ba0e9f7..0fca95bea2d 100644 --- a/lisp/ChangeLog +++ b/lisp/ChangeLog @@ -1,3 +1,8 @@ +2008-11-18 Sam Steingold + + * progmodes/compile.el (compilation-start-hook): New hook. + (compilation-start): Run it on the compilation process. + 2008-11-18 Juanma Barranquero * international/mule-cmds.el (update-leim-list-file): Simplify. diff --git a/lisp/progmodes/compile.el b/lisp/progmodes/compile.el index f29c93f5ffa..9993f1197c3 100644 --- a/lisp/progmodes/compile.el +++ b/lisp/progmodes/compile.el @@ -91,6 +91,17 @@ :type 'hook :group 'compilation) +;;;###autoload +(defcustom compilation-start-hook nil + "List of hook functions run by `compilation-start' on the compilation process. +\(See `run-hook-with-args'). +If you use \"omake -P\" and do not want \\[save-buffers-kill-terminal] to ask whether you want +the compilation to be killed, you can use this hook: + (add-hook 'compilation-start-hook + (lambda (process) (set-process-query-on-exit-flag process nil)) nil t)" + :type 'hook + :group 'compilation) + ;;;###autoload (defcustom compilation-window-height nil "Number of lines in a compilation window. If nil, use Emacs default." @@ -1277,7 +1288,8 @@ Returns the compilation buffer created." (process-send-eof proc) ;; The process may have exited already. (error nil))) - (setq compilation-in-progress + (run-hook-with-args 'compilation-start-hook proc) + (setq compilation-in-progress (cons proc compilation-in-progress))) ;; No asynchronous processes available. (message "Executing `%s'..." command)