gnuboot-patches
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[PATCH v1 01/12] website: Makefile.am: wrap Guix commands instead of tar


From: Denis 'GNUtoo' Carikli
Subject: [PATCH v1 01/12] website: Makefile.am: wrap Guix commands instead of targets.
Date: Mon, 4 Nov 2024 00:18:54 +0100

Signed-off-by: Denis 'GNUtoo' Carikli <GNUtoo@cyberdimension.org>
---
 website/Makefile.am | 110 ++++++++++++++++++++++----------------------
 1 file changed, 56 insertions(+), 54 deletions(-)

diff --git a/website/Makefile.am b/website/Makefile.am
index d186af8..26f43c1 100644
--- a/website/Makefile.am
+++ b/website/Makefile.am
@@ -28,8 +28,8 @@ index.html: index.html.tmpl
        sed -e "s#WEBSITE_PREFIX#$(WEBSITE_PREFIX)#g" "$^" > "$@"
 
 if WANT_GUIX
-history/git-history.jpg: history/git-history.dot
-       guix time-machine \
+DOT_CMD = \
+guix time-machine \
        --commit=$(GUIX_REVISION) \
        -- \
        shell \
@@ -37,12 +37,14 @@ history/git-history.jpg: history/git-history.dot
                --container \
                graphviz \
        -- \
-       dot -T jpg history/git-history.dot > "$@"
+       dot
 else
-history/git-history.jpg: history/git-history.dot
-       dot -T jpg history/git-history.dot > "$@"
+DOT_CMD = dot
 endif
 
+history/git-history.jpg: history/git-history.dot
+       $(DOT_CMD) -T jpg history/git-history.dot > "$@"
+
 # We need force the regeneration of the page because if only the git
 # commit changes, there is no way to know about it. In addition the
 # full website is regenerated each time the build target is run, so
@@ -72,8 +74,8 @@ site.cfg: site.cfg.tmpl
        sed -e "s#WEBSITE_PREFIX#$(WEBSITE_PREFIX)#g" "$^" > "$@"
 
 if WANT_GUIX
-build: site.cfg pages/footer.include
-       guix time-machine \
+BUILD_SH_CMD = \
+guix time-machine \
        --commit=c15a1cd88f80a90437f4b0159f22dfc84b9e6851 \
        -- shell \
                --container \
@@ -89,42 +91,41 @@ build: site.cfg pages/footer.include
                pandoc \
                sed \
                -- \
-               ./build.sh $(BUILD_OPTIONS)
+               ./build.sh
 else
-build: site.cfg pages/footer.include
-               ./build.sh $(BUILD_OPTIONS)
+BUILD_SH_CMD = ./build.sh
 endif
 
-if WANT_GUIX
-check: build website.tar.gz index.html history/git-history.jpg
-       rm -rf site/
-       mkdir -p site/$(WEBSITE_PREFIX)
-       tar xf website.tar.gz -C site/$(WEBSITE_PREFIX)
+build: site.cfg pages/footer.include
+       $(BUILD_SH_CMD) $(BUILD_OPTIONS)
 
-       guix shell \
-               --container \
-               --network \
-               --emulate-fhs \
-               bash \
-               coreutils \
-               findutils \
-               grep \
-               gzip \
-               sed \
-               tar \
-               -- \
-               ./check.sh --website-prefix $(WEBSITE_PREFIX) \
-                       --directory site && \
-               ./check.sh  --website-prefix $(WEBSITE_PREFIX) \
-                       --tarball website.tar.gz
+if WANT_GUIX
+CHECK_SH_CMD = \
+guix shell \
+       --container \
+       --network \
+       --emulate-fhs \
+       bash \
+       coreutils \
+       findutils \
+       grep \
+       gzip \
+       sed \
+       tar \
+       -- \
+       ./check.sh
 else
+CHECK_SH_CMD = ./check.sh
+endif
+
 check: build website.tar.gz index.html history/git-history.jpg
        rm -rf site/
        mkdir -p site/$(WEBSITE_PREFIX)
        tar xf website.tar.gz -C site/$(WEBSITE_PREFIX)
-       ./check.sh --website-prefix $(WEBSITE_PREFIX) --directory site
-       ./check.sh --website-prefix $(WEBSITE_PREFIX) --tarball website.tar.gz
-endif
+       $(CHECK_SH_CMD) --website-prefix $(WEBSITE_PREFIX) \
+               --directory site
+       $(CHECK_SH_CMD) --website-prefix $(WEBSITE_PREFIX) \
+               --tarball website.tar.gz
 
 help:
        @printf "%s\n\t%s\n\t%s\n\t%s\n\t%s\n\t%s\n\t%s\n" \
@@ -137,32 +138,33 @@ help:
                "website.tar.gz # Create a tarball of the website"
 
 if WANT_GUIX
-serve: website.tar.gz
-       guix shell \
-               --container \
-               --network \
-               --emulate-fhs \
-               bash \
-               coreutils \
-               gzip \
-               lighttpd \
-               sed \
-               tar \
-               -- \
-               ./serve.sh --website-prefix $(WEBSITE_PREFIX) \
-                       website.tar.gz $(LIGHTTPD_PORT)
-else
-if WANT_LIGHTTPD
-serve: website.tar.gz
-               ./serve.sh --website-prefix $(WEBSITE_PREFIX) \
-                       website.tar.gz $(LIGHTTPD_PORT)
+SERVE_SH_CMD = \
+guix shell \
+       --container \
+       --network \
+       --emulate-fhs \
+       bash \
+       coreutils \
+       gzip \
+       lighttpd \
+       sed \
+       tar \
+       -- \
+       ./serve.sh
 else
+SERVE_SH_CMD = ./serve.sh
+endif
+
+if ! WANT_LIGHTTPD
 serve:
        @printf "%s %s\n" \
                "The $@ target is disabled." \
                "To enable it, run './configure --enable-lighttpd'."
        @false
-endif
+else
+serve: website.tar.gz
+       $(SERVE_SH_CMD) --website-prefix $(WEBSITE_PREFIX) \
+                       website.tar.gz $(LIGHTTPD_PORT)
 endif
 
 RSYNC_OPTIONS := -av --progress --delete
-- 
2.46.0




reply via email to

[Prev in Thread] Current Thread [Next in Thread]