/* * Wireshark - Network traffic analyzer * By Gerald Combs * Copyright 2001 Gerald Combs * * SPDX-License-Identifier: GPL-2.0-or-later */ #ifndef DFILTER_H #define DFILTER_H #include #include "ws_symbol_export.h" /* Passed back to user */ typedef struct epan_dfilter dfilter_t; #include #ifdef __cplusplus extern "C" { #endif /* __cplusplus */ struct epan_dissect; /* Module-level initialization */ void dfilter_init(void); /* Module-level cleanup */ void dfilter_cleanup(void); /* Compiles a string to a dfilter_t. * On success, sets the dfilter* pointed to by dfp * to either a NULL pointer (if the filter is a null * filter, as generated by an all-blank string) or to * a pointer to the newly-allocated dfilter_t * structure. * * On failure, *err_msg is set to point to the error * message. This error message is allocated with * g_malloc(), and must be freed with g_free(). * The dfilter* will be set to NULL after a failure. * * Returns TRUE on success, FALSE on failure. */ WS_DLL_PUBLIC gboolean dfilter_compile(const gchar *text, dfilter_t **dfp, gchar **err_msg); /* Frees all memory used by dfilter, and frees * the dfilter itself. */ WS_DLL_PUBLIC void dfilter_free(dfilter_t *df); /* Apply compiled dfilter */ WS_DLL_PUBLIC gboolean dfilter_apply_edt(dfilter_t *df, struct epan_dissect *edt); /* Apply compiled dfilter */ gboolean dfilter_apply(dfilter_t *df, proto_tree *tree); /* Prime a proto_tree using the fields/protocols used in a dfilter. */ void dfilter_prime_proto_tree(const dfilter_t *df, proto_tree *tree); /* Check if dfilter has interesting fields */ gboolean dfilter_has_interesting_fields(const dfilter_t *df); WS_DLL_PUBLIC GPtrArray * dfilter_deprecated_tokens(dfilter_t *df); /* Print bytecode of dfilter to stdout */ WS_DLL_PUBLIC void dfilter_dump(dfilter_t *df); #ifdef __cplusplus } #endif /* __cplusplus */ #endif /* DFILTER_H */