(py-execute-region): Hack around the different behavior and switch

semantics between CPython/JPython when the script source is piped to
stdin.
This commit is contained in:
Barry Warsaw 1998-11-20 03:04:07 +00:00
parent 99ff8c4361
commit 34d8317013
1 changed files with 21 additions and 14 deletions

View File

@ -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,8 +1233,12 @@ 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
;; 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 py-which-shell py-output-buffer)
(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))
@ -1241,7 +1248,7 @@ is inserted at the end. See also the command `py-clear-queue'."
(pop-to-buffer py-output-buffer)
(if err-p
(pop-to-buffer py-exception-buffer)))
))
)))
)))