aboutsummaryrefslogtreecommitdiff
path: root/src/nvim/lua
diff options
context:
space:
mode:
authorbfredl <bjorn.linse@gmail.com>2024-02-08 11:43:27 +0100
committerGitHub <noreply@github.com>2024-02-08 11:43:27 +0100
commit3f2d543ee8d01ce0d4515ed35b96e274b1668a54 (patch)
treed138042dfb217ce2a3153df2b447f587c3e49a56 /src/nvim/lua
parent02cc84b4d9d8efdd27c3f60fef11e02297051fab (diff)
parentca2635adf9c9c45ea745b9f750dc4da7063bdd14 (diff)
downloadrneovim-3f2d543ee8d01ce0d4515ed35b96e274b1668a54.tar.gz
rneovim-3f2d543ee8d01ce0d4515ed35b96e274b1668a54.tar.bz2
rneovim-3f2d543ee8d01ce0d4515ed35b96e274b1668a54.zip
Merge pull request #27284 from bfredl/unkeydict
refactor(api): use keydict and arena for more api return values
Diffstat (limited to 'src/nvim/lua')
-rw-r--r--src/nvim/lua/converter.c43
1 files changed, 43 insertions, 0 deletions
diff --git a/src/nvim/lua/converter.c b/src/nvim/lua/converter.c
index 91f2db3ac9..3cf5b0e94f 100644
--- a/src/nvim/lua/converter.c
+++ b/src/nvim/lua/converter.c
@@ -1360,3 +1360,46 @@ void nlua_pop_keydict(lua_State *L, void *retval, FieldHashfn hashy, char **err_
lua_pop(L, 1);
// []
}
+
+void nlua_push_keydict(lua_State *L, void *value, KeySetLink *table)
+{
+ lua_createtable(L, 0, 0);
+ for (size_t i = 0; table[i].str; i++) {
+ KeySetLink *field = &table[i];
+ bool is_set = true;
+ if (field->opt_index >= 0) {
+ OptKeySet *ks = (OptKeySet *)value;
+ is_set = ks->is_set_ & (1ULL << field->opt_index);
+ }
+
+ if (!is_set) {
+ continue;
+ }
+
+ char *mem = ((char *)value + field->ptr_off);
+
+ lua_pushstring(L, field->str);
+ if (field->type == kObjectTypeNil) {
+ nlua_push_Object(L, *(Object *)mem, false);
+ } else if (field->type == kObjectTypeInteger || field->type == kObjectTypeBuffer
+ || field->type == kObjectTypeWindow || field->type == kObjectTypeTabpage) {
+ lua_pushinteger(L, *(Integer *)mem);
+ } else if (field->type == kObjectTypeFloat) {
+ lua_pushnumber(L, *(Float *)mem);
+ } else if (field->type == kObjectTypeBoolean) {
+ lua_pushboolean(L, *(Boolean *)mem);
+ } else if (field->type == kObjectTypeString) {
+ nlua_push_String(L, *(String *)mem, false);
+ } else if (field->type == kObjectTypeArray) {
+ nlua_push_Array(L, *(Array *)mem, false);
+ } else if (field->type == kObjectTypeDictionary) {
+ nlua_push_Dictionary(L, *(Dictionary *)mem, false);
+ } else if (field->type == kObjectTypeLuaRef) {
+ nlua_pushref(L, *(LuaRef *)mem);
+ } else {
+ abort();
+ }
+
+ lua_rawset(L, -3);
+ }
+}