lib: rewrite toLuaObject, deprecate everything else

This commit is contained in:
Gerg-L 2025-10-10 19:52:10 -04:00
commit c8734cc4db
No known key found for this signature in database
4 changed files with 53 additions and 94 deletions

View file

@ -1,92 +1,52 @@
# Helpers for converting values to lua # Helpers for converting values to lua
{lib}: let {lib}: let
inherit (builtins) hasAttr head throw typeOf isList isAttrs isBool isInt isString isPath isFloat toJSON;
inherit (lib.attrsets) mapAttrsToList filterAttrs;
inherit (lib.strings) concatStringsSep concatMapStringsSep stringToCharacters;
inherit (lib.trivial) boolToString warn;
in rec {
# Convert a null value to lua's nil
nullString = value:
if value == null
then "nil"
else "'${value}'";
# convert an expression to lua
expToLua = exp:
if isList exp
then listToLuaTable exp # if list, convert to lua table
else if isAttrs exp
then attrsetToLuaTable exp # if attrs, convert to table
else if isBool exp
then boolToString exp # if bool, convert to string
else if isInt exp
then toString exp # if int, convert to string
else if exp == null
then "nil"
else (toJSON exp); # otherwise jsonify the value and print as is
# convert list to a lua table
listToLuaTable = list:
"{ " + (concatStringsSep ", " (map expToLua list)) + " }";
# convert attrset to a lua table
attrsetToLuaTable = attrset:
"{ "
+ (
concatStringsSep ", "
(
mapAttrsToList (
name: value:
name
+ " = "
+ (expToLua value)
)
attrset
)
)
+ " }";
# Convert a list of lua expressions to a lua table. The difference to listToLuaTable is that the elements here are expected to be lua expressions already, whereas listToLuaTable converts from nix types to lua first
luaTable = items: ''{${concatStringsSep "," items}}'';
isLuaInline = object: (object._type or null) == "lua-inline"; isLuaInline = object: (object._type or null) == "lua-inline";
toLuaObject = args: toLuaObject = args:
if isAttrs args {
then int = toString args;
if isLuaInline args float = toString args;
then args.expr
else if hasAttr "__empty" args # escapes \ and quotes
then string = builtins.toJSON args;
warn '' path = builtins.toJSON args;
Using `__empty` to define an empty lua table is deprecated. Use an empty attrset instead.
'' "{ }" bool = lib.boolToString args;
else null = "nil";
"{"
+ (concatStringsSep "," list = "{${lib.concatMapStringsSep ",\n" toLuaObject args}}";
(mapAttrsToList
(n: v: set =
if head (stringToCharacters n) == "@" if lib.isDerivation args
then toLuaObject v then ''"${args}"''
else "[${toLuaObject n}] = " + (toLuaObject v)) else if isLuaInline args
(filterAttrs then args.expr
(_: v: v != null) else "{${
args))) lib.pipe args [
+ "}" (lib.filterAttrs (_: v: v != null))
else if isList args (builtins.mapAttrs (
then "{" + concatMapStringsSep "," toLuaObject args + "}" n: v:
else if isString args if lib.hasPrefix "@" n
then then toLuaObject v
# This should be enough! else "[${toLuaObject n}] = ${toLuaObject v}"
toJSON args ))
else if isPath args builtins.attrValues
then toJSON (toString args) (lib.concatStringsSep ",\n")
else if isBool args ]
then "${boolToString args}" }}";
else if isFloat args }
then "${toString args}" .${
else if isInt args builtins.typeOf args
then "${toString args}" }
else if (args == null) or (builtins.throw "Could not convert object of type `${builtins.typeOf args}` to lua object");
then "nil" in
else throw "could not convert object of type `${typeOf args}` to lua object"; {
} inherit isLuaInline toLuaObject;
luaTable = x: (toLuaObject (map lib.mkLuaInline x));
}
// lib.genAttrs [
"nullString"
"expToLua"
"listToLuaTable"
"attrsetToLuaTable"
] (name: lib.warn "${name} is deprecated use toLuaObject instead" toLuaObject)

