Skip to content

Commit

Permalink
Refactor and add LD_LIBRARY_PATH
Browse files Browse the repository at this point in the history
  • Loading branch information
Jakski committed Jan 10, 2024
1 parent 3eefdfa commit 06f9b82
Show file tree
Hide file tree
Showing 7 changed files with 73 additions and 127 deletions.
4 changes: 2 additions & 2 deletions .editorconfig
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
root = true

[*]
indent_style = space
[bin/*]
indent_style = tab
indent_size = 2
charset = utf-8
trim_trailing_whitespace = true
Expand Down
44 changes: 26 additions & 18 deletions bin/download
Original file line number Diff line number Diff line change
Expand Up @@ -2,21 +2,29 @@

set -euo pipefail

current_script_path=${BASH_SOURCE[0]}
plugin_dir=$(dirname "$(dirname "$current_script_path")")

# shellcheck source=../lib/utils.bash
source "${plugin_dir}/lib/utils.bash"

mkdir -p "$ASDF_DOWNLOAD_PATH"

release_file="$ASDF_DOWNLOAD_PATH/$TOOL_NAME-$ASDF_INSTALL_VERSION.tar.gz"

# Download tar.gz file to the download directory
download_release "$ASDF_INSTALL_VERSION" "$release_file"

# Extract contents of tar.gz file into the download directory
tar -xzf "$release_file" -C "$ASDF_DOWNLOAD_PATH" --strip-components=1 || fail "Could not extract $release_file"

# Remove the tar.gz file since we don't need to keep it
rm "$release_file"
declare \
janet_repo="https://github.com/janet-lang/janet" \
janet_version=$ASDF_INSTALL_VERSION \
jpm_repo="https://github.com/janet-lang/jpm" \
jpm_ref="master"
declare -a curl_opts=(-fsSL)

if [ -v JPM_REF ] && [ -n "$JPM_REF" ]; then
jpm_ref=""
fi
if [ -n "${GITHUB_API_TOKEN:-}" ]; then
curl_opts=("${curl_opts[@]}" -H "Authorization: token $GITHUB_API_TOKEN")
fi
if [ "$ASDF_INSTALL_TYPE" = "version" ]; then
janet_version="v${janet_version}"
fi
if [ ! -d "${ASDF_DOWNLOAD_PATH}/janet" ]; then
mkdir -p "${ASDF_DOWNLOAD_PATH}/janet"
curl "${curl_opts[@]}" "${janet_repo}/archive/${janet_version}.tar.gz" |
tar -C "${ASDF_DOWNLOAD_PATH}/janet" --strip-components=1 -xzf -
fi
if [ -n "$jpm_ref" ] && [ ! -d "${ASDF_DOWNLOAD_PATH}/jpm" ]; then
mkdir -p "${ASDF_DOWNLOAD_PATH}/jpm"
curl "${curl_opts[@]}" "${jpm_repo}/archive/${jpm_ref}.tar.gz" |
tar -C "${ASDF_DOWNLOAD_PATH}/jpm" --strip-components=1 -xzf -
fi
9 changes: 9 additions & 0 deletions bin/exec-env
Original file line number Diff line number Diff line change
@@ -0,0 +1,9 @@
#!/usr/bin/env bash

set -euo pipefail

if [ -v LD_LIBRARY_PATH ]; then
export LD_LIBRARY_PATH="${ASDF_INSTALL_PATH}/bin:${LD_LIBRARY_PATH}/lib"
else
export LD_LIBRARY_PATH="${ASDF_INSTALL_PATH}/lib"
fi
35 changes: 30 additions & 5 deletions bin/install
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,35 @@

set -euo pipefail

current_script_path=${BASH_SOURCE[0]}
plugin_dir=$(dirname "$(dirname "$current_script_path")")
declare git_hash

# shellcheck source=../lib/utils.bash
source "${plugin_dir}/lib/utils.bash"
if [ "$ASDF_INSTALL_TYPE" = "version" ]; then
git_hash="meson"
else
git_hash="$ASDF_INSTALL_VERSION"
fi

install_version "$ASDF_INSTALL_TYPE" "$ASDF_INSTALL_VERSION" "$ASDF_INSTALL_PATH"
if [ -v LD_LIBRARY_PATH ]; then
export LD_LIBRARY_PATH="${ASDF_INSTALL_PATH}/bin:${LD_LIBRARY_PATH}/lib"
else
export LD_LIBRARY_PATH="${ASDF_INSTALL_PATH}/lib"
fi

mkdir -p "$ASDF_INSTALL_PATH"
pushd "${ASDF_DOWNLOAD_PATH}/janet" >/dev/null
meson setup build \
--buildtype release \
--optimization 2 \
--prefix "$ASDF_INSTALL_PATH" \
--libdir "${ASDF_INSTALL_PATH}/lib" \
-Dgit_hash="$git_hash"
ninja -C build -j "${ASDF_CONCURRENCY:-1}"
ninja -C build install -j "${ASDF_CONCURRENCY:-1}"
popd >/dev/null
[ -x "${ASDF_INSTALL_PATH}/bin/janet" ]
if [ ! -v JPM_REF ] || [ -n "$JPM_REF" ]; then
pushd "${ASDF_DOWNLOAD_PATH}/jpm" >/dev/null
PREFIX="$ASDF_INSTALL_PATH" "${ASDF_INSTALL_PATH}/bin/janet" bootstrap.janet
popd >/dev/null
[ -x "${ASDF_INSTALL_PATH}/bin/jpm" ]
fi
12 changes: 5 additions & 7 deletions bin/list-all
Original file line number Diff line number Diff line change
Expand Up @@ -2,10 +2,8 @@

set -euo pipefail

current_script_path=${BASH_SOURCE[0]}
plugin_dir=$(dirname "$(dirname "$current_script_path")")

# shellcheck source=../lib/utils.bash
source "${plugin_dir}/lib/utils.bash"

list_all_versions | sort_versions | xargs echo
declare janet_repo="https://github.com/janet-lang/janet"
git ls-remote --tags --refs "$janet_repo" |
sed -ne 's/.*\s\+refs\/tags\/v\(\([[:digit:]]\+\.\)\{2\}[[:digit:]]\+\)$/\1/p' |
LC_ALL=C sort -t. -k 1,1 -k 2,2n -k 3,3n -k 4,4n -k 5,5n |
xargs printf "%s "
94 changes: 0 additions & 94 deletions lib/utils.bash

This file was deleted.

2 changes: 1 addition & 1 deletion scripts/shellcheck.bash
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
#!/usr/bin/env bash

exec shellcheck -s bash -x \
bin/* -P lib/
bin/* -P lib/

0 comments on commit 06f9b82

Please sign in to comment.