chore: refactor lua generation
parent
f118fdcfe2
commit
861dd6c22c
144
lib/lua.nix
144
lib/lua.nix
|
|
@ -1,66 +1,79 @@
|
||||||
{lib, ...}: let
|
{lib, ...}: let
|
||||||
inherit (lib.strings) removeSuffix;
|
inherit (lib.strings) removeSuffix;
|
||||||
inherit (builtins) match;
|
inherit (builtins) match isNull typeOf concatStringsSep attrNames concatMap;
|
||||||
handleAst = data: let
|
|
||||||
ast = data.__ast;
|
commaJoin = concatStringsSep ", ";
|
||||||
in
|
wrapNotNull' = val: value:
|
||||||
if ast == "raw"
|
if isNull val
|
||||||
then data.data
|
then []
|
||||||
else if ast == "return"
|
else [value];
|
||||||
# TODO nix2lua can return null
|
wrapNotNull = val: wrapNotNull' val val;
|
||||||
then "return ${nix2lua data.data}"
|
|
||||||
else if ast == "fn"
|
toLua = {
|
||||||
then "function ${data.name}()\n${nix2lua data.data}\nend"
|
ast = {
|
||||||
else abort ''Unknown ast type ${ast.__ast}'';
|
raw = {data, ...}: data;
|
||||||
|
return = {data, ...}: "return ${nix2lua data}";
|
||||||
|
fn = {
|
||||||
|
data,
|
||||||
|
name,
|
||||||
|
args,
|
||||||
|
...
|
||||||
|
}: "function ${name}(${commaJoin args})\n${nix2lua data}\nend";
|
||||||
|
};
|
||||||
|
|
||||||
|
type = rec {
|
||||||
|
null = _: "nil";
|
||||||
|
string = data: ''"${data}"'';
|
||||||
|
path = string;
|
||||||
|
lambda = data: builtins.trace "Skipping function" null;
|
||||||
|
int = data: toString data;
|
||||||
|
|
||||||
|
bool = data:
|
||||||
|
if data
|
||||||
|
then "true"
|
||||||
|
else "false";
|
||||||
|
|
||||||
|
ast = data: let
|
||||||
|
astType = data.__ast;
|
||||||
|
in
|
||||||
|
if toLua.ast ? ${astType}
|
||||||
|
then toLua.ast.${astType} data
|
||||||
|
else abort ''Unknown ast type ${astType}'';
|
||||||
|
|
||||||
|
list = data: let
|
||||||
|
nix2luaList = val: wrapNotNull (nix2lua val);
|
||||||
|
listContent = commaJoin (concatMap nix2luaList data);
|
||||||
|
in "{ ${listContent} }";
|
||||||
|
|
||||||
|
set = data: let
|
||||||
|
mkKeyValue = key: let
|
||||||
|
value = data.${key};
|
||||||
|
luaKey =
|
||||||
|
if isNull (match "[a-zA-Z_][a-zA-Z_0-9]+" key)
|
||||||
|
then ''["${key}"]''
|
||||||
|
else key;
|
||||||
|
luaValue = nix2lua value;
|
||||||
|
in
|
||||||
|
wrapNotNull' luaValue ''
|
||||||
|
${luaKey} = ${luaValue},
|
||||||
|
'';
|
||||||
|
attrsContent = concatMap mkKeyValue (attrNames data);
|
||||||
|
in ''
|
||||||
|
{
|
||||||
|
${concatStringsSep "" attrsContent}}
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
newAst = type: set: set // {__ast = type;};
|
||||||
|
|
||||||
nix2lua = data: let
|
nix2lua = data: let
|
||||||
inherit (builtins) isInt isBool isNull isString isList isPath isAttrs isFunction typeOf concatStringsSep attrNames concatMap;
|
|
||||||
type = typeOf data;
|
type = typeOf data;
|
||||||
condValue2list = val: value:
|
|
||||||
if isNull val
|
|
||||||
then []
|
|
||||||
else [value];
|
|
||||||
value2list = val: condValue2list val val;
|
|
||||||
in
|
in
|
||||||
if data ? __ast
|
if data ? __ast
|
||||||
then handleAst data
|
then toLua.type.ast data
|
||||||
else if isInt data
|
else if toLua.type ? ${type}
|
||||||
then toString data
|
then toLua.type.${type} data
|
||||||
else if isBool data
|
|
||||||
then
|
|
||||||
if data
|
|
||||||
then "true"
|
|
||||||
else "false"
|
|
||||||
else if isString data || isPath data
|
|
||||||
then ''"${data}"''
|
|
||||||
else if isNull data
|
|
||||||
then "nil"
|
|
||||||
else if isFunction data
|
|
||||||
then (builtins.trace "Skipping function" null)
|
|
||||||
else if isList data
|
|
||||||
then let
|
|
||||||
nix2luaList = val: value2list (nix2lua val);
|
|
||||||
listContent = concatStringsSep ", " (concatMap nix2luaList data);
|
|
||||||
in "{ ${listContent} }"
|
|
||||||
else if isAttrs data
|
|
||||||
then let
|
|
||||||
mkKeyValue = key: let
|
|
||||||
value = data.${key};
|
|
||||||
luaKey =
|
|
||||||
if isNull (match "[a-zA-Z_][a-zA-Z_0-9]+" key)
|
|
||||||
then ''["${key}"]''
|
|
||||||
else key;
|
|
||||||
luaValue = nix2lua value;
|
|
||||||
in
|
|
||||||
# TODO Handle indentifier keys
|
|
||||||
condValue2list luaValue ''
|
|
||||||
${luaKey} = ${luaValue},
|
|
||||||
'';
|
|
||||||
attrsContent = concatMap mkKeyValue (attrNames data);
|
|
||||||
in ''
|
|
||||||
{
|
|
||||||
${concatStringsSep "" attrsContent}}
|
|
||||||
''
|
|
||||||
else abort ''Type "${type}"'';
|
else abort ''Type "${type}"'';
|
||||||
in rec {
|
in rec {
|
||||||
inherit nix2lua;
|
inherit nix2lua;
|
||||||
|
|
@ -75,21 +88,16 @@ in rec {
|
||||||
(${wrapFunction (removeSuffix "\n" lua)})();
|
(${wrapFunction (removeSuffix "\n" lua)})();
|
||||||
-- end ${section}
|
-- end ${section}
|
||||||
'';
|
'';
|
||||||
|
raw = data: newAst "raw" {inherit data;};
|
||||||
|
|
||||||
raw = data: {
|
functionWithArgs = name: args: data:
|
||||||
inherit data;
|
newAst "fn" {
|
||||||
__ast = "raw";
|
inherit name data args;
|
||||||
};
|
};
|
||||||
|
|
||||||
function = name: data: {
|
function = name: data: functionWithArgs name [] data;
|
||||||
inherit name data;
|
|
||||||
__ast = "fn";
|
|
||||||
};
|
|
||||||
|
|
||||||
lambda = function "";
|
lambda = function "";
|
||||||
|
|
||||||
return = data: {
|
return = data: newAst "return" {inherit data;};
|
||||||
inherit data;
|
|
||||||
__ast = "return";
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue