mirror of
https://git.savannah.gnu.org/git/guix.git
synced 2025-01-19 05:57:04 +01:00
ui: Do not call 'port-filename' on closed file ports.
* guix/ui.scm (call-with-error-handling)[port-filename*]: New procedure. Use it in the 'nar-error?' case.
This commit is contained in:
parent
8bcdc23fd0
commit
bec7f35214
1 changed files with 8 additions and 2 deletions
10
guix/ui.scm
10
guix/ui.scm
|
@ -410,6 +410,12 @@ (define unit
|
|||
|
||||
(define (call-with-error-handling thunk)
|
||||
"Call THUNK within a user-friendly error handler."
|
||||
(define (port-filename* port)
|
||||
;; 'port-filename' returns #f for non-file ports, but it raises an
|
||||
;; exception for file ports that are closed. Work around that.
|
||||
(and (not (port-closed? port))
|
||||
(port-filename port)))
|
||||
|
||||
(guard (c ((package-input-error? c)
|
||||
(let* ((package (package-error-package c))
|
||||
(input (package-error-invalid-input c))
|
||||
|
@ -440,9 +446,9 @@ (define (call-with-error-handling thunk)
|
|||
(port (nar-error-port c)))
|
||||
(if file
|
||||
(leave (_ "corrupt input while restoring '~a' from ~s~%")
|
||||
file (or (port-filename port) port))
|
||||
file (or (port-filename* port) port))
|
||||
(leave (_ "corrupt input while restoring archive from ~s~%")
|
||||
(or (port-filename port) port)))))
|
||||
(or (port-filename* port) port)))))
|
||||
((nix-connection-error? c)
|
||||
(leave (_ "failed to connect to `~a': ~a~%")
|
||||
(nix-connection-error-file c)
|
||||
|
|
Loading…
Reference in a new issue