mirror of
https://github.com/the-sane/lug-helper.git
synced 2025-01-16 19:50:35 +00:00
Compare commits
No commits in common. "1c3bb8d61e3ce271ed468da0acdce8237976f349" and "5f3819bd6a3e15ce3c8943dd5c6c6466e1a97ef3" have entirely different histories.
1c3bb8d61e
...
5f3819bd6a
@ -71,11 +71,11 @@ fi
|
|||||||
# notify-send "lug-helper" "The package 'zstd' was not found on this system. It is required for extracting some runner packages.\n" --icon=dialog-warning
|
# notify-send "lug-helper" "The package 'zstd' was not found on this system. It is required for extracting some runner packages.\n" --icon=dialog-warning
|
||||||
# exit 1
|
# exit 1
|
||||||
#fi
|
#fi
|
||||||
if [ ! -x "$(command -v mktemp)" ] || [ ! -x "$(command -v sort)" ] || [ ! -x "$(command -v basename)" ] || [ ! -x "$(command -v realpath)" ] || [ ! -x "$(command -v dirname)" ] || [ ! -x "$(command -v cut)" ] || [ ! -x "$(command -v numfmt)" ]; then
|
if [ ! -x "$(command -v mktemp)" ] || [ ! -x "$(command -v sort)" ] || [ ! -x "$(command -v basename)" ] || [ ! -x "$(command -v realpath)" ] || [ ! -x "$(command -v dirname)" ] || [ ! -x "$(command -v numfmt)" ]; then
|
||||||
# coreutils
|
# coreutils
|
||||||
# Print to stderr and also try warning the user through notify-send
|
# Print to stderr and also try warning the user through notify-send
|
||||||
printf "lug-helper.sh: One or more required packages were not found on this system.\nPlease check that the following coreutils packages are installed:\n- mktemp\n- sort\n- basename\n- realpath\n- dirname\n- cut\n- numfmt\n" 1>&2
|
printf "lug-helper.sh: One or more required packages were not found on this system.\nPlease check that the following coreutils packages are installed:\n- mktemp\n- sort\n- basename\n- realpath\n- dirname\n" 1>&2
|
||||||
notify-send "lug-helper" "One or more required packages were not found on this system.\nPlease check that the following coreutils packages are installed:\n- mktemp\n- sort\n- basename\n- realpath\n- dirname\n- cut\n- numfmt\n" --icon=dialog-warning
|
notify-send "lug-helper" "One or more required packages were not found on this system.\nPlease check that the following coreutils packages are installed:\n- mktemp\n- sort\n- basename\n- realpath\n- dirname\n- numfmt\n" --icon=dialog-warning
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
if [ ! -x "$(command -v xargs)" ]; then
|
if [ ! -x "$(command -v xargs)" ]; then
|
||||||
@ -171,7 +171,7 @@ runners_dir_flatpak="$lutris_flatpak_dir/data/lutris/runners/wine"
|
|||||||
# URLs for downloading Lutris runners
|
# URLs for downloading Lutris runners
|
||||||
# Elements in this array must be added in quoted pairs of: "description" "url"
|
# Elements in this array must be added in quoted pairs of: "description" "url"
|
||||||
# The first string in the pair is expected to contain the runner description
|
# The first string in the pair is expected to contain the runner description
|
||||||
# The second is expected to contain the api releases url
|
# The second is expected to contain the github api releases url
|
||||||
# ie. "RawFox" "https://api.github.com/repos/rawfoxDE/raw-wine/releases"
|
# ie. "RawFox" "https://api.github.com/repos/rawfoxDE/raw-wine/releases"
|
||||||
runner_sources=(
|
runner_sources=(
|
||||||
"GloriousEggroll" "https://api.github.com/repos/GloriousEggroll/wine-ge-custom/releases"
|
"GloriousEggroll" "https://api.github.com/repos/GloriousEggroll/wine-ge-custom/releases"
|
||||||
@ -189,13 +189,11 @@ dxvk_dir_flatpak="$lutris_flatpak_dir/data/lutris/runtime/dxvk"
|
|||||||
# URLs for downloading dxvk versions
|
# URLs for downloading dxvk versions
|
||||||
# Elements in this array must be added in quoted pairs of: "description" "url"
|
# Elements in this array must be added in quoted pairs of: "description" "url"
|
||||||
# The first string in the pair is expected to contain the runner description
|
# The first string in the pair is expected to contain the runner description
|
||||||
# The second is expected to contain the api releases url
|
# The second is expected to contain the github api releases url
|
||||||
# ie. "Sporif Async" "https://api.github.com/repos/Sporif/dxvk-async/releases"
|
# ie. "Sporif Async" "https://api.github.com/repos/Sporif/dxvk-async/releases"
|
||||||
# ie. "Ph42oN GPL+Async" "https://gitlab.com/api/v4/projects/Ph42oN%2Fdxvk-gplasync/releases"
|
|
||||||
dxvk_sources=(
|
dxvk_sources=(
|
||||||
"doitsujin (standard dxvk)" "https://api.github.com/repos/doitsujin/dxvk/releases"
|
"doitsujin (standard dxvk)" "https://api.github.com/repos/doitsujin/dxvk/releases"
|
||||||
"Sporif Async" "https://api.github.com/repos/Sporif/dxvk-async/releases"
|
"Sporif Async" "https://api.github.com/repos/Sporif/dxvk-async/releases"
|
||||||
"Ph42oN GPL+Async" "https://gitlab.com/api/v4/projects/Ph42oN%2Fdxvk-gplasync/releases"
|
|
||||||
"gnusenpai" "https://api.github.com/repos/gnusenpai/dxvk/releases"
|
"gnusenpai" "https://api.github.com/repos/gnusenpai/dxvk/releases"
|
||||||
"/dev/null" "https://api.github.com/repos/gort818/dxvk/releases"
|
"/dev/null" "https://api.github.com/repos/gort818/dxvk/releases"
|
||||||
)
|
)
|
||||||
@ -1375,22 +1373,15 @@ download_install() {
|
|||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
|
|
||||||
# Set the search key we'll use to parse the api for the download url
|
# Get the selected download url
|
||||||
# To add new sources, handle them here and in the
|
# To add new sources, handle them here and in the
|
||||||
# download_select_install function below
|
# download_select_install function below
|
||||||
if [ "$download_url_type" = "github" ]; then
|
if [ "$download_url_type" = "github" ]; then
|
||||||
search_key="browser_download_url"
|
download_url="$(curl -s "$contributor_url" | grep "browser_download_url.*$download_file" | cut -d \" -f4)"
|
||||||
query_string="?per_page=$max_download_items"
|
|
||||||
elif [ "$download_url_type" = "gitlab" ]; then
|
|
||||||
search_key="direct_asset_url"
|
|
||||||
query_string="?per_page=$max_download_items"
|
|
||||||
else
|
else
|
||||||
debug_print exit "Script error: Unknown api/url format in ${download_type}_sources array. Aborting."
|
debug_print exit "Script error: Unknown api/url format in ${download_type}_sources array. Aborting."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Get the selected download url
|
|
||||||
download_url="$(curl -s "$contributor_url$query_string" | grep -o "$search_key.*$download_file" | cut -d \" -f3)"
|
|
||||||
|
|
||||||
# Sanity check
|
# Sanity check
|
||||||
if [ -z "$download_url" ]; then
|
if [ -z "$download_url" ]; then
|
||||||
message warning "Could not find the requested ${download_type}. The source API may be down or rate limited."
|
message warning "Could not find the requested ${download_type}. The source API may be down or rate limited."
|
||||||
@ -1547,6 +1538,18 @@ download_select_install() {
|
|||||||
contributor_name="${download_sources[$1]}"
|
contributor_name="${download_sources[$1]}"
|
||||||
contributor_url="${download_sources[$1+1]}"
|
contributor_url="${download_sources[$1+1]}"
|
||||||
|
|
||||||
|
# Check the provided contributor url to make sure we know how to handle it
|
||||||
|
# To add new sources, add them here and handle in the if statement
|
||||||
|
# just below and the download_install function above
|
||||||
|
case "$contributor_url" in
|
||||||
|
https://api.github.com*)
|
||||||
|
download_url_type="github"
|
||||||
|
;;
|
||||||
|
*)
|
||||||
|
debug_print exit "Script error: Unknown api/url format in ${download_type}_sources array. Aborting."
|
||||||
|
;;
|
||||||
|
esac
|
||||||
|
|
||||||
# For runners, check GlibC version against runner requirements
|
# For runners, check GlibC version against runner requirements
|
||||||
if [ "$download_type" = "runner" ] && { [ "$contributor_name" = "/dev/null" ] || [ "$contributor_name" = "TKG" ]; }; then
|
if [ "$download_type" = "runner" ] && { [ "$contributor_name" = "/dev/null" ] || [ "$contributor_name" = "TKG" ]; }; then
|
||||||
unset glibc_fail
|
unset glibc_fail
|
||||||
@ -1612,41 +1615,18 @@ download_select_install() {
|
|||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Check the provided contributor url to make sure we know how to handle it
|
# Fetch a list of versions from the selected contributor
|
||||||
# To add new sources, add them here and handle in the if statement
|
|
||||||
# just below and the download_install function above
|
|
||||||
case "$contributor_url" in
|
|
||||||
https://api.github.com/*)
|
|
||||||
download_url_type="github"
|
|
||||||
;;
|
|
||||||
https://gitlab.com/api/v4/projects/*)
|
|
||||||
download_url_type="gitlab"
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
debug_print exit "Script error: Unknown api/url format in ${download_type}_sources array. Aborting."
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
# Set the search key we'll use to parse the api for the download url
|
|
||||||
# To add new sources, handle them here, in the if statement
|
# To add new sources, handle them here, in the if statement
|
||||||
# just above, and the download_install function above
|
# just above, and the download_install function above
|
||||||
|
unset download_versions
|
||||||
if [ "$download_url_type" = "github" ]; then
|
if [ "$download_url_type" = "github" ]; then
|
||||||
search_key="browser_download_url"
|
while IFS='' read -r line; do
|
||||||
query_string="?per_page=$max_download_items"
|
download_versions+=("$line")
|
||||||
elif [ "$download_url_type" = "gitlab" ]; then
|
done < <(curl -s "$contributor_url" | awk '/browser_download_url/ {print $2}' | xargs basename -a)
|
||||||
search_key="direct_asset_url"
|
|
||||||
query_string="?per_page=$max_download_items"
|
|
||||||
else
|
else
|
||||||
debug_print exit "Script error: Unknown api/url format in ${download_type}_sources array. Aborting."
|
debug_print exit "Script error: Unknown api/url format in ${download_type}_sources array. Aborting."
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# Fetch a list of versions from the selected contributor
|
|
||||||
unset download_versions
|
|
||||||
while IFS='' read -r line; do
|
|
||||||
download_versions+=("$line")
|
|
||||||
done < <(curl -s "$contributor_url$query_string" | grep -Po "$search_key.*?[^\\\](\",|\$)" | cut -d \" -f3 | xargs basename -a)
|
|
||||||
# Note: match from search_key until ", or EOL (Handles embedded commas and escaped quotes)
|
|
||||||
|
|
||||||
# Sanity check
|
# Sanity check
|
||||||
if [ "${#download_versions[@]}" -eq 0 ]; then
|
if [ "${#download_versions[@]}" -eq 0 ]; then
|
||||||
message warning "No $download_type versions were found. The source API may be down or rate limited."
|
message warning "No $download_type versions were found. The source API may be down or rate limited."
|
||||||
|
Loading…
x
Reference in New Issue
Block a user