π Please support the project
-
BTC:
bc1qaj2ef2jlrt2uafn4kc9cmscuu8yqkjkvxxr5zu -
ETH:
0x284E6121362ea1C69528eDEdc309fC8b90fA5578 -
ZEC:
t1Jb5tH61zcSTy2QyfsxftUEWHikdSYpPoz -
Or by my music on π· bandcamp
-
Or message me if you would like to donate in other way π°
micro-minecraft-launcher is under development. Serious bugs are possible!
β οΈ Not tested on OSX
usage: micro-minecraft-launcher-1.2.dev5-linux-x86_64 [-h] [-c CONFIG] [-d GAME_DIR] [-l] [-u USER] [--auth-uuid AUTH_UUID]
[--auth-access-token AUTH_ACCESS_TOKEN] [--user-type USER_TYPE] [-i]
[--java-path JAVA_PATH] [-e KEY=VALUE [KEY=VALUE ...]] [-j JVM_ARGS]
[-g GAME_ARGS] [--resolver-processes RESOLVER_PROCESSES] [--write-profiles]
[--run-before RUN_BEFORE] [--run-before-java RUN_BEFORE_JAVA]
[--delete-files DELETE_FILES [DELETE_FILES ...]] [--verbose] [--version]
[id]
Simple cross-platform cli launcher for Minecraft
positional arguments:
id minecraft version to launch. Run with --list-versions to see available versions
options:
-h, --help show this help message and exit
-c CONFIG, --config CONFIG
path to config file (Default: .micro-minecraft-launcher.json)
-d GAME_DIR, --game-dir GAME_DIR
path to .minecraft (Default: /home/fern/.minecraft)
-l, --list-versions print online (official), local versions and exit
-u USER, --user USER player's username
--auth-uuid AUTH_UUID
player's UUID (Default: offline UUID from username)
--auth-access-token AUTH_ACCESS_TOKEN
Mojang Access Token or the final token in the Microsoft authentication scheme
--user-type USER_TYPE
"msa" for Microsoft Authentication Scheme, "legacy" for Legacy Minecraft Authentication and "mojang" for
Legacy Mojang Authentication (Default: mojang)
-i, --isolate put "saves", "logs" and all other profile data inside versions/version_id directory instead of game_dir
--java-path JAVA_PATH
custom path to java binary (Default: download locally)
-e KEY=VALUE [KEY=VALUE ...], --env-variables KEY=VALUE [KEY=VALUE ...]
env variable(s) for final command as key=value pairs (Ex.: -e version_type=snapshot launcher_name=custom-
launcher) NOTE: If a value contains spaces, you should define it with double quotes: launcher_name="Custom
launcher" NOTE: Values are always treated as strings NOTE: Will merge "env_variables" from config file and
overwrite same variables
-j JVM_ARGS, --jvm-args JVM_ARGS
extra arguments for Java separated with spaces (Ex.: -j="-Xmx6G -XX:G1NewSizePercent=20") NOTE: You should
define it with double quotes as in example NOTE: If an argument contains spaces, you should define it with
double quotes: -j '-foo "multiple words"' NOTE: Will append to the bottom of "jvm_args" from config file
-g GAME_ARGS, --game-args GAME_ARGS
extra arguments for Minecraft separated with spaces (Ex.: -g="--server 192.168.0.1 --port 25565") NOTE: You
should define it with double quotes as in example NOTE: If an argument contains spaces, you should define it
with double quotes: -g '-foo "multiple words"' NOTE: Will append to the bottom of "game_args" from config
file
--resolver-processes RESOLVER_PROCESSES
number of processes to resolve (download, copy and unpack) files(Default: 4)
--write-profiles write all found local versions into game_dir/launcher_profiles.json (useful for installing Forge/Fabric)
--run-before RUN_BEFORE
run specified command in shell before launching game (ex.: --run-before "{local_java} -jar
forge_installer.jar --installClient .") NOTE: Consider adding --run-before-java 17 argument to replace all
{local_java} with downloaded java NOTE: Consider adding --write-profiles argument NOTE: Consider adding
--delete-files "file/to/delete" argument
--run-before-java RUN_BEFORE_JAVA
download specified version of Java and replace all "{local_java}" in --run-before with local java path
--delete-files DELETE_FILES [DELETE_FILES ...]
delete files before launching minecraft. Uses glob to find files (Ex.: --delete-files "forge*installer.jar"
"hs_err_pid*.log")
--verbose debug logs
--version show launcher's version number and exit
examples:
micro-minecraft-launcher --list-versions
micro-minecraft-launcher 1.21
micro-minecraft-launcher --isolate 1.18.2
micro-minecraft-launcher --config /path/to/custom/micro-minecraft-launcher.json
micro-minecraft-launcher -d /path/to/custom/minecraft -j="-Xmx6G" -g="--server 192.168.0.1" 1.21
micro-minecraft-launcher -j="-Xmx4G" -g="--width 800 --height 640" 1.18.2
micro-minecraft-launcher --write-profiles
micro-minecraft-launcher --write-profiles --run-before-java 17 --run-before "java -jar forge-1.18.2-40.2.4-installer.jar --installClient ." --delete-files "forge*.jar"
β οΈ NOTE: CLI arguments will overwrite config
You can use micro-minecraft-launcher in your modpack. For that, create configuration file (see section below) and install custom profile (
versions/version_id/version_id.json) and it's extra libraries if needed (ex. forge)
- To download executable file, go to the link https://github.com/F33RNI/micro-minecraft-launcher/releases/latest and download the file for your device
- Alternatively, you can build the app yourself. For this, refer to the
ποΈ Build from Sourcesection
With configuration file, users can just lauch executable file without any other arguments For that, create file named
.micro-minecraft-launcher.jsonin the same directory as launcher and specify whatever you want in it
{
"game_dir": "path/to/custom/game/dir or . to use current dir",
"id": "version id to launch. Ex.: 1.18.2-forge-40.2.4",
"isolate_profile": true to save logs, opions, saves, resourcepacks, etc. inside versions/version_id,
"user": "player's username (if not specified, user will be asked)",
"auth_uuid": "player's UUID",
"auth_access_token": "Mojang Access Token or the final token in the Microsoft authentication scheme",
"user_type": "msa" for Microsoft Authentication Scheme,
"legacy" for Legacy Minecraft Authentication and
"mojang" for Legacy Mojang Authentication (Default: mojang),
"java_path": "path/to/custom/java/executable",
"env_variables": {
"launcher_name": "custom-launcher"
}
"jvm_args": [
"-Xss1M",
"-Xmx4G",
"-XX:+UnlockExperimentalVMOptions",
"-XX:+UseG1GC",
"-XX:G1NewSizePercent=20",
"-XX:G1ReservePercent=20",
"-XX:MaxGCPauseMillis=50",
"-XX:G1HeapRegionSize=32M",
"-Dfml.ignoreInvalidMinecraftCertificates=true",
"-Dfml.ignorePatchDiscrepancies=true",
"-Djava.net.preferIPv4Stack=true",
"-Dminecraft.applet.TargetDirectory=."
],
"game_args": [
"--server",
"server ip to join automatically",
"--width",
"925",
"--height",
"530"
],
"resolver_processes": 4 (number of processes to download / copy / unpack files),
"write_profiles": true (write all found local versions into game_dir/launcher_profiles.json),
"run_before": "{local_java} -jar path/to/forge-...-installer.jar --installClient .",
"run_before_java": version of java to install and replace {local_java} with it's path,
"delete_files": [
"any file patterns to delete (for glob)",
...
]
}
NOTE: You can omit any config key. None of them are required
{
"game_dir": ".",
"id": "1.18.2-forge-40.2.4",
"jvm_args": [
"-Xss1M",
"-Xmx4G",
"-XX:+UnlockExperimentalVMOptions",
"-XX:+UseG1GC",
"-XX:G1NewSizePercent=20",
"-XX:G1ReservePercent=20",
"-XX:MaxGCPauseMillis=50",
"-XX:G1HeapRegionSize=32M",
"-Dfml.ignoreInvalidMinecraftCertificates=true",
"-Dfml.ignorePatchDiscrepancies=true",
"-Djava.net.preferIPv4Stack=true",
"-Dminecraft.applet.TargetDirectory=."
],
"game_args": [
"--width",
"925",
"--height",
"530"
],
"write_profiles": true,
"run_before": "{local_java} -jar forge-1.18.2-40.2.4-installer.jar --installClient .",
"run_before_java": 17,
"delete_files": [
"forge-1.18.2-40.2.4-installer*",
"hs_err_pid*.log"
]
}{
"game_dir": ".",
"id": "fabric-loader-0.15.11-1.20.1",
"jvm_args": [
"-Xss1M",
"-Xmx6G",
"-XX:+UnlockExperimentalVMOptions",
"-XX:+UseG1GC",
"-XX:G1NewSizePercent=20",
"-XX:G1ReservePercent=20",
"-XX:MaxGCPauseMillis=50",
"-XX:G1HeapRegionSize=32M",
"-Dfml.ignoreInvalidMinecraftCertificates=true",
"-Dfml.ignorePatchDiscrepancies=true",
"-Djava.net.preferIPv4Stack=true",
"-Dminecraft.applet.TargetDirectory=.",
"-Dorg.lwjgl.glfw.libname=./fix/libglfw.so"
],
"game_args": [
"--width",
"925",
"--height",
"530"
],
"write_profiles": true,
"run_before": "{local_java} -jar fabric-installer-1.0.1.jar client -dir . -mcversion 1.20.1 -loader 0.15.11",
"run_before_java": 17,
"delete_files": [
"fabric-installer-*",
"hs_err_pid*.log"
]
}On linux, just run launcher with DRI_PRIME=1 (for open-source drivers) or prime-run (for proprietary driver)
- ex.:
DRI_PRIME=1 ./micro-minecraft-launcher-1.2.dev7-linux-x86_64 - ex.:
prime-run ./micro-minecraft-launcher-1.2.dev7-linux-x86_64
You need to manually specify what GPU launcher and java.exe should use
This tutorial is copied from https://pureinfotech.com/set-gpu-app-windows-10/ I don't have windows, so idk will it work or not
- Open Settings on Windows 10.
- Click on System.
- Click on Display.
- Under the "Multiple displays" section, click the Graphics settings option.
- Select the app type using the drop-down menu: Classic app β traditional (Win32) desktop programs.
- Click the "Browse" button and locate the locally downloaded "java.exe" by launcher
- Use the drop-down menu and select the app.
- Click the Add button.
- Set GPU for app
- Click the Options button.
- App GPU options
- Set the graphics card preference to use for the app: High performance β runs the app on the most capable GPU, usually an external or discrete graphics processor. Click the Save button.
The problem is related to the libglfw.so library on Linux, so you need to manually recompile it from source
# Select working dir (optionally)
cd "$HOME/Downloads"
# Clone repo
git clone https://github.com/glfw/glfw.git && cd glfw
# Build it
cmake -S . -B build -D BUILD_SHARED_LIBS=ON -D GLFW_BUILD_EXAMPLES=OFF -D GLFW_BUILD_TESTS=OFF -D GLFW_BUILD_DOCS=OFF -D GLFW_BUILD_WAYLAND=ON -D GLFW_BUILD_X11=ON && cmake --build build
# Copy shared libs
mkdir -p "$HOME/.local/lib/glfw" && cp build/src/libglfw* "$HOME/.local/lib/glfw/"
# Delete repo (optional)
cd ..
rm -rf glfw# Select working dir (optionally)
cd "$HOME/Downloads"
# Clone glfw-wayland from BoyOrigin
git clone --recursive https://github.com/BoyOrigin/glfw-wayland.git && cd glfw-wayland
# Or my fork (it's the same, just in case)
# git clone --recursive https://github.com/F33RNI/glfw-wayland.git && cd glfw-wayland
# Make sure you setup git in your system properly
# If not, run this
# git config --global user.name "You name"
# git config --global user.email "You email"
# In case of warning / error try to run this 2 times
./applyPatches.sh
# Build patched version without X11
cd glfw-wayland
cmake -S . -B build -D BUILD_SHARED_LIBS=ON -D GLFW_BUILD_EXAMPLES=OFF -D GLFW_BUILD_TESTS=OFF -D GLFW_BUILD_DOCS=OFF -D GLFW_BUILD_WAYLAND=ON -D GLFW_BUILD_X11=OFF && cmake --build build
# Copy shared libs
mkdir -p "$HOME/.local/lib/glfw" && cp build/src/libglfw* "$HOME/.local/lib/glfw/"
# Delete repo (optional)
cd ../..
rm -rf glfw-waylandSpecify path to shared lib in jvm_args (in config) or using --jvm-args argument like so:
{
"game_dir": ".",
"id": "fabric-loader-0.15.11-1.20.1",
"jvm_args": [
...
"-Dorg.lwjgl.glfw.libname=/path/to/.local/lib/glfw/libglfw.so"
],
...
}git clone https://github.com/F33RNI/micro-minecraft-launcher.git
cd micro-minecraft-launcherpython -m venv venv
# For Linux
source venv/bin/activate
# For Windows
venv\Scripts\activate.bat
pip install -r requirements.txt --upgrade-
Linux
export PYTHONPATH=./src:$PYTHONPATH
-
Windows
set PYTHONPATH=.\src;%PYTHONPATH%
python -m mml --verbosepip install pyinstaller
pyinstaller micro-minecraft-launcher.specExecutable will be inside dist/ directory
- Anyone can contribute! Just create a pull request
- Please use black formatter style for code
- Please use Conventional Commits style for commits
