From 72b20bf6e0c96da6d83daa042c242f2fb38c1650 Mon Sep 17 00:00:00 2001 From: Rohan Kumar Date: Wed, 2 Jun 2021 18:59:54 -0700 Subject: [PATCH] Switch from Zopfli to Efficient Compression Tool ECT is more efficient than Zopfli given the same amount of time. It uses Zopfli under the hood. - Switch from binaries.tar.br to binaries.tar.gz - Bring in the statically-linked ect/brotli binaries from binaries.tar.gz --- .build.yml | 5 ++--- Makefile | 4 ++-- README.md | 17 +++++++++++++---- 3 files changed, 17 insertions(+), 9 deletions(-) diff --git a/.build.yml b/.build.yml index de349fe..118d9bd 100644 --- a/.build.yml +++ b/.build.yml @@ -2,7 +2,6 @@ image: alpine/edge packages: - rsync - - brotli # for max compression w/ brotli_static, decompressing binaries - git # for Hugo's gitInfo - make - jq @@ -17,9 +16,9 @@ triggers: tasks: - deps: | echo "StrictHostKeyChecking=no" >> ~/.ssh/config - rsync deploy@seirdy.one:/home/deploy/binaries.tar.br . + rsync -v deploy@seirdy.one:/home/deploy/binaries.tar.gz . mkdir -p ~/bin - brotli -dc binaries.tar.br | tar x -oC ~/bin + tar xzf binaries.tar.gz -oC ~/bin cd seirdy.one - build_deploy: | cd seirdy.one diff --git a/Makefile b/Makefile index 826983c..7e542f7 100644 --- a/Makefile +++ b/Makefile @@ -14,7 +14,7 @@ GEMINI_RSYNC_DEST = $(USER):$(GEMINI_ROOT) OUTPUT_DIR = public RSYNCFLAGS += -rlvz --zc=zstd # compression has dimishing returns after this point -ZOPFLI_ITERATIONS=70 +ECT_LEVEL=1009 .PHONY: hugo hugo: clean @@ -67,7 +67,7 @@ build: hugo ifndef NO_STATIC find $(OUTPUT_DIR) -type f -name '*.html' -o -name '*.css' -o -name '*.xml' -o -name '*.txt' -o -name '*.asc' -o -name '*.webmanifest' -o -name "*.svg" \ | grep -v gemini \ - | xargs zopfli --i$(ZOPFLI_ITERATIONS) --gzip + | xargs ect -$(ECT_LEVEL) -gzip --ultra=3 --stagnations=200 find $(OUTPUT_DIR) -type f -name '*.html' -o -name '*.css' -o -name '*.xml' -o -name '*.txt' -o -name '*.asc' -o -name '*.webmanifest' -o -name "*.svg" \ | grep -v gemini \ | xargs brotli -q 11 diff --git a/README.md b/README.md index 8d16afe..775cc70 100644 --- a/README.md +++ b/README.md @@ -1,9 +1,14 @@ seirdy.one ========== -[![sourcehut](https://img.shields.io/badge/repository-sourcehut-lightgrey.svg?logo=)](https://sr.ht/~seirdy/seirdy.one) [![GitLab mirror](https://img.shields.io/badge/mirror-GitLab-orange.svg?logo=gitlab)](https://gitlab.com/Seirdy/seirdy.one) [![GitHub mirror](https://img.shields.io/badge/mirror-GitHub-black.svg?logo=github)](https://github.com/Seirdy/seirdy.one) +[![sourcehut](https://img.shields.io/badge/repository-sourcehut-lightgrey.svg?logo=)](https://sr.ht/~seirdy/seirdy.one) +[![GitLab +mirror](https://img.shields.io/badge/mirror-GitLab-orange.svg?logo=gitlab)](https://gitlab.com/Seirdy/seirdy.one) +[![GitHub +mirror](https://img.shields.io/badge/mirror-GitHub-black.svg?logo=github)](https://github.com/Seirdy/seirdy.one) -[![builds.sr.ht status](https://builds.sr.ht/~seirdy/seirdy.one.svg)](https://builds.sr.ht/~seirdy/seirdy.one) +[![builds.sr.ht +status](https://builds.sr.ht/~seirdy/seirdy.one.svg)](https://builds.sr.ht/~seirdy/seirdy.one) Code for my personal website, [seirdy.one](https://seirdy.one). Built with Hugo. @@ -15,7 +20,10 @@ To build: - Hugo 0.75 or later - Make - Git (Hugo uses Git info for features like date last updated) -- Zopfli (optional; set `NO_STATIC=1` to disable) +- [Efficient Compression Tool](https://github.com/fhanau/Efficient-Compression-Tool) + with patches from + [MegaByte](https://github.com/MegaByte/Efficient-Compression-Tool/tree/iterations) + (optional; set `NO_STATIC=1` to disable). It's like zopfli but more efficient and faster. - Brotli (optional; set `NO_STATIC=1` to disable) - POSIX utils: grep, find, etc. @@ -37,6 +45,7 @@ To test in CI, after deploying to the staging environment: - webhint CLI - [lighthouse-ci](https://github.com/GoogleChrome/lighthouse-ci) -CI also runs [static-webmention](https://github.com/nekr0z/static-webmentions) to gather a list of WebMentions for me to send and review manually. +CI also runs [static-webmention](https://github.com/nekr0z/static-webmentions) to +gather a list of WebMentions for me to send and review manually. See the `Makefile` for details.