struct metric *metric,
const gchar *symbol,
double flag,
- GList * opts,
+ const gchar *opt,
gboolean single)
{
struct metric_result *metric_res;
struct symbol *s;
+ char *opt_cpy;
gdouble w, *gr_score = NULL;
struct rspamd_symbol_def *sdef;
struct rspamd_symbols_group *gr = NULL;
*/
single = TRUE;
}
- if (s->options && opts && opts != s->options &&
- !(sdef && (sdef->flags & RSPAMD_SYMBOL_FLAG_ONEPARAM))) {
- /* Append new options */
- s->options = g_list_concat (s->options, g_list_copy (opts));
- /*
- * Note that there is no need to add new destructor of GList as elements of appended
- * GList are used directly, so just free initial GList
- */
- }
- else if (opts) {
- s->options = g_list_copy (opts);
- rspamd_mempool_add_destructor (task->task_pool,
- (rspamd_mempool_destruct_t) g_list_free, s->options);
+ if (opt) {
+ if (s->options && !(sdef &&
+ (sdef->flags & RSPAMD_SYMBOL_FLAG_ONEPARAM))) {
+ /* Append new options */
+ if (!g_hash_table_lookup (s->options, opt)) {
+ opt_cpy = rspamd_mempool_strdup (task->task_pool, opt);
+ g_hash_table_insert (s->options, opt_cpy, opt_cpy);
+ }
+ }
+ else {
+ s->options = g_hash_table_new (rspamd_strcase_hash,
+ rspamd_strcase_equal);
+ rspamd_mempool_add_destructor (task->task_pool,
+ (rspamd_mempool_destruct_t)g_hash_table_unref,
+ s->options);
+ opt_cpy = rspamd_mempool_strdup (task->task_pool, opt);
+ g_hash_table_insert (s->options, opt_cpy, opt_cpy);
+ }
}
if (!single) {
/* Handle grow factor */
s->def = sdef;
metric_res->score += w;
- if (opts) {
- s->options = g_list_copy (opts);
+ if (opt) {
+ s->options = g_hash_table_new (rspamd_strcase_hash,
+ rspamd_strcase_equal);
rspamd_mempool_add_destructor (task->task_pool,
- (rspamd_mempool_destruct_t) g_list_free, s->options);
+ (rspamd_mempool_destruct_t)g_hash_table_unref,
+ s->options);
+ opt_cpy = rspamd_mempool_strdup (task->task_pool, opt);
+ g_hash_table_insert (s->options, opt_cpy, opt_cpy);
}
else {
s->options = NULL;
g_hash_table_insert (metric_res->symbols, (gpointer) symbol, s);
}
+
msg_debug ("symbol %s, score %.2f, metric %s, factor: %f",
symbol,
s->score,
insert_result_common (struct rspamd_task *task,
const gchar *symbol,
double flag,
- GList * opts,
+ const gchar *opt,
gboolean single)
{
struct metric *metric;
while (cur) {
metric = cur->data;
- insert_metric_result (task, metric, symbol, flag, opts, single);
+ insert_metric_result (task, metric, symbol, flag, opt, single);
cur = g_list_next (cur);
}
}
task->cfg->default_metric,
symbol,
flag,
- opts,
+ opt,
single);
}
if (task->cfg->cache) {
rspamd_symbols_cache_inc_frequency (task->cfg->cache, symbol);
}
-
- if (opts != NULL) {
- /* XXX: it is not wise to destroy them here */
- g_list_free (opts);
- }
}
/* Insert result that may be increased on next insertions */
rspamd_task_insert_result (struct rspamd_task *task,
const gchar *symbol,
double flag,
- GList * opts)
+ const gchar *opt)
{
- insert_result_common (task, symbol, flag, opts, task->cfg->one_shot_mode);
+ insert_result_common (task, symbol, flag, opt, task->cfg->one_shot_mode);
}
/* Insert result as a single option */
rspamd_task_insert_result_single (struct rspamd_task *task,
const gchar *symbol,
double flag,
- GList * opts)
+ const gchar *opt)
{
- insert_result_common (task, symbol, flag, opts, TRUE);
+ insert_result_common (task, symbol, flag, opt, TRUE);
}
gboolean
}
static ucl_object_t *
-rspamd_str_list_ucl (GList *str_list)
+rspamd_str_hash_ucl (GHashTable *ht)
{
+ GHashTableIter it;
+ gpointer k, v;
ucl_object_t *top = NULL, *obj;
- GList *cur;
top = ucl_object_typed_new (UCL_ARRAY);
- cur = str_list;
- while (cur) {
- obj = ucl_object_fromstring (cur->data);
- ucl_array_append (top, obj);
- cur = g_list_next (cur);
+
+ if (ht) {
+ g_hash_table_iter_init (&it, ht);
+
+ while (g_hash_table_iter_next (&it, &k, &v)) {
+ obj = ucl_object_fromstring ((const char *)v);
+ ucl_array_append (top, obj);
+ }
}
return top;
description), "description", 0, false);
}
if (sym->options != NULL) {
- ucl_object_insert_key (obj, rspamd_str_list_ucl (
- sym->options), "options", 0, false);
+ ucl_object_insert_key (obj, rspamd_str_hash_ucl (sym->options),
+ "options", 0, false);
}
return obj;
struct metric_result *metric_res;
struct symbol *s;
gint j;
- GList *opt;
metric_res = g_hash_table_lookup (task->results, metric->name);
if (metric_res) {
}
if (s->options) {
- opt = s->options;
+ GHashTableIter it;
+ gpointer k, v;
+
lua_pushstring (L, "options");
- lua_newtable (L);
+ lua_createtable (L, g_hash_table_size (s->options), 0);
+ g_hash_table_iter_init (&it, s->options);
- while (opt) {
- lua_pushstring (L, opt->data);
+ while (g_hash_table_iter_next (&it, &k, &v)) {
+ lua_pushstring (L, (const char*)v);
lua_rawseti (L, -2, j++);
- opt = g_list_next (opt);
}
lua_settable (L, -3);