fix(tools): Ensure dispatch script passes arguments correctly
This commit is contained in:
parent
892493a478
commit
b2f40b6ed8
1 changed files with 15 additions and 15 deletions
|
@ -2,30 +2,30 @@
|
||||||
# This script dispatches invocations transparently to programs instantiated from
|
# This script dispatches invocations transparently to programs instantiated from
|
||||||
# Nix.
|
# Nix.
|
||||||
#
|
#
|
||||||
# To add a new tool, in
|
# To add a new tool, insert it into the case statement below by setting `attr`
|
||||||
|
# to the key in nixpkgs which represents the program you want to run.
|
||||||
set -ueo pipefail
|
set -ueo pipefail
|
||||||
|
|
||||||
readonly REPO_ROOT=$(git rev-parse --show-toplevel)
|
readonly REPO_ROOT=$(git rev-parse --show-toplevel)
|
||||||
readonly ARGS="$@"
|
|
||||||
readonly TARGET_TOOL=$(basename $0)
|
readonly TARGET_TOOL=$(basename $0)
|
||||||
|
|
||||||
function nix_dispatch() {
|
|
||||||
local attr="${1}"
|
|
||||||
local result=$(nix-build --no-out-link --attr "${attr}" "${REPO_ROOT}")
|
|
||||||
|
|
||||||
PATH="${result}/bin:$PATH"
|
|
||||||
if [ -z "${ARGS}" ]; then
|
|
||||||
exec "${TARGET_TOOL}"
|
|
||||||
else
|
|
||||||
exec "${TARGET_TOOL}" "${ARGS}"
|
|
||||||
fi
|
|
||||||
}
|
|
||||||
|
|
||||||
case "${TARGET_TOOL}" in
|
case "${TARGET_TOOL}" in
|
||||||
git-appraise)
|
git-appraise)
|
||||||
nix_dispatch "thirdParty.gitAppraise"
|
attr="thirdParty.gitAppraise"
|
||||||
|
;;
|
||||||
|
bazel)
|
||||||
|
attr="bazel"
|
||||||
|
;;
|
||||||
|
stylish-haskell)
|
||||||
|
attr="haskellPackages.stylish-haskell"
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
echo "The tool '${TARGET_TOOL}' is currently not installed in this repository."
|
echo "The tool '${TARGET_TOOL}' is currently not installed in this repository."
|
||||||
|
exit 1
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
|
result=$(nix-build --no-out-link --attr "${attr}" "${REPO_ROOT}")
|
||||||
|
PATH="${result}/bin:$PATH"
|
||||||
|
|
||||||
|
exec "${TARGET_TOOL}" "${@}"
|
||||||
|
|
Loading…
Reference in a new issue