mirror of
https://git.savannah.gnu.org/git/guix.git
synced 2025-01-18 21:46:35 +01:00
database: 'sqlite-register' takes a database, not a file name.
* guix/store/database.scm (sqlite-register): Remove #:db-file and add 'db' parameter. Remove #:schema and 'parameterize'. (register-path): Wrap 'sqlite-register' call in 'with-database' and in 'parameterize'. * tests/store-database.scm ("new database") ("register-path with unregistered references"): Adjust accordingly.
This commit is contained in:
parent
c45477d2a1
commit
ef1297e8c7
2 changed files with 46 additions and 51 deletions
|
@ -157,30 +157,24 @@ (define (add-references db referrer references)
|
|||
(last-insert-row-id db))
|
||||
references)))
|
||||
|
||||
;; XXX figure out caching of statement and database objects... later
|
||||
(define* (sqlite-register #:key db-file path (references '())
|
||||
deriver hash nar-size
|
||||
(schema (sql-schema)))
|
||||
"Registers this stuff in a database specified by DB-FILE. PATH is the string
|
||||
path of some store item, REFERENCES is a list of string paths which the store
|
||||
item PATH refers to (they need to be already registered!), DERIVER is a string
|
||||
path of the derivation that created the store item PATH, HASH is the
|
||||
base16-encoded sha256 hash of the store item denoted by PATH (prefixed with
|
||||
\"sha256:\") after being converted to nar form, and NAR-SIZE is the size in
|
||||
bytes of the store item denoted by PATH after being converted to nar form.
|
||||
(define* (sqlite-register db #:key path (references '())
|
||||
deriver hash nar-size)
|
||||
"Registers this stuff in DB. PATH is the store item to register and
|
||||
REFERENCES is the list of store items PATH refers to; DERIVER is the '.drv'
|
||||
that produced PATH, HASH is the base16-encoded Nix sha256 hash of
|
||||
PATH (prefixed with \"sha256:\"), and NAR-SIZE is the size in bytes PATH after
|
||||
being converted to nar form.
|
||||
|
||||
Every store item in REFERENCES must already be registered."
|
||||
(parameterize ((sql-schema schema))
|
||||
(with-database db-file db
|
||||
(let ((id (update-or-insert db #:path path
|
||||
#:deriver deriver
|
||||
#:hash hash
|
||||
#:nar-size nar-size
|
||||
#:time (time-second (current-time time-utc)))))
|
||||
;; Call 'path-id' on each of REFERENCES. This ensures we get a
|
||||
;; "non-NULL constraint" failure if one of REFERENCES is unregistered.
|
||||
(add-references db id
|
||||
(map (cut path-id db <>) references))))))
|
||||
(let ((id (update-or-insert db #:path path
|
||||
#:deriver deriver
|
||||
#:hash hash
|
||||
#:nar-size nar-size
|
||||
#:time (time-second (current-time time-utc)))))
|
||||
;; Call 'path-id' on each of REFERENCES. This ensures we get a
|
||||
;; "non-NULL constraint" failure if one of REFERENCES is unregistered.
|
||||
(add-references db id
|
||||
(map (cut path-id db <>) references))))
|
||||
|
||||
|
||||
;;;
|
||||
|
@ -267,15 +261,16 @@ (define* (register-path path
|
|||
(when reset-timestamps?
|
||||
(reset-timestamps real-path))
|
||||
(mkdir-p db-dir)
|
||||
(sqlite-register
|
||||
#:db-file (string-append db-dir "/db.sqlite")
|
||||
#:schema schema
|
||||
#:path to-register
|
||||
#:references references
|
||||
#:deriver deriver
|
||||
#:hash (string-append "sha256:"
|
||||
(bytevector->base16-string hash))
|
||||
#:nar-size nar-size)
|
||||
(parameterize ((sql-schema schema))
|
||||
(with-database (string-append db-dir "/db.sqlite") db
|
||||
(sqlite-register
|
||||
db
|
||||
#:path to-register
|
||||
#:references references
|
||||
#:deriver deriver
|
||||
#:hash (string-append "sha256:"
|
||||
(bytevector->base16-string hash))
|
||||
#:nar-size nar-size)))
|
||||
|
||||
(when deduplicate?
|
||||
(deduplicate real-path hash #:store store-dir)))))
|
||||
|
|
|
@ -57,20 +57,20 @@ (define %store
|
|||
(call-with-temporary-output-file
|
||||
(lambda (db-file port)
|
||||
(delete-file db-file)
|
||||
(sqlite-register #:db-file db-file
|
||||
#:path "/gnu/foo"
|
||||
#:references '()
|
||||
#:deriver "/gnu/foo.drv"
|
||||
#:hash (string-append "sha256:" (make-string 64 #\e))
|
||||
#:nar-size 1234)
|
||||
(sqlite-register #:db-file db-file
|
||||
#:path "/gnu/bar"
|
||||
#:references '("/gnu/foo")
|
||||
#:deriver "/gnu/bar.drv"
|
||||
#:hash (string-append "sha256:" (make-string 64 #\a))
|
||||
#:nar-size 4321)
|
||||
(let ((path-id (@@ (guix store database) path-id)))
|
||||
(with-database db-file db
|
||||
(with-database db-file db
|
||||
(sqlite-register db
|
||||
#:path "/gnu/foo"
|
||||
#:references '()
|
||||
#:deriver "/gnu/foo.drv"
|
||||
#:hash (string-append "sha256:" (make-string 64 #\e))
|
||||
#:nar-size 1234)
|
||||
(sqlite-register db
|
||||
#:path "/gnu/bar"
|
||||
#:references '("/gnu/foo")
|
||||
#:deriver "/gnu/bar.drv"
|
||||
#:hash (string-append "sha256:" (make-string 64 #\a))
|
||||
#:nar-size 4321)
|
||||
(let ((path-id (@@ (guix store database) path-id)))
|
||||
(list (path-id db "/gnu/foo")
|
||||
(path-id db "/gnu/bar")))))))
|
||||
|
||||
|
@ -83,12 +83,12 @@ (define %store
|
|||
(delete-file db-file)
|
||||
(catch 'sqlite-error
|
||||
(lambda ()
|
||||
(sqlite-register #:db-file db-file
|
||||
#:path "/gnu/foo"
|
||||
#:references '("/gnu/bar")
|
||||
#:deriver "/gnu/foo.drv"
|
||||
#:hash (string-append "sha256:" (make-string 64 #\e))
|
||||
#:nar-size 1234)
|
||||
(with-database db-file db
|
||||
(sqlite-register db #:path "/gnu/foo"
|
||||
#:references '("/gnu/bar")
|
||||
#:deriver "/gnu/foo.drv"
|
||||
#:hash (string-append "sha256:" (make-string 64 #\e))
|
||||
#:nar-size 1234))
|
||||
#f)
|
||||
(lambda args
|
||||
(pk 'welcome-exception! args)
|
||||
|
|
Loading…
Reference in a new issue