aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/libucl/lua_ucl.c
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@rspamd.com>2024-08-15 14:57:54 +0100
committerVsevolod Stakhov <vsevolod@rspamd.com>2024-08-15 14:57:54 +0100
commit56343d2576e88573d1a26431cfa54ee1a22c9715 (patch)
tree84541e082ec79a9e16922b2b1a26d4457e88992d /contrib/libucl/lua_ucl.c
parentc787e333ff9d339dba816120dbec434dbf1da5d6 (diff)
downloadrspamd-56343d2576e88573d1a26431cfa54ee1a22c9715.tar.gz
rspamd-56343d2576e88573d1a26431cfa54ee1a22c9715.zip
[Minor] Some minor fixes
Diffstat (limited to 'contrib/libucl/lua_ucl.c')
-rw-r--r--contrib/libucl/lua_ucl.c16
1 files changed, 10 insertions, 6 deletions
diff --git a/contrib/libucl/lua_ucl.c b/contrib/libucl/lua_ucl.c
index a06273820..fd925870d 100644
--- a/contrib/libucl/lua_ucl.c
+++ b/contrib/libucl/lua_ucl.c
@@ -100,7 +100,7 @@ static ucl_object_t *lua_ucl_object_get(lua_State *L, int index);
static void *ucl_null;
-struct _rspamd_lua_text {
+struct rspamd_compat_lua_text {
const char *start;
unsigned int len;
unsigned int flags;
@@ -543,7 +543,7 @@ ucl_object_lua_fromelt(lua_State *L, int idx, ucl_string_flags_t flags)
}
else {
/* Assume it is a text like object */
- struct _rspamd_lua_text *t = lua_touserdata(L, idx);
+ struct rspamd_compat_lua_text *t = lua_touserdata(L, idx);
if (t) {
if (t->len > 0) {
@@ -902,7 +902,7 @@ static int
lua_ucl_parser_parse_text(lua_State *L)
{
struct ucl_parser *parser;
- struct _rspamd_lua_text *t;
+ struct rspamd_compat_lua_text *t;
enum ucl_parse_type type = UCL_PARSE_UCL;
int ret = 2;
@@ -914,7 +914,7 @@ lua_ucl_parser_parse_text(lua_State *L)
else if (lua_type(L, 2) == LUA_TSTRING) {
const char *s;
gsize len;
- static struct _rspamd_lua_text st_t;
+ static struct rspamd_compat_lua_text st_t;
s = lua_tolstring(L, 2, &len);
st_t.start = s;
@@ -1385,11 +1385,15 @@ lua_ucl_newindex(lua_State *L)
ucl_object_replace_key(obj, value_obj, key, keylen, true);
}
else {
- return luaL_error(L, "invalid value type: %s", lua_typename(L, value_type));
+ /* Delete key */
+ ucl_object_delete_keyl(obj, key, keylen);
}
}
else {
- ucl_object_insert_key(obj, value_obj, key, keylen, true);
+ if (value_obj != NULL) {
+ ucl_object_insert_key(obj, value_obj, key, keylen, true);
+ }
+ /* Do nothing if value_obj is null, like Lua does */
}
return 0;