mirror of
https://git.savannah.gnu.org/git/guix.git
synced 2025-01-18 21:46:35 +01:00
store: Add `query-path-hash'.
* guix/store.scm (write-arg, read-arg): Add `base16' literal and corresponding rule. (query-path-hash): New operation. * tests/derivations.scm ("fixed-output derivation"): Check whether `query-path-hash' returns a bytevector.
This commit is contained in:
parent
e6cc3d8654
commit
82058eff59
2 changed files with 17 additions and 6 deletions
|
@ -17,6 +17,7 @@
|
|||
;;; along with Guix. If not, see <http://www.gnu.org/licenses/>.
|
||||
|
||||
(define-module (guix store)
|
||||
#:use-module (guix utils)
|
||||
#:use-module (rnrs bytevectors)
|
||||
#:use-module (rnrs io ports)
|
||||
#:use-module (srfi srfi-1)
|
||||
|
@ -44,6 +45,7 @@ (define-module (guix store)
|
|||
close-connection
|
||||
set-build-options
|
||||
valid-path?
|
||||
query-path-hash
|
||||
add-text-to-store
|
||||
add-to-store
|
||||
build-derivations
|
||||
|
@ -217,7 +219,7 @@ (define %archive-version-1 "nix-archive-1")
|
|||
(write-string ")" p))))
|
||||
|
||||
(define-syntax write-arg
|
||||
(syntax-rules (integer boolean file string string-list)
|
||||
(syntax-rules (integer boolean file string string-list base16)
|
||||
((_ integer arg p)
|
||||
(write-int arg p))
|
||||
((_ boolean arg p)
|
||||
|
@ -227,10 +229,12 @@ (define-syntax write-arg
|
|||
((_ string arg p)
|
||||
(write-string arg p))
|
||||
((_ string-list arg p)
|
||||
(write-string-list arg p))))
|
||||
(write-string-list arg p))
|
||||
((_ base16 arg p)
|
||||
(write-string (bytevector->base16-string arg) p))))
|
||||
|
||||
(define-syntax read-arg
|
||||
(syntax-rules (integer boolean string store-path)
|
||||
(syntax-rules (integer boolean string store-path base16)
|
||||
((_ integer p)
|
||||
(read-int p))
|
||||
((_ boolean p)
|
||||
|
@ -238,7 +242,9 @@ (define-syntax read-arg
|
|||
((_ string p)
|
||||
(read-string p))
|
||||
((_ store-path p)
|
||||
(read-store-path p))))
|
||||
(read-store-path p))
|
||||
((_ hash p)
|
||||
(base16-string->bytevector (read-string p)))))
|
||||
|
||||
|
||||
;; remote-store.cc
|
||||
|
@ -391,6 +397,10 @@ (define-operation (valid-path? (string path))
|
|||
"Return #t when PATH is a valid store path."
|
||||
boolean)
|
||||
|
||||
(define-operation (query-path-hash (string path))
|
||||
"Return the SHA256 hash of PATH as a bytevector."
|
||||
base16)
|
||||
|
||||
(define-operation (add-text-to-store (string name) (string text)
|
||||
(string-list references))
|
||||
"Add TEXT under file NAME in the store."
|
||||
|
|
|
@ -124,8 +124,9 @@ (define prefix-len (string-length dir))
|
|||
(succeeded? (build-derivations %store (list drv-path))))
|
||||
(and succeeded?
|
||||
(let ((p (derivation-path->output-path drv-path)))
|
||||
(equal? (string->utf8 "hello")
|
||||
(call-with-input-file p get-bytevector-all))))))
|
||||
(and (equal? (string->utf8 "hello")
|
||||
(call-with-input-file p get-bytevector-all))
|
||||
(bytevector? (query-path-hash %store p)))))))
|
||||
|
||||
(test-assert "multiple-output derivation"
|
||||
(let* ((builder (add-text-to-store %store "my-fixed-builder.sh"
|
||||
|
|
Loading…
Reference in a new issue