summary refs log tree commit diff
path: root/pkgs/build-support/setup-hooks
diff options
context:
space:
mode:
authorUri Baghin <uri@canva.com>2022-02-11 09:26:32 +1100
committerGitHub <noreply@github.com>2022-02-11 09:26:32 +1100
commit1c2d7f85b986b82036af65d542cd0a03cb94c41f (patch)
treee18555e7c13b0dae22ddbfe8a878e31827b78838 /pkgs/build-support/setup-hooks
parentba8a28d6118f69d1a4c697c9e7a1a85c04798e00 (diff)
parent850fc57f56d9f6732e6eaa5688ce2d6e9f4f2d09 (diff)
downloadnixpkgs-1c2d7f85b986b82036af65d542cd0a03cb94c41f.tar
nixpkgs-1c2d7f85b986b82036af65d542cd0a03cb94c41f.tar.gz
nixpkgs-1c2d7f85b986b82036af65d542cd0a03cb94c41f.tar.bz2
nixpkgs-1c2d7f85b986b82036af65d542cd0a03cb94c41f.tar.lz
nixpkgs-1c2d7f85b986b82036af65d542cd0a03cb94c41f.tar.xz
nixpkgs-1c2d7f85b986b82036af65d542cd0a03cb94c41f.tar.zst
nixpkgs-1c2d7f85b986b82036af65d542cd0a03cb94c41f.zip
Merge pull request #131891 from hexagonal-sun/darwin-app-creation
Darwin Application Launcher creation expression
Diffstat (limited to 'pkgs/build-support/setup-hooks')
-rw-r--r--pkgs/build-support/setup-hooks/desktop-to-darwin-bundle.sh48
1 files changed, 48 insertions, 0 deletions
diff --git a/pkgs/build-support/setup-hooks/desktop-to-darwin-bundle.sh b/pkgs/build-support/setup-hooks/desktop-to-darwin-bundle.sh
new file mode 100644
index 00000000000..d1175d3a5f9
--- /dev/null
+++ b/pkgs/build-support/setup-hooks/desktop-to-darwin-bundle.sh
@@ -0,0 +1,48 @@
+#!/usr/bin/env bash
+fixupOutputHooks+=('convertDesktopFiles $prefix')
+
+# Get a param out of a desktop file. First parameter is the file and the second
+# is a pattern of the key who's value we should fetch.
+getDesktopParam() {
+    local file="$1";
+    local pattern="$2";
+
+    awk -F "=" "/${pattern}/ {print \$2}" "${file}"
+}
+
+# For a given .desktop file, generate a darwin '.app' bundle for it.
+convertDesktopFile() {
+    local -r file="$1"
+    local -r name=$(getDesktopParam "${file}" "^Name")
+    local -r exec=$(getDesktopParam "${file}" "Exec")
+    local -r iconName=$(getDesktopParam "${file}" "Icon")
+    local -r iconFiles=$(find "$out/share/icons/" -name "${iconName}.*" 2>/dev/null);
+    local -r pixMaps=$(find "$out/share/pixmaps/" -name "${iconName}.xpm" 2>/dev/null);
+
+    mkdir -p "$out/Applications/${name}.app/Contents/MacOS"
+    mkdir -p "$out/Applications/${name}.app/Contents/Resources"
+
+    local i=0;
+    for icon in $iconFiles; do
+      ln -s "$icon" "$out/Applications/${name}.app/Contents/Resources/$i-$(basename "$icon")"
+      (( i +=1 ));
+    done
+
+    for pixmap in $pixMaps; do
+      local newIconName="$i-$(basename "$pixmap")";
+      convert "$pixmap" "$out/Applications/${name}.app/Contents/Resources/${newIconName%.xpm}.png"
+      (( i +=1 ));
+    done
+
+    write-darwin-bundle "$out" "$name" "$exec"
+}
+
+convertDesktopFiles() {
+    local dir="$1/share/applications/"
+
+    if [ -d "${dir}" ]; then
+        for desktopFile in $(find "$dir" -iname "*.desktop"); do
+            convertDesktopFile "$desktopFile";
+        done
+    fi
+}