store: 'with-store' returns as many values as its body.

Fixes <https://bugs.gnu.org/42912>.
Reported by Ricardo Wurmus <rekado@elephly.net>.

* guix/store.scm (call-with-store)[thunk]: Wrap call to PROC in
'call-with-values'.
* tests/store.scm ("with-store, multiple values"): New test.
This commit is contained in:
Ludovic Courtès 2020-08-28 15:05:17 +02:00
parent b630840920
commit 3d9ea605c8
No known key found for this signature in database
GPG key ID: 090B11993D9AEBB5
2 changed files with 13 additions and 3 deletions

View file

@ -628,9 +628,10 @@ (define (call-with-store proc)
(define (thunk)
(parameterize ((current-store-protocol-version
(store-connection-version store)))
(let ((result (proc store)))
(close-connection store)
result)))
(call-with-values (lambda () (proc store))
(lambda results
(close-connection store)
(apply values results)))))
(cond-expand
(guile-3

View file

@ -141,6 +141,15 @@ (define %shell
(string-append (%store-prefix) "/"
(make-string 32 #\e) "-foobar"))))
(test-equal "with-store, multiple values" ;<https://bugs.gnu.org/42912>
'(1 2 3)
(call-with-values
(lambda ()
(with-store s
(add-text-to-store s "foo" "bar")
(values 1 2 3)))
list))
(test-assert "valid-path? error"
(with-store s
(guard (c ((store-protocol-error? c) #t))