View file

@ -9,7 +9,7 @@
inherit (lib.strings) concatLines concatStringsSep optionalString; inherit (lib.strings) concatLines concatStringsSep optionalString;
inherit (lib.attrsets) mapAttrsToList; inherit (lib.attrsets) mapAttrsToList;
inherit (lib.types) listOf str attrsOf; inherit (lib.types) listOf str attrsOf;
inherit (lib.nvim.lua) listToLuaTable; inherit (lib.nvim.lua) toLuaObject;
inherit (lib.nvim.dag) entryAfter; inherit (lib.nvim.dag) entryAfter;
cfg = config.vim.spellcheck; cfg = config.vim.spellcheck;
@ -152,7 +152,7 @@ in {
vim.api.nvim_create_augroup("nvf_autocmds", {clear = false}) vim.api.nvim_create_augroup("nvf_autocmds", {clear = false})
vim.api.nvim_create_autocmd({ "FileType" }, { vim.api.nvim_create_autocmd({ "FileType" }, {
group = "nvf_autocmds", group = "nvf_autocmds",
pattern = ${listToLuaTable cfg.ignoredFiletypes}, pattern = ${toLuaObject cfg.ignoredFiletypes},
callback = function() callback = function()
vim.opt_local.spell = false vim.opt_local.spell = false
end, end,

View file

@ -11,11 +11,10 @@
inherit (lib.modules) mkIf mkMerge; inherit (lib.modules) mkIf mkMerge;
inherit (lib.nvim.types) mkGrammarOption; inherit (lib.nvim.types) mkGrammarOption;
inherit (lib.nvim.dag) entryAfter; inherit (lib.nvim.dag) entryAfter;
inherit (lib.nvim.lua) expToLua; inherit (lib.nvim.lua) toLuaObject;
inherit (lib.meta) getExe'; inherit (lib.meta) getExe';
inherit (lib.generators) mkLuaInline; inherit (lib.generators) mkLuaInline;
inherit (pkgs) haskellPackages; inherit (pkgs) haskellPackages;
inherit (lib.nvim.lua) toLuaObject;
cfg = config.vim.languages.haskell; cfg = config.vim.languages.haskell;
@ -120,7 +119,7 @@ in {
dap = { dap = {
cmd = ${ cmd = ${
if isList cfg.dap.package if isList cfg.dap.package
then expToLua cfg.dap.package then toLuaObject cfg.dap.package
else ''{"${cfg.dap.package}/bin/haskell-debug-adapter"}'' else ''{"${cfg.dap.package}/bin/haskell-debug-adapter"}''
}, },
}, },

View file

@ -13,7 +13,7 @@
inherit (lib.lists) isList; inherit (lib.lists) isList;
inherit (lib.types) bool package str listOf either enum; inherit (lib.types) bool package str listOf either enum;
inherit (lib.nvim.types) mkGrammarOption; inherit (lib.nvim.types) mkGrammarOption;
inherit (lib.nvim.lua) expToLua; inherit (lib.nvim.lua) toLuaObject;
inherit (lib.nvim.dag) entryAfter entryAnywhere; inherit (lib.nvim.dag) entryAfter entryAnywhere;
cfg = config.vim.languages.rust; cfg = config.vim.languages.rust;
@ -153,7 +153,7 @@ in {
server = { server = {
cmd = ${ cmd = ${
if isList cfg.lsp.package if isList cfg.lsp.package
then expToLua cfg.lsp.package then toLuaObject cfg.lsp.package
else ''{"${cfg.lsp.package}/bin/rust-analyzer"}'' else ''{"${cfg.lsp.package}/bin/rust-analyzer"}''
}, },
default_settings = { default_settings = {