summary refs log tree commit diff
path: root/pkgs/games/runelite
diff options
context:
space:
mode:
authorKarl Meakin <karlwfmeakin@gmail.com>2021-05-27 01:02:02 +0100
committerJonathan Ringer <jonringer@users.noreply.github.com>2021-05-29 16:11:41 -0700
commit6ee94fc354cb75fe55b7ee6b7cf0ad6d95568264 (patch)
tree9dcc4c8e03448bc2ea74a71594573c030e64d57d /pkgs/games/runelite
parent793a73a7684b0931934c70fe3deca720be19ed03 (diff)
downloadnixpkgs-6ee94fc354cb75fe55b7ee6b7cf0ad6d95568264.tar
nixpkgs-6ee94fc354cb75fe55b7ee6b7cf0ad6d95568264.tar.gz
nixpkgs-6ee94fc354cb75fe55b7ee6b7cf0ad6d95568264.tar.bz2
nixpkgs-6ee94fc354cb75fe55b7ee6b7cf0ad6d95568264.tar.lz
nixpkgs-6ee94fc354cb75fe55b7ee6b7cf0ad6d95568264.tar.xz
nixpkgs-6ee94fc354cb75fe55b7ee6b7cf0ad6d95568264.tar.zst
nixpkgs-6ee94fc354cb75fe55b7ee6b7cf0ad6d95568264.zip
runelite: 2.0.0 -> 2.1.5
Diffstat (limited to 'pkgs/games/runelite')
-rw-r--r--pkgs/games/runelite/default.nix41
1 files changed, 27 insertions, 14 deletions
diff --git a/pkgs/games/runelite/default.nix b/pkgs/games/runelite/default.nix
index e9e77e275dc..9a2ce6314cd 100644
--- a/pkgs/games/runelite/default.nix
+++ b/pkgs/games/runelite/default.nix
@@ -1,12 +1,12 @@
-{ stdenv, fetchurl, makeWrapper, jre, makeDesktopItem, lib }:
+{ pkgs, lib, stdenv, makeDesktopItem, fetchurl, unzip, makeWrapper, xorg, jre, }:
 
 stdenv.mkDerivation rec {
   pname = "runelite";
-  version = "2.0.0";
+  version = "2.1.5";
 
-  src = fetchurl {
+  jar = fetchurl {
     url = "https://github.com/runelite/launcher/releases/download/${version}/RuneLite.jar";
-    sha256 = "0q0x8g43ggkvp5fgnymgygx59xfhnyyrhpi6ha333gqg97rr0rvw";
+    sha256 = "4BX188QIjIFTxng2ktqlKn7AqQ9tdBcKWmgOj/5yd10=";
   };
 
   icon = fetchurl {
@@ -14,6 +14,17 @@ stdenv.mkDerivation rec {
     sha256 = "04fcjm7p546gr82g0jbh497j7rnh70lrvas0k171bff4v3knrjw1";
   };
 
+  # The `.so` files provided by these two jars aren't detected by RuneLite for some reason, so we have to provide them manually
+  jogl = fetchurl {
+    url = "https://repo.runelite.net/net/runelite/jogl/jogl-all/2.4.0-rc-20200429/jogl-all-2.4.0-rc-20200429-natives-linux-amd64.jar";
+    sha256 = "S60qxyWY9RfyhLFygn/OxZFWnc8qVRtTFdWMbdu+2U0=";
+  };
+  gluegen = fetchurl {
+    url = "https://repo.runelite.net/net/runelite/gluegen/gluegen-rt/2.4.0-rc-20200429/gluegen-rt-2.4.0-rc-20200429-natives-linux-amd64.jar";
+    sha256 = "eF8S5sQkJFDtW8rcVBKIyeyKm5Ze5rXK5r/yosZcHjU=";
+  };
+  dontUnpack = true;
+
   desktop = makeDesktopItem {
     name = "RuneLite";
     type = "Application";
@@ -24,23 +35,25 @@ stdenv.mkDerivation rec {
     desktopName = "RuneLite";
     genericName = "Oldschool Runescape";
     categories = "Game";
-    startupNotify = null;
   };
 
-  nativeBuildInputs = [ makeWrapper ];
-
-  # colon is bash form of no-op (do nothing)
-  dontUnpack = true;
-
+  nativeBuildInputs = [ makeWrapper unzip ];
   installPhase = ''
     mkdir -p $out/share/runelite
     mkdir -p $out/share/applications
+    mkdir -p $out/natives
+
+    unzip ${jogl}    'natives/*' -d $out
+    unzip ${gluegen} 'natives/*' -d $out
 
-    ln -s ${src} $out/share/runelite/RuneLite.jar
-    ln -s ${desktop}/share/applications/* $out/share/applications
+    ln -s ${jar} $out/share/runelite/RuneLite.jar
+    ln -s ${desktop}/share/applications/RuneLite.desktop $out/share/applications/RuneLite.desktop
 
+    # RuneLite looks for `.so` files in $PWD/natives, so ensure that we set the PWD to the right place
     makeWrapper ${jre}/bin/java $out/bin/runelite \
-    --add-flags "-jar $out/share/runelite/RuneLite.jar"
+      --run "cd $out" \
+      --prefix LD_LIBRARY_PATH : "${xorg.libXxf86vm}/lib" \
+      --add-flags "-jar $out/share/runelite/RuneLite.jar"
   '';
 
   meta = with lib; {
@@ -48,6 +61,6 @@ stdenv.mkDerivation rec {
     homepage = "https://runelite.net/";
     license = licenses.bsd2;
     maintainers = with maintainers; [ kmeakin ];
-    platforms = platforms.all;
+    platforms = [ "x86_64-linux" ];
   };
 }