Compare commits
1 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| df3c780270 |
@@ -1,76 +1,122 @@
|
||||
# Helldivers 2 Mod Manager CLI
|
||||
|
||||
## Deprecation notice
|
||||
|
||||
> [!Caution]
|
||||
> This project is deprecated as of 30/09/2025 in favor of [Arsenal](https://www.nexusmods.com/helldivers2/mods/4664)'s 0.30.0 release, a GUI mod manager that supports every feature of Helldivers 2 Mod Manager CLI and more, on Linux.
|
||||
|
||||
**Thank you for the support up until now and make sure to check out Arsenal!**
|
||||
|
||||
## Overview
|
||||
|
||||
Helldivers 2 Mod Manager CLI is a command line interface for managing Helldivers 2 mods. Since there is no Linux mod manager available and I like being a nerd by using CLI tools instead of GUIs, this project was born.
|
||||
|
||||
This mod manager is complete, the version will always [remain at 0.x.x](https://0ver.org/). Version 0.6.x will be the last version of this mod manager.
|
||||
|
||||
## Installation
|
||||
|
||||
Pre-requisites:
|
||||
|
||||
- The `unzip` package must be installed for ZIP archives.
|
||||
- The `unarchiver` package is recommended for RAR and 7Z archives.
|
||||
- You must have the `unzip` package installed for zip archives;
|
||||
- You might want to have the `unarchiver` package installed for rar archives.
|
||||
|
||||
To install Helldivers 2 Mod Manager CLI run the following command in the terminal:
|
||||
To install Helldivers 2 Mod Manager CLI run the following command in your terminal:
|
||||
|
||||
```bash
|
||||
bash -c "$(curl -fsSL https://raw.githubusercontent.com/v4n00/h2mm-cli/refs/heads/master/install.sh)"
|
||||
```
|
||||
|
||||
> [!CAUTION]
|
||||
> 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 repository for yourself.
|
||||
|
||||
## Usage
|
||||
|
||||
The script gets added to `/usr/local/bin/h2mm` (or `$HOME/.local/bin` on Steam Deck) and can be used by running `h2mm` in the shell, which will print the help message along with all available commands.
|
||||
The script gets added to `/usr/local/bin/h2mm` (or `$HOME/.local/bin` on Steam Deck) and can be used by running `h2mm` in your shell, which will show the help message explaining how to use the script.
|
||||
|
||||
```bash
|
||||
h2mm --help
|
||||
h2mm
|
||||
```
|
||||
|
||||
To find out how to use a command, run `h2mm COMMAND --help`. This is the most up-to-date source of information about the commands.
|
||||
### Available commands
|
||||
|
||||
## Available commands
|
||||
- `install` or `i` - Install a mod by the file provided (directory, zip, patch);
|
||||
- `uninstall` or `u` - Uninstall a mod;
|
||||
- `list` or `l` - List all installed mods;
|
||||
- `enable` or `e` - Enable a mod;
|
||||
- `disable` or `d` - Disable a mod;
|
||||
- `rename` or `r` - Rename a mod;
|
||||
- `order` or `o` - Change load order for a mod;
|
||||
- `export` or `ex` - Export installed mods to a zip file;
|
||||
- `import` or `im` - Import mods from a zip file;
|
||||
- `modpack-create` or `mc` - Create a modpack from the currently installed mods;
|
||||
- `modpack-switch` or `ms` - Switch to a modpack;
|
||||
- `modpack-list` or `ml` - List all installed modpacks;
|
||||
- `modpack-delete` or `md` - Delete a modpack;
|
||||
- `modpack-overwrite` or `mo` - Overwrite a modpack;
|
||||
- `modpack-reset` or `mr` - Reset all installed modpacks;
|
||||
- `nexus-setup` or `ns` - Setup Nexus Mods integration;
|
||||
- `update` or `up` - Update h2mm to latest version;
|
||||
- `reset` or `rs` - Reset all installed mods;
|
||||
- `help` or `h` - Display this help message.
|
||||
|
||||
- `install` or `i` - Install a mod by the file provided (directory, zip, patch)
|
||||
- `uninstall` or `u` - Uninstall a mod
|
||||
- `list` or `l` - List all installed mods
|
||||
- `enable` or `e` - Enable a mod
|
||||
- `disable` or `d` - Disable a mod
|
||||
- `rename` or `r` - Rename a mod
|
||||
- `order` or `o` - Change load order for a mod
|
||||
- `export` or `ex` - Export installed mods to a zip file
|
||||
- `import` or `im` - Import mods from a zip file
|
||||
- `modpack` or `m` - Manage modpacks (collections of mods)
|
||||
- `nexus-setup` or `ns` - Setup Nexus Mods integration
|
||||
- `update` or `up` - Update h2mm to latest version
|
||||
- `reset` or `rs` - Reset all installed mods
|
||||
- `help` or `h` - Display this help message
|
||||
### Examples
|
||||
|
||||
## Examples
|
||||
To find out how to use a command, you can run `h2mm <COMMAND> --help`.
|
||||
|
||||
#### Install mod(s)
|
||||
|
||||
```bash
|
||||
h2mm install --help
|
||||
h2mm install ~/Downloads/mod.zip
|
||||
h2mm install ~/Downloads/mod\ files/
|
||||
h2mm install a0b1c2d3.patch_0 a0b1c2d3.patch_0.stream -n "Example mod"
|
||||
h2mm list
|
||||
h2mm uninstall --index 3
|
||||
h2mm modpack create "Example modpack"
|
||||
h2mm modpack switch "Example modpack"
|
||||
h2mm install mod.zip
|
||||
h2mm install /path/to/mod/directory/
|
||||
h2mm install /path/to/mod.zip /path/to/mod2.zip /path/to/mod/files # mix and match hoewever you want
|
||||
h2mm install -n "Example mod" mod.patch_0 mod.patch_0.stream # -n is mandatory when using files
|
||||
```
|
||||
|
||||
> When installing, it is recommended to be in the directory where mod archives are, or to use absolute paths. Use `cd ~/Downloads` to go to the Downloads folder, and run `ls -la` to find the archives to install. Use the Tab key to auto-complete file and folder names, this helps escape spaces and special characters.
|
||||
> It's better to be in the directory where the mod files are located, so you don't have to specify the full path. For mod downloads, you can do `cd ~/Downloads` and then run the command.
|
||||
>
|
||||
> Use the `--index` flag with commands that normally require a mod name to specify a mod by its index. The index can be obtained with `h2mm list`.
|
||||
> Also, use the Tab key to autocomplete the file names, as it will help you escape special characters likes spaces or quotes.
|
||||
|
||||
#### List installed mods
|
||||
|
||||
```bash
|
||||
h2mm list
|
||||
h2mm list -v # verbose mode
|
||||
```
|
||||
|
||||
#### Uninstall a mod
|
||||
|
||||
```bash
|
||||
h2mm uninstall -n "Example mod"
|
||||
h2mm uninstall -i 3 # get the index from the list command
|
||||
```
|
||||
|
||||
#### Enable/disable mods
|
||||
|
||||
```bash
|
||||
h2mm enable -n "Example mod"
|
||||
h2mm enable -i 3
|
||||
h2mm disable -n "Example mod"
|
||||
h2mm disable -i 3
|
||||
```
|
||||
|
||||
#### Updating the script
|
||||
|
||||
```bash
|
||||
h2mm update
|
||||
```
|
||||
|
||||
## Nexus Mods integration
|
||||
|
||||
Nexus Mods integration allows the use the 1-click install feature of Nexus Mods (with the "Vortex" or "Mod manager download" buttons). Set up Nexus Mods integration by running `h2mm nexus-setup`. Setup includes providing the Nexus Mods API key and selecting the preferred terminal.
|
||||
Nexus Mods integration allows you to use the 1-click install feature of Nexus Mods (with the "Vortex" or "Mod manager download" buttons). You can set up Nexus Mods integration by running the following command:
|
||||
|
||||
```bash
|
||||
h2mm nexus-setup
|
||||
```
|
||||
|
||||
You will be walked through the setup process, which will ask you for your Nexus Mods API key and your preferred terminal.
|
||||
|
||||
## Compatibility
|
||||
|
||||
The script is developed and tested on Arch Linux, but it should work on other Linux distributions as well. If you encounter any issues, please open an issue on the repository.
|
||||
|
||||
Status of platforms:
|
||||
|
||||
- Linux :white_check_mark:
|
||||
- Steam Deck :white_check_mark:
|
||||
- Windows - 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`. Nexus Mods integration is not supported on WSL.
|
||||
|
||||
## Contributing
|
||||
|
||||
|
||||
+26
-39
@@ -27,7 +27,17 @@ function log() {
|
||||
|
||||
# --- Main ---
|
||||
|
||||
log INFO "Running h2mm CLI Installer (https://github.com/v4n00/h2mm-cli)"
|
||||
# warning
|
||||
|
||||
log INFO "${RED}!!! WARNING !!!${NC}"
|
||||
cat << EOF
|
||||
This script will install Helldivers 2 Mod Manager CLI for Linux to $DESTINATION_PATH/h2mm.
|
||||
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 repository for yourself:
|
||||
https://github.com/v4n00/h2mm-cli
|
||||
EOF
|
||||
log INFO "${RED}!!! WARNING !!!${NC}"
|
||||
log INFO ""
|
||||
|
||||
# breaking changes hash table
|
||||
breaking_changes_patches=(
|
||||
@@ -61,29 +71,22 @@ if [[ -x "$(command -v h2mm)" ]]; then
|
||||
fi
|
||||
fi
|
||||
|
||||
# if steam os, set destination path to ~/.local/bin
|
||||
steamos=false
|
||||
# if steam deck, set destination path to ~/.local/bin
|
||||
log PROMPT "Are you installing on a Steam Deck? (y/N): "
|
||||
IFS= read -e response_sd
|
||||
|
||||
if [[ -f "/etc/os-release" ]]; then
|
||||
if grep -q "ID=steamos" /etc/os-release; then
|
||||
steamos=true
|
||||
fi
|
||||
fi
|
||||
|
||||
if [[ $steamos == true ]]; then
|
||||
# steam os
|
||||
if [[ "$response_sd" == "y" || "$response_sd" == "Y" ]]; then
|
||||
# steam deck
|
||||
DESTINATION_PATH="$HOME/.local/bin"
|
||||
log INFO "Detected SteamOS, setting installation path to ${ORANGE}$DESTINATION_PATH${NC}."
|
||||
|
||||
mkdir -p "$DESTINATION_PATH"
|
||||
|
||||
# check if ~/.local/bin is in PATH
|
||||
if [[ ":$PATH:" != *":$HOME/.local/bin:"* ]]; then
|
||||
# add ~/.local/bin to PATH
|
||||
log INFO "Installing the script on SteamOS means adding ${ORANGE}$DESTINATION_PATH${NC} to your \$PATH."
|
||||
log INFO "Installing the script on a Steam Deck means adding $DESTINATION_PATH to your \$PATH."
|
||||
log INFO "If you're using a different shell than bash (the default), you may need to add it manually."
|
||||
|
||||
log PROMPT "Do you want to automatically add ${ORANGE}$DESTINATION_PATH${NC} to your \$PATH in ~/.bashrc? (Y/n): "
|
||||
log PROMPT "Do you want to add $DESTINATION_PATH to your \$PATH in ~/.bashrc? (Y/n): "
|
||||
IFS= read -e response
|
||||
if [[ "$response" == "y" || "$response" = "Y" || -z "$response" ]]; then
|
||||
echo "export PATH=\"\$HOME/.local/bin:\$PATH\"" >> "$HOME/.bashrc"
|
||||
@@ -92,13 +95,13 @@ if [[ $steamos == true ]]; then
|
||||
source "$HOME/.bashrc"
|
||||
export PATH="$HOME/.local/bin:$PATH" # fallback kinda in case sourcing fails
|
||||
|
||||
log INFO "Added ${ORANGE}$DESTINATION_PATH${NC} to your \$PATH in ~/.bashrc."
|
||||
log INFO "Added $DESTINATION_PATH to your \$PATH in ~/.bashrc."
|
||||
fi
|
||||
fi
|
||||
else
|
||||
# not steam os
|
||||
# not steam deck
|
||||
# set another path if needed
|
||||
log PROMPT "Install the script to ${ORANGE}$DESTINATION_PATH${NC} or specify another path (must be included in \$PATH)? (Y/path): "
|
||||
log PROMPT "Install the script to $DESTINATION_PATH or specify another path (must be included in \$PATH)? (Y/path): "
|
||||
IFS= read -e response
|
||||
|
||||
if [[ "$response" != "y" && "$response" != "Y" && -n "$response" ]]; then
|
||||
@@ -177,17 +180,9 @@ if [[ $latest_major -gt $installed_major ]]; then
|
||||
fi
|
||||
|
||||
# install
|
||||
log INFO "Installing h2mm to ${ORANGE}$DESTINATION_PATH${NC}."
|
||||
|
||||
# check if we need sudo based on destination path
|
||||
SUDO_CMD=""
|
||||
if [[ ! -w "$DESTINATION_PATH" || ( -f "$DESTINATION_PATH/h2mm" && ! -w "$DESTINATION_PATH/h2mm" ) ]]; then
|
||||
SUDO_CMD="sudo"
|
||||
log INFO "Destination path ${RED}requires${NC} elevated permissions, using sudo."
|
||||
fi
|
||||
|
||||
$SUDO_CMD curl "$REPO_URL"/h2mm --output "$DESTINATION_PATH/h2mm"
|
||||
$SUDO_CMD chmod +x "$DESTINATION_PATH/h2mm"
|
||||
log INFO "Installing h2mm to $DESTINATION_PATH."
|
||||
sudo curl "$REPO_URL"/h2mm --output "$DESTINATION_PATH/h2mm"
|
||||
sudo chmod +x "$DESTINATION_PATH/h2mm"
|
||||
log INFO ""
|
||||
|
||||
[[ ! -x "$(command -v h2mm)" ]] && { log ERROR "Installation failed. Mod manager was not found in \$PATH." ; exit 1; }
|
||||
@@ -199,13 +194,5 @@ log INFO " -> \"unarchiver\" package for .rar archives"
|
||||
log INFO "If you do not know how to install these packages, please search for your linux distro on how to install packages."
|
||||
log INFO ""
|
||||
log INFO "Use the mod manager by running 'h2mm' in your terminal."
|
||||
log INFO "View the changelogs: https://github.com/v4n00/h2mm-cli/releases/latest"
|
||||
log INFO "Check out the ${ORANGE}Nexus Mods integration${NC} by running 'h2mm nexus-setup'."
|
||||
log INFO "Made with <3 by v4n and contributors."
|
||||
log INFO ""
|
||||
log INFO "${RED}Special announcement:${NC}"
|
||||
log INFO "The Helldivers 2 Mod Manager CLI is now deprecated in favor of the Arsenal Mod Manager."
|
||||
log INFO "Check it out here: https://www.nexusmods.com/helldivers2/mods/4664"
|
||||
log INFO "The Arsenal Mod Manager has a GUI and is more user friendly,"
|
||||
log INFO "making it the preferred choice for most users, especially since it now works on Linux!"
|
||||
log INFO "Thank you for using the Helldivers 2 Mod Manager CLI, and we hope to see you on the Arsenal Mod Manager!"
|
||||
log INFO "Check out the Nexus Mods integration by running 'h2mm nexus-setup'."
|
||||
log INFO "Made with love <3 by v4n and contributors."
|
||||
|
||||
Reference in New Issue
Block a user