diff options
Diffstat (limited to 'nixpkgs/pkgs/applications/emulators/retroarch/wrapper.nix')
-rw-r--r-- | nixpkgs/pkgs/applications/emulators/retroarch/wrapper.nix | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/nixpkgs/pkgs/applications/emulators/retroarch/wrapper.nix b/nixpkgs/pkgs/applications/emulators/retroarch/wrapper.nix new file mode 100644 index 000000000000..4698bbe5bbed --- /dev/null +++ b/nixpkgs/pkgs/applications/emulators/retroarch/wrapper.nix @@ -0,0 +1,59 @@ +{ lib +, stdenv +, makeWrapper +, retroarch +, symlinkJoin +, runCommand +, cores ? [ ] +, settings ? { } +}: + +let + settingsPath = runCommand "declarative-retroarch.cfg" + { + value = lib.concatStringsSep "\n" (lib.mapAttrsToList (n: v: "${n} = \"${v}\"") settings); + passAsFile = [ "value" ]; + } + '' + cp "$valuePath" "$out" + ''; + + # All cores should be located in the same path after symlinkJoin, + # but let's be safe here + coresPath = lib.lists.unique (map (c: c.libretroCore) cores); + wrapperArgs = lib.strings.escapeShellArgs ( + (lib.lists.flatten (map (p: [ "--add-flags" "-L ${placeholder "out" + p}" ]) coresPath)) + ++ [ "--add-flags" "--appendconfig=${settingsPath}" ] + ); +in +symlinkJoin { + name = "retroarch-with-cores-${lib.getVersion retroarch}"; + + paths = [ retroarch ] ++ cores; + + nativeBuildInputs = [ makeWrapper ]; + + passthru = { + inherit cores; + unwrapped = retroarch; + }; + + postBuild = '' + # remove core specific binaries + find $out/bin -name 'retroarch-*' -type l -delete + + # wrap binary to load cores from the proper location(s) + wrapProgram $out/bin/retroarch ${wrapperArgs} + ''; + + meta = with retroarch.meta; { + inherit changelog description homepage license maintainers platforms; + longDescription = '' + RetroArch is the reference frontend for the libretro API. + '' + + lib.optionalString (cores != [ ]) '' + The following cores are included: ${lib.concatStringsSep ", " (map (c: c.core) cores)} + ''; + mainProgram = "retroarch"; + }; +} |