diff options
author | Matthew Wild <mwild1@gmail.com> | 2016-07-27 14:08:32 +0100 |
---|---|---|
committer | Matthew Wild <mwild1@gmail.com> | 2016-07-27 14:08:32 +0100 |
commit | 3a8e8da3dfd5635cbf67c9d9d1c768e07a53cee3 (patch) | |
tree | a1568a41de954c6611e3334860644f96a2866121 /util-src/table.c | |
parent | 6cf7ca7a863b099ee8382a474a8ca53519c05b36 (diff) | |
parent | f78f6631d3694a1ed5c0827629bd40e34e60bef9 (diff) | |
download | prosody-3a8e8da3dfd5635cbf67c9d9d1c768e07a53cee3.tar.gz prosody-3a8e8da3dfd5635cbf67c9d9d1c768e07a53cee3.zip |
Merge 0.10 -> trunk
Diffstat (limited to 'util-src/table.c')
-rw-r--r-- | util-src/table.c | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/util-src/table.c b/util-src/table.c index 6ad45dce..423f8f29 100644 --- a/util-src/table.c +++ b/util-src/table.c @@ -6,9 +6,24 @@ static int Lcreate_table(lua_State* L) { return 1; } +static int Lpack(lua_State* L) { + unsigned int n_args = lua_gettop(L); + lua_createtable(L, n_args, 1); + lua_insert(L, 1); + for(int arg = n_args; arg >= 1; arg--) { + lua_rawseti(L, 1, arg); + } + lua_pushinteger(L, n_args); + lua_setfield(L, -2, "n"); + return 1; +} + + int luaopen_util_table(lua_State* L) { lua_newtable(L); lua_pushcfunction(L, Lcreate_table); lua_setfield(L, -2, "create"); + lua_pushcfunction(L, Lpack); + lua_setfield(L, -2, "pack"); return 1; } |