A Minecraft CLI mod manager using Modrinth AND CurseForge
I recommend to create a new virtualenv and use pip to install modweaver.
git clone https://github.com/tyra314/modweaver.git
cd modweaver
pip install -U virtualenv
python -m venv venv
# On Linux and MacOS
. venv/bin/activate
# ... or on Windows:
.\venv\Scripts\activate
pip install .
The first step is to create a new mod environment. For that, we use the init
command
and provide the Minecraft version and Modloader. For example:
cd /path/to/minecraft/mods
modweaver init 1.17.1 fabric
This creates the file .mods.toml
, which modweaver uses to store information about the tracked mods.
If there are already mods in the folder, we can ask modweaver to track those.
modweaver --mr discover *.jar
modweaver --cf discover *.jar
In the above example, if a mod was found using the first call with Modrinth backend, modweaver won't try to find it during the second call with CurseForge
We can get a list of all currently tracked mods:
modweaver list
Now, we can start adding mods as well:
modweaver --mr add Abc12345
modweaver --cf add 123456
Or remove mods:
modweaver remove Abc12345
modweaver remove 123456
If we need to know everything about a mod, the info
command is our friend:
modweaver --mr info Abc12345
modweaver --cf info 123456
We can also upgrade mods. First, let us look for outdated mods:
modweaver --mr outdated
modweaver --cf outdated
And to upgrade all mods, we can use:
modweaver --mr upgrade
modweaver --cf upgrade
Or, we can also upgrade specific mods only:
modweaver --mr upgrade Abc12345
modweaver --cf upgrade 123456
If a particular release introduced a grave bug, we can roll back to a different version of the mod.
The versions
command can list compatible or even all versions for a given mod:
modweaver --mr versions Abc12345
modweaver --cf versions 123456
Using the mod id and version id, we can install the desired version:
modweaver --mr versions Abc12345 DEFG5467
modweaver --cf versions 123456 789101112
Once downgraded, we probably want to pin the current version of the mod, so it doesn't get automatically upgraded in the future.
modweaver pin Abc12345
modweaver pin 123456
A pinned mod, won't be automatically upgrade, but it still gets listed by the outdated
command.
Of course, there is also an unpin command, which might come in handy, once the bug gets resolved in a newer release.
modweaver unpin Abc12345
modweaver unpin 123456
The Modrinth backend also allows to search for mods matching a search term and the current mod environment.
modweaver --mr search Fabric
Modweaver supports Modrinth and curseforge as backend for downloading mods.
You need to manually switch between the backends using the --provider
option.
Modweaver also accepts the shorthands --modrinth
, --mr
, --curseforge
, and --cf
.
- The output could be improved for some commands, if no mods were affected
- The mod backend could be more transparent, some commands should use both, e.g., upgrade, outdated
- Downloading dependencies of mods isn't implemented yet
- There's no progress bar :(
- Don't manually update or remove mods that are tracked by Modweaver, it will be confused.