mirror of
https://github.com/alexbelgium/hassio-addons.git
synced 2026-06-30 03:06:06 +02:00
Direct update
This commit is contained in:
@@ -26,35 +26,26 @@ candidate_shebangs+=(
|
|||||||
"/usr/bin/env bashio"
|
"/usr/bin/env bashio"
|
||||||
"/usr/bin/bashio"
|
"/usr/bin/bashio"
|
||||||
"/usr/bin/bash"
|
"/usr/bin/bash"
|
||||||
|
"/usr/bin/sh"
|
||||||
"/bin/bash"
|
"/bin/bash"
|
||||||
"/bin/sh"
|
"/bin/sh"
|
||||||
)
|
)
|
||||||
|
|
||||||
# Find the first valid shebang interpreter in candidate list by probing bashio::addon.version
|
# Find the first valid shebang interpreter in candidate list
|
||||||
shebang=""
|
shebang=""
|
||||||
tmp="$(mktemp)"
|
|
||||||
trap 'rm -f "$tmp"' EXIT
|
|
||||||
|
|
||||||
for candidate in "${candidate_shebangs[@]}"; do
|
for candidate in "${candidate_shebangs[@]}"; do
|
||||||
echo "Trying $candidate"
|
command_path="${candidate%% *}"
|
||||||
# Build a tiny probe script that prints the addon version
|
# Test if command exists and can actually execute a shell command (for shells)
|
||||||
printf '#!%s\n' "$candidate" >"$tmp"
|
if [ -x "$command_path" ]; then
|
||||||
cat >>"$tmp" <<'EOF'
|
# Try as both 'sh -c' and 'bashio echo' style
|
||||||
out="$(bashio::addon.version 2>/dev/null || true)"
|
if "$command_path" -c 'echo yes' >/dev/null 2>&1 || "$command_path" echo "yes" >/dev/null 2>&1; then
|
||||||
[ -n "$out" ] && printf '%s\n' "$out"
|
shebang="$candidate"
|
||||||
EOF
|
break
|
||||||
chmod +x "$tmp"
|
fi
|
||||||
|
|
||||||
# Run the probe and check for at least one digit in the output
|
|
||||||
out="$(exec "$tmp" 2>/dev/null || true)"
|
|
||||||
if printf '%s' "$out" | grep -qE '[0-9]'; then
|
|
||||||
shebang="$candidate"
|
|
||||||
break
|
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
if [ -z "$shebang" ]; then
|
if [ -z "$shebang" ]; then
|
||||||
echo "ERROR: No valid shebang found!" >&2
|
echo "ERROR: No valid shebang found!"
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user