diff options
author | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-12-27 15:23:31 +0000 |
---|---|---|
committer | Vsevolod Stakhov <vsevolod@highsecure.ru> | 2015-12-27 15:23:31 +0000 |
commit | 0eb0172c3c3cea2981ed728653cee127130e3177 (patch) | |
tree | 17f810c06291dd54a7d416c8c89a3815f48198ae /src/libserver/cfg_rcl.c | |
parent | 2275d0b9ebeda6a1edffb3f1f38d3b3af7c9c8a3 (diff) | |
download | rspamd-0eb0172c3c3cea2981ed728653cee127130e3177.tar.gz rspamd-0eb0172c3c3cea2981ed728653cee127130e3177.zip |
Initial implementation of documentation strings in rspamd
Diffstat (limited to 'src/libserver/cfg_rcl.c')
-rw-r--r-- | src/libserver/cfg_rcl.c | 82 |
1 files changed, 82 insertions, 0 deletions
diff --git a/src/libserver/cfg_rcl.c b/src/libserver/cfg_rcl.c index bff732c4f..aa5c91864 100644 --- a/src/libserver/cfg_rcl.c +++ b/src/libserver/cfg_rcl.c @@ -61,6 +61,7 @@ struct rspamd_rcl_section { struct rspamd_rcl_default_handler_data *default_parser; /**< generic parsing fields */ rspamd_rcl_section_fin_t fin; /** called at the end of section parsing */ gpointer fin_ud; + ucl_object_t *doc_ref; /**< reference to the section's documentation */ }; struct rspamd_worker_param_key { @@ -1214,6 +1215,7 @@ rspamd_rcl_add_section (struct rspamd_rcl_section **top, enum ucl_type type, gboolean required, gboolean strict_type) { struct rspamd_rcl_section *new; + ucl_object_t *parent_doc; new = g_slice_alloc0 (sizeof (struct rspamd_rcl_section)); new->name = name; @@ -1222,6 +1224,43 @@ rspamd_rcl_add_section (struct rspamd_rcl_section **top, new->type = type; new->strict_type = strict_type; + if (*top == NULL) { + parent_doc = NULL; + new->doc_ref = NULL; + } + else { + parent_doc = (*top)->doc_ref; + new->doc_ref = new->doc_ref = rspamd_rcl_add_doc_obj (parent_doc, + NULL, + name, + type, + NULL, + 0); + } + + HASH_ADD_KEYPTR (hh, *top, new->name, strlen (new->name), new); + return new; +} + +struct rspamd_rcl_section * +rspamd_rcl_add_section_doc (struct rspamd_rcl_section **top, + const gchar *name, const gchar *key_attr, rspamd_rcl_handler_t handler, + enum ucl_type type, gboolean required, gboolean strict_type, + ucl_object_t *doc_target, + const gchar *doc_string) +{ + struct rspamd_rcl_section *new; + + new = g_slice_alloc0 (sizeof (struct rspamd_rcl_section)); + new->name = name; + new->key_attr = key_attr; + new->handler = handler; + new->type = type; + new->strict_type = strict_type; + + new->doc_ref = rspamd_rcl_add_doc_obj (doc_target, doc_string, + name, type, NULL, 0); + HASH_ADD_KEYPTR (hh, *top, new->name, strlen (new->name), new); return new; } @@ -1242,6 +1281,11 @@ rspamd_rcl_add_default_handler (struct rspamd_rcl_section *section, new->pd.offset = offset; new->pd.flags = flags; + if (section->doc_ref != NULL) { + rspamd_rcl_add_doc_obj (section->doc_ref, doc_string, name, UCL_NULL, + handler, flags); + } + HASH_ADD_KEYPTR (hh, section->default_parser, new->key, strlen ( new->key), new); return new; @@ -2804,3 +2848,41 @@ rspamd_config_read (struct rspamd_config *cfg, const gchar *filename, return TRUE; } + +ucl_object_t * +rspamd_rcl_add_doc_obj (ucl_object_t *doc_target, + const char *doc_string, + const char *doc_name, + ucl_type_t type, + rspamd_rcl_default_handler_t handler, + gint flags) +{ + ucl_object_t *doc_obj; + + if (doc_target == NULL || doc_name == NULL) { + return NULL; + } + + doc_obj = ucl_object_typed_new (UCL_OBJECT); + + /* Insert doc string itself */ + if (doc_string) { + ucl_object_insert_key (doc_obj, ucl_object_fromstring (doc_string), + "data", 0, false); + } + else { + ucl_object_insert_key (doc_obj, ucl_object_fromstring ("undocumented"), + "data", 0, false); + } + + if (type != UCL_NULL) { + ucl_object_insert_key (doc_obj, + ucl_object_fromstring (ucl_object_type_to_string (type)), + "type", 0, false); + } + + /* TODO: add type from handler */ + ucl_object_insert_key (doc_target, doc_obj, doc_name, 0, true); + + return doc_obj; +} |