mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-11 21:59:08 -05:00
remote, ssh: Show the command exit status upon failure.
* guix/remote.scm (remote-pipe-for-gexp): Show the exit status in error message. * guix/ssh.scm (remote-inferior): Likewise.
This commit is contained in:
parent
2a5f781e76
commit
e09c7f4ae4
2 changed files with 15 additions and 11 deletions
|
@ -27,6 +27,7 @@ (define-module (guix remote)
|
|||
#:use-module (guix derivations)
|
||||
#:use-module (guix utils)
|
||||
#:use-module (ssh popen)
|
||||
#:use-module (ssh channel)
|
||||
#:use-module (srfi srfi-1)
|
||||
#:use-module (srfi srfi-34)
|
||||
#:use-module (srfi srfi-35)
|
||||
|
@ -68,10 +69,13 @@ (define repl-command
|
|||
|
||||
(let ((pipe (apply open-remote-pipe* session OPEN_READ repl-command)))
|
||||
(when (eof-object? (peek-char pipe))
|
||||
(raise (condition
|
||||
(&message
|
||||
(message (format #f (G_ "failed to run '~{~a~^ ~}'")
|
||||
repl-command))))))
|
||||
(let ((status (channel-get-exit-status pipe)))
|
||||
(close-port pipe)
|
||||
(raise (condition
|
||||
(&message
|
||||
(message (format #f (G_ "remote command '~{~a~^ ~}' failed \
|
||||
with status ~a")
|
||||
repl-command status)))))))
|
||||
pipe))
|
||||
|
||||
(define* (%remote-eval lowered session #:optional become-command)
|
||||
|
|
14
guix/ssh.scm
14
guix/ssh.scm
|
@ -106,14 +106,14 @@ (define* (remote-inferior session #:optional become-command)
|
|||
(let* ((repl-command (append (or become-command '())
|
||||
'("guix" "repl" "-t" "machine")))
|
||||
(pipe (apply open-remote-pipe* session OPEN_BOTH repl-command)))
|
||||
;; XXX: 'channel-get-exit-status' would be better here, but hangs if the
|
||||
;; process does succeed. This doesn't reflect the documentation, so it's
|
||||
;; possible that it's a bug in guile-ssh.
|
||||
(when (eof-object? (peek-char pipe))
|
||||
(raise (condition
|
||||
(&message
|
||||
(message (format #f (G_ "failed to run '~{~a~^ ~}'")
|
||||
repl-command))))))
|
||||
(let ((status (channel-get-exit-status pipe)))
|
||||
(close-port pipe)
|
||||
(raise (condition
|
||||
(&message
|
||||
(message (format #f (G_ "remote command '~{~a~^ ~}' failed \
|
||||
with status ~a")
|
||||
repl-command status)))))))
|
||||
(port->inferior pipe)))
|
||||
|
||||
(define* (inferior-remote-eval exp session #:optional become-command)
|
||||
|
|
Loading…
Reference in a new issue