summaryrefslogtreecommitdiff
path: root/scripts
diff options
context:
space:
mode:
authorLibravatar kim <89579420+NyaaaWhatsUpDoc@users.noreply.github.com>2023-05-28 13:08:35 +0100
committerLibravatar GitHub <noreply@github.com>2023-05-28 14:08:35 +0200
commit5faeb4de2032e112ab49751eeeb906ac43826f3d (patch)
treeea94b86f27384954ff93aec864b13b83c7f46db0 /scripts
parent[docs] Update + simplify roadmap, revise beta estimate (#1826) (diff)
downloadgotosocial-5faeb4de2032e112ab49751eeeb906ac43826f3d.tar.xz
[chore] tidy up media manager, add calling func to errors, build-script improvements (#1835)
* media manager tidy-up: de-interface and remove unused PostDataFunc Signed-off-by: kim <grufwub@gmail.com> * remove last traces of media.Manager being an interface Signed-off-by: kim <grufwub@gmail.com> * update error to provide caller, allow tuneable via build tags Signed-off-by: kim <grufwub@gmail.com> * remove kim-specific build script changes Signed-off-by: kim <grufwub@gmail.com> * fix merge conflicts Signed-off-by: kim <grufwub@gmail.com> * update build-script to support externally setting build variables Signed-off-by: kim <grufwub@gmail.com> --------- Signed-off-by: kim <grufwub@gmail.com>
Diffstat (limited to 'scripts')
-rwxr-xr-xscripts/build.sh28
1 files changed, 22 insertions, 6 deletions
diff --git a/scripts/build.sh b/scripts/build.sh
index dde199549..490f68038 100755
--- a/scripts/build.sh
+++ b/scripts/build.sh
@@ -1,11 +1,27 @@
#!/bin/sh
-set -eu
+set -e
-# DEBUG returns whether DEBUG build is enabled.
-DEBUG() { [ ! -z "${DEBUG-}" ]; }
+# Log and execute provided args.
+log_exec() { echo "$ ${*}"; "$@"; }
-CGO_ENABLED=0 go build -trimpath \
- -tags "netgo osusergo static_build kvformat $(DEBUG && echo 'debugenv')" \
- -ldflags="-s -w -extldflags '-static' -X 'main.Version=${VERSION:-$(git describe --tags --abbrev=0)}'" \
+# Grab environment variables and set defaults + requirements.
+GO_BUILDTAGS="${GO_BUILDTAGS-} netgo osusergo static_build kvformat"
+GO_LDFLAGS="${GO_LDFLAGS-} -s -w -extldflags '-static' -X 'main.Version=${VERSION:-$(git describe --tags --abbrev=0)}'"
+GO_GCFLAGS=${GO_GCFLAGS-}
+
+# Maintain old $DEBUG compat.
+[ ! -z "$DEBUG" ] && \
+ GO_BUILDTAGS="${GO_BUILDTAGS} debugenv"
+
+# Available Go build tags, with explanation, followed by benefits of enabling it:
+# - kvformat: enables prettier output of log fields (slightly better performance)
+# - notracing: disables compiling-in otel tracing support (reduced binary size, better performance)
+# - noerrcaller: disables caller function prefix in errors (slightly better performance, at cost of err readability)
+# - debug: enables /debug/pprof endpoint (adds debug, at performance cost)
+# - debugenv: enables /debug/pprof endpoint if DEBUG=1 env during runtime (adds debug, at performance cost)
+log_exec env CGO_ENABLED=0 go build -trimpath -v \
+ -tags "${GO_BUILDTAGS}" \
+ -ldflags="${GO_LDFLAGS}" \
+ -gcflags="${GO_GCFLAGS}" \
./cmd/gotosocial