mirror of
https://git.in.rschanz.org/ryan77627/guix.git
synced 2025-01-12 06:06:53 -05:00
inferior: '&inferior-exception' includes a stack trace.
* guix/inferior.scm (port->inferior): Bump protocol to (0 1 1). (&inferior-exception)[stack]: New field. (read-repl-response): Recognize 'exception' form for protocol (0 1 1). * tests/inferior.scm ("&inferior-exception"): Check the value returned by 'inferior-exception-stack'.
This commit is contained in:
parent
2b0a370d00
commit
1dca6aaafa
2 changed files with 18 additions and 4 deletions
|
@ -66,6 +66,7 @@ (define-module (guix inferior)
|
|||
inferior-exception?
|
||||
inferior-exception-arguments
|
||||
inferior-exception-inferior
|
||||
inferior-exception-stack
|
||||
read-repl-response
|
||||
|
||||
inferior-packages
|
||||
|
@ -164,7 +165,7 @@ (define* (port->inferior pipe #:optional (close close-port))
|
|||
(match rest
|
||||
((n _ ...)
|
||||
(when (>= n 1)
|
||||
(send-inferior-request '(() repl-version 0 1) result)))
|
||||
(send-inferior-request '(() repl-version 0 1 1) result)))
|
||||
(_
|
||||
#t))
|
||||
|
||||
|
@ -211,7 +212,8 @@ (define (write-inferior-object object port)
|
|||
(define-condition-type &inferior-exception &error
|
||||
inferior-exception?
|
||||
(arguments inferior-exception-arguments) ;key + arguments
|
||||
(inferior inferior-exception-inferior)) ;<inferior> | #f
|
||||
(inferior inferior-exception-inferior) ;<inferior> | #f
|
||||
(stack inferior-exception-stack)) ;list of (FILE COLUMN LINE)
|
||||
|
||||
(define* (read-repl-response port #:optional inferior)
|
||||
"Read a (guix repl) response from PORT and return it as a Scheme object.
|
||||
|
@ -226,10 +228,19 @@ (define sexp->object
|
|||
(match (read port)
|
||||
(('values objects ...)
|
||||
(apply values (map sexp->object objects)))
|
||||
(('exception key objects ...)
|
||||
(('exception ('arguments key objects ...)
|
||||
('stack frames ...))
|
||||
;; Protocol (0 1 1) and later.
|
||||
(raise (condition (&inferior-exception
|
||||
(arguments (cons key (map sexp->object objects)))
|
||||
(inferior inferior)))))))
|
||||
(inferior inferior)
|
||||
(stack frames)))))
|
||||
(('exception key objects ...)
|
||||
;; Protocol (0 0).
|
||||
(raise (condition (&inferior-exception
|
||||
(arguments (cons key (map sexp->object objects)))
|
||||
(inferior inferior)
|
||||
(stack '())))))))
|
||||
|
||||
(define (read-inferior-response inferior)
|
||||
(read-repl-response (inferior-socket inferior)
|
||||
|
|
|
@ -68,6 +68,9 @@ (define (manifest-entry->list entry)
|
|||
(guard (c ((inferior-exception? c)
|
||||
(close-inferior inferior)
|
||||
(and (eq? inferior (inferior-exception-inferior c))
|
||||
(match (inferior-exception-stack c)
|
||||
(((_ (files lines columns)) ..1)
|
||||
(member "guix/repl.scm" files)))
|
||||
(inferior-exception-arguments c))))
|
||||
(inferior-eval '(throw 'a 'b 'c 'd) inferior)
|
||||
'badness)))
|
||||
|
|
Loading…
Reference in a new issue