2016-02-01 19:25:55 +00:00
|
|
|
#!/usr/bin/env bash
|
2013-12-19 19:22:08 +00:00
|
|
|
#
|
2015-10-22 18:16:01 +00:00
|
|
|
# This script builds the application from source for multiple platforms.
|
2013-12-19 19:22:08 +00:00
|
|
|
set -e
|
|
|
|
|
2016-02-13 00:50:37 +00:00
|
|
|
export GO15VENDOREXPERIMENT=1
|
2016-02-18 07:16:47 +00:00
|
|
|
export CGO_ENABLED=0
|
2016-02-13 00:50:37 +00:00
|
|
|
|
2013-12-19 19:22:08 +00:00
|
|
|
# Get the parent directory of where this script is.
|
|
|
|
SOURCE="${BASH_SOURCE[0]}"
|
|
|
|
while [ -h "$SOURCE" ] ; do SOURCE="$(readlink "$SOURCE")"; done
|
|
|
|
DIR="$( cd -P "$( dirname "$SOURCE" )/.." && pwd )"
|
|
|
|
|
|
|
|
# Change into that directory
|
2015-09-11 16:19:22 +00:00
|
|
|
cd "$DIR"
|
2013-12-19 19:22:08 +00:00
|
|
|
|
|
|
|
# Get the git commit
|
|
|
|
GIT_COMMIT=$(git rev-parse HEAD)
|
|
|
|
GIT_DIRTY=$(test -n "`git status --porcelain`" && echo "+CHANGES" || true)
|
2014-11-18 22:06:46 +00:00
|
|
|
GIT_DESCRIBE=$(git describe --tags)
|
2013-12-19 19:22:08 +00:00
|
|
|
|
2015-10-22 18:16:01 +00:00
|
|
|
# Determine the arch/os combos we're building for
|
|
|
|
XC_ARCH=${XC_ARCH:-"386 amd64 arm"}
|
2016-01-06 02:20:46 +00:00
|
|
|
XC_OS=${XC_OS:-"solaris darwin freebsd linux windows"}
|
2013-12-19 19:22:08 +00:00
|
|
|
|
2015-10-22 18:16:01 +00:00
|
|
|
# Delete the old dir
|
|
|
|
echo "==> Removing old directory..."
|
|
|
|
rm -f bin/*
|
|
|
|
rm -rf pkg/*
|
|
|
|
mkdir -p bin/
|
2014-05-30 20:05:06 +00:00
|
|
|
|
2015-10-22 19:00:35 +00:00
|
|
|
# If it's dev mode, only build for ourself
|
2015-10-22 18:16:01 +00:00
|
|
|
if [ "${CONSUL_DEV}x" != "x" ]; then
|
|
|
|
XC_OS=$(go env GOOS)
|
|
|
|
XC_ARCH=$(go env GOARCH)
|
2014-06-11 17:07:38 +00:00
|
|
|
fi
|
|
|
|
|
2013-12-19 19:22:08 +00:00
|
|
|
# Build!
|
2015-10-22 18:16:01 +00:00
|
|
|
echo "==> Building..."
|
2016-01-21 10:55:12 +00:00
|
|
|
$GOPATH/bin/gox \
|
2015-10-22 18:16:01 +00:00
|
|
|
-os="${XC_OS}" \
|
|
|
|
-arch="${XC_ARCH}" \
|
|
|
|
-ldflags "-X main.GitCommit ${GIT_COMMIT}${GIT_DIRTY} -X main.GitDescribe ${GIT_DESCRIBE}" \
|
|
|
|
-output "pkg/{{.OS}}_{{.Arch}}/consul" \
|
|
|
|
.
|
|
|
|
|
|
|
|
# Move all the compiled things to the $GOPATH/bin
|
|
|
|
GOPATH=${GOPATH:-$(go env GOPATH)}
|
|
|
|
case $(uname) in
|
|
|
|
CYGWIN*)
|
|
|
|
GOPATH="$(cygpath $GOPATH)"
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
OLDIFS=$IFS
|
|
|
|
IFS=: MAIN_GOPATH=($GOPATH)
|
|
|
|
IFS=$OLDIFS
|
|
|
|
|
|
|
|
# Copy our OS/Arch to the bin/ directory
|
|
|
|
DEV_PLATFORM="./pkg/$(go env GOOS)_$(go env GOARCH)"
|
|
|
|
for F in $(find ${DEV_PLATFORM} -mindepth 1 -maxdepth 1 -type f); do
|
|
|
|
cp ${F} bin/
|
|
|
|
cp ${F} ${MAIN_GOPATH}/bin/
|
|
|
|
done
|
|
|
|
|
|
|
|
if [ "${CONSUL_DEV}x" = "x" ]; then
|
|
|
|
# Zip and copy to the dist dir
|
|
|
|
echo "==> Packaging..."
|
|
|
|
for PLATFORM in $(find ./pkg -mindepth 1 -maxdepth 1 -type d); do
|
|
|
|
OSARCH=$(basename ${PLATFORM})
|
|
|
|
echo "--> ${OSARCH}"
|
|
|
|
|
|
|
|
pushd $PLATFORM >/dev/null 2>&1
|
|
|
|
zip ../${OSARCH}.zip ./*
|
|
|
|
popd >/dev/null 2>&1
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Done!
|
|
|
|
echo
|
|
|
|
echo "==> Results:"
|
|
|
|
ls -hl bin/
|