2024-09-19 14:19:46 +00:00
|
|
|
{ lib, symlinkJoin, makeWrapper, kakoune, plugins ? [], configure ? {} }:
|
2020-04-24 23:36:52 +00:00
|
|
|
|
|
|
|
let
|
2020-11-03 02:18:15 +00:00
|
|
|
# "plugins" is the preferred way, but some configurations may be
|
|
|
|
# using "configure.plugins", so accept both
|
|
|
|
requestedPlugins = plugins ++ (configure.plugins or []);
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2020-11-03 02:18:15 +00:00
|
|
|
in
|
|
|
|
symlinkJoin {
|
|
|
|
name = "kakoune-${kakoune.version}";
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2021-03-09 03:18:52 +00:00
|
|
|
nativeBuildInputs = [ makeWrapper ];
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2020-11-03 02:18:15 +00:00
|
|
|
paths = [ kakoune ] ++ requestedPlugins;
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2020-11-03 02:18:15 +00:00
|
|
|
postBuild = ''
|
2024-09-19 14:19:46 +00:00
|
|
|
# create a directory for bins that kakoune needs
|
|
|
|
# access to, without polluting the users path by adding
|
|
|
|
# that binary nested with this symlinkJoin.
|
|
|
|
mkdir -p $out/share/kak/bin
|
|
|
|
|
2020-11-03 02:18:15 +00:00
|
|
|
# location of kak binary is used to find ../share/kak/autoload,
|
|
|
|
# unless explicitly overriden with KAKOUNE_RUNTIME
|
|
|
|
rm "$out/bin/kak"
|
2024-09-19 14:19:46 +00:00
|
|
|
makeWrapper "${kakoune}/bin/kak" "$out/bin/kak" \
|
|
|
|
--set KAKOUNE_RUNTIME "$out/share/kak" \
|
|
|
|
--suffix PATH : "$out/share/kak/bin"
|
2020-04-24 23:36:52 +00:00
|
|
|
|
2020-11-03 02:18:15 +00:00
|
|
|
# currently kakoune ignores doc files if they are symlinks, so workaround by
|
|
|
|
# copying doc files over, so they become regular files...
|
|
|
|
mkdir "$out/DELETE_ME"
|
|
|
|
mv "$out/share/kak/doc" "$out/DELETE_ME"
|
|
|
|
cp -r --dereference "$out/DELETE_ME/doc" "$out/share/kak"
|
|
|
|
rm -Rf "$out/DELETE_ME"
|
|
|
|
'';
|
|
|
|
|
2024-09-19 14:19:46 +00:00
|
|
|
meta = kakoune.meta // { priority = (kakoune.meta.priority or lib.meta.defaultPriority) - 1; };
|
2020-11-03 02:18:15 +00:00
|
|
|
}
|