aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMathieu Othacehe <othacehe@gnu.org>2021-03-10 11:28:35 +0100
committerMathieu Othacehe <othacehe@gnu.org>2021-03-10 13:08:32 +0100
commit8898eaec57f6294221888e6dca1802abdd3d5868 (patch)
tree9198512bfdebd666fd43dab67582606a57684515
parente5f89570c1d72c4b674fad6b6ad5591ead02d419 (diff)
downloadguix-8898eaec57f6294221888e6dca1802abdd3d5868.tar
guix-8898eaec57f6294221888e6dca1802abdd3d5868.tar.gz
Revert "inferior: Break cached-channel-instance into two procedures."
This reverts commit 7d63b775513e7049047222dbe403a4181f63828d because it raises some concerns, see: https://lists.gnu.org/archive/html/guix-devel/2021-03/msg00124.html.
-rw-r--r--guix/inferior.scm82
-rw-r--r--guix/scripts/time-machine.scm5
2 files changed, 29 insertions, 58 deletions
diff --git a/guix/inferior.scm b/guix/inferior.scm
index d0cd1ccee7..259be3f27d 100644
--- a/guix/inferior.scm
+++ b/guix/inferior.scm
@@ -98,8 +98,7 @@
gexp->derivation-in-inferior
%inferior-cache-directory
- channels->cached-profile
- instances->cached-profile
+ cached-channel-instance
inferior-for-channels))
;;; Commentary:
@@ -709,14 +708,22 @@ prefix, resolve it; and if 'commit' is unset, fetch CHANNEL's branch tip."
#:check-out? #f)))
commit))))
-(define* (cached-profile store instances
- #:key
- cache-directory
- commits ttl)
- "Return a directory containing a guix filetree defined by INSTANCES, a
-procedure returning a list of channel instances. The directory is a
-subdirectory of CACHE-DIRECTORY, where entries can be reclaimed after TTL
-seconds. This procedure opens a new connection to the build daemon."
+(define* (cached-channel-instance store
+ channels
+ #:key
+ (authenticate? #t)
+ (cache-directory (%inferior-cache-directory))
+ (ttl (* 3600 24 30)))
+ "Return a directory containing a guix filetree defined by CHANNELS, a list of channels.
+The directory is a subdirectory of CACHE-DIRECTORY, where entries can be reclaimed after TTL seconds.
+This procedure opens a new connection to the build daemon. AUTHENTICATE?
+determines whether CHANNELS are authenticated."
+ (define commits
+ ;; Since computing the instances of CHANNELS is I/O-intensive, use a
+ ;; cheaper way to get the commit list of CHANNELS. This limits overhead
+ ;; to the minimum in case of a cache hit.
+ (map channel-full-commit channels))
+
(define key
(bytevector->base32-string
(sha256
@@ -748,8 +755,12 @@ seconds. This procedure opens a new connection to the build daemon."
(if (file-exists? cached)
cached
(run-with-store store
- (mlet* %store-monad ((profile
- (channel-instances->derivation (instances))))
+ (mlet* %store-monad ((instances
+ -> (latest-channel-instances store channels
+ #:authenticate?
+ authenticate?))
+ (profile
+ (channel-instances->derivation instances)))
(mbegin %store-monad
(show-what-to-build* (list profile))
(built-derivations (list profile))
@@ -760,45 +771,6 @@ seconds. This procedure opens a new connection to the build daemon."
(add-indirect-root* cached))
(return cached))))))
-(define* (channels->cached-profile store channels
- #:key
- (authenticate? #t)
- (cache-directory
- (%inferior-cache-directory))
- (ttl (* 3600 24 30)))
- "Return a cached profile from CHANNELS using the CACHED-PROFILE procedure.
-AUTHENTICATE? determines whether CHANNELS are authenticated."
- (define commits
- ;; Since computing the instances of CHANNELS is I/O-intensive, use a
- ;; cheaper way to get the commit list of CHANNELS. This limits overhead
- ;; to the minimum in case of a cache hit.
- (map channel-full-commit channels))
-
- (define instances
- (lambda ()
- (latest-channel-instances store channels
- #:authenticate? authenticate?)))
-
- (cached-profile store instances
- #:cache-directory cache-directory
- #:commits commits
- #:ttl ttl))
-
-(define* (instances->cached-profile store instances
- #:key
- (cache-directory
- (%inferior-cache-directory))
- (ttl (* 3600 24 30)))
- "Return a cached profile from INSTANCES a list of channel instances using
-the CACHED-PROFILE procedure."
- (define commits
- (map channel-instance-commit instances))
-
- (cached-profile store (lambda () instances)
- #:cache-directory cache-directory
- #:commits commits
- #:ttl ttl))
-
(define* (inferior-for-channels channels
#:key
(cache-directory (%inferior-cache-directory))
@@ -811,10 +783,10 @@ This is a convenience procedure that people may use in manifests passed to
'guix package -m', for instance."
(define cached
(with-store store
- (channels->cached-profile store
- channels
- #:cache-directory cache-directory
- #:ttl ttl)))
+ (cached-channel-instance store
+ channels
+ #:cache-directory cache-directory
+ #:ttl ttl)))
(open-inferior cached))
;;; Local Variables:
diff --git a/guix/scripts/time-machine.scm b/guix/scripts/time-machine.scm
index c4dca47d1d..0d27414702 100644
--- a/guix/scripts/time-machine.scm
+++ b/guix/scripts/time-machine.scm
@@ -142,8 +142,7 @@ Execute COMMAND ARGS... in an older version of Guix.\n"))
(with-store store
(with-status-verbosity (assoc-ref opts 'verbosity)
(set-build-options-from-command-line store opts)
- (channels->cached-profile
- store channels
- #:authenticate? authenticate?))))
+ (cached-channel-instance store channels
+ #:authenticate? authenticate?))))
(executable (string-append directory "/bin/guix")))
(apply execl (cons* executable executable command-line))))))))