Merge pull request #45853 from bkchr/android_studio_desktop

android-studio: Add desktop item
This commit is contained in:
Michael Weiss 2018-09-02 16:27:46 +02:00 committed by GitHub
commit 044c16a978
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

@ -34,11 +34,12 @@
, writeTextFile , writeTextFile
, xkeyboard_config , xkeyboard_config
, zlib , zlib
, makeDesktopItem
}: }:
let let
drvName = "android-studio-${channel}-${version}"; drvName = "android-studio-${channel}-${version}";
androidStudio = stdenv.mkDerivation { androidStudio = stdenv.mkDerivation rec {
name = drvName; name = drvName;
src = fetchurl { src = fetchurl {
@ -110,7 +111,20 @@ let
]}" \ ]}" \
--set QT_XKB_CONFIG_ROOT "${xkeyboard_config}/share/X11/xkb" \ --set QT_XKB_CONFIG_ROOT "${xkeyboard_config}/share/X11/xkb" \
--set FONTCONFIG_FILE ${fontsConf} --set FONTCONFIG_FILE ${fontsConf}
install -Dm644 bin/studio.png $out/share/pixmaps/${drvName}.png
ln -s ${desktopItem}/share/applications $out/share/applications
''; '';
desktopItem = makeDesktopItem rec {
name = drvName;
exec = pname;
icon = drvName;
desktopName = "Android Studio";
comment = "The official Android IDE";
categories = "Development;IDE;";
};
}; };
# Android Studio downloads prebuilt binaries as part of the SDK. These tools # Android Studio downloads prebuilt binaries as part of the SDK. These tools
@ -121,8 +135,7 @@ let
multiPkgs = pkgs: [ pkgs.ncurses5 ]; multiPkgs = pkgs: [ pkgs.ncurses5 ];
}; };
in wrapper = writeTextFile {
writeTextFile {
name = "${drvName}-wrapper"; name = "${drvName}-wrapper";
# TODO: Rename preview -> beta (and add -stable suffix?): # TODO: Rename preview -> beta (and add -stable suffix?):
destination = "/bin/${pname}"; destination = "/bin/${pname}";
@ -131,18 +144,29 @@ in
#!${bash}/bin/bash #!${bash}/bin/bash
${fhsEnv}/bin/${drvName}-fhs-env ${androidStudio}/bin/studio.sh ${fhsEnv}/bin/${drvName}-fhs-env ${androidStudio}/bin/studio.sh
''; '';
} // { };
meta = with stdenv.lib; { in stdenv.mkDerivation {
description = "The Official IDE for Android (${channel} channel)"; name = "${drvName}-with-desktop-item";
longDescription = ''
Android Studio is the official IDE for Android app development, based on buildCommand = ''
IntelliJ IDEA. mkdir -p $out/{bin,share/pixmaps}
''; ln -s ${wrapper}/bin/${pname} $out/bin/${pname}
homepage = if channel == "stable"
then https://developer.android.com/studio/index.html ln -s ${androidStudio}/share/pixmaps/${drvName}.png $out/share/pixmaps/${drvName}.png
else https://developer.android.com/studio/preview/index.html; ln -s ${androidStudio}/share/applications $out/share/applications
license = licenses.asl20; '';
platforms = [ "x86_64-linux" ];
maintainers = with maintainers; [ primeos ]; meta = with stdenv.lib; {
}; description = "The Official IDE for Android (${channel} channel)";
} longDescription = ''
Android Studio is the official IDE for Android app development, based on
IntelliJ IDEA.
'';
homepage = if channel == "stable"
then https://developer.android.com/studio/index.html
else https://developer.android.com/studio/preview/index.html;
license = licenses.asl20;
platforms = [ "x86_64-linux" ];
maintainers = with maintainers; [ primeos ];
};
}