aboutsummaryrefslogtreecommitdiffstats
path: root/src/lua/lua_expression.c
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2019-05-17 17:54:26 +0100
committerVsevolod Stakhov <vsevolod@highsecure.ru>2019-05-17 17:54:26 +0100
commit6d72c9e66f5d8a11258bcf3a84224cfd8d45f24f (patch)
treeb7d84172bc60736a3732acab8c81eeb92f9bc6e6 /src/lua/lua_expression.c
parent12fee52a2fc74660279413a208883fe71b705ca7 (diff)
downloadrspamd-6d72c9e66f5d8a11258bcf3a84224cfd8d45f24f.tar.gz
rspamd-6d72c9e66f5d8a11258bcf3a84224cfd8d45f24f.zip
[Minor] Lua_expression: Allow simplier invocation of create function
Diffstat (limited to 'src/lua/lua_expression.c')
-rw-r--r--src/lua/lua_expression.c82
1 files changed, 45 insertions, 37 deletions
diff --git a/src/lua/lua_expression.c b/src/lua/lua_expression.c
index d65f8c454..d2c1b4a4b 100644
--- a/src/lua/lua_expression.c
+++ b/src/lua/lua_expression.c
@@ -351,7 +351,8 @@ lua_expr_create (lua_State *L)
rspamd_mempool_t *pool;
/* Check sanity of the arguments */
- if (lua_type (L, 1) != LUA_TSTRING || lua_type (L, 2) != LUA_TTABLE ||
+ if (lua_type (L, 1) != LUA_TSTRING ||
+ (lua_type (L, 2) != LUA_TTABLE || lua_type (L, 2) != LUA_TFUNCTION) ||
rspamd_lua_check_mempool (L, 3) == NULL) {
msg_info ("bad arguments to lua_expr_create");
lua_pushnil (L);
@@ -361,60 +362,67 @@ lua_expr_create (lua_State *L)
line = lua_tolstring (L, 1, &len);
pool = rspamd_lua_check_mempool (L, 3);
- /* Check callbacks */
- lua_pushvalue (L, 2);
- lua_pushnumber (L, 1);
- lua_gettable (L, -2);
-
- if (lua_type (L, -1) != LUA_TFUNCTION) {
- lua_pop (L, 2);
- lua_pushnil (L);
- lua_pushstring (L, "bad parse callback");
-
- return 2;
- }
-
- lua_pop (L, 1);
+ e = rspamd_mempool_alloc (pool, sizeof (*e));
+ e->L = L;
+ e->pool = pool;
- lua_pushnumber (L, 2);
- lua_gettable (L, -2);
+ /* Check callbacks */
+ if (lua_istable (L, 2)) {
+ lua_pushvalue (L, 2);
+ lua_pushnumber (L, 1);
+ lua_gettable (L, -2);
- if (lua_type (L, -1) != LUA_TFUNCTION) {
- if (lua_type (L, -1) != LUA_TNIL && lua_type (L, -1) != LUA_TNONE) {
+ if (lua_type (L, -1) != LUA_TFUNCTION) {
lua_pop (L, 2);
lua_pushnil (L);
- lua_pushstring (L, "bad process callback");
+ lua_pushstring (L, "bad parse callback");
return 2;
}
- else {
- no_process = TRUE;
- }
- }
- lua_pop (L, 1);
+ lua_pop (L, 1);
- /* Table is still on the top of stack */
+ lua_pushnumber (L, 2);
+ lua_gettable (L, -2);
- e = rspamd_mempool_alloc (pool, sizeof (*e));
- e->L = L;
- e->pool = pool;
+ if (lua_type (L, -1) != LUA_TFUNCTION) {
+ if (lua_type (L, -1) != LUA_TNIL && lua_type (L, -1) != LUA_TNONE) {
+ lua_pop (L, 2);
+ lua_pushnil (L);
+ lua_pushstring (L, "bad process callback");
+
+ return 2;
+ }
+ else {
+ no_process = TRUE;
+ }
+ }
- lua_pushnumber (L, 1);
- lua_gettable (L, -2);
- e->parse_idx = luaL_ref (L, LUA_REGISTRYINDEX);
+ lua_pop (L, 1);
+ /* Table is still on the top of stack */
- if (!no_process) {
- lua_pushnumber (L, 2);
+ lua_pushnumber (L, 1);
lua_gettable (L, -2);
- e->process_idx = luaL_ref (L, LUA_REGISTRYINDEX);
+ e->parse_idx = luaL_ref (L, LUA_REGISTRYINDEX);
+
+ if (!no_process) {
+ lua_pushnumber (L, 2);
+ lua_gettable (L, -2);
+ e->process_idx = luaL_ref (L, LUA_REGISTRYINDEX);
+ }
+ else {
+ e->process_idx = -1;
+ }
+
+ lua_pop (L, 1); /* Table */
}
else {
+ /* Process function is just a function, not a table */
+ lua_pushvalue (L, 2);
+ e->parse_idx = luaL_ref (L, LUA_REGISTRYINDEX);
e->process_idx = -1;
}
- lua_pop (L, 1); /* Table */
-
if (!rspamd_parse_expression (line, len, &lua_atom_subr, e, pool, &err,
&e->expr)) {
lua_pushnil (L);