compatibility: easier for WSL, read now accepts autocompletion
This commit is contained in:
@@ -25,7 +25,7 @@ Helldivers 2 Mod Manager CLI is a command line interface for managing Helldivers
|
|||||||
To install/update Helldivers 2 Mod Manager CLI run the following command in your terminal:
|
To install/update Helldivers 2 Mod Manager CLI run the following command in your terminal:
|
||||||
|
|
||||||
```bash
|
```bash
|
||||||
sh -c "$(curl -fsSL https://raw.githubusercontent.com/v4n00/h2mm-cli/refs/heads/master/install.sh)"
|
bash -c "$(curl -fsSL https://raw.githubusercontent.com/v4n00/h2mm-cli/refs/heads/master/install.sh)"
|
||||||
```
|
```
|
||||||
|
|
||||||
Running this script will require sudo permissions. **DO NOT TRUST** random scripts from the internet. If you want to review the script before running it, check out the mod repository for yourself.
|
Running this script will require sudo permissions. **DO NOT TRUST** random scripts from the internet. If you want to review the script before running it, check out the mod repository for yourself.
|
||||||
@@ -92,8 +92,10 @@ The script is developed and tested on Arch Linux, but it should work on other Li
|
|||||||
Status of other platforms:
|
Status of other platforms:
|
||||||
|
|
||||||
- Linux :white_check_mark:
|
- Linux :white_check_mark:
|
||||||
- Steam Deck - Untested :grey_question:
|
- Steam Deck - untested (should work) :grey_question:
|
||||||
- WSL - Untested, should work :grey_question:
|
- WSL :white_check_mark:
|
||||||
|
|
||||||
|
> The script works on WSL, but you need to specify the path to the Helldivers 2 mods directory manually, to find your Windows partition head to `/mnt/` and from there go to your Helldivers 2 data directory, on a typical install it should be on `/mnt/c/Program\ Files\ \(x86\)/Steam/steamapps/common/Helldivers\ 2/data`. You also need to have `unzip` installed, which can be done by running `sudo apt install unzip`.
|
||||||
|
|
||||||
## Advanced usage
|
## Advanced usage
|
||||||
|
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
#!/bin/bash
|
#!/bin/bash
|
||||||
|
|
||||||
VERSION="0.2.1"
|
VERSION="0.2.2"
|
||||||
|
|
||||||
# --- Globals ---
|
# --- Globals ---
|
||||||
|
|
||||||
@@ -73,8 +73,7 @@ function find_game_directory() {
|
|||||||
|
|
||||||
if [[ -z "$game_dir" ]]; then
|
if [[ -z "$game_dir" ]]; then
|
||||||
echo "Could not find the Helldivers 2 data directory automatically." >&2
|
echo "Could not find the Helldivers 2 data directory automatically." >&2
|
||||||
read -p "Please enter the path to the Helldivers 2 data directory: " game_dir
|
IFS= read -ep "Please enter the path to the Helldivers 2 data directory: " game_dir
|
||||||
game_dir=$(eval echo "$game_dir")
|
|
||||||
if [[ ! -d "$game_dir" ]]; then
|
if [[ ! -d "$game_dir" ]]; then
|
||||||
echo -e "${RED}Error${NC}: Provided path is not a valid directory." >&2
|
echo -e "${RED}Error${NC}: Provided path is not a valid directory." >&2
|
||||||
exit 1
|
exit 1
|
||||||
@@ -212,7 +211,7 @@ function display_import_help() {
|
|||||||
function check_for_updates() {
|
function check_for_updates() {
|
||||||
if [[ -f "$LAST_CHECKED_UPDATE_FILE" ]]; then
|
if [[ -f "$LAST_CHECKED_UPDATE_FILE" ]]; then
|
||||||
last_update=$(cat "$LAST_CHECKED_UPDATE_FILE")
|
last_update=$(cat "$LAST_CHECKED_UPDATE_FILE")
|
||||||
if [[ $(date +%Y-%m-%d) -gt $(date +%Y-%m-%d -d "$last_update + 7 days") ]]; then
|
if [[ $(date +%Y-%m-%d) -gt $(date +%Y-%m-%d -d "$last_update + 3 days") ]]; then
|
||||||
return
|
return
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
@@ -295,38 +294,38 @@ function mod_disable() {
|
|||||||
}
|
}
|
||||||
|
|
||||||
function mod_enable() {
|
function mod_enable() {
|
||||||
local mod_name=""
|
local mod_name=""
|
||||||
local mod_index=""
|
local mod_index=""
|
||||||
|
|
||||||
[[ $# -eq 0 ]] && { display_enable_help; exit 0; }
|
[[ $# -eq 0 ]] && { display_enable_help; exit 0; }
|
||||||
|
|
||||||
# parse arguments
|
# parse arguments
|
||||||
while [[ $# -gt 0 ]]; do
|
while [[ $# -gt 0 ]]; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
-i)
|
-i)
|
||||||
mod_index="$2"; shift 2
|
mod_index="$2"; shift 2
|
||||||
;;
|
;;
|
||||||
--help|-h)
|
--help|-h)
|
||||||
display_enable_help; exit 0
|
display_enable_help; exit 0
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
mod_name="$1"; shift 1
|
mod_name="$1"; shift 1
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
[[ -z "$mod_name" && -z "$mod_index" ]] && { echo -e "${RED}Error${NC}: Mod name or index is required to enable." >&2; exit 1; }
|
[[ -z "$mod_name" && -z "$mod_index" ]] && { echo -e "${RED}Error${NC}: Mod name or index is required to enable." >&2; exit 1; }
|
||||||
|
|
||||||
# find mod files
|
# find mod files
|
||||||
get_mod_name_and_index "$mod_name" "$mod_index"
|
get_mod_name_and_index "$mod_name" "$mod_index"
|
||||||
|
|
||||||
[[ "$status" == "ENABLED" ]] && { echo -e "${RED}Error${NC}: Mod $mod_name is already enabled." >&2; exit 1; }
|
[[ "$status" == "ENABLED" ]] && { echo -e "${RED}Error${NC}: Mod $mod_name is already enabled." >&2; exit 1; }
|
||||||
|
|
||||||
files=$(get_files_by_entry_from_db "$entry")
|
files=$(get_files_by_entry_from_db "$entry")
|
||||||
|
|
||||||
# enable each mod file by removing disabled_ from the start of the filename
|
# enable each mod file by removing disabled_ from the start of the filename
|
||||||
for file in $files; do
|
for file in $files; do
|
||||||
disabled_file="disabled_$file"
|
disabled_file="disabled_$file"
|
||||||
|
|
||||||
# check if the files exists
|
# check if the files exists
|
||||||
[[ -f "$MODS_DIR/$disabled_file" ]] || { echo -e "${RED}Error${NC}: Mod file $file does not exist." >&2; exit 1; }
|
[[ -f "$MODS_DIR/$disabled_file" ]] || { echo -e "${RED}Error${NC}: Mod file $file does not exist." >&2; exit 1; }
|
||||||
@@ -336,17 +335,17 @@ function mod_enable() {
|
|||||||
# check if the file was moved successfully
|
# check if the file was moved successfully
|
||||||
[[ $? -ne 0 ]] && { echo -e "${RED}Error${NC}: Could not enable mod file $disabled_file." >&2; exit 1; }
|
[[ $? -ne 0 ]] && { echo -e "${RED}Error${NC}: Could not enable mod file $disabled_file." >&2; exit 1; }
|
||||||
echo -e "Enabled ${ORANGE}$disabled_file${NC} (changed to ${GREEN}\$MODS_DIR/$file${NC})." >&2
|
echo -e "Enabled ${ORANGE}$disabled_file${NC} (changed to ${GREEN}\$MODS_DIR/$file${NC})." >&2
|
||||||
done
|
done
|
||||||
|
|
||||||
# update the database
|
# update the database
|
||||||
sed -i "/^$mod_index,/s/DISABLED/ENABLED/" "$DB_FILE"
|
sed -i "/^$mod_index,/s/DISABLED/ENABLED/" "$DB_FILE"
|
||||||
|
|
||||||
if [[ $? -eq 0 ]]; then
|
if [[ $? -eq 0 ]]; then
|
||||||
echo -e "Mod $mod_name ${GREEN}enabled${NC} successfully." >&2
|
echo -e "Mod $mod_name ${GREEN}enabled${NC} successfully." >&2
|
||||||
else
|
else
|
||||||
echo -e "${RED}Error${NC}: Failed to enable mod." >&2
|
echo -e "${RED}Error${NC}: Failed to enable mod." >&2
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
|
||||||
function mod_reset() {
|
function mod_reset() {
|
||||||
@@ -377,23 +376,23 @@ function mod_install() {
|
|||||||
# parse arguments
|
# parse arguments
|
||||||
while [[ $# -gt 0 ]]; do
|
while [[ $# -gt 0 ]]; do
|
||||||
case "$1" in
|
case "$1" in
|
||||||
-n)
|
-n)
|
||||||
mod_name="$2"; shift 2
|
mod_name="$2"; shift 2
|
||||||
;;
|
;;
|
||||||
--help|-h)
|
--help|-h)
|
||||||
display_install_help; exit 0
|
display_install_help; exit 0
|
||||||
;;
|
;;
|
||||||
*)
|
*)
|
||||||
if [[ -f "$1" && "$1" == *.zip ]]; then
|
if [[ -f "$1" && "$1" == *.zip ]]; then
|
||||||
mod_zip="$1"
|
mod_zip="$1"
|
||||||
elif [[ -d "$1" ]]; then
|
elif [[ -d "$1" ]]; then
|
||||||
mod_dir="$1"
|
mod_dir="$1"
|
||||||
else
|
else
|
||||||
mod_files+=("$1")
|
mod_files+=("$1")
|
||||||
fi
|
fi
|
||||||
shift
|
shift
|
||||||
;;
|
;;
|
||||||
esac
|
esac
|
||||||
done
|
done
|
||||||
|
|
||||||
# zip file containing mod files
|
# zip file containing mod files
|
||||||
@@ -569,9 +568,9 @@ function mod_list() {
|
|||||||
|
|
||||||
echo "Installed mods:" >&2
|
echo "Installed mods:" >&2
|
||||||
awk -v GREEN="$GREEN" -v RED="$RED" -v NC="$NC" -F, '{
|
awk -v GREEN="$GREEN" -v RED="$RED" -v NC="$NC" -F, '{
|
||||||
color = ($2 == "DISABLED") ? RED : GREEN;
|
color = ($2 == "DISABLED") ? RED : GREEN;
|
||||||
if (length($4) > 150) $4 = substr($4, 1, 147) "...";
|
if (length($4) > 150) $4 = substr($4, 1, 147) "...";
|
||||||
printf "%2s. [%s%s%s] %s (%s)\n", $1, color, $2, NC, $3, $4}' "$DB_FILE"
|
printf "%2s. [%s%s%s] %s (%s)\n", $1, color, $2, NC, $3, $4}' "$DB_FILE"
|
||||||
}
|
}
|
||||||
|
|
||||||
function mod_export() {
|
function mod_export() {
|
||||||
@@ -581,7 +580,7 @@ function mod_export() {
|
|||||||
fi
|
fi
|
||||||
|
|
||||||
echo -ne "Archive file will be saved in the current directory ($(pwd)). Continue? (Y/n): "
|
echo -ne "Archive file will be saved in the current directory ($(pwd)). Continue? (Y/n): "
|
||||||
read -r confirm
|
read -r confirm
|
||||||
if [[ "$confirm" == "y" || "$confirm" == "Y" || "$confirm" = "" ]]; then
|
if [[ "$confirm" == "y" || "$confirm" == "Y" || "$confirm" = "" ]]; then
|
||||||
OUT_DIR=$(mktemp -d)
|
OUT_DIR=$(mktemp -d)
|
||||||
MODS_EXPORT_DIR="$OUT_DIR/Helldivers 2 Mods"
|
MODS_EXPORT_DIR="$OUT_DIR/Helldivers 2 Mods"
|
||||||
|
|||||||
+14
-15
@@ -34,7 +34,7 @@ breaking_changes_patches=(
|
|||||||
["2"]='sed -i "s/^\([0-9]\+\),/\1,ENABLED,/" "$1/mods.csv"'
|
["2"]='sed -i "s/^\([0-9]\+\),/\1,ENABLED,/" "$1/mods.csv"'
|
||||||
)
|
)
|
||||||
|
|
||||||
# Script
|
# Handle breaking changes
|
||||||
|
|
||||||
if [[ -x "$(command -v $SCRIPT_NAME)" ]]; then
|
if [[ -x "$(command -v $SCRIPT_NAME)" ]]; then
|
||||||
installed_version=$($SCRIPT_NAME --version)
|
installed_version=$($SCRIPT_NAME --version)
|
||||||
@@ -62,17 +62,16 @@ if [[ -x "$(command -v $SCRIPT_NAME)" ]]; then
|
|||||||
search_dir="${HOME}"
|
search_dir="${HOME}"
|
||||||
target_dir="Steam/steamapps/common/Helldivers\ 2/data"
|
target_dir="Steam/steamapps/common/Helldivers\ 2/data"
|
||||||
echo "Searching for the Helldivers 2 data directory... (20 seconds timeout)" >&2
|
echo "Searching for the Helldivers 2 data directory... (20 seconds timeout)" >&2
|
||||||
|
|
||||||
game_dir=$(timeout 20 find "$search_dir" -type d -path "*/$target_dir" 2>/dev/null | head -n 1)
|
game_dir=$(timeout 20 find "$search_dir" -type d -path "*/$target_dir" 2>/dev/null | head -n 1)
|
||||||
if [[ -z "$game_dir" ]]; then
|
if [[ -z "$game_dir" ]]; then
|
||||||
echo "Could not find the Helldivers 2 data directory automatically." >&2
|
echo "Could not find the Helldivers 2 data directory automatically." >&2
|
||||||
read -p "Please enter the path to the Helldivers 2 data directory: " game_dir
|
IFS= read -ep "Please enter the path to the Helldivers 2 data directory: " game_dir
|
||||||
game_dir=$(eval echo "$game_dir")
|
if [[ ! -d "$game_dir" ]]; then
|
||||||
|
echo -e "${RED}Error${NC}: Provided path is not a valid directory." >&2
|
||||||
if [[ ! -d "$game_dir" ]]; then
|
exit 1
|
||||||
echo -e "${RED}Error${NC}: Provided path is not a valid directory." >&2
|
fi
|
||||||
exit 1
|
fi
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
[[ ! -f "$game_dir/mods.csv" ]] && { echo -e "${RED}Error:${NC} mods.csv not found in $game_dir."; exit 1; }
|
[[ ! -f "$game_dir/mods.csv" ]] && { echo -e "${RED}Error:${NC} mods.csv not found in $game_dir."; exit 1; }
|
||||||
|
|
||||||
@@ -87,11 +86,11 @@ if [[ -x "$(command -v $SCRIPT_NAME)" ]]; then
|
|||||||
[[ -n "${breaking_changes_patches[$i]}" ]] && eval $(echo "${breaking_changes_patches[$i]}" | sed "s:\$1:$game_dir:")
|
[[ -n "${breaking_changes_patches[$i]}" ]] && eval $(echo "${breaking_changes_patches[$i]}" | sed "s:\$1:$game_dir:")
|
||||||
if [[ $? -ne 0 ]]; then
|
if [[ $? -ne 0 ]]; then
|
||||||
echo -ne "${RED}Error:${NC} Failed to apply breaking changes patch for version $i. Do you want to continue? (Y/n): "
|
echo -ne "${RED}Error:${NC} Failed to apply breaking changes patch for version $i. Do you want to continue? (Y/n): "
|
||||||
read -r response
|
read -er response
|
||||||
|
|
||||||
[[ "$response" != "y" && "$response" != "Y" && -n "$response" ]] && { echo "Exiting. Uninstall the script first the retry the install script."; exit 1; }
|
[[ "$response" != "y" && "$response" != "Y" && -n "$response" ]] && { echo "Exiting. Uninstall the script first the retry the install script."; exit 1; }
|
||||||
else
|
else
|
||||||
echo -e "Breaking changes patch for version $i applied ${GREEN}successfully${NC}."
|
echo -e "Breaking changes patch for version ${ORANGE}$i${NC} applied ${GREEN}successfully${NC}."
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
@@ -100,12 +99,12 @@ fi
|
|||||||
|
|
||||||
# Install
|
# Install
|
||||||
|
|
||||||
read -p "Install the script to $DESTINATION_PATH or specify another path (must be included in \$PATH)? (Y/path): " response
|
IFS= read -ep "Install the script to $DESTINATION_PATH or specify another path (must be included in \$PATH)? (Y/path): " response
|
||||||
|
|
||||||
if [[ "$response" != "y" && "$response" != "Y" && -n "$response" ]]; then
|
if [[ "$response" != "y" && "$response" != "Y" && -n "$response" ]]; then
|
||||||
DESTINATION_PATH=$(eval echo "$response")
|
DESTINATION_PATH="$response"
|
||||||
if [[ ! -d "$DESTINATION_PATH" ]]; then
|
if [[ ! -d "$DESTINATION_PATH" ]]; then
|
||||||
echo -e "${RED}Error:${NC} Path $DESTINATION_PATH does not exist. Exiting..."
|
echo -e "${RED}Error:${NC} Path $DESTINATION_PATH does not exist."
|
||||||
exit 1
|
exit 1
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|||||||
Reference in New Issue
Block a user