mirror of
https://github.com/etcd-io/etcd.git
synced 2024-09-27 06:25:44 +00:00
Merge pull request #1650 from jonboulle/build_release
scripts: clean build-release script a bit
This commit is contained in:
commit
4f85a68c25
@ -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
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user