Wireshark 4.5.0
The Wireshark network protocol analyzer
|
Go to the source code of this file.
Classes | |
struct | _fld_data_t |
struct | epan_uat |
Macros | |
#define | UAT_UPDATE(uat) do { *((uat)->user_ptr) = (void*)((uat)->user_data->data); *((uat)->nrows_p) = (uat)->user_data->len; } while(0) |
#define | UAT_INDEX_PTR(uat, idx) (uat->raw_data->data + (uat->record_size * (idx))) |
#define | UAT_USER_INDEX_PTR(uat, idx) (uat->user_data->data + (uat->record_size * (idx))) |
Typedefs | |
typedef struct _uat_fld_rep_t | uat_fld_rep_t |
typedef struct _uat_rep_t | uat_rep_t |
typedef void(* | uat_rep_fld_free_cb_t) (uat_fld_rep_t *) |
typedef void(* | uat_rep_free_cb_t) (uat_rep_t *) |
typedef struct _fld_data_t | fld_data_t |
Functions | |
WS_DLL_PUBLIC char * | uat_get_actual_filename (uat_t *uat, bool for_writing) |
WS_DLL_PUBLIC void * | uat_add_record (uat_t *uat, const void *orig_rec_ptr, bool valid_rec) |
WS_DLL_PUBLIC void | uat_update_record (uat_t *uat, const void *record, bool valid_rec) |
WS_DLL_PUBLIC void | uat_swap (uat_t *uat, unsigned idx_a, unsigned idx_b) |
WS_DLL_PUBLIC void | uat_insert_record_idx (uat_t *uat, unsigned rec_idx, const void *src_record) |
WS_DLL_PUBLIC void | uat_remove_record_idx (uat_t *uat, unsigned rec_idx) |
WS_DLL_PUBLIC void | uat_remove_record_range (uat_t *uat, unsigned rec_idx, unsigned count) |
WS_DLL_PUBLIC void | uat_move_index (uat_t *uat, unsigned old_idx, unsigned new_idx) |
WS_DLL_PUBLIC void | uat_clear (uat_t *uat) |
WS_DLL_PUBLIC bool | uat_save (uat_t *uat, char **error) |
void | uat_load_all (void) |
WS_DLL_PUBLIC char * | uat_fld_tostr (void *rec, uat_field_t *f) |
User Accessible Tables Maintain an array of user accessible data structures Internal interface
(c) 2007, Luis E. Garcia Ontanon luis@.nosp@m.onta.nosp@m.non.o.nosp@m.rg
Wireshark - Network traffic analyzer By Gerald Combs geral.nosp@m.d@wi.nosp@m.resha.nosp@m.rk.o.nosp@m.rg Copyright 2001 Gerald Combs
SPDX-License-Identifier: GPL-2.0-or-later
#define UAT_INDEX_PTR | ( | uat, | |
idx | |||
) | (uat->raw_data->data + (uat->record_size * (idx))) |
Get a record from the array of all UAT entries, whether they are semantically valid or not. This memory must only be used internally in the UAT core and must not be exposed to dissectors.
#define UAT_UPDATE | ( | uat | ) | do { *((uat)->user_ptr) = (void*)((uat)->user_data->data); *((uat)->nrows_p) = (uat)->user_data->len; } while(0) |
Exposes the array of valid records to the UAT consumer (dissectors), updating the contents of 'data_ptr' and 'num_items_ptr' (see 'uat_new').
#define UAT_USER_INDEX_PTR | ( | uat, | |
idx | |||
) | (uat->user_data->data + (uat->record_size * (idx))) |
Get a record from the array of all valid entries. These records will be shared with UAT consumers (dissectors).
WS_DLL_PUBLIC void * uat_add_record | ( | uat_t * | uat, |
const void * | orig_rec_ptr, | ||
bool | valid_rec | ||
) |
Clones the given record and stores it internally in the UAT. If it is considered a valid record, then it will also be cloned and stored in the externally visible list.
WS_DLL_PUBLIC void uat_clear | ( | uat_t * | uat | ) |
Removes and destroys all records from the UAT.
WS_DLL_PUBLIC char * uat_fld_tostr | ( | void * | rec, |
uat_field_t * | f | ||
) |
Dump given UAT record to string in form which can be later loaded with uat_load_str(). XXX - In fact this only dumps a single field. To produce the format for uat_load_str(), join all the fields as CSV records, escaping and double- quoting field types other than PT_TXTMOD_HEXBYTES. Perhaps we should have a function that dumps the entire record.
WS_DLL_PUBLIC void uat_insert_record_idx | ( | uat_t * | uat, |
unsigned | rec_idx, | ||
const void * | src_record | ||
) |
Inserts the record at the given index in the internal record list.
void uat_load_all | ( | void | ) |
Loads the records for all registered UATs from file.
WS_DLL_PUBLIC void uat_move_index | ( | uat_t * | uat, |
unsigned | old_idx, | ||
unsigned | new_idx | ||
) |
Moves the entry from the old position to the new one
WS_DLL_PUBLIC void uat_remove_record_idx | ( | uat_t * | uat, |
unsigned | rec_idx | ||
) |
Removes the record with the given index from the internal record list. If the UAT has a free_cb it is called for the removed record.
WS_DLL_PUBLIC void uat_remove_record_range | ( | uat_t * | uat, |
unsigned | rec_idx, | ||
unsigned | count | ||
) |
Removes the given number of records starting with the given index from the internal record list. If the UAT has a free_cb it is called for the removed records.
WS_DLL_PUBLIC bool uat_save | ( | uat_t * | uat, |
char ** | error | ||
) |
Saves the records from an UAT to file. Returns true on success and false on failure, storing the reason in 'error' (which must be freed using g_free).
WS_DLL_PUBLIC void uat_swap | ( | uat_t * | uat, |
unsigned | idx_a, | ||
unsigned | idx_b | ||
) |
Changes the order of two internal UAT records.
WS_DLL_PUBLIC void uat_update_record | ( | uat_t * | uat, |
const void * | record, | ||
bool | valid_rec | ||
) |
Marks the internal record in the UAT as valid or invalid. The record must exist in the UAT.