make-desktopitem: refactoring, documentation and improvement

- New parameter `extraDesktopEntries` to easily add some less usual entries to the desktop file
- Rewrite of the core logic. Instead of a key-value-list, use an attribute set with nullable values to make it overridable
- Added some comments
- Some cosmetic/readability code refactors
	- I didn't like the doubly nested strings around the `fileValidation`
This commit is contained in:
piegames 2020-06-29 23:23:50 +02:00
parent 56f8f6f31f
commit 51cc553307

View File

@ -1,50 +1,58 @@
{ lib, runCommandLocal, desktop-file-utils }: { lib, runCommandLocal, desktop-file-utils }:
{ name # See https://specifications.freedesktop.org/desktop-entry-spec/desktop-entry-spec-latest.html
{ name # The name of the desktop file
, type ? "Application" , type ? "Application"
, exec , exec
, icon ? null , icon ? null
, comment ? null , comment ? null
, terminal ? "false" , terminal ? "false"
, desktopName , desktopName # The name of the application
, genericName ? null , genericName ? null
, mimeType ? null , mimeType ? null
, categories ? null , categories ? null
, startupNotify ? null , startupNotify ? null
, extraEntries ? null , extraDesktopEntries ? {} # Extra key-value pairs to add to the [Desktop Entry] section. This may override other values
, extraEntries ? "" # Extra configuration. Will be appended to the end of the file and may thus contain extra sections
, fileValidation ? true # whether to validate resulting desktop file. , fileValidation ? true # whether to validate resulting desktop file.
}: }:
let let
optionalEntriesList = [{k="Icon"; v=icon;} # like builtins.toString, but null -> null instead of null -> ""
{k="Comment"; v=comment;} nullableToString = value: if value == null then null else builtins.toString value;
{k="GenericName"; v=genericName;}
{k="MimeType"; v=mimeType;}
{k="Categories"; v=categories;}
{k="StartupNotify"; v=startupNotify;}];
valueNotNull = {k, v}: v != null; # The [Desktop entry] section of the desktop file, as attribute set.
entriesToKeep = builtins.filter valueNotNull optionalEntriesList; mainSection = {
"Type" = toString type;
"Exec" = (nullableToString exec);
"Icon" = (nullableToString icon);
"Comment" = (nullableToString comment);
"Terminal" = (nullableToString terminal);
"Name" = toString name;
"GenericName" = (nullableToString genericName);
"MimeType" = (nullableToString mimeType);
"Categories" = (nullableToString categories);
"StartupNotify" = (nullableToString startupNotify);
} // extraDesktopEntries;
mkEntry = {k, v}: k + "=" + v; # Map all entries to a list of lines
optionalEntriesString = lib.concatMapStringsSep "\n" mkEntry entriesToKeep; desktopFileStrings =
["[Desktop Entry]"]
++ builtins.filter
(v: v != null)
(lib.mapAttrsToList
(name: value: if value != null then "${name}=${value}" else null)
mainSection
)
++ (if extraEntries == "" then [] else ["${extraEntries}"]);
in in
runCommandLocal "${name}.desktop" {} runCommandLocal "${name}.desktop" {}
'' (''
mkdir -p "$out/share/applications" mkdir -p "$out/share/applications"
cat > "$out/share/applications/${name}.desktop" <<EOF cat > "$out/share/applications/${name}.desktop" <<EOF
[Desktop Entry] ${builtins.concatStringsSep "\n" desktopFileStrings}
Type=${type} EOF
Exec=${exec} '' + lib.optionalString fileValidation ''
Terminal=${terminal} echo "Running desktop-file validation"
Name=${desktopName} ${desktop-file-utils}/bin/desktop-file-validate "$out/share/applications/${name}.desktop"
${optionalEntriesString} '')
${if extraEntries == null then ''EOF'' else ''
${extraEntries}
EOF''}
${lib.optionalString fileValidation ''
echo "Running desktop-file validation"
${desktop-file-utils}/bin/desktop-file-validate "$out/share/applications/${name}.desktop"
''}
''