Compare commits

...

10 Commits

Author SHA1 Message Date
the Sane
4fd9fec8f7
Fix version number (don't ask) 2021-09-18 16:33:06 -04:00
the Sane
130704107b
Bump version 2021-09-18 16:31:37 -04:00
the Sane
15cad464e3
Remove extraneous / from path 2021-09-18 16:22:50 -04:00
the Sane
cabfd03c29
Bump version number 2021-09-18 15:52:41 -04:00
the Sane
33170fae78
Add better cancel button labels
Closes #22
2021-09-18 15:51:57 -04:00
the Sane
b701ea5e3d
Fix gzip error for non-gzip archives 2021-09-18 15:27:51 -04:00
the Sane
05d75ec82f
Ignore sha512sum files when creating download list 2021-09-18 15:17:39 -04:00
the Sane
2f97a8eb2d
Revert "ignoring .sha512sum files in runner release pages" and "solving trying to download the .sha512sum as archive"
Reverts commits c07e673 and 675621c.
2021-09-18 15:14:40 -04:00
the Sane
cb3fc5d0d7
Reorganize version checker 2021-09-18 13:10:44 -04:00
the Sane
c42d459ef2
Minor syntax, formatting, and organizational tweaks 2021-09-18 12:57:22 -04:00

View File

@ -48,9 +48,9 @@
############################################################################ ############################################################################
# Check if script is run as root # Check if script is run as root
if [ "$(id -u)" = 0 ]; then if [ "$(id -u)" -eq 0 ]; then
echo "This script is not supposed to be run as root!" echo "This script is not supposed to be run as root!"
exit 1 exit 1
fi fi
# Check for dependencies # Check for dependencies
@ -126,6 +126,11 @@ else
lug_logo="info" lug_logo="info"
fi fi
# Github repo and script version info
repo="the-sane/lug-helper"
releases_url="https://github.com/the-sane/lug-helper/releases"
current_version="v1.9.2"
############################################################################ ############################################################################
############################################################################ ############################################################################
@ -258,6 +263,7 @@ message() {
# This text will be displayed above the menu options. # This text will be displayed above the menu options.
# Zenity supports Pango Markup for text formatting. # Zenity supports Pango Markup for text formatting.
# - The integer "menu_height" specifies the height of the zenity menu. # - The integer "menu_height" specifies the height of the zenity menu.
# - The string "cancel_label" should contain the text of the cancel button.
# #
# The final element in each array is expected to be a quit option. # The final element in each array is expected to be a quit option.
# #
@ -279,6 +285,8 @@ menu() {
debug_print exit "Script error: The string 'menu_text_terminal' was not set\nbefore calling the menu function. Aborting." debug_print exit "Script error: The string 'menu_text_terminal' was not set\nbefore calling the menu function. Aborting."
elif [ -z "$menu_height" ]; then elif [ -z "$menu_height" ]; then
debug_print exit "Script error: The string 'menu_height' was not set\nbefore calling the menu function. Aborting." debug_print exit "Script error: The string 'menu_height' was not set\nbefore calling the menu function. Aborting."
elif [ -z "$cancel_label" ]; then
debug_print exit "Script error: The string 'menu_height' was not set\nbefore calling the menu function. Aborting."
fi fi
# Use Zenity if it is available # Use Zenity if it is available
@ -298,7 +306,7 @@ menu() {
done done
# Display the zenity radio button menu # Display the zenity radio button menu
choice="$(zenity --list --radiolist --width="480" --height="$menu_height" --text="$menu_text_zenity" --title="Star Citizen LUG Helper" --hide-header --window-icon=$lug_logo --column="" --column="Option" "${zen_options[@]}" 2>/dev/null)" choice="$(zenity --list --radiolist --width="480" --height="$menu_height" --text="$menu_text_zenity" --title="Star Citizen LUG Helper" --hide-header --cancel-label "$cancel_label" --window-icon=$lug_logo --column="" --column="Option" "${zen_options[@]}" 2>/dev/null)"
# Loop through the options array to match the chosen option # Loop through the options array to match the chosen option
matched="false" matched="false"
@ -472,7 +480,7 @@ getdirs() {
# $live_or_ptu is set in the set_version() function # $live_or_ptu is set in the set_version() function
############################################################################ ############################################################################
# The game's user directory # The game's user directory
user_dir="$game_path/$live_or_ptu/USER/Client/0/" user_dir="$game_path/$live_or_ptu/USER/Client/0"
# The location within the USER directory to which the game exports keybinds # The location within the USER directory to which the game exports keybinds
keybinds_dir="$user_dir/Controls/Mappings" keybinds_dir="$user_dir/Controls/Mappings"
# Shaders directory # Shaders directory
@ -794,6 +802,9 @@ runner_select_delete() {
menu_height="400" menu_height="400"
fi fi
# Set the label for the cancel button
cancel_label="Go Back"
# Call the menu function. It will use the options as configured above # Call the menu function. It will use the options as configured above
menu menu
} }
@ -824,9 +835,6 @@ runner_install() {
*.tar.xz) *.tar.xz)
runner_name="$(basename "$runner_file" .tar.xz)" runner_name="$(basename "$runner_file" .tar.xz)"
;; ;;
*.sha512sum)
runner_name="$(basename "$runner_file" .tar.xz)"
;;
*) *)
debug_print exit "Unknown archive filetype in runner_install function. Aborting." debug_print exit "Unknown archive filetype in runner_install function. Aborting."
;; ;;
@ -837,7 +845,6 @@ runner_install() {
# runner_select_install function below # runner_select_install function below
if [ "$runner_url_type" = "github" ]; then if [ "$runner_url_type" = "github" ]; then
runner_dl_url="$(curl -s "$contributor_url" | grep "browser_download_url.*$runner_file" | cut -d \" -f4)" runner_dl_url="$(curl -s "$contributor_url" | grep "browser_download_url.*$runner_file" | cut -d \" -f4)"
debug_print continue "runner_dl_url= $runner_dl_url"
else else
debug_print exit "Script error: Unknown api/url format in runner_sources array. Aborting." debug_print exit "Script error: Unknown api/url format in runner_sources array. Aborting."
fi fi
@ -882,7 +889,7 @@ runner_install() {
# Get the path of the first item listed in the archive # Get the path of the first item listed in the archive
# This should either be a subdirectory or the path ./ # This should either be a subdirectory or the path ./
# depending on how the archive was created # depending on how the archive was created
first_filepath="$(stdbuf -oL tar -tzf "$tmp_dir/$runner_file" | head -n 1)" first_filepath="$(stdbuf -oL tar -tf "$tmp_dir/$runner_file" | head -n 1)"
# Extract the runner # Extract the runner
case "$first_filepath" in case "$first_filepath" in
@ -925,7 +932,8 @@ runner_select_install() {
debug_print exit "Script error: The runner_select_install function expects a numerical argument. Aborting." debug_print exit "Script error: The runner_select_install function expects a numerical argument. Aborting."
fi fi
# Store the url from the selected contributor # Store info from the selected contributor
contributor_name="${runner_sources[$1]}"
contributor_url="${runner_sources[$1+1]}" contributor_url="${runner_sources[$1+1]}"
# Check the provided contributor url to make sure we know how to handle it # Check the provided contributor url to make sure we know how to handle it
@ -940,15 +948,14 @@ runner_select_install() {
;; ;;
esac esac
# Check for GlibC-Version if TKG is selected, as he requires 2.33 # Check GlibC version against the requirements of the selected runner
if [ "$contributor_url" = "https://api.github.com/repos/gort818/wine-sc-lug/releases" ]; then if [ "$contributor_name" = "/dev/null" ]; then
printf "checking for glibc \n"
system_glibc=($(ldd --version | awk '/ldd/{print $NF}'))
printf "system glibc-versuib: $system_glibc \n"
required_glibc="2.33" required_glibc="2.33"
if [ "$(bc <<< "$required_glibc>$system_glibc")" == "1" ]; then system_glibc="$(ldd --version | awk '/ldd/{print $NF}')"
message warning "Your glibc version is too low, /dev/null requires v$required_glibc "
proton_manage if [ "$(bc <<< "$required_glibc > $system_glibc")" = "1" ]; then
message warning "Your glibc version is incompatible with the selected runner.\n\nSystem glibc: v$system_glibc\nMinimum required glibc: v$required_glibc"
return 1
fi fi
fi fi
@ -956,7 +963,7 @@ runner_select_install() {
# 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 runner_install function above # just above, and the runner_install function above
if [ "$runner_url_type" = "github" ]; then if [ "$runner_url_type" = "github" ]; then
runner_versions=($(curl -s "$contributor_url" | awk '/browser_download_url/ {print $2}' | xargs basename -a)) runner_versions=($(curl -s "$contributor_url" | awk '/browser_download_url/ {print $2}' | grep -vE "*.sha512sum" | xargs basename -a))
else else
debug_print exit "Script error: Unknown api/url format in runner_sources array. Aborting." debug_print exit "Script error: Unknown api/url format in runner_sources array. Aborting."
fi fi
@ -992,14 +999,12 @@ runner_select_install() {
runner_name="$(basename "${runner_versions[i]}" .tar.xz)" runner_name="$(basename "${runner_versions[i]}" .tar.xz)"
;; ;;
*) *)
runner_name="skip" debug_print exit "Unknown archive filetype in runner_select_install function. Aborting."
;; ;;
esac esac
# Add the runner names to the menu # Add the runner names to the menu
if [ "$runner_name" = "skip" ]; then if [ -d "$runners_dir/$runner_name" ]; then
continue
elif [ -d "$runners_dir/$runner_name" ]; then
menu_options+=("$runner_name [installed]") menu_options+=("$runner_name [installed]")
else else
menu_options+=("$runner_name") menu_options+=("$runner_name")
@ -1017,6 +1022,9 @@ runner_select_install() {
menu_height="400" menu_height="400"
fi fi
# Set the label for the cancel button
cancel_label="Go Back"
# Call the menu function. It will use the options as configured above # Call the menu function. It will use the options as configured above
menu menu
} }
@ -1064,6 +1072,9 @@ runner_manage() {
# Calculate the total height the menu should be # Calculate the total height the menu should be
menu_height="$(($menu_option_height * ${#menu_options[@]} + $menu_text_height))" menu_height="$(($menu_option_height * ${#menu_options[@]} + $menu_text_height))"
# Set the label for the cancel button
cancel_label="Go Back"
# Call the menu function. It will use the options as configured above # Call the menu function. It will use the options as configured above
menu menu
done done
@ -1201,7 +1212,10 @@ maintenance_menu() {
# Calculate the total height the menu should be # Calculate the total height the menu should be
menu_height="$(($menu_option_height * ${#menu_options[@]} + $menu_text_height))" menu_height="$(($menu_option_height * ${#menu_options[@]} + $menu_text_height))"
# Set the label for the cancel button
cancel_label="Go Back"
# Call the menu function. It will use the options as configured above # Call the menu function. It will use the options as configured above
menu menu
done done
@ -1242,6 +1256,19 @@ reset_helper() {
fi fi
} }
# Get the latest release version of a repo. Expects "user/repo_name" as input
# Credits for this go to https://gist.github.com/lukechilds/a83e1d7127b78fef38c2914c4ececc3c
get_latest_release() {
# Sanity check
if [ "$#" -lt 1 ]; then
debug_print exit "Script error: The get_latest_release function expects one argument. Aborting."
fi
curl --silent "https://api.github.com/repos/$1/releases/latest" | # Get latest release from GitHub api
grep '"tag_name":' | # Get tag line
sed -E 's/.*"([^"]+)".*/\1/' # Pluck JSON value
}
quit() { quit() {
exit 0 exit 0
} }
@ -1261,22 +1288,17 @@ fi
live_or_ptu="$live_dir" live_or_ptu="$live_dir"
lutris_needs_restart="false" lutris_needs_restart="false"
# Credits for this go to https://gist.github.com/lukechilds/a83e1d7127b78fef38c2914c4ececc3c # Check if a newer verison of the script is available
get_latest_release() {
curl --silent "https://api.github.com/repos/$1/releases/latest" | # Get latest release from GitHub api
grep '"tag_name":' | # Get tag line
sed -E 's/.*"([^"]+)".*/\1/' # Pluck JSON value
}
# Check if a new Verison of the script is available
repo="the-sane/lug-helper"
current_version="v1.9.1"
latest_version=$(get_latest_release "$repo") latest_version=$(get_latest_release "$repo")
if [ "$latest_version" != "$current_version" ]; then if [ "$latest_version" != "$current_version" ]; then
# Print to stdout and also try warning the user through message if [ "$use_zenity" -eq 1 ]; then
printf "New version available, check https://github.com/the-sane/lug-helper/releases \n" releases_url_formatted="<a href='$releases_url'>$releases_url</a>"
message info "New version available, check <a href='https://github.com/the-sane/lug-helper/releases'>https://github.com/the-sane/lug-helper/releases</a> \n" else
releases_url_formatted="$releases_url"
fi
message info "The latest version of the LUG Helper is $latest_version\nYou are using $current_version\n\nYou can download new releases here:\n$releases_url_formatted"
fi fi
# If invoked with command line arguments, process them and exit # If invoked with command line arguments, process them and exit
@ -1387,6 +1409,9 @@ while true; do
# Calculate the total height the menu should be # Calculate the total height the menu should be
menu_height="$(($menu_option_height * ${#menu_options[@]} + $menu_text_height))" menu_height="$(($menu_option_height * ${#menu_options[@]} + $menu_text_height))"
# Set the label for the cancel button
cancel_label="Quit"
# Call the menu function. It will use the options as configured above # Call the menu function. It will use the options as configured above
menu menu
done done