diff options
author | Vsevolod Stakhov <vsevolod@rambler-co.ru> | 2011-02-24 18:51:13 +0300 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@rambler-co.ru> | 2011-02-24 18:51:13 +0300 |
commit | 121efbcddf8ec41eea91aa80574dab3730bf8976 (patch) | |
tree | 2d39b5895526d63c7994aa81575c2db15a46cee1 /src/lua/lua_task.c | |
parent | 7eb9b642db888b26a97b06394695e55173c45895 (diff) | |
download | rspamd-121efbcddf8ec41eea91aa80574dab3730bf8976.tar.gz rspamd-121efbcddf8ec41eea91aa80574dab3730bf8976.zip |
* Rewrite URL storage system
Diffstat (limited to 'src/lua/lua_task.c')
-rw-r--r-- | src/lua/lua_task.c | 61 |
1 files changed, 31 insertions, 30 deletions
diff --git a/src/lua/lua_task.c b/src/lua/lua_task.c index 48db4c833..0a6185f7e 100644 --- a/src/lua/lua_task.c +++ b/src/lua/lua_task.c @@ -220,27 +220,37 @@ lua_task_insert_result (lua_State * L) return 1; } +struct lua_tree_cb_data { + lua_State *L; + int i; +}; + +static gboolean +lua_tree_url_callback (gpointer key, gpointer value, gpointer ud) +{ + struct uri **purl; + struct lua_tree_cb_data *cb = ud; + + purl = lua_newuserdata (cb->L, sizeof (struct uri *)); + lua_setclass (cb->L, "rspamd{url}", -1); + *purl = value; + lua_rawseti (cb->L, -2, cb->i++); + + return FALSE; +} + static gint lua_task_get_urls (lua_State * L) { - gint i = 1; struct worker_task *task = lua_check_task (L); - GList *cur; - struct uri **purl; + struct lua_tree_cb_data cb; if (task) { - cur = task->urls; - if (cur != NULL) { - lua_newtable (L); - while (cur) { - purl = lua_newuserdata (L, sizeof (struct uri *)); - lua_setclass (L, "rspamd{url}", -1); - *purl = cur->data; - lua_rawseti (L, -2, i++); - cur = g_list_next (cur); - } - return 1; - } + lua_newtable (L); + cb.i = 1; + cb.L = L; + g_tree_foreach (task->urls, lua_tree_url_callback, &cb); + return 1; } lua_pushnil (L); @@ -250,24 +260,15 @@ lua_task_get_urls (lua_State * L) static gint lua_task_get_emails (lua_State * L) { - gint i = 1; struct worker_task *task = lua_check_task (L); - GList *cur; - struct uri **purl; + struct lua_tree_cb_data cb; if (task) { - cur = task->emails; - if (cur != NULL) { - lua_newtable (L); - while (cur) { - purl = lua_newuserdata (L, sizeof (struct uri *)); - lua_setclass (L, "rspamd{url}", -1); - *purl = cur->data; - lua_rawseti (L, -2, i++); - cur = g_list_next (cur); - } - return 1; - } + lua_newtable (L); + cb.i = 1; + cb.L = L; + g_tree_foreach (task->emails, lua_tree_url_callback, &cb); + return 1; } lua_pushnil (L); |