Recompile dfilter for all tap listeners when fields changed

When fields have changed the compiled display filter may be invalid
or need a recompile to be valid.

Filters which are not valid after a recompile is set to a filter
matching no packets (frame.number == 0) to indicate that this does
no longer match anything.  We should probably have a better filter
matching no packet for this purpose.

Change-Id: Id27efa9f46e77e20df50d7366f26d5cada186f93
Reviewed-on: https://code.wireshark.org/review/10123
Petri-Dish: Stig Bjørlykke <stig@bjorlykke.org>
Tested-by: Petri Dish Buildbot <buildbot-no-reply@wireshark.org>
Reviewed-by: Stig Bjørlykke <stig@bjorlykke.org>
This commit is contained in:
Stig Bjørlykke 2015-08-19 09:00:54 +02:00
parent b755a6687b
commit fa40025a7e
3 changed files with 34 additions and 0 deletions

View File

@ -93,6 +93,7 @@ typedef struct _tap_listener_t {
int tap_id;
gboolean needs_redraw;
guint flags;
gchar *fstring;
dfilter_t *code;
void *tapdata;
tap_reset_cb reset;
@ -529,6 +530,7 @@ register_tap_listener(const char *tapname, void *tapdata, const char *fstring,
return error_string;
}
}
tl->fstring=g_strdup(fstring);
tl->tap_id=tap_id;
tl->tapdata=tapdata;
@ -573,8 +575,10 @@ set_tap_dfilter(void *tapdata, const char *fstring)
tl->code=NULL;
}
tl->needs_redraw=TRUE;
g_free(tl->fstring);
if(fstring){
if(!dfilter_compile(fstring, &tl->code, &err_msg)){
tl->fstring=NULL;
error_string = g_string_new("");
g_string_printf(error_string,
"Filter \"%s\" is invalid - %s",
@ -583,11 +587,36 @@ set_tap_dfilter(void *tapdata, const char *fstring)
return error_string;
}
}
tl->fstring=g_strdup(fstring);
}
return NULL;
}
/* this function recompiles dfilter for all registered tap listeners
*/
void
tap_listeners_dfilter_recompile(void)
{
tap_listener_t *tl;
gchar *err_msg;
for(tl=(tap_listener_t *)tap_listener_queue;tl;tl=tl->next){
if(tl->code){
dfilter_free(tl->code);
tl->code=NULL;
}
tl->needs_redraw=TRUE;
if(tl->fstring){
if(!dfilter_compile(tl->fstring, &tl->code, &err_msg)){
g_free(err_msg);
/* Not valid, make a dfilter matching no packets */
dfilter_compile("frame.number == 0", &tl->code, &err_msg);
}
}
}
}
/* this function removes a tap listener
*/
void
@ -617,6 +646,7 @@ remove_tap_listener(void *tapdata)
if(tl->code){
dfilter_free(tl->code);
}
g_free(tl->fstring);
g_free(tl);
}

View File

@ -218,6 +218,9 @@ WS_DLL_PUBLIC GString *register_tap_listener(const char *tapname, void *tapdata,
/** This function sets a new dfilter to a tap listener */
WS_DLL_PUBLIC GString *set_tap_dfilter(void *tapdata, const char *fstring);
/** This function recompiles dfilter for all registered tap listeners */
WS_DLL_PUBLIC void tap_listeners_dfilter_recompile(void);
/** this function removes a tap listener */
WS_DLL_PUBLIC void remove_tap_listener(void *tapdata);

View File

@ -1308,6 +1308,7 @@ void MainWindow::redissectPackets()
void MainWindow::fieldsChanged()
{
color_filters_reload();
tap_listeners_dfilter_recompile();
if (!df_combo_box_->checkDisplayFilter()) {
g_free(CaptureFile::globalCapFile()->dfilter);