2018-11-02 03:47:21 +08:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
set -x
|
|
|
|
set -e
|
|
|
|
|
2019-09-26 10:50:21 +08:00
|
|
|
system_profiler SPHardwareDataType
|
|
|
|
|
2020-03-23 03:14:46 +08:00
|
|
|
brew install s3cmd gcc@9
|
2018-11-02 03:47:21 +08:00
|
|
|
|
|
|
|
ZIGDIR="$(pwd)"
|
2020-07-24 14:26:34 +08:00
|
|
|
LLVMVER="10.0.1"
|
2019-12-10 14:32:45 +08:00
|
|
|
ARCH="x86_64"
|
2020-03-23 03:35:54 +08:00
|
|
|
CACHE_BASENAME="llvm+clang+lld-$LLVMVER-$ARCH-macosx-gcc9-release"
|
2018-11-02 03:47:21 +08:00
|
|
|
PREFIX="$HOME/$CACHE_BASENAME"
|
|
|
|
JOBS="-j2"
|
|
|
|
|
|
|
|
# I tried using the system default compiler (clang), but it couldn't statically link libc++.
|
2020-03-23 03:14:46 +08:00
|
|
|
# So we use gcc-9 from homebrew.
|
|
|
|
export CC=gcc-9
|
|
|
|
export CXX=g++-9
|
2018-11-02 03:47:21 +08:00
|
|
|
|
|
|
|
rm -rf $PREFIX
|
|
|
|
|
|
|
|
cd $HOME
|
2020-07-24 14:26:34 +08:00
|
|
|
wget -nv "https://ziglang.org/builds/$CACHE_BASENAME.tar.xz"
|
|
|
|
tar xf "$CACHE_BASENAME.tar.xz"
|
2018-11-02 03:47:21 +08:00
|
|
|
|
|
|
|
cd $ZIGDIR
|
2019-10-25 16:26:22 +08:00
|
|
|
|
2019-10-25 15:25:10 +08:00
|
|
|
# Make the `zig version` number consistent.
|
|
|
|
# This will affect the cmake command below.
|
|
|
|
git config core.abbrev 9
|
|
|
|
|
2018-11-02 03:47:21 +08:00
|
|
|
mkdir build
|
|
|
|
cd build
|
|
|
|
cmake .. -DCMAKE_BUILD_TYPE=Release -DCMAKE_PREFIX_PATH=$PREFIX -DCMAKE_INSTALL_PREFIX=$(pwd)/release -DZIG_STATIC=ON
|
|
|
|
make $JOBS install
|
2019-09-22 11:55:56 +08:00
|
|
|
release/bin/zig build test
|
2018-11-02 03:47:21 +08:00
|
|
|
|
|
|
|
if [ "${BUILD_REASON}" != "PullRequest" ]; then
|
|
|
|
mv ../LICENSE release/
|
|
|
|
mv ../zig-cache/langref.html release/
|
|
|
|
mv release/bin/zig release/
|
|
|
|
rmdir release/bin
|
|
|
|
|
|
|
|
VERSION=$(release/zig version)
|
2019-12-10 14:32:45 +08:00
|
|
|
DIRNAME="zig-macos-$ARCH-$VERSION"
|
2018-11-02 03:47:21 +08:00
|
|
|
TARBALL="$DIRNAME.tar.xz"
|
|
|
|
mv release "$DIRNAME"
|
|
|
|
tar cfJ "$TARBALL" "$DIRNAME"
|
|
|
|
|
|
|
|
mv "$DOWNLOADSECUREFILE_SECUREFILEPATH" "$HOME/.s3cfg"
|
2019-06-05 08:29:38 +08:00
|
|
|
s3cmd put -P --add-header="cache-control: public, max-age=31536000, immutable" "$TARBALL" s3://ziglang.org/builds/
|
2018-11-05 05:24:46 +08:00
|
|
|
|
2018-11-05 12:26:23 +08:00
|
|
|
SHASUM=$(shasum -a 256 $TARBALL | cut '-d ' -f1)
|
2018-11-05 05:24:46 +08:00
|
|
|
BYTESIZE=$(wc -c < $TARBALL)
|
2019-03-21 11:19:18 +08:00
|
|
|
|
|
|
|
JSONFILE="macos-$GITBRANCH.json"
|
|
|
|
touch $JSONFILE
|
|
|
|
echo "{\"tarball\": \"$TARBALL\"," >>$JSONFILE
|
|
|
|
echo "\"shasum\": \"$SHASUM\"," >>$JSONFILE
|
|
|
|
echo "\"size\": \"$BYTESIZE\"}" >>$JSONFILE
|
|
|
|
|
2019-04-04 04:04:24 +08:00
|
|
|
s3cmd put -P --add-header="Cache-Control: max-age=0, must-revalidate" "$JSONFILE" "s3://ziglang.org/builds/$JSONFILE"
|
2019-12-10 14:32:45 +08:00
|
|
|
s3cmd put -P "$JSONFILE" "s3://ziglang.org/builds/$ARCH-macos-$VERSION.json"
|
2019-03-21 11:19:18 +08:00
|
|
|
|
2018-11-30 00:05:30 +08:00
|
|
|
# `set -x` causes these variables to be mangled.
|
|
|
|
# See https://developercommunity.visualstudio.com/content/problem/375679/pipeline-variable-incorrectly-inserts-single-quote.html
|
|
|
|
set +x
|
2018-11-05 05:24:46 +08:00
|
|
|
echo "##vso[task.setvariable variable=tarball;isOutput=true]$TARBALL"
|
|
|
|
echo "##vso[task.setvariable variable=shasum;isOutput=true]$SHASUM"
|
|
|
|
echo "##vso[task.setvariable variable=bytesize;isOutput=true]$BYTESIZE"
|
2018-11-02 03:47:21 +08:00
|
|
|
fi
|