From 34d83170132c73478a90952a25e1b1e68fe64eb1 Mon Sep 17 00:00:00 2001 From: Barry Warsaw Date: Fri, 20 Nov 1998 03:04:07 +0000 Subject: [PATCH] (py-execute-region): Hack around the different behavior and switch semantics between CPython/JPython when the script source is piped to stdin. --- Misc/python-mode.el | 35 +++++++++++++++++++++-------------- 1 file changed, 21 insertions(+), 14 deletions(-) diff --git a/Misc/python-mode.el b/Misc/python-mode.el index 2adc3c66fd2..a99bfdfe6aa 100644 --- a/Misc/python-mode.el +++ b/Misc/python-mode.el @@ -1215,8 +1215,11 @@ is inserted at the end. See also the command `py-clear-queue'." (cond ;; always run the code in its own asynchronous subprocess (async - (let* ((buf (generate-new-buffer-name py-output-buffer))) - (start-process py-which-bufname buf py-which-shell "-u" file) + (let* ((buf (generate-new-buffer-name py-output-buffer)) + ;; TBD: a horrible hack, but why create new Custom variables? + (arg (if (string-equal py-which-bufname "Python") + "-u" ""))) + (start-process py-which-bufname buf py-which-shell arg file) (pop-to-buffer buf) (py-postprocess-output-buffer buf) )) @@ -1230,18 +1233,22 @@ is inserted at the end. See also the command `py-clear-queue'." (setq py-file-queue (append py-file-queue (list file))) (setq py-exception-buffer (cons file (current-buffer)))) (t - ;; otherwise either run it synchronously in a subprocess - (shell-command-on-region start end py-which-shell py-output-buffer) - ;; shell-command-on-region kills the output buffer if it never - ;; existed and there's no output from the command - (if (not (get-buffer py-output-buffer)) - (message "No output.") - (setq py-exception-buffer (current-buffer)) - (let ((err-p (py-postprocess-output-buffer py-output-buffer))) - (pop-to-buffer py-output-buffer) - (if err-p - (pop-to-buffer py-exception-buffer))) - )) + ;; TBD: a horrible hack, buy why create new Custom variables? + (let ((cmd (concat py-which-shell + (if (string-equal py-which-bufname "JPython") + " -" "")))) + ;; otherwise either run it synchronously in a subprocess + (shell-command-on-region start end cmd py-output-buffer) + ;; shell-command-on-region kills the output buffer if it never + ;; existed and there's no output from the command + (if (not (get-buffer py-output-buffer)) + (message "No output.") + (setq py-exception-buffer (current-buffer)) + (let ((err-p (py-postprocess-output-buffer py-output-buffer))) + (pop-to-buffer py-output-buffer) + (if err-p + (pop-to-buffer py-exception-buffer))) + ))) )))