2017-11-01 16:08:46 +01:00
|
|
|
#!/bin/bash -eu
|
2017-09-06 21:41:22 +02:00
|
|
|
#
|
|
|
|
# Compile gocryptfs and bake the git version string of itself and the go-fuse
|
|
|
|
# library into the binary.
|
|
|
|
#
|
|
|
|
# If you want to fake a build date to reproduce a specific build,
|
|
|
|
# you can use:
|
|
|
|
# BUILDDATE=2017-02-03 ./build.bash
|
2015-10-05 20:32:10 +02:00
|
|
|
|
2015-12-20 17:44:11 +01:00
|
|
|
cd "$(dirname "$0")"
|
2017-06-20 18:59:48 +02:00
|
|
|
MYDIR=$PWD
|
2015-12-20 17:44:11 +01:00
|
|
|
|
2017-11-01 16:08:46 +01:00
|
|
|
# Make sure we have the go binary
|
|
|
|
go version > /dev/null
|
|
|
|
|
2017-02-19 20:14:46 +01:00
|
|
|
# GOPATH may contain multiple paths separated by ":"
|
|
|
|
GOPATH1=$(go env GOPATH | cut -f1 -d:)
|
2016-06-29 22:27:32 +02:00
|
|
|
|
2017-11-01 18:58:10 +01:00
|
|
|
if [[ $PWD != *"/src/github.com/rfjakob/gocryptfs" ]] ; then
|
|
|
|
echo "Warning: Building outside of GOPATH will most likely fail."
|
|
|
|
echo " Please rename $PWD to $GOPATH1/src/github.com/rfjakob/gocryptfs ."
|
|
|
|
sleep 5
|
|
|
|
echo
|
|
|
|
fi
|
|
|
|
|
2017-11-01 16:08:46 +01:00
|
|
|
# gocryptfs version according to git or a VERSION file
|
|
|
|
if [[ -d .git ]] ; then
|
|
|
|
GITVERSION=$(git describe --tags --dirty)
|
|
|
|
elif [[ -f VERSION ]] ; then
|
|
|
|
GITVERSION=$(cat VERSION)
|
|
|
|
else
|
|
|
|
echo "Warning: could not determine gocryptfs version"
|
|
|
|
GITVERSION="[unknown]"
|
|
|
|
fi
|
|
|
|
|
|
|
|
# go-fuse version, if available
|
|
|
|
if [[ -d vendor/github.com/hanwen/go-fuse ]] ; then
|
|
|
|
GITVERSIONFUSE="[vendored]"
|
|
|
|
else
|
|
|
|
# go-fuse version according to git
|
|
|
|
# Note: git in CentOS 7 does not have "git -C" yet, so we use plain "cd".
|
|
|
|
FAIL=0
|
|
|
|
cd $GOPATH1/src/github.com/hanwen/go-fuse
|
|
|
|
OUT=$(git describe --tags --dirty 2>&1) || FAIL=1
|
|
|
|
if [[ $FAIL -eq 0 ]]; then
|
|
|
|
GITVERSIONFUSE=$OUT
|
|
|
|
else
|
|
|
|
echo "$PWD: git describe: $OUT"
|
|
|
|
echo "Warning: could not determine go-fuse version"
|
|
|
|
GITVERSIONFUSE="[unknown]"
|
|
|
|
fi
|
|
|
|
cd "$MYDIR"
|
2017-06-20 18:59:48 +02:00
|
|
|
fi
|
2015-11-01 13:55:35 +01:00
|
|
|
|
2018-12-16 20:16:12 +01:00
|
|
|
# Build date, something like "2017-09-06". Don't override BUILDDATE
|
|
|
|
# if it is already set. This may be done for reproducible builds.
|
2017-09-06 21:41:22 +02:00
|
|
|
if [[ -z ${BUILDDATE:-} ]] ; then
|
|
|
|
BUILDDATE=$(date +%Y-%m-%d)
|
|
|
|
fi
|
2016-07-03 16:49:42 +02:00
|
|
|
|
2018-12-16 20:16:12 +01:00
|
|
|
# If SOURCE_DATE_EPOCH is set, it overrides BUILDDATE. This is the
|
|
|
|
# standard environment variable for faking the date in reproducible builds.
|
|
|
|
if [[ -n ${SOURCE_DATE_EPOCH:-} ]] ; then
|
|
|
|
BUILDDATE=$(date --utc --date="@${SOURCE_DATE_EPOCH}" +%Y-%m-%d)
|
|
|
|
fi
|
|
|
|
|
2018-12-16 20:39:01 +01:00
|
|
|
# For reproducible builds, we get rid of $HOME references in the binary
|
|
|
|
# using "-trimpath".
|
|
|
|
# Note: we have to set both -gcflags and -asmflags because otherwise
|
|
|
|
# "$HOME/go/src/golang.org/x/sys/unix/asm_linux_amd64.s" stays in the binary.
|
|
|
|
GV=$(go version)
|
|
|
|
if [[ $GV == *"1.7"* ]] || [[ $GV == *"1.8"* ]] || [[ $GV == *"1.9"* ]] ; then
|
|
|
|
TRIM="-trimpath=${GOPATH1}/src"
|
|
|
|
else
|
|
|
|
# Go 1.10 changed the syntax. You now have to prefix "all=" to affect
|
|
|
|
# all compiled packages.
|
|
|
|
TRIM="all=-trimpath=${GOPATH1}/src"
|
|
|
|
fi
|
|
|
|
|
2017-09-06 21:41:22 +02:00
|
|
|
LDFLAGS="-X main.GitVersion=$GITVERSION -X main.GitVersionFuse=$GITVERSIONFUSE -X main.BuildDate=$BUILDDATE"
|
2018-12-16 20:16:12 +01:00
|
|
|
|
2018-12-16 20:39:01 +01:00
|
|
|
go build "-ldflags=$LDFLAGS" "-gcflags=$TRIM" "-asmflags=$TRIM" "$@"
|
2017-02-19 20:27:29 +01:00
|
|
|
|
2018-12-16 20:39:01 +01:00
|
|
|
(cd gocryptfs-xray; go build "-gcflags=$TRIM" "-asmflags=$TRIM" "$@")
|
2015-12-20 17:30:10 +01:00
|
|
|
|
|
|
|
./gocryptfs -version
|
2016-01-09 15:31:34 +01:00
|
|
|
|
2016-10-30 16:13:16 +01:00
|
|
|
mkdir -p $GOPATH1/bin
|
|
|
|
cp -af gocryptfs $GOPATH1/bin
|