6.1 KiB
Prism Launcher Nix Packaging
Installing a stable release (nixpkgs)
Prism Launcher is packaged in nixpkgs since 22.11.
Check the NixOS Wiki for up-to-date instructions.
Installing a development release (flake)
We use cachix to cache our development and release builds.
If you want to avoid rebuilds you may add the Cachix bucket to your substitutors, or use --accept-flake-config
to temporarily enable it when using nix commands.
Example (NixOS):
{
nix.settings = {
trusted-substituters = [ "https://prismlauncher.cachix.org" ];
trusted-public-keys = [
"prismlauncher.cachix.org-1:9/n/FGyABA2jLUVfY+DEp4hKds/rwO+SCOtbOkDzd+c="
];
};
}
Installing the package directly
After adding github:PrismLauncher/PrismLauncher to your flake inputs, you can access the flake's packages output.
Example:
{
inputs = {
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
prismlauncher = {
url = "github:PrismLauncher/PrismLauncher";
# Optional: Override the nixpkgs input of prismlauncher to use the same revision as the rest of your flake
# Note that this may break the reproducibility mentioned above, and you might not be able to access the binary cache
#
# inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs =
{ nixpkgs, prismlauncher, ... }:
{
nixosConfigurations.foo = nixpkgs.lib.nixosSystem {
modules = [
./configuration.nix
(
{ pkgs, ... }:
{
environment.systemPackages = [ prismlauncher.packages.${pkgs.system}.prismlauncher ];
}
)
];
};
};
}
Using the overlay
Alternatively, if you don't want to use our packages output, you can add our overlay to your nixpkgs instance.
This will ensure Prism is built with your system's packages.
Warning
Depending on what revision of nixpkgs your system uses, this may result in binaries that differ from the above
packagesoutput If this is the case, you will not be able to use the binary cache
Example:
{
inputs = {
nixpkgs.url = "github:NixOS/nixpkgs/nixos-unstable";
prismlauncher = {
url = "github:PrismLauncher/PrismLauncher";
# Optional: Override the nixpkgs input of prismlauncher to use the same revision as the rest of your flake
# Note that this may break the reproducibility mentioned above, and you might not be able to access the binary cache
#
# inputs.nixpkgs.follows = "nixpkgs";
};
};
outputs =
{ nixpkgs, prismlauncher, ... }:
{
nixosConfigurations.foo = nixpkgs.lib.nixosSystem {
modules = [
./configuration.nix
(
{ pkgs, ... }:
{
nixpkgs.overlays = [ prismlauncher.overlays.default ];
environment.systemPackages = [ pkgs.prismlauncher ];
}
)
];
};
};
}
Installing the package ad-hoc (nix shell, nix run, etc.)
You can simply call the default package of this flake.
Example:
nix run github:PrismLauncher/PrismLauncher
nix shell github:PrismLauncher/PrismLauncher
nix profile install github:PrismLauncher/PrismLauncher
Installing a development release (without flakes)
We use Cachix to cache our development and release builds. If you want to avoid rebuilds you may add the Cachix bucket to your substitutors.
Example (NixOS):
{
nix.settings = {
trusted-substituters = [ "https://prismlauncher.cachix.org" ];
trusted-public-keys = [
"prismlauncher.cachix.org-1:9/n/FGyABA2jLUVfY+DEp4hKds/rwO+SCOtbOkDzd+c="
];
};
}
Installing the package directly (fetchTarball)
We use flake-compat to allow using this Flake on a system that doesn't use flakes.
Example:
{ pkgs, ... }:
{
environment.systemPackages = [
(import (
builtins.fetchTarball "https://github.com/PrismLauncher/PrismLauncher/archive/develop.tar.gz"
)).packages.${pkgs.system}.prismlauncher
];
}
Using the overlay (fetchTarball)
Alternatively, if you don't want to use our packages output, you can add our overlay to your instance of nixpkgs.
This results in Prism using your system's libraries
Example:
{ pkgs, ... }:
{
nixpkgs.overlays = [
(import (
builtins.fetchTarball "https://github.com/PrismLauncher/PrismLauncher/archive/develop.tar.gz"
)).overlays.default
];
environment.systemPackages = [ pkgs.prismlauncher ];
}
Installing the package ad-hoc (nix-env)
You can add this repository as a channel and install its packages that way.
Example:
nix-channel --add https://github.com/PrismLauncher/PrismLauncher/archive/develop.tar.gz prismlauncher
nix-channel --update prismlauncher
nix-env -iA prismlauncher.prismlauncher
Package variants
Both Nixpkgs and this repository offer the following packages:
prismlauncher- The preferred build, wrapped with everything necessary to run the launcher and Minecraftprismlauncher-unwrapped- A minimal build that allows for advanced customization of the launcher's runtime environment
Customizing wrapped packages
The wrapped package (prismlauncher) offers some build parameters to further customize the launcher's environment.
The following parameters can be overridden:
additionalLibs(default:[ ]) Additional libraries that will be added toLD_LIBRARY_PATHadditionalPrograms(default:[ ]) Additional libraries that will be added toPATHcontrollerSupport(default:isLinux) Turn on/off support for controllers on Linux (macOS will always have this)gamemodeSupport(default:isLinux) Turn on/off support for Feral GameMode on Linuxjdks(default:[ jdk21 jdk17 jdk8 ]) Java runtimes added toPRISMLAUNCHER_JAVA_PATHSvariablemsaClientID(default:null, requires full rebuild!) Client ID used for Microsoft AuthenticationtextToSpeechSupport(default:isLinux) Turn on/off support for text-to-speech on Linux (macOS will always have this)