Merge pull request #1650 from jonboulle/build_release

scripts: clean build-release script a bit
This commit is contained in:
Jonathan Boulle 2014-11-07 12:51:30 -08:00
commit 4f85a68c25

View File

@ -1,35 +1,43 @@
#!/bin/sh -e #!/bin/sh -e
VER=$1 VER=$1
PROJ="etcd"
function build { if [ -z "$1" ]; then
proj=${1} echo "Usage: ${0} VERSION" >> /dev/stderr
ver=${2} exit 255
fi
set -u
function setup_env {
local proj=${1}
local ver=${2}
if [ ! -d ${proj} ]; then if [ ! -d ${proj} ]; then
git clone https://github.com/coreos/${proj} git clone https://github.com/coreos/${proj}
fi fi
cd ${proj} pushd ${proj} >/dev/null
git checkout master git checkout master
git fetch --all git fetch --all
git reset --hard origin/master git reset --hard origin/master
git checkout $ver git checkout $ver
./build popd >/dev/null
cd -
} }
function package {
target=${1}
ccdir="${proj}/bin/${GOOS}_${GOARCH}" function package {
local target=${1}
local srcdir="${2}/bin"
local ccdir="${srcdir}/${GOOS}_${GOARCH}"
if [ -d ${ccdir} ]; then if [ -d ${ccdir} ]; then
cp ${ccdir}/etcdctl ${target} srcdir=${ccdir}
cp ${ccdir}/etcd ${target}
else
cp ${proj}/bin/etcd ${target}
cp ${proj}/bin/etcdctl ${target}
fi fi
for bin in etcd etcdctl; do
cp ${srcdir}/${bin} ${target}
done
cp etcd/README.md ${target}/README.md cp etcd/README.md ${target}/README.md
cp etcd/etcdctl/README.md ${target}/README-etcdctl.md cp etcd/etcdctl/README.md ${target}/README-etcdctl.md
@ -37,23 +45,31 @@ function package {
cp -R etcd/Documentation/0.5 ${target}/Documentation cp -R etcd/Documentation/0.5 ${target}/Documentation
} }
mkdir release function main {
cd release mkdir release
cd release
setup_env ${PROJ} ${VER}
for i in darwin windows linux; do for os in darwin windows linux; do
export GOOS=${i} export GOOS=${os}
export GOARCH="amd64" export GOARCH="amd64"
build etcd ${VER} pushd etcd >/dev/null
./build
popd >/dev/null
TARGET="etcd-${VER}-${GOOS}-${GOARCH}" TARGET="etcd-${VER}-${GOOS}-${GOARCH}"
mkdir ${TARGET} mkdir ${TARGET}
package ${TARGET} ${PROJ}
package ${TARGET} if [ ${GOOS} == "linux" ]; then
tar cfz ${TARGET}.tar.gz ${TARGET}
echo "Wrote release/${TARGET}.tar.gz"
else
zip -qr ${TARGET}.zip ${TARGET}
echo "Wrote release/${TARGET}.zip"
fi
done
}
if [ ${GOOS} == "linux" ]; then main
tar cvvfz ${TARGET}.tar.gz ${TARGET}
else
zip -r ${TARGET}.zip ${TARGET}
fi
done