]> git.eshelyaron.com Git - emacs.git/commitdiff
* progmodes/python.el (python-shell-send-string-no-output): Allow
authorFabián Ezequiel Gallina <fgallina@gnu.org>
Tue, 17 Jul 2012 16:47:58 +0000 (13:47 -0300)
committerFabián Ezequiel Gallina <fgallina@gnu.org>
Tue, 17 Jul 2012 16:47:58 +0000 (13:47 -0300)
accept-process-output to quit, keeping shell process ready for
future interactions.

Fixes: debbugs:11868
lisp/ChangeLog
lisp/progmodes/python.el

index 34fe5a509f4b0f6318db7b8a37097ad8446c82a9..8fbe6d35940598ff862b5bd9126dd1dfc743ff39 100644 (file)
@@ -1,3 +1,9 @@
+2012-07-17  Fabián Ezequiel Gallina  <fgallina@cuca>
+
+       * progmodes/python.el (python-shell-send-string-no-output): Allow
+       accept-process-output to quit, keeping shell process ready for
+       future interactions (Bug#11868).
+
 2012-07-17  Stefan Monnier  <monnier@iro.umontreal.ca>
 
        * emacs-lisp/cl-macs.el (cl-progv): Use a properly prefixed var name.
index e0a58d1523e2fb6dff6ac41d6e06f2fa282bcc1e..f6a1fbf3ab705098a71080f6600c8a11fbd3b7ff 100644 (file)
@@ -1701,24 +1701,29 @@ When MSG is non-nil messages the first line of STRING."
   "Send STRING to PROCESS and inhibit output.
 When MSG is non-nil messages the first line of STRING.  Return
 the output."
-  (let* ((output-buffer)
+  (let* ((output-buffer "")
          (process (or process (python-shell-get-or-create-process)))
          (comint-preoutput-filter-functions
           (append comint-preoutput-filter-functions
                   '(ansi-color-filter-apply
                     (lambda (string)
                       (setq output-buffer (concat output-buffer string))
-                      "")))))
-    (python-shell-send-string string process msg)
-    (accept-process-output process)
-    (replace-regexp-in-string
-     (if (> (length python-shell-prompt-output-regexp) 0)
-         (format "\n*%s$\\|^%s\\|\n$"
-                 python-shell-prompt-regexp
-                 (or python-shell-prompt-output-regexp ""))
-       (format "\n*$\\|^%s\\|\n$"
-               python-shell-prompt-regexp))
-     "" output-buffer)))
+                      ""))))
+         (inhibit-quit t))
+    (or
+     (with-local-quit
+       (python-shell-send-string string process msg)
+       (accept-process-output process)
+       (replace-regexp-in-string
+        (if (> (length python-shell-prompt-output-regexp) 0)
+            (format "\n*%s$\\|^%s\\|\n$"
+                    python-shell-prompt-regexp
+                    (or python-shell-prompt-output-regexp ""))
+          (format "\n*$\\|^%s\\|\n$"
+                  python-shell-prompt-regexp))
+        "" output-buffer))
+     (with-current-buffer (process-buffer process)
+       (comint-interrupt-subjob)))))
 
 (defun python-shell-internal-send-string (string)
   "Send STRING to the Internal Python interpreter.