summaryrefslogtreecommitdiff
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*