2023-11-16 04:20:00 +00:00
|
|
|
{ lib
|
|
|
|
, stdenvNoCC }:
|
|
|
|
|
2024-01-02 11:29:13 +00:00
|
|
|
let
|
|
|
|
escapedList = with lib; concatMapStringsSep " " (s: "'${escape [ "'" ] s}'");
|
|
|
|
fileName = pathStr: lib.last (lib.splitString "/" pathStr);
|
|
|
|
scriptsDir = "$out/share/mpv/scripts";
|
|
|
|
|
|
|
|
# similar to `lib.extends`, but with inverted precedence and recursive update
|
|
|
|
extendedBy = args: orig: self:
|
|
|
|
let super = args self;
|
|
|
|
in lib.recursiveUpdate (orig super) super
|
|
|
|
;
|
2023-11-16 04:20:00 +00:00
|
|
|
in
|
2024-01-02 11:29:13 +00:00
|
|
|
|
|
|
|
lib.makeOverridable (args: stdenvNoCC.mkDerivation (extendedBy
|
|
|
|
(if lib.isFunction args then args else (_: args)) (
|
|
|
|
{ pname
|
|
|
|
, extraScripts ? []
|
|
|
|
, ... }@args:
|
|
|
|
let
|
|
|
|
strippedName = with builtins;
|
|
|
|
let groups = match "mpv[-_](.*)" pname; in
|
|
|
|
if groups != null
|
|
|
|
then head groups
|
|
|
|
else pname
|
|
|
|
;
|
|
|
|
# either passthru.scriptName, inferred from scriptPath, or from pname
|
|
|
|
scriptName = (args.passthru or {}).scriptName or (
|
|
|
|
if args ? scriptPath
|
|
|
|
then fileName args.scriptPath
|
|
|
|
else "${strippedName}.lua"
|
|
|
|
);
|
|
|
|
scriptPath = args.scriptPath or "./${scriptName}";
|
|
|
|
in {
|
2023-11-16 04:20:00 +00:00
|
|
|
dontBuild = true;
|
|
|
|
preferLocalBuild = true;
|
|
|
|
|
2024-01-02 11:29:13 +00:00
|
|
|
# Prevent `patch` from emitting `.orig` files (that end up in the output)
|
|
|
|
patchFlags = [ "--no-backup-if-mismatch" "-p1" ];
|
|
|
|
|
2023-11-16 04:20:00 +00:00
|
|
|
outputHashMode = "recursive";
|
|
|
|
installPhase = ''
|
|
|
|
runHook preInstall
|
2024-01-02 11:29:13 +00:00
|
|
|
|
|
|
|
if [ -d "${scriptPath}" ]; then
|
|
|
|
[ -f "${scriptPath}/main.lua" ] || {
|
|
|
|
echo "Script directory '${scriptPath}' does not contain 'main.lua'" >&2
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
[ ${with builtins; toString (length extraScripts)} -eq 0 ] || {
|
|
|
|
echo "mpvScripts.buildLua does not support 'extraScripts'" \
|
|
|
|
"when 'scriptPath' is a directory"
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
mkdir -p "${scriptsDir}"
|
|
|
|
cp -a "${scriptPath}" "${scriptsDir}/${scriptName}"
|
|
|
|
else
|
|
|
|
install -m644 -Dt "${scriptsDir}" \
|
|
|
|
${escapedList ([ scriptPath ] ++ extraScripts)}
|
|
|
|
fi
|
|
|
|
|
2023-11-16 04:20:00 +00:00
|
|
|
runHook postInstall
|
|
|
|
'';
|
|
|
|
|
2024-01-02 11:29:13 +00:00
|
|
|
passthru = { inherit scriptName; };
|
2024-01-13 08:15:51 +00:00
|
|
|
meta = {
|
|
|
|
platforms = lib.platforms.all;
|
|
|
|
} // (
|
|
|
|
let pos =
|
|
|
|
if (args.meta or {}) ? description then
|
|
|
|
builtins.unsafeGetAttrPos "description" args.meta
|
|
|
|
else
|
|
|
|
builtins.unsafeGetAttrPos "pname" args;
|
|
|
|
in lib.optionalAttrs
|
|
|
|
(pos != null)
|
|
|
|
{ position = "${pos.file}:${toString pos.line}"; }
|
|
|
|
);
|
2024-01-02 11:29:13 +00:00
|
|
|
})
|
|
|
|
))
|