summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorFabián Ezequiel Gallina <fgallina@gnu.org>2014-07-31 21:18:19 -0300
committerFabián Ezequiel Gallina <fgallina@gnu.org>2014-07-31 21:18:19 -0300
commitbc1ce1df863ffd32d1290b448591f8897029b10b (patch)
treeb494025cc3479a74a5d6e935c2391d65e61ca6e5
parent1b2567263531e4f584cef5f79ef731cd4dbd741b (diff)
downloademacs-bc1ce1df863ffd32d1290b448591f8897029b10b.tar.gz
emacs-bc1ce1df863ffd32d1290b448591f8897029b10b.tar.bz2
emacs-bc1ce1df863ffd32d1290b448591f8897029b10b.zip
* lisp/progmodes/python.el: Shell output capture enhancements.
(python-shell-accept-process-output): New function. (inferior-python-mode) (python-shell-send-setup-code): Use it.
-rw-r--r--lisp/ChangeLog7
-rw-r--r--lisp/progmodes/python.el34
2 files changed, 32 insertions, 9 deletions
diff --git a/lisp/ChangeLog b/lisp/ChangeLog
index 5b07bbe6c74..e7496454fcc 100644
--- a/lisp/ChangeLog
+++ b/lisp/ChangeLog
@@ -1,3 +1,10 @@
+2014-07-31 Fabián Ezequiel Gallina <fgallina@gnu.org>
+
+ * progmodes/python.el: Shell output capture enhancements.
+ (python-shell-accept-process-output): New function.
+ (inferior-python-mode)
+ (python-shell-send-setup-code): Use it.
+
2014-07-30 Christophe Deleuze <christophe.deleuze@free.fr> (tiny change)
* calendar/icalendar.el (icalendar--decode-isodatetime): Use
diff --git a/lisp/progmodes/python.el b/lisp/progmodes/python.el
index d1dd9bef4bc..7d7cd9de19e 100644
--- a/lisp/progmodes/python.el
+++ b/lisp/progmodes/python.el
@@ -2129,6 +2129,27 @@ uniqueness for different types of configurations."
directory package package)
(python-shell-get-process)))
+(defun python-shell-accept-process-output (process &optional timeout regexp)
+ "Accept PROCESS output with TIMEOUT until REGEXP is found.
+Optional argument TIMEOUT is the timeout argument to
+`accept-process-output' calls. Optional argument REGEXP
+overrides the regexp to match the end of output, defaults to
+`comint-prompt-regexp.'. Returns non-nil when output was
+properly captured.
+
+This utility is useful in situations where the output may be
+received in chunks, since `accept-process-output' gives no
+guarantees they will be grabbed in a single call. An example use
+case for this would be the CPython shell start-up, where the
+banner and the initial prompt are received separetely."
+ (let ((regexp (or regexp comint-prompt-regexp)))
+ (catch 'found
+ (while t
+ (when (not (accept-process-output process timeout))
+ (throw 'found nil))
+ (when (looking-back regexp)
+ (throw 'found t))))))
+
(defun python-shell-comint-end-of-output-p (output)
"Return non-nil if OUTPUT is ends with input prompt."
(string-match
@@ -2380,13 +2401,8 @@ variable.
(when python-shell-font-lock-enable
(python-shell-font-lock-turn-on))
(compilation-shell-minor-mode 1)
- ;; Ensure all the output is accepted before running any hooks.
- (accept-process-output (get-buffer-process (current-buffer)))
- ;; At this point, all process output should have been received, but
- ;; on GNU/Linux, calling `python-shell-internal-send-string' without
- ;; a running internal shell fails to grab output properly unless
- ;; this `sit-for' is in place.
- (sit-for 0.1 t))
+ (python-shell-accept-process-output
+ (get-buffer-process (current-buffer))))
(defun python-shell-make-comint (cmd proc-name &optional pop internal)
"Create a Python shell comint buffer.
@@ -2790,8 +2806,8 @@ This function takes the list of setup code to send from the
python-shell-setup-codes
"\n\n")
"\n\nprint ('python.el: sent setup code')")))
- (python-shell-send-string code)
- (accept-process-output process)))
+ (python-shell-send-string code process)
+ (python-shell-accept-process-output process)))
(add-hook 'inferior-python-mode-hook
#'python-shell-send-setup-code)