Merge pull request #1574 from Scrumplex/refactor-flake

This commit is contained in:
Sefa Eyeoglu 2023-09-04 17:02:01 +02:00 committed by GitHub
commit e9ecdd05b9
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 153 additions and 69 deletions

View File

@ -23,5 +23,19 @@
outputs = inputs: outputs = inputs:
inputs.flake-parts.lib.mkFlake inputs.flake-parts.lib.mkFlake
{inherit inputs;} {inherit inputs;}
{imports = [./nix];}; {
imports = [
inputs.pre-commit-hooks.flakeModule
./nix/dev.nix
./nix/distribution.nix
];
systems = [
"x86_64-linux"
"aarch64-linux"
"x86_64-darwin"
"aarch64-darwin"
];
};
} }

View File

@ -1,31 +0,0 @@
{
inputs,
self,
...
}: {
imports = [
./dev.nix
./distribution.nix
];
_module.args = {
# User-friendly version number.
version = builtins.substring 0 8 self.lastModifiedDate;
};
perSystem = {system, ...}: {
# Nixpkgs instantiated for supported systems with our overlay.
_module.args.pkgs = import inputs.nixpkgs {
inherit system;
overlays = [self.overlays.default];
};
};
# Supported systems.
systems = [
"x86_64-linux"
"aarch64-linux"
"x86_64-darwin"
"aarch64-darwin"
];
}

View File

@ -1,37 +1,33 @@
{ {
inputs,
self,
...
}: {
perSystem = { perSystem = {
system, config,
lib,
pkgs, pkgs,
... ...
}: { }: {
checks = { pre-commit.settings = {
pre-commit-check = inputs.pre-commit-hooks.lib.${system}.run { hooks = {
src = self; markdownlint.enable = true;
hooks = {
markdownlint.enable = true;
alejandra.enable = true; alejandra.enable = true;
deadnix.enable = true; deadnix.enable = true;
nil.enable = true; nil.enable = true;
clang-format = { clang-format = {
enable = true; enable = true;
types_or = ["c" "c++" "java" "json" "objective-c"]; types_or = ["c" "c++" "java" "json" "objective-c"];
};
}; };
tools.clang-tools = pkgs.clang-tools_16;
}; };
tools.clang-tools = lib.mkForce pkgs.clang-tools_16;
}; };
devShells.default = pkgs.mkShell { devShells.default = pkgs.mkShell {
inherit (self.checks.${system}.pre-commit-check) shellHook; shellHook = ''
${config.pre-commit.installationScript}
'';
inputsFrom = [self.packages.${system}.prismlauncher-unwrapped]; inputsFrom = [config.packages.prismlauncher-unwrapped];
buildInputs = with pkgs; [ccache ninja]; buildInputs = with pkgs; [ccache ninja];
}; };

View File

@ -1,30 +1,44 @@
{ {
inputs, inputs,
self, self,
version,
... ...
}: { }: {
perSystem = {pkgs, ...}: { perSystem = {
packages = { lib,
inherit (pkgs) prismlauncher-qt5-unwrapped prismlauncher-qt5 prismlauncher-unwrapped prismlauncher; pkgs,
default = pkgs.prismlauncher; ...
}: {
packages = let
ourPackages = lib.fix (final: self.overlays.default ({inherit (pkgs) darwin;} // final) pkgs);
in {
inherit
(ourPackages)
prismlauncher-qt5-unwrapped
prismlauncher-qt5
prismlauncher-unwrapped
prismlauncher
;
default = ourPackages.prismlauncher;
}; };
}; };
flake = { flake = {
overlays.default = final: prev: let overlays.default = final: prev: let
# Helper function to build prism against different versions of Qt. version = builtins.substring 0 8 self.lastModifiedDate or "dirty";
mkPrism = qt:
qt.callPackage ./package.nix { # common args for prismlauncher evaluations
inherit (inputs) libnbtplusplus; unwrappedArgs = {
inherit (prev.darwin.apple_sdk.frameworks) Cocoa; inherit (inputs) libnbtplusplus;
inherit self version; inherit (final.darwin.apple_sdk.frameworks) Cocoa;
}; inherit self version;
};
in { in {
prismlauncher-qt5-unwrapped = mkPrism final.libsForQt5; prismlauncher-qt5-unwrapped = prev.libsForQt5.callPackage ./pkg unwrappedArgs;
prismlauncher-qt5 = prev.prismlauncher-qt5.override {prismlauncher-unwrapped = final.prismlauncher-qt5-unwrapped;}; prismlauncher-qt5 = prev.libsForQt5.callPackage ./pkg/wrapper.nix {
prismlauncher-unwrapped = mkPrism final.qt6Packages; prismlauncher-unwrapped = final.prismlauncher-qt5-unwrapped;
prismlauncher = prev.prismlauncher.override {inherit (final) prismlauncher-unwrapped;}; };
prismlauncher-unwrapped = prev.qt6Packages.callPackage ./pkg unwrappedArgs;
prismlauncher = prev.qt6Packages.callPackage ./pkg/wrapper.nix {inherit (final) prismlauncher-unwrapped;};
}; };
}; };
} }

91
nix/pkg/wrapper.nix Normal file
View File

@ -0,0 +1,91 @@
{
lib,
stdenv,
symlinkJoin,
prismlauncher-unwrapped,
wrapQtAppsHook,
qtbase, # needed for wrapQtAppsHook
qtsvg,
qtwayland,
xorg,
libpulseaudio,
libGL,
glfw,
openal,
jdk8,
jdk17,
gamemode,
flite,
mesa-demos,
udev,
msaClientID ? null,
gamemodeSupport ? stdenv.isLinux,
textToSpeechSupport ? stdenv.isLinux,
jdks ? [jdk17 jdk8],
additionalLibs ? [],
additionalPrograms ? [],
}: let
prismlauncherFinal = prismlauncher-unwrapped.override {
inherit msaClientID gamemodeSupport;
};
in
symlinkJoin {
name = "prismlauncher-${prismlauncherFinal.version}";
paths = [prismlauncherFinal];
nativeBuildInputs = [
wrapQtAppsHook
];
buildInputs =
[
qtbase
qtsvg
]
++ lib.optional (lib.versionAtLeast qtbase.version "6" && stdenv.isLinux) qtwayland;
postBuild = ''
wrapQtAppsHook
'';
qtWrapperArgs = let
runtimeLibs =
(with xorg; [
libX11
libXext
libXcursor
libXrandr
libXxf86vm
])
++ [
# lwjgl
libpulseaudio
libGL
glfw
openal
stdenv.cc.cc.lib
# oshi
udev
]
++ lib.optional gamemodeSupport gamemode.lib
++ lib.optional textToSpeechSupport flite
++ additionalLibs;
runtimePrograms =
[
xorg.xrandr
mesa-demos # need glxinfo
]
++ additionalPrograms;
in
["--prefix PRISMLAUNCHER_JAVA_PATHS : ${lib.makeSearchPath "bin/java" jdks}"]
++ lib.optionals stdenv.isLinux [
"--set LD_LIBRARY_PATH /run/opengl-driver/lib:${lib.makeLibraryPath runtimeLibs}"
# xorg.xrandr needed for LWJGL [2.9.2, 3) https://github.com/LWJGL/lwjgl/issues/128
"--prefix PATH : ${lib.makeBinPath runtimePrograms}"
];
inherit (prismlauncherFinal) meta;
}