refactor: reformat zig wrapper
This commit is contained in:
parent
16ec05c75b
commit
5bc0ca5f74
1 changed files with 22 additions and 18 deletions
40
zig
40
zig
|
@ -5,65 +5,69 @@ ARCH=$(uname -m)
|
||||||
|
|
||||||
BASEDIR="$(cd "$(dirname "$0")" && pwd)"
|
BASEDIR="$(cd "$(dirname "$0")" && pwd)"
|
||||||
ZIGDIR=$BASEDIR/.cache/zig
|
ZIGDIR=$BASEDIR/.cache/zig
|
||||||
VERSION=$(< build.zig.version)
|
VERSION=$(<build.zig.version)
|
||||||
|
|
||||||
OS=$(uname)
|
OS=$(uname)
|
||||||
|
|
||||||
if [ "$OS" == "Linux" ] ; then
|
if [ "$OS" == "Linux" ]; then
|
||||||
OS=linux
|
OS=linux
|
||||||
elif [ "$OS" == "Darwin" ] ; then
|
elif [ "$OS" == "Darwin" ]; then
|
||||||
OS=macos
|
OS=macos
|
||||||
elif [ "$OS" == "FreeBSD" ] ; then
|
elif [ "$OS" == "FreeBSD" ]; then
|
||||||
OS=freebsd
|
OS=freebsd
|
||||||
if [ "$ARCH" == "amd64" ] ; then
|
if [ "$ARCH" == "amd64" ]; then
|
||||||
ARCH=x86_64
|
ARCH=x86_64
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$ARCH" == "arm64" ] ; then
|
if [ "$ARCH" == "arm64" ]; then
|
||||||
ARCH=aarch64
|
ARCH=aarch64
|
||||||
fi
|
fi
|
||||||
|
|
||||||
ZIGVER="zig-$OS-$ARCH-$VERSION"
|
ZIGVER="zig-$OS-$ARCH-$VERSION"
|
||||||
ZIG=$ZIGDIR/$ZIGVER/zig
|
ZIG=$ZIGDIR/$ZIGVER/zig
|
||||||
|
|
||||||
if [ "$1" == "update" ] ; then
|
if [ "$1" == "update" ]; then
|
||||||
curl -L --silent https://ziglang.org/download/index.json | jq -r '.master | .version' > build.zig.version
|
curl -L --silent https://ziglang.org/download/index.json | jq -r '.master | .version' >build.zig.version
|
||||||
NEWVERSION=$(< build.zig.version)
|
NEWVERSION=$(<build.zig.version)
|
||||||
|
|
||||||
if [ "$VERSION" != "$NEWVERSION" ] ; then
|
if [ "$VERSION" != "$NEWVERSION" ]; then
|
||||||
echo zig version updated from $VERSION to $NEWVERSION
|
echo "zig version updated from $VERSION to $NEWVERSION"
|
||||||
echo rebuilding to update cdb...
|
echo "rebuilding to update cdb..."
|
||||||
$0 cdb
|
$0 cdb
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
echo zig version $VERSION is up-to-date
|
echo "zig version $VERSION is up-to-date"
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
get_zig() {
|
get_zig() {
|
||||||
(
|
(
|
||||||
mkdir -p "$ZIGDIR"
|
mkdir -p "$ZIGDIR"
|
||||||
cd "$ZIGDIR"
|
cd "$ZIGDIR"
|
||||||
TARBALL="https://ziglang.org/builds/$ZIGVER.tar.xz"
|
TARBALL="https://ziglang.org/builds/$ZIGVER.tar.xz"
|
||||||
if [ "$OS" == "freebsd" ] ; then
|
if [ "$OS" == "freebsd" ]; then
|
||||||
TARBALL="https://ziglang.org/download/$VERSION/$ZIGVER.tar.xz"
|
TARBALL="https://ziglang.org/download/$VERSION/$ZIGVER.tar.xz"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ ! -d "$ZIGVER" ] ; then
|
if [ ! -d "$ZIGVER" ]; then
|
||||||
curl "$TARBALL" | tar -xJ
|
curl "$TARBALL" | tar -xJ
|
||||||
fi
|
fi
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
get_zig
|
get_zig
|
||||||
|
|
||||||
if [ "$1" == "cdb" ] ; then
|
if [ "$1" == "cdb" ]; then
|
||||||
rm -rf zig-cache
|
rm -rf zig-cache
|
||||||
rm -rf .cache/cdb
|
rm -rf .cache/cdb
|
||||||
|
|
||||||
$ZIG build
|
$ZIG build
|
||||||
|
|
||||||
(echo \[ ; cat .cache/cdb/* ; echo {}\]) | perl -0777 -pe 's/,\n\{\}//igs' | jq . | grep -v 'no-default-config' > compile_commands.json
|
(
|
||||||
|
echo \[
|
||||||
|
cat .cache/cdb/*
|
||||||
|
echo {}\]
|
||||||
|
) | perl -0777 -pe 's/,\n\{\}//igs' | jq . | grep -v 'no-default-config' >compile_commands.json
|
||||||
exit 0
|
exit 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue