Another FTL: Faster Than Light Mod Manager
This project is an alternative to the Slipstream Mod Manager, written in Rust and with some additional features.
- Regular FTL mods (mostly Slipstream compatible*)
- Supports mod tags from Blizz's Slipstream fork
- Automatic Hyperspace installer
- Mostly functional XML Sandbox
Currently automatic hyperspace installation is supported for the following FTL versions:
- Steam (Linux and Windows)
- Epic (untested)
- Origin (untested)
Patching the Microsoft version is technically supported but you may encounter permission problems if you try to patch it in the original installation directory.
* Most Slipstream mods are supported but these Slipstream features are currently unimplemented:
- .rawappend.xml/.xml.rawappend files
- Some ill-formed XML files may still be rejected by ftlman but accepted by Slipstream.
These features are not particularly difficult to implement but I just don't have any mods that actually use them so I can't test changes. If you find a mod that requires any of these please open an issue.
If you find a mod that fails to patch with ftlman but works with slipstream or one that works different under ftlman also open an issue.
Pre-built binaries for both Linux and Windows are available in the Releases tab.
Compilation requires a nightly Rust toolchain due to questionable design decisions I made in silpkg. For instructions on installing Rust go to https://www.rust-lang.org/tools/install, make sure to select the nightly toolchain release during installation.
After installing Rust, open a terminal then execute the following command:
cargo install --locked --git https://github.com/afishhh/ftlman ftlman
Note
The same command can be used to update the program.
You should then be able to run ftlman
in a terminal to start the program.
Note
These instructions also apply to Windows users, just replace terminal with cmd.exe
.
Add this repository to your flake inputs and then use the default package output.
{
# ... other inputs ...
inputs.ftlman.url = "github:afishhh/ftlman";
# Optionally reuse top-level nixpkgs
# inputs.ftlman.inputs.nixpkgs.follows = "nixpkgs";
outputs = { self, ftlman, ... }:
let
package = ftlman.packages.${system}.default;
in {
# use package
};
}
You can also try out the program using nix run
:
nix run github:afishhh/ftlman