summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--src/rspamadm/lua_repl.c16
1 files changed, 16 insertions, 0 deletions
diff --git a/src/rspamadm/lua_repl.c b/src/rspamadm/lua_repl.c
index 024561733..2f6ee5676 100644
--- a/src/rspamadm/lua_repl.c
+++ b/src/rspamadm/lua_repl.c
@@ -32,6 +32,7 @@
static gchar **paths = NULL;
static gchar **scripts = NULL;
+static gchar **lua_args = NULL;
static gchar *histfile = NULL;
static guint max_history = 2000;
static gchar *serve = NULL;
@@ -109,6 +110,8 @@ static GOptionEntry entries[] = {
"Serve http lua server", NULL},
{"batch", 'b', 0, G_OPTION_ARG_NONE, &batch,
"Batch execution mode", NULL},
+ {"args", 'a', 0, G_OPTION_ARG_STRING_ARRAY, &lua_args,
+ "Arguments to pass to Lua", NULL},
{NULL, 0, 0, G_OPTION_ARG_NONE, NULL, NULL, NULL}
};
@@ -124,6 +127,7 @@ rspamadm_lua_help (gboolean full_help)
"-p: add additional lua paths (may be repeated)\n"
"-s: load scripts on start from specified files (may be repeated)\n"
"-S: listen on a specified address as HTTP server\n"
+ "-a: pass argument to lua (may be repeated)\n"
"--help: shows available options and commands";
}
else {
@@ -682,6 +686,18 @@ rspamadm_lua (gint argc, gchar **argv)
}
}
+ if (lua_args) {
+ int i = 1;
+ lua_newtable (L);
+ for (elt = lua_args; *elt != NULL; elt ++) {
+ lua_pushnumber(L, i);
+ lua_pushstring(L, *elt);
+ lua_settable (L, -3);
+ i++;
+ }
+ lua_setglobal (L, "arg");
+ }
+
if (scripts) {
for (elt = scripts; *elt != NULL; elt ++) {
if (!rspamadm_lua_load_script (L, *elt)) {