aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorPetter Rasmussen2015-07-18 16:48:40 +0200
committerPetter Rasmussen2015-07-18 16:48:40 +0200
commit2cf9d76d9b5bfae020971b2a42be4ba0a8df0eb5 (patch)
treec839a99edb79f5ca242e50c5c53f457a9c31c7aa
parent72cfaf15c13bab07338df8e90af6cdb3dccc005e (diff)
downloadgdrive-2cf9d76d9b5bfae020971b2a42be4ba0a8df0eb5.tar.bz2
Update release scripts
- Move scripts into _release folder - Include crosscrompile script - Minor adjustments
-rw-r--r--.gitignore2
-rwxr-xr-x_release/build-all.sh (renamed from build-all.sh)19
-rw-r--r--_release/crosscompile.bash73
-rwxr-xr-x_release/upload.sh (renamed from upload.sh)4
4 files changed, 84 insertions, 14 deletions
diff --git a/.gitignore b/.gitignore
index 769fd25..6b18ed8 100644
--- a/.gitignore
+++ b/.gitignore
@@ -1,5 +1,5 @@
# Ignore bin folder and drive binary
-bin/
+_release/bin
drive
# vim files
diff --git a/build-all.sh b/_release/build-all.sh
index bffb11f..414ae18 100755
--- a/build-all.sh
+++ b/_release/build-all.sh
@@ -1,25 +1,22 @@
#!/bin/bash
-if [ -z "$1" ]; then
- echo "Usage: $0 <app>"
- exit 1
-fi
-
# Load crosscompile environment
-source /Users/pii/scripts/golang-crosscompile/crosscompile.bash
+source _release/crosscompile.bash
+APP_NAME="drive"
PLATFORMS="darwin/386 darwin/amd64 freebsd/386 freebsd/amd64 linux/386 linux/amd64 linux/arm linux/rpi windows/386 windows/amd64"
-APP_NAME=$1
+BIN_PATH="_release/bin"
-# Remove old binaries
-rm bin/*
+# Initialize bin dir
+mkdir -p $BIN_PATH
+rm $BIN_PATH/*
# Build binary for each platform in parallel
for PLATFORM in $PLATFORMS; do
GOOS=${PLATFORM%/*}
GOARCH=${PLATFORM#*/}
- BIN_NAME="${APP_NAME}-$GOOS-$GOARCH"
+ BIN_NAME="${APP_NAME}-${GOOS/darwin/osx}-${GOARCH/amd64/x64}"
if [ $GOOS == "windows" ]; then
BIN_NAME="${BIN_NAME}.exe"
@@ -33,7 +30,7 @@ for PLATFORM in $PLATFORMS; do
unset GOARM
fi
- BUILD_CMD="go-${GOOS}-${GOARCH} build -ldflags "-w" -o bin/${BIN_NAME} $APP_NAME.go"
+ BUILD_CMD="go-${GOOS}-${GOARCH} build -ldflags '-w' -o ${BIN_PATH}/${BIN_NAME} $APP_NAME.go"
echo "Building $BIN_NAME"
$BUILD_CMD &
diff --git a/_release/crosscompile.bash b/_release/crosscompile.bash
new file mode 100644
index 0000000..ef38522
--- /dev/null
+++ b/_release/crosscompile.bash
@@ -0,0 +1,73 @@
+#!/bin/bash
+# Copyright 2012 The Go Authors. All rights reserved.
+# Use of this source code is governed by a BSD-style
+# license that can be found in the LICENSE file.
+
+# support functions for go cross compilation
+
+type setopt >/dev/null 2>&1 && setopt shwordsplit
+PLATFORMS="darwin/386 darwin/amd64 freebsd/386 freebsd/amd64 freebsd/arm linux/386 linux/amd64 linux/arm windows/386 windows/amd64 openbsd/386 openbsd/amd64"
+
+function go-alias {
+ GOOS=${1%/*}
+ GOARCH=${1#*/}
+ eval "function go-${GOOS}-${GOARCH} { ( GOOS=${GOOS} GOARCH=${GOARCH} go \"\$@\" ) }"
+}
+
+function go-crosscompile-build {
+ GOOS=${1%/*}
+ GOARCH=${1#*/}
+ cd $(go env GOROOT)/src ; GOOS=${GOOS} GOARCH=${GOARCH} ./make.bash --no-clean 2>&1
+}
+
+function go-crosscompile-build-all {
+ FAILURES=""
+ for PLATFORM in $PLATFORMS; do
+ CMD="go-crosscompile-build ${PLATFORM}"
+ echo "$CMD"
+ $CMD || FAILURES="$FAILURES $PLATFORM"
+ done
+ if [ "$FAILURES" != "" ]; then
+ echo "*** go-crosscompile-build-all FAILED on $FAILURES ***"
+ return 1
+ fi
+}
+
+function go-all {
+ FAILURES=""
+ for PLATFORM in $PLATFORMS; do
+ GOOS=${PLATFORM%/*}
+ GOARCH=${PLATFORM#*/}
+ CMD="go-${GOOS}-${GOARCH} $@"
+ echo "$CMD"
+ $CMD || FAILURES="$FAILURES $PLATFORM"
+ done
+ if [ "$FAILURES" != "" ]; then
+ echo "*** go-all FAILED on $FAILURES ***"
+ return 1
+ fi
+}
+
+function go-build-all {
+ FAILURES=""
+ for PLATFORM in $PLATFORMS; do
+ GOOS=${PLATFORM%/*}
+ GOARCH=${PLATFORM#*/}
+ SRCFILENAME=`echo $@ | sed 's/\.go//'`
+ CURDIRNAME=${PWD##*/}
+ OUTPUT=${SRCFILENAME:-$CURDIRNAME} # if no src file given, use current dir name
+ CMD="go-${GOOS}-${GOARCH} build -o $OUTPUT-${GOOS}-${GOARCH} $@"
+ echo "$CMD"
+ $CMD || FAILURES="$FAILURES $PLATFORM"
+ done
+ if [ "$FAILURES" != "" ]; then
+ echo "*** go-build-all FAILED on $FAILURES ***"
+ return 1
+ fi
+}
+
+for PLATFORM in $PLATFORMS; do
+ go-alias $PLATFORM
+done
+
+unset -f go-alias
diff --git a/upload.sh b/_release/upload.sh
index 365ca36..ec66841 100755
--- a/upload.sh
+++ b/_release/upload.sh
@@ -5,12 +5,12 @@ HEADER='### Downloads'
ROW_TEMPLATE='- [{{name}}]({{url}})'
# Grab application version
-VERSION=$(bin/drive-darwin-amd64 --version | awk '{print $2}' | sed -e 's/v//')
+VERSION=$(_release/bin/drive-osx-x64 --version | awk '{print $2}' | sed -e 's/v//')
# Print markdown header
echo "$HEADER"
-for bin_path in bin/drive-*; do
+for bin_path in _release/bin/drive-*; do
# Upload file
URL=$(drive upload --file $bin_path --share | awk '/https/ {print $9}')