summaryrefslogtreecommitdiff
path: root/piem.el
diff options
context:
space:
mode:
authorKyle Meyer <kyle@kyleam.com>2020-06-05 20:27:59 -0400
committerKyle Meyer <kyle@kyleam.com>2020-06-06 11:20:49 -0400
commitd557be18da6cd61dd2830677bbc08b06d39f0eac (patch)
treeb196a0e888739e5dbc08574a8da496e9decfdf1a /piem.el
parent5631f6d6371c243b85c54c20f3baa5a44b40c5c3 (diff)
downloadpiem-d557be18da6cd61dd2830677bbc08b06d39f0eac.tar.gz
b4: Drop custom process buffer
Directing all piem-related output to one buffer should be sufficient, for now at least.
Diffstat (limited to 'piem.el')
-rw-r--r--piem.el44
1 files changed, 23 insertions, 21 deletions
diff --git a/piem.el b/piem.el
index d4a0e1b..d688c17 100644
--- a/piem.el
+++ b/piem.el
@@ -152,6 +152,8 @@ intended to be used by libraries implementing a function for
line-end)
(0 font-lock-comment-face))))
+(defconst piem-process-output-buffer "*piem-process-output*")
+
(define-derived-mode piem-process-mode nil "piem-process"
"Major mode for displaying processes created by piem."
:group 'piem
@@ -164,33 +166,33 @@ intended to be used by libraries implementing a function for
(defvar-local piem--buffer-process nil)
-(defun piem--process-go (buffer dir program program-args fn)
+(defun piem--process-go (dir program program-args fn)
(setq dir (or dir default-directory))
- (setq buffer (get-buffer-create buffer))
- (with-current-buffer buffer
- (when (and piem--buffer-process
- (process-live-p piem--buffer-process))
- (user-error "Buffer %s already has an active process: %s"
- (current-buffer) piem--buffer-process))
- (unless (derived-mode-p 'piem-process-mode)
- (piem-process-mode))
- (setq default-directory (file-name-as-directory dir))
- (display-buffer buffer)
- (let ((inhibit-read-only t))
- (insert (format "
+ (let ((buffer (get-buffer-create piem-process-output-buffer)))
+ (with-current-buffer buffer
+ (when (and piem--buffer-process
+ (process-live-p piem--buffer-process))
+ (user-error "Buffer %s already has an active process: %s"
+ (current-buffer) piem--buffer-process))
+ (unless (derived-mode-p 'piem-process-mode)
+ (piem-process-mode))
+ (setq default-directory (file-name-as-directory dir))
+ (display-buffer buffer)
+ (let ((inhibit-read-only t))
+ (insert (format "
%s
;;; process: %S
;;; directory: %s
"
- (char-to-string 12) ; form feed
- (cons program program-args)
- default-directory))
- (funcall fn))))
+ (char-to-string 12) ; form feed
+ (cons program program-args)
+ default-directory))
+ (funcall fn)))))
-(defun piem-process-start (buffer dir program &rest program-args)
+(defun piem-process-start (dir program &rest program-args)
(setq program-args (remq nil program-args))
(piem--process-go
- buffer dir program program-args
+ dir program program-args
(lambda ()
(setq piem--buffer-process
(apply #'start-process
@@ -198,10 +200,10 @@ intended to be used by libraries implementing a function for
(current-buffer)
program program-args)))))
-(defun piem-process-call (buffer dir program &rest program-args)
+(defun piem-process-call (dir program &rest program-args)
(setq program-args (remq nil program-args))
(piem--process-go
- buffer dir program program-args
+ dir program program-args
(lambda ()
(unless (= 0 (apply #'call-process program nil t nil program-args))
(signal 'piem-error