1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182
|
#include <stdlib.h>
#include <string.h>
#ifdef HAVE_CONFIG_H
#include <config.h>
#endif
#include <jmp-config.h>
#include <cls.h>
#include <filter.h>
struct class_filter {
int filter_type; /** FILTER_MATCH_CLASS, ... */
char* filter_name; /** java.lang */
int inc_or_exc; /** include or exclude filter */
};
/** double linked list for easy handling. */
struct filter_list {
class_filter* filter;
filter_list* next;
filter_list* prev;
};
static filter_list* current_filters = NULL;
/** Get the filter type
* @return one of the FILTER_MATCH_*
*/
int get_filter_type (class_filter* cf) {
return cf->filter_type;
}
/** Get the filter name
* @return the name that is matched for the given filter.
*/
char* get_filter_name (class_filter* cf) {
return cf->filter_name;
}
/**
* @return FILTER_INCLUDE or FILTER_EXCLUDE
*/
int get_inc_or_exc (class_filter* cf) {
return cf->inc_or_exc;
}
filter_list* get_current_filters () {
return current_filters;
}
filter_list* get_next_filter (filter_list* fl) {
return fl->next;
}
class_filter* get_class_filter (filter_list* fl) {
return fl->filter;
}
int filter_class_name (const char *name)
{
filter_list* fl = current_filters;
if (current_filters == NULL)
return 1;
while (fl) {
class_filter* filter = fl->filter;
if (filter->filter_type == FILTER_MATCH_ALL) {
return filter->inc_or_exc;
} else if (filter->filter_type == FILTER_MATCH_CLASS) {
if (!strcmp (name, filter->filter_name))
return filter->inc_or_exc;
} else if (filter->filter_type == FILTER_MATCH_RECURSIVE) {
if (!strncmp(name, filter->filter_name, strlen (filter->filter_name)))
return filter->inc_or_exc;
}else if (filter->filter_type == FILTER_MATCH_PACKAGE) {
size_t len = strlen (filter->filter_name);
if (!strncmp (name, filter->filter_name, len))
if (!strchr (name + len, '.'))
return filter->inc_or_exc;
}
fl = fl->next;
}
return 0;
}
void set_filtered (cls* c) {
cls_set_filtered (c, filter_class_name (cls_get_name (c)));
}
/** Update each class filtered variable. */
static void update_classes () {
hashtab* classes = get_classes ();
jmphash_lock (classes);
jmphash_for_each ((jmphash_iter_f)set_filtered, classes);
jmphash_unlock (classes);
}
static void filter_add_filter_internal (class_filter* filter) {
filter_list* fl;
fl = malloc (sizeof (*current_filters));
if (fl == NULL)
return;
fl->next = current_filters;
fl->prev = NULL;
fl->filter = filter;
if (current_filters)
current_filters->prev = fl;
current_filters = fl;
update_classes ();
}
void filter_add_filter (int mode, const char* text, int type) {
class_filter* cfilter;
if (text == NULL)
return;
cfilter = malloc (sizeof (*cfilter));
if (cfilter == NULL)
return;
cfilter->filter_type = type;
cfilter->filter_name = strdup (text);
cfilter->inc_or_exc = mode;
filter_add_filter_internal (cfilter);
}
static void free_filter_list_elem (filter_list* fl) {
free (fl->filter->filter_name);
free (fl->filter);
free (fl);
}
void remove_filter (class_filter* filter) {
filter_list* fl = current_filters;
while (fl) {
if (fl->filter == filter) {
if (fl->next)
fl->next->prev = fl->prev;
if (fl->prev)
fl->prev->next = fl->next;
else /* first in list */
current_filters = fl->next;
free_filter_list_elem (fl);
break;
} else {
fl = fl->next;
}
}
update_classes ();
}
void filter_clear_filters_internal (int do_update_classes) {
while (current_filters) {
filter_list* next_filter = current_filters->next;
free_filter_list_elem (current_filters);
current_filters = next_filter;
}
if (do_update_classes)
update_classes ();
}
/** Removes all current filters. */
void filter_clear_filters () {
filter_clear_filters_internal (1);
}
/* Set the filter.
* @param filtertype one of FILTER_MATCH_*
* @param filter the string to filter on ("rabbit.proxy").
*/
void filter_set_filter (int filter_type, const char* filter) {
if (filter == NULL)
return;
filter_clear_filters (0);
filter_add_filter (FILTER_INCLUDE, filter, filter_type);
}
/* Emacs Local Variables: */
/* Emacs mode:C */
/* Emacs c-indentation-style:"gnu" */
/* Emacs c-hanging-braces-alist:((brace-list-open)(brace-entry-open)(defun-open after)(substatement-open after)(block-close . c-snug-do-while)(extern-lang-open after)) */
/* Emacs c-cleanup-list:(brace-else-brace brace-elseif-brace space-before-funcall) */
/* Emacs c-basic-offset:4 */
/* Emacs End: */
|