diff options
author | Bignaux Ronan <ronan@aimao.org> | 2018-08-05 13:05:23 +0200 |
---|---|---|
committer | Bignaux Ronan <ronan@aimao.org> | 2018-08-06 11:45:21 +0200 |
commit | ae7cc3eb5c5edacb586fa613a2e98fc4b94aff3a (patch) | |
tree | 2c765d1738b07fe316ab3ff3fed29216006deea1 /pkgs/applications/networking | |
parent | 1258e6dd3a19e24e3dd4c08bca516abfa3d997aa (diff) | |
download | nixlib-ae7cc3eb5c5edacb586fa613a2e98fc4b94aff3a.tar nixlib-ae7cc3eb5c5edacb586fa613a2e98fc4b94aff3a.tar.gz nixlib-ae7cc3eb5c5edacb586fa613a2e98fc4b94aff3a.tar.bz2 nixlib-ae7cc3eb5c5edacb586fa613a2e98fc4b94aff3a.tar.lz nixlib-ae7cc3eb5c5edacb586fa613a2e98fc4b94aff3a.tar.xz nixlib-ae7cc3eb5c5edacb586fa613a2e98fc4b94aff3a.tar.zst nixlib-ae7cc3eb5c5edacb586fa613a2e98fc4b94aff3a.zip |
soulseekqt : refactoring appimage manipulation to be more generic.
Diffstat (limited to 'pkgs/applications/networking')
-rw-r--r-- | pkgs/applications/networking/p2p/soulseekqt/default.nix | 40 |
1 files changed, 20 insertions, 20 deletions
diff --git a/pkgs/applications/networking/p2p/soulseekqt/default.nix b/pkgs/applications/networking/p2p/soulseekqt/default.nix index 44e434aa8ee9..e67d768f3ded 100644 --- a/pkgs/applications/networking/p2p/soulseekqt/default.nix +++ b/pkgs/applications/networking/p2p/soulseekqt/default.nix @@ -5,7 +5,7 @@ , qtbase, qtmultimedia , libjson, libgpgerror , libX11, libxcb, libXau, libXdmcp, freetype, libbsd -, pythonPackages, squashfsTools, makeDesktopItem +, pythonPackages, squashfsTools, desktop_file_utils }: with stdenv.lib; @@ -23,16 +23,6 @@ let }; }; - desktopItem = makeDesktopItem { - name = "SoulseekQt"; - exec = "soulseekqt"; - icon = "$out/share/soulseekqt/"; - comment = "Official Qt SoulSeek client"; - desktopName = "SoulseekQt"; - genericName = "SoulseekQt"; - categories = "Network;"; - }; - in stdenv.mkDerivation rec { name = "soulseekqt-${version}"; @@ -41,26 +31,36 @@ in stdenv.mkDerivation rec { dontBuild = true; - buildInputs = [ pythonPackages.binwalk squashfsTools ]; + buildInputs = [ pythonPackages.binwalk squashfsTools desktop_file_utils ]; - # avoid usage of appimagetool + # avoid usage of appimage's runner option --appimage-extract unpackCmd = '' export HOME=$(pwd) # workaround for binwalk - tar xvf $curSrc && binwalk --quiet \ - ${mainbin}.AppImage -D 'squashfs:.squashfs:unsquashfs %e' + appimage=$(tar xvf $curSrc) && binwalk --quiet \ + $appimage -D 'squashfs:squashfs:unsquashfs %e' ''; + + patchPhase = '' + cd squashfs-root/ + binary="$(readlink AppRun)" + + # fixup desktop file + desktop-file-edit --set-key Exec --set-value $binary default.desktop + desktop-file-edit --set-key Comment --set-value "${meta.description}" default.desktop + desktop-file-edit --set-key Categories --set-value Network default.desktop + ''; installPhase = '' - mkdir -p $out/{bin,share/soulseekqt} - cd squashfs-root/ - cp -R soulseek.png translations $out/share/soulseekqt - cp SoulseekQt $out/bin/soulseekqt + mkdir -p $out/{bin,share/applications,share/icons/} + cp default.desktop $out/share/applications/$binary.desktop + cp soulseek.png $out/share/icons/ + cp $binary $out/bin/ ''; fixupPhase = '' patchelf --set-interpreter "$(cat $NIX_CC/nix-support/dynamic-linker)" \ --set-rpath ${libPath} \ - $out/bin/soulseekqt + $out/bin/$binary ''; meta = with stdenv.lib; { |