summary refs log tree commit diff
diff options
context:
space:
mode:
authorArun Isaac2025-03-25 20:01:51 +0000
committerArun Isaac2025-03-25 22:17:04 +0000
commit0b6c354eda626a99d7b5c785ca58cb2e30e7ea90 (patch)
treee605e8c95a33f62224c6988c6cd8f5682f40f2a1
parent03aaffde5d0448e4bd5aa83b33bfebc747ec0891 (diff)
downloadtissue-0b6c354eda626a99d7b5c785ca58cb2e30e7ea90.tar.gz
tissue-0b6c354eda626a99d7b5c785ca58cb2e30e7ea90.tar.lz
tissue-0b6c354eda626a99d7b5c785ca58cb2e30e7ea90.zip
bin: Spin out loading config from repository into separate function.
* bin/tissue (normalize-host): Spin out loading config from repository
into ...
(load-config-from-repository): ... new function.
-rwxr-xr-xbin/tissue27
1 files changed, 16 insertions, 11 deletions
diff --git a/bin/tissue b/bin/tissue
index 566cf36..1f91d48 100755
--- a/bin/tissue
+++ b/bin/tissue
@@ -242,6 +242,16 @@ port."
              socket-or-port)
      (make-tcp-server-socket #:port socket-or-port)))))
 
+(define (load-config-from-repository repository-directory)
+  "Load configuration from @var{repository-directory}, and return a
+@code{<tissue-configuration>} object."
+  (parameterize ((%current-git-repository
+                  (repository-open repository-directory)))
+    (call-with-temporary-checkout repository-directory
+      (lambda (temporary-checkout)
+        (call-with-current-directory temporary-checkout
+          load-config)))))
+
 (define (normalize-host state-directory host)
   "Normalize @var{host} from @file{tissue.conf} adding in default and
 extra parameters for convenient processing later on.
@@ -252,17 +262,12 @@ extra parameters for convenient processing later on.
      ;; settings for each host.
      (let ((repository-directory
             (string-append state-directory "/" name "/repository")))
-       (parameterize ((%current-git-repository
-                       (repository-open repository-directory)))
-         (cons name
-               `((project . ,(call-with-temporary-checkout repository-directory
-                               (lambda (temporary-checkout)
-                                 (call-with-current-directory temporary-checkout
-                                   load-config))))
-                 (repository-directory . ,repository-directory)
-                 (website-directory . ,(string-append state-directory "/" name "/website"))
-                 (xapian-directory . ,(string-append state-directory "/" name "/xapian"))
-                 ,@parameters)))))))
+       (cons name
+             `((project . ,(load-config-from-repository repository-directory))
+               (repository-directory . ,repository-directory)
+               (website-directory . ,(string-append state-directory "/" name "/website"))
+               (xapian-directory . ,(string-append state-directory "/" name "/xapian"))
+               ,@parameters))))))
 
 (define tissue-web
   (match-lambda*