X-Git-Url: https://git.octo.it/?a=blobdiff_plain;f=src%2Fgraph.h;h=b7a7a8919e0ac93d6a238d57229f52758c1fdb78;hb=eceb676f7780ab7490b32708131f5c115e838427;hp=26b4ac619bf5975074bbec6721e0629ee2de1b43;hpb=f393a5cc0a2a7b0cd1d5b06166966d7af6f9daf5;p=collection4.git diff --git a/src/graph.h b/src/graph.h index 26b4ac6..b7a7a89 100644 --- a/src/graph.h +++ b/src/graph.h @@ -29,6 +29,7 @@ #include "oconfig.h" #include "rrd_args.h" #include "utils_array.h" +#include "utils_search.h" /* * Functions @@ -52,12 +53,19 @@ graph_def_t *graph_get_defs (graph_config_t *cfg); int graph_add_def (graph_config_t *cfg, graph_def_t *def); -_Bool graph_matches_ident (graph_config_t *cfg, const graph_ident_t *ident); +/* Returns true if the given "ident" matches the (more general) selector of + * the graph "cfg". */ +_Bool graph_ident_matches (graph_config_t *cfg, const graph_ident_t *ident); -/* Compares the given string with the appropriate field of the selector. If the - * selector field is "/all/" or "/any/", returns true without checking the - * instances. See "graph_inst_search_field" for finding all matching instances. - * */ +/* Returns true if the selector of the graph "cfg" matches the more general + * ident "selector". */ +_Bool graph_matches_ident (graph_config_t *cfg, + const graph_ident_t *selector); + +/* Compares the given string with the appropriate field of the selector. If + * the selector field is "/all/" or "/any/", returns true without checking the + * instances. See "graph_inst_search_field" for finding all matching + * instances. */ _Bool graph_matches_field (graph_config_t *cfg, graph_ident_field_t field, const char *field_value); @@ -74,7 +82,13 @@ int graph_inst_find_all_matching (graph_config_t *cfg, const graph_ident_t *ident, graph_inst_callback_t callback, void *user_data); -int graph_inst_search (graph_config_t *cfg, const char *term, +/* Search for instances using a search_info_t. The code assumes that the + * graph's selector has already been checked against the search_info_t, using + * "search_to_ident" and "graph_matches_ident". */ +int graph_search_inst (graph_config_t *cfg, search_info_t *si, + graph_inst_callback_t callback, void *user_data); + +int graph_search_inst_string (graph_config_t *cfg, const char *term, graph_inst_callback_t callback, void *user_data); /* Iterates over all instances and calls "inst_matches_field". If that method @@ -85,6 +99,8 @@ int graph_inst_search_field (graph_config_t *cfg, int graph_compare (graph_config_t *cfg, const graph_ident_t *ident); +size_t graph_num_instances (graph_config_t *cfg); + int graph_sort_instances (graph_config_t *cfg); int graph_clear_instances (graph_config_t *cfg);