]> git.eshelyaron.com Git - emacs.git/commitdiff
(eshell-needs-pipe): New variable.
authorGlenn Morris <rgm@gnu.org>
Sun, 30 Nov 2008 01:28:01 +0000 (01:28 +0000)
committerGlenn Morris <rgm@gnu.org>
Sun, 30 Nov 2008 01:28:01 +0000 (01:28 +0000)
(eshell-needs-pipe-p): New function.
(eshell-gather-process-output): Set process-connection-type according to
eshell-needs-pipe-p.  (Bug#1388)

lisp/ChangeLog
lisp/eshell/esh-proc.el

index 2c6c789b67bc63187127e8dfece8eedc9fe86064..12e27d97c88a88c8ecc6a6170082b620ee60ce5f 100644 (file)
@@ -1,3 +1,10 @@
+2008-11-30  Glenn Morris  <rgm@gnu.org>
+
+       * eshell/esh-proc.el (eshell-needs-pipe): New variable.
+       (eshell-needs-pipe-p): New function.
+       (eshell-gather-process-output): Set process-connection-type according to
+       eshell-needs-pipe-p.  (Bug#1388)
+
 2008-11-30  Juanma Barranquero  <lekktu@gmail.com>
 
        * calendar/diary-lib.el (diary-cyclic): Doc fix.
index 25d9dd6466390512c3d78a27b9a519b5b53d5c01..20bc98c2ea728301976d3599db8fe5e94e8dec90 100644 (file)
@@ -236,6 +236,26 @@ The prompt will be set to PROMPT."
   "A marker that tracks the beginning of output of the last subprocess.
 Used only on systems which do not support async subprocesses.")
 
+(defvar eshell-needs-pipe '("bc")
+  "List of commands which need `process-connection-type' to be nil.
+Currently only affects commands in pipelines, and not those at
+the front.  If an element contains a directory part it must match
+the full name of a command, otherwise just the nondirectory part must match.")
+
+(defun eshell-needs-pipe-p (command)
+  "Return non-nil if COMMAND needs `process-connection-type' to be nil.
+See `eshell-needs-pipe'."
+  (and eshell-in-pipeline-p
+       (not (eq eshell-in-pipeline-p 'first))
+       ;; FIXME should this return non-nil for anything that is
+       ;; neither 'first nor 'last?  See bug#1388 discussion.
+       (catch 'found
+        (dolist (exe eshell-needs-pipe)
+          (if (string-equal exe (if (string-match "/" exe)
+                                    command
+                                  (file-name-nondirectory command)))
+              (throw 'found t))))))
+
 (defun eshell-gather-process-output (command args)
   "Gather the output from COMMAND + ARGS."
   (unless (and (file-executable-p command)
@@ -250,11 +270,13 @@ Used only on systems which do not support async subprocesses.")
     (cond
      ((fboundp 'start-process)
       (setq proc
-           (apply 'start-process
-                  (file-name-nondirectory command) nil
-                  ;; `start-process' can't deal with relative
-                  ;; filenames
-                  (append (list (expand-file-name command)) args)))
+           (let ((process-connection-type
+                  (unless (eshell-needs-pipe-p command)
+                    process-connection-type)))
+             (apply 'start-process
+                    (file-name-nondirectory command) nil
+                    ;; `start-process' can't deal with relative filenames.
+                    (append (list (expand-file-name command)) args))))
       (eshell-record-process-object proc)
       (set-process-buffer proc (current-buffer))
       (if (eshell-interactive-output-p)