diff options
Diffstat (limited to 'pkgs/by-name/bl/blockbench/package.nix')
-rw-r--r-- | pkgs/by-name/bl/blockbench/package.nix | 83 |
1 files changed, 53 insertions, 30 deletions
diff --git a/pkgs/by-name/bl/blockbench/package.nix b/pkgs/by-name/bl/blockbench/package.nix index fb19793583c43..9cf8cac46c72c 100644 --- a/pkgs/by-name/bl/blockbench/package.nix +++ b/pkgs/by-name/bl/blockbench/package.nix @@ -1,62 +1,83 @@ -{ lib -, stdenv -, buildNpmPackage -, fetchFromGitHub -, imagemagick -, makeWrapper -, makeDesktopItem -, copyDesktopItems -, electron_28 +{ + lib, + stdenv, + buildNpmPackage, + fetchFromGitHub, + makeWrapper, + imagemagick, + copyDesktopItems, + makeDesktopItem, + electron_28, }: let electron = electron_28; + electronDist = "${electron}/${if stdenv.isDarwin then "Applications" else "libexec/electron"}"; in buildNpmPackage rec { pname = "blockbench"; - version = "4.9.4"; + version = "4.10.2"; src = fetchFromGitHub { owner = "JannisX11"; repo = "blockbench"; rev = "v${version}"; - hash = "sha256-z4hr1pQh7Jp/DB8+pxwuHvi4gvTHHVn0yrruwnXm2iM="; + hash = "sha256-Ch+vPSvdqfJF2gNgZN2x5KSY1S1CYfHCyMyUf4W+Vn8="; }; - nativeBuildInputs = [ - imagemagick # for icon resizing - makeWrapper - copyDesktopItems - ]; + nativeBuildInputs = + [ makeWrapper ] + ++ lib.optionals (!stdenv.isDarwin) [ + imagemagick # for icon resizing + copyDesktopItems + ]; - npmDepsHash = "sha256-onfz+J77jNIgdc7ALiyoXt1CdTyX/C7+bKwtpJm+H+I="; + npmDepsHash = "sha256-au6GzBTxPcYcqrPEnQ+yEhVRdAbiUa/Ocq7UCPdiox4="; env.ELECTRON_SKIP_BINARY_DOWNLOAD = 1; + # disable code signing on Darwin + postConfigure = lib.optionalString stdenv.isDarwin '' + export CSC_IDENTITY_AUTO_DISCOVERY=false + sed -i "/afterSign/d" package.json + ''; + npmBuildScript = "bundle"; postBuild = '' + # electronDist needs to be modifiable on Darwin + cp -r ${electronDist} electron-dist + chmod -R u+w electron-dist + npm exec electron-builder -- \ --dir \ - -c.electronDist=${electron}/libexec/electron \ + -c.electronDist=electron-dist \ -c.electronVersion=${electron.version} ''; installPhase = '' runHook preInstall - mkdir -p $out/share/blockbench - cp -r dist/*-unpacked/{locales,resources{,.pak}} $out/share/blockbench + ${lib.optionalString stdenv.isDarwin '' + mkdir -p $out/Applications + cp -r dist/mac*/Blockbench.app $out/Applications + makeWrapper $out/Applications/Blockbench.app/Contents/MacOS/Blockbench $out/bin/blockbench + ''} + + ${lib.optionalString (!stdenv.isDarwin) '' + mkdir -p $out/share/blockbench + cp -r dist/*-unpacked/{locales,resources{,.pak}} $out/share/blockbench - for size in 16 32 48 64 128 256 512; do - mkdir -p $out/share/icons/hicolor/"$size"x"$size"/apps - convert -resize "$size"x"$size" icon.png $out/share/icons/hicolor/"$size"x"$size"/apps/blockbench.png - done + for size in 16 32 48 64 128 256 512; do + mkdir -p $out/share/icons/hicolor/"$size"x"$size"/apps + convert -resize "$size"x"$size" icon.png $out/share/icons/hicolor/"$size"x"$size"/apps/blockbench.png + done - makeWrapper ${lib.getExe electron} $out/bin/blockbench \ - --add-flags $out/share/blockbench/resources/app.asar \ - --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform-hint=auto --enable-features=WaylandWindowDecorations}}" \ - --inherit-argv0 + makeWrapper ${lib.getExe electron} $out/bin/blockbench \ + --add-flags $out/share/blockbench/resources/app.asar \ + --add-flags "\''${NIXOS_OZONE_WL:+\''${WAYLAND_DISPLAY:+--ozone-platform-hint=auto --enable-features=WaylandWindowDecorations}}" \ + --inherit-argv0 + ''} runHook postInstall ''; @@ -81,7 +102,9 @@ buildNpmPackage rec { homepage = "https://blockbench.net/"; license = lib.licenses.gpl3Only; mainProgram = "blockbench"; - maintainers = with lib.maintainers; [ ckie tomasajt ]; - broken = stdenv.isDarwin; + maintainers = with lib.maintainers; [ + ckie + tomasajt + ]; }; } |