Wireshark 4.7.0
The Wireshark network protocol analyzer
Loading...
Searching...
No Matches
prefs.h
Go to the documentation of this file.
1
10#pragma once
11#include <glib.h>
12
13#include <epan/params.h>
14#include <epan/range.h>
15
16#include <wsutil/color.h>
17
18#include "ws_symbol_export.h"
19
20#ifdef __cplusplus
21extern "C" {
22#endif /* __cplusplus */
23
24#define DEF_WIDTH 750
25#define DEF_HEIGHT 550
26
27#define MAX_VAL_LEN 1024
28
29#define TAP_UPDATE_DEFAULT_INTERVAL 3000
30#define ST_DEF_BURSTRES 5
31#define ST_DEF_BURSTLEN 100
32#define ST_MAX_BURSTRES 600000 /* somewhat arbitrary limit of 10 minutes */
33#define ST_MAX_BURSTBUCKETS 100 /* somewhat arbitrary limit - more buckets degrade performance */
34#define DEF_GUI_DECIMAL_PLACES1 2
35#define DEF_GUI_DECIMAL_PLACES2 4
36#define DEF_GUI_DECIMAL_PLACES3 6
37
38#define CONV_DEINT_KEY_CAPFILE 0x01 /* unused yet */
39#define CONV_DEINT_KEY_INTERFACE 0x02
40#define CONV_DEINT_KEY_MAC 0x04
41#define CONV_DEINT_KEY_VLAN 0x08
42
43/* Bitmask of flags for the effect of a preference in Wireshark */
44#define PREF_EFFECT_DISSECTION (1u << 0)
45#define PREF_EFFECT_CAPTURE (1u << 1)
46#define PREF_EFFECT_GUI_LAYOUT (1u << 2)
47#define PREF_EFFECT_FIELDS (1u << 3)
48#define PREF_EFFECT_GUI (1u << 4)
49#define PREF_EFFECT_GUI_COLOR (1u << 5)
50#define PREF_EFFECT_AGGREGATION (1u << 6)
51
52/* Default update interval in milliseconds */
53#define DEFAULT_UPDATE_INTERVAL 100
54
55struct epan_uat;
56struct _e_addr_resolve;
57
69WS_DLL_PUBLIC
70char string_to_name_resolve(const char *string, struct _e_addr_resolve *name_resolve);
71
72/*
73 * Modes for the starting directory in File Open dialogs.
74 */
75#define FO_STYLE_LAST_OPENED 0 /* start in last directory we looked at */
76#define FO_STYLE_SPECIFIED 1 /* start in specified directory */
77#define FO_STYLE_CWD 2 /* start in current working directory at startup */
78
79/*
80 * Toolbar styles.
81 */
82#define TB_STYLE_ICONS 0
83#define TB_STYLE_TEXT 1
84#define TB_STYLE_BOTH 2
85
86#define COLOR_SCHEME_DEFAULT 0
87#define COLOR_SCHEME_LIGHT 1
88#define COLOR_SCHEME_DARK 2
89
103
104
115
116
126
127
135
136
145
146
156
157
167
168
178
179
187
188
198
199
208
209
213typedef struct _e_prefs {
214 GList *col_list;
215 unsigned num_cols;
219 /* GUI appearance */
224 /* Colorized column colors */
228 /* Window geometry */
233 /* Recent entries */
237 /* File open dialog */
244 /* Dialog behavior */
249 /* Window title */
255 /* Export/tree limits */
262 /* Layout */
269 /* Interface filtering */
274 /* I/O graph */
278 /* Plot */
285 /* Capture device settings */
296 /* Capture behavior */
303 /* Aggregation */
307 /* Capture startup */
313 /* Update intervals */
316 /* Dissection display options */
321 /* Dissector checking */
327 /* Duplicate frame detection */
331 /* Migration flags */
335 /* Auto-update */
343 /* Packet list display options */
357 /* Multi-color stripe settings */
363 /* Decimal places for statistics calculations */
368 /* RTP player */
372 /* Flow graph */
375 /* Statistics burst detection */
381 /* Statistics sorting */
393
394WS_DLL_PUBLIC e_prefs prefs;
395
396/*
397 * Routines to let modules that have preference settings register
398 * themselves by name, and to let them register preference settings
399 * by name.
400 */
401struct pref_module;
402
403struct pref_custom_cbs;
404
405typedef struct pref_module module_t;
406
415void prefs_init(const char** col_fmt, int num_cols);
416
426WS_DLL_PUBLIC void prefs_reset(const char* app_env_var_prefix, const char** col_fmt, int num_cols);
427
433void prefs_cleanup(void);
434
443WS_DLL_PUBLIC module_t *prefs_register_protocol(int id, void (*apply_cb)(void));
444
451WS_DLL_PUBLIC void prefs_register_module_alias(const char *name, module_t *module);
452
458void prefs_deregister_protocol(int id);
459
470WS_DLL_PUBLIC module_t *prefs_register_stat(const char *name, const char *title,
471 const char *description, void (*apply_cb)(void));
472
483WS_DLL_PUBLIC module_t *prefs_register_codec(const char *name, const char *title,
484 const char *description, void (*apply_cb)(void));
485
497WS_DLL_PUBLIC module_t *prefs_register_protocol_subtree(const char *subtree, int id,
498 void (*apply_cb)(void));
499
507WS_DLL_PUBLIC module_t *prefs_register_protocol_obsolete(int id);
508
528WS_DLL_PUBLIC module_t*
529prefs_register_module(wmem_tree_t* pref_tree, wmem_tree_t* master_pref_tree, const char* name, const char* title,
530 const char* description, const char* help, void (*apply_cb)(void),
531 const bool use_gui);
532
536typedef unsigned (*module_cb)(module_t *module, void *user_data);
537
543WS_DLL_PUBLIC bool prefs_module_has_submodules(module_t *module);
544
557WS_DLL_PUBLIC unsigned prefs_modules_foreach(const wmem_tree_t* module, module_cb callback, void *user_data);
558
573WS_DLL_PUBLIC unsigned prefs_modules_foreach_submodules(const wmem_tree_t* module, module_cb callback, void *user_data);
574
586WS_DLL_PUBLIC unsigned prefs_modules_for_all_modules(module_cb callback, void* user_data);
587
594WS_DLL_PUBLIC void prefs_apply_all(void);
595
603WS_DLL_PUBLIC void prefs_apply(module_t *module);
604
605
606struct preference;
607
608typedef struct preference pref_t;
609
615WS_DLL_PUBLIC bool prefs_is_registered_protocol(const char *name);
616
622WS_DLL_PUBLIC const char *prefs_get_title_by_name(const char *name);
623
632WS_DLL_PUBLIC module_t *prefs_find_module(const char *name);
633
643WS_DLL_PUBLIC pref_t *prefs_find_preference(module_t * module, const char *pref);
644
662WS_DLL_PUBLIC void prefs_register_uint_preference(module_t *module, const char *name,
663 const char *title, const char *description, unsigned base, unsigned *var);
664
681WS_DLL_PUBLIC void prefs_register_int_preference(module_t* module, const char* name,
682 const char* title, const char* description, int* var);
683
701WS_DLL_PUBLIC void prefs_register_float_preference(module_t* module, const char* name,
702 const char* title, const char* description, unsigned num_decimal, double* var);
703
704/*
705 * prefs_register_ callers must conform to the following:
706 *
707 * Names must be in lowercase letters only (underscore allowed).
708 * Titles and descriptions must be valid UTF-8 or NULL.
709 * Titles must be short (less than 80 characters)
710 * Titles must not contain newlines.
711 */
712
729WS_DLL_PUBLIC void prefs_register_bool_preference(module_t *module, const char *name,
730 const char *title, const char *description, bool *var);
731
752WS_DLL_PUBLIC void prefs_register_enum_preference(module_t *module, const char *name,
753 const char *title, const char *description, int *var,
754 const enum_val_t *enumvals, bool radio_buttons);
755
777WS_DLL_PUBLIC void prefs_register_string_preference(module_t *module, const char *name,
778 const char *title, const char *description, const char **var);
779
807WS_DLL_PUBLIC void prefs_register_filename_preference(module_t *module, const char *name,
808 const char *title, const char *description, const char **var, bool for_writing);
809
834WS_DLL_PUBLIC void prefs_register_directory_preference(module_t *module, const char *name,
835 const char *title, const char *description, const char **var);
836
861WS_DLL_PUBLIC void prefs_register_list_string_preference(module_t* module, const char* name,
862 const char* title, const char* description, wmem_list_t** var);
863
889WS_DLL_PUBLIC void prefs_register_multiple_string_preference(module_t* module, const char* name,
890 const char* title, const char* description, wmem_list_t** var);
891
909WS_DLL_PUBLIC void prefs_register_range_preference(module_t *module, const char *name,
910 const char *title, const char *description, range_t **var,
911 uint32_t max_value);
912
927WS_DLL_PUBLIC void prefs_register_static_text_preference(module_t *module, const char *name,
928 const char *title, const char *description);
929
947WS_DLL_PUBLIC void prefs_register_uat_preference(module_t *module,
948 const char *name, const char* title, const char *description, struct epan_uat* uat);
949
970void prefs_register_color_preference(module_t *module, const char *name,
971 const char *title, const char *description, color_t *color);
972
994 const char *title, const char *description, struct pref_custom_cbs* custom_cbs,
995 void** custom_data);
996
1017 const char *title, const char *description, range_t **var,
1018 uint32_t max_value, const char *dissector_table, const char *dissector_description);
1019
1036WS_DLL_PUBLIC void prefs_register_password_preference(module_t *module, const char *name,
1037 const char *title, const char *description, const char **var);
1038
1060WS_DLL_PUBLIC void prefs_register_dissector_preference(module_t *module, const char *name,
1061 const char *title, const char *description, const char **var);
1062
1079WS_DLL_PUBLIC void prefs_register_obsolete_preference(module_t *module,
1080 const char *name);
1081
1102WS_DLL_PUBLIC void prefs_register_custom_preference_TCP_Analysis(module_t *module, const char *name,
1103 const char *title, const char *description, int *var,
1104 const enum_val_t *enumvals, bool radio_buttons);
1105
1122WS_DLL_PUBLIC void prefs_set_preference_effect_fields(module_t *module,
1123 const char *name);
1124
1132WS_DLL_PUBLIC void prefs_set_preference_effect(module_t* module,
1133 const char* name, unsigned flags);
1134
1135typedef unsigned (*pref_cb)(pref_t *pref, void *user_data);
1136
1151WS_DLL_PUBLIC unsigned prefs_pref_foreach(module_t *module, pref_cb callback,
1152 void *user_data);
1153
1164WS_DLL_PUBLIC GList *prefs_get_string_list(const char *str);
1165
1170WS_DLL_PUBLIC void prefs_clear_string_list(GList *sl);
1171
1179WS_DLL_PUBLIC
1180const char *prefs_pref_type_name(pref_t *pref);
1181
1191WS_DLL_PUBLIC
1193
1202WS_DLL_PUBLIC
1203char *prefs_pref_to_str(pref_t *pref, pref_source_t source);
1204
1212WS_DLL_PUBLIC
1213int prefs_num_non_uat(module_t* module);
1214
1215
1223WS_DLL_PUBLIC
1225
1238extern e_prefs *read_prefs(const char* app_env_var_prefix);
1239
1250WS_DLL_PUBLIC int write_prefs(const char* app_env_var_prefix, char **pf_path_return);
1251
1258WS_DLL_PUBLIC void pref_write_individual(void* data, void* user_data);
1259
1266WS_DLL_PUBLIC void pref_free_individual(void* data, void* user_data);
1267
1277
1291WS_DLL_PUBLIC prefs_set_pref_e prefs_set_pref(char *prefarg, char **errmsg);
1292
1302WS_DLL_PUBLIC range_t* prefs_get_range_value(const char *module_name, const char* pref_name);
1303
1310WS_DLL_PUBLIC bool prefs_is_capture_device_hidden(const char *name);
1311
1318WS_DLL_PUBLIC bool prefs_capture_device_monitor_mode(const char *name);
1319
1326WS_DLL_PUBLIC bool prefs_capture_options_dialog_column_is_visible(const char *column);
1327
1334WS_DLL_PUBLIC bool prefs_has_layout_pane_content (layout_pane_content_e layout_pane_content);
1335
1336#ifdef __cplusplus
1337}
1338#endif /* __cplusplus */
1339
1340/*
1341 * Editor modelines - https://www.wireshark.org/tools/modelines.html
1342 *
1343 * Local variables:
1344 * c-basic-offset: 4
1345 * tab-width: 8
1346 * indent-tabs-mode: nil
1347 * End:
1348 *
1349 * vi: set shiftwidth=4 tabstop=8 expandtab:
1350 * :indentSize=4:tabSize=8:noTabs=true:
1351 */
WS_DLL_PUBLIC module_t * prefs_register_codec(const char *name, const char *title, const char *description, void(*apply_cb)(void))
Definition prefs.c:816
WS_DLL_PUBLIC void prefs_register_filename_preference(module_t *module, const char *name, const char *title, const char *description, const char **var, bool for_writing)
Definition prefs.c:1603
pref_source_t
Selects which copy of a preference value is used as the active source.
Definition prefs.h:140
@ pref_stashed
Definition prefs.h:142
@ pref_current
Definition prefs.h:143
@ pref_default
Definition prefs.h:141
WS_DLL_PUBLIC bool prefs_is_preference_obsolete(pref_t *pref)
Fetch whether a preference is marked obsolete.
Definition prefs.c:2086
WS_DLL_PUBLIC void prefs_set_preference_effect(module_t *module, const char *name, unsigned flags)
Set the effect flags for a preference in a given module.
Definition prefs.c:2097
WS_DLL_PUBLIC module_t * prefs_register_protocol_subtree(const char *subtree, int id, void(*apply_cb)(void))
Definition prefs.c:717
WS_DLL_PUBLIC prefs_set_pref_e prefs_set_pref(char *prefarg, char **errmsg)
Definition prefs.c:5014
WS_DLL_PUBLIC void prefs_register_uat_preference(module_t *module, const char *name, const char *title, const char *description, struct epan_uat *uat)
Definition prefs.c:1842
WS_DLL_PUBLIC void prefs_clear_string_list(GList *sl)
Clear the given list of string data.
Definition prefs.c:4234
void prefs_register_color_preference(module_t *module, const char *name, const char *title, const char *description, color_t *color)
Definition prefs.c:1860
abs_time_format_e
Controls whether absolute timestamps are rendered as ASCII in tree and column views.
Definition prefs.h:172
@ ABS_TIME_ASCII_NEVER
Definition prefs.h:173
@ ABS_TIME_ASCII_ALWAYS
Definition prefs.h:176
@ ABS_TIME_ASCII_COLUMN
Definition prefs.h:175
@ ABS_TIME_ASCII_TREE
Definition prefs.h:174
WS_DLL_PUBLIC range_t * prefs_get_range_value(const char *module_name, const char *pref_name)
Definition prefs.c:1803
WS_DLL_PUBLIC bool prefs_capture_options_dialog_column_is_visible(const char *column)
Returns true if the user has marked this column as visible.
Definition prefs.c:5402
WS_DLL_PUBLIC void prefs_register_directory_preference(module_t *module, const char *name, const char *title, const char *description, const char **var)
Definition prefs.c:1617
gui_packet_list_multi_color_separator_e
Visual style of the separator between adjacent color stripes in the packet list.
Definition prefs.h:203
@ PACKET_LIST_MULTI_COLOR_SEPARATOR_BUBBLE
Definition prefs.h:206
@ PACKET_LIST_MULTI_COLOR_SEPARATOR_DIAGONAL
Definition prefs.h:205
@ PACKET_LIST_MULTI_COLOR_SEPARATOR_VERTICAL
Definition prefs.h:204
WS_DLL_PUBLIC void prefs_register_range_preference(module_t *module, const char *name, const char *title, const char *description, range_t **var, uint32_t max_value)
Definition prefs.c:1659
WS_DLL_PUBLIC char * prefs_pref_type_description(pref_t *pref)
Fetch a long description of the preference type.
Definition prefs.c:6357
WS_DLL_PUBLIC void prefs_register_obsolete_preference(module_t *module, const char *name)
Register a preference that used to be supported but no longer is.
Definition prefs.c:2080
WS_DLL_PUBLIC module_t * prefs_find_module(const char *name)
Definition prefs.c:824
elide_mode_e
Controls which end of a text string is elided when it is too long to display.
Definition prefs.h:150
@ ELIDE_MIDDLE
Definition prefs.h:153
@ ELIDE_NONE
Definition prefs.h:154
@ ELIDE_LEFT
Definition prefs.h:151
@ ELIDE_RIGHT
Definition prefs.h:152
e_prefs * read_prefs(const char *app_env_var_prefix)
Read the preferences file, fill in "prefs", and return a pointer to it.
Definition prefs.c:4659
WS_DLL_PUBLIC void prefs_register_multiple_string_preference(module_t *module, const char *name, const char *title, const char *description, wmem_list_t **var)
WS_DLL_PUBLIC void prefs_apply_all(void)
Definition prefs.c:952
WS_DLL_PUBLIC void prefs_register_string_preference(module_t *module, const char *name, const char *title, const char *description, const char **var)
Definition prefs.c:1589
void prefs_register_decode_as_range_preference(module_t *module, const char *name, const char *title, const char *description, range_t **var, uint32_t max_value, const char *dissector_table, const char *dissector_description)
Definition prefs.c:1994
gui_packet_list_multi_color_mode_e
Multi-color stripe display mode for the packet list scrollbar and rows.
Definition prefs.h:192
@ PACKET_LIST_MULTI_COLOR_MODE_SCROLLBAR_ONLY
Definition prefs.h:194
@ PACKET_LIST_MULTI_COLOR_MODE_OFF
Definition prefs.h:193
@ PACKET_LIST_MULTI_COLOR_MODE_SHIFT_RIGHT
Definition prefs.h:196
@ PACKET_LIST_MULTI_COLOR_MODE_FULL
Definition prefs.h:195
WS_DLL_PUBLIC void prefs_register_float_preference(module_t *module, const char *name, const char *title, const char *description, unsigned num_decimal, double *var)
Definition prefs.c:1226
WS_DLL_PUBLIC bool prefs_has_layout_pane_content(layout_pane_content_e layout_pane_content)
Returns true if the layout pane content is enabled.
Definition prefs.c:5417
unsigned(* module_cb)(module_t *module, void *user_data)
Definition prefs.h:536
WS_DLL_PUBLIC bool prefs_is_registered_protocol(const char *name)
Definition prefs.c:1167
WS_DLL_PUBLIC void prefs_register_static_text_preference(module_t *module, const char *name, const char *title, const char *description)
Definition prefs.c:1830
WS_DLL_PUBLIC void prefs_set_preference_effect_fields(module_t *module, const char *name)
Mark a preference that affects fields change.
Definition prefs.c:2092
WS_DLL_PUBLIC void pref_free_individual(void *data, void *user_data)
Callback function for freeing individual preferences.
WS_DLL_PUBLIC const char * prefs_get_title_by_name(const char *name)
Definition prefs.c:1178
layout_pane_content_e
Content assigned to a single layout pane in the main window.
Definition prefs.h:108
@ layout_pane_content_plist
Definition prefs.h:110
@ layout_pane_content_pbytes
Definition prefs.h:112
@ layout_pane_content_pdetails
Definition prefs.h:111
@ layout_pane_content_pdiagram
Definition prefs.h:113
@ layout_pane_content_none
Definition prefs.h:109
WS_DLL_PUBLIC unsigned prefs_pref_foreach(module_t *module, pref_cb callback, void *user_data)
Call a callback function, with a specified argument, for each preference in a given module.
Definition prefs.c:2458
WS_DLL_PUBLIC pref_t * prefs_find_preference(module_t *module, const char *pref)
Definition prefs.c:1158
WS_DLL_PUBLIC module_t * prefs_register_protocol_obsolete(int id)
Definition prefs.c:769
void prefs_deregister_protocol(int id)
Definition prefs.c:705
WS_DLL_PUBLIC bool prefs_capture_device_monitor_mode(const char *name)
Returns true if the given device should capture in monitor mode by default.
Definition prefs.c:5378
WS_DLL_PUBLIC void prefs_register_module_alias(const char *name, module_t *module)
Register an alias for a preference module.
Definition prefs.c:650
prefs_set_pref_e
Result of setting a preference.
Definition prefs.h:1271
@ PREFS_SET_OK
Definition prefs.h:1272
@ PREFS_SET_SYNTAX_ERR
Definition prefs.h:1273
@ PREFS_SET_OBSOLETE
Definition prefs.h:1275
@ PREFS_SET_NO_SUCH_PREF
Definition prefs.h:1274
WS_DLL_PUBLIC void pref_write_individual(void *data, void *user_data)
Callback function for writing individual preferences.
Definition prefs.c:6700
version_info_e
Controls where version information is displayed in the GUI.
Definition prefs.h:120
@ version_both
Definition prefs.h:123
@ version_title_only
Definition prefs.h:122
@ version_neither
Definition prefs.h:124
@ version_welcome_only
Definition prefs.h:121
WS_DLL_PUBLIC char * prefs_pref_to_str(pref_t *pref, pref_source_t source)
Fetch a string representation of the preference.
Definition prefs.c:6563
WS_DLL_PUBLIC const char * prefs_pref_type_name(pref_t *pref)
Fetch a short preference type name, e.g. "Integer".
Definition prefs.c:6211
WS_DLL_PUBLIC unsigned prefs_modules_foreach(const wmem_tree_t *module, module_cb callback, void *user_data)
Definition prefs.c:901
WS_DLL_PUBLIC unsigned prefs_modules_for_all_modules(module_cb callback, void *user_data)
Definition prefs.c:923
void prefs_cleanup(void)
Clean up preferences.
Definition prefs.c:421
copy_format_e
Output format for copying packet list rows to the clipboard.
Definition prefs.h:161
@ COPY_FORMAT_CSV
Definition prefs.h:163
@ COPY_FORMAT_YAML
Definition prefs.h:164
@ COPY_FORMAT_TEXT
Definition prefs.h:162
@ COPY_FORMAT_HTML
Definition prefs.h:165
WS_DLL_PUBLIC void prefs_register_uint_preference(module_t *module, const char *name, const char *title, const char *description, unsigned base, unsigned *var)
Definition prefs.c:1189
software_update_channel_e
Automatic software update channel selection.
Definition prefs.h:183
@ UPDATE_CHANNEL_DEVELOPMENT
Definition prefs.h:184
@ UPDATE_CHANNEL_STABLE
Definition prefs.h:185
WS_DLL_PUBLIC void prefs_register_dissector_preference(module_t *module, const char *name, const char *title, const char *description, const char **var)
Definition prefs.c:2024
WS_DLL_PUBLIC int prefs_num_non_uat(module_t *module)
Fetch the number of preferences in a module that are not UATs.
Definition prefs.c:6811
WS_DLL_PUBLIC int write_prefs(const char *app_env_var_prefix, char **pf_path_return)
Write out "prefs" to the user's preferences file, and return 0.
Definition prefs.c:6894
WS_DLL_PUBLIC module_t * prefs_register_protocol(int id, void(*apply_cb)(void))
Definition prefs.c:693
void prefs_init(const char **col_fmt, int num_cols)
Initialize preferences system.
Definition prefs.c:326
WS_DLL_PUBLIC GList * prefs_get_string_list(const char *str)
Parse through a list of comma-separated, possibly quoted strings. Return a list of the string data.
Definition prefs.c:4105
WS_DLL_PUBLIC void prefs_apply(module_t *module)
Definition prefs.c:964
WS_DLL_PUBLIC void prefs_reset(const char *app_env_var_prefix, const char **col_fmt, int num_cols)
Resets preferences to their default values.
Definition prefs.c:4545
WS_DLL_PUBLIC module_t * prefs_register_module(wmem_tree_t *pref_tree, wmem_tree_t *master_pref_tree, const char *name, const char *title, const char *description, const char *help, void(*apply_cb)(void), const bool use_gui)
Register a module that will have preferences. Specify the module under which to register it,...
Definition prefs.c:512
WS_DLL_PUBLIC void prefs_register_bool_preference(module_t *module, const char *name, const char *title, const char *description, bool *var)
Definition prefs.c:1263
struct _e_prefs e_prefs
Global Wireshark preferences structure holding all persistent configuration settings.
layout_type_e
Arrangement type of the summary, details, and hex panes in the main window.
Definition prefs.h:93
@ layout_type_5
Definition prefs.h:95
@ layout_type_4
Definition prefs.h:98
@ layout_type_1
Definition prefs.h:97
@ layout_unused
Definition prefs.h:94
@ layout_type_3
Definition prefs.h:99
@ layout_type_2
Definition prefs.h:96
@ layout_type_6
Definition prefs.h:100
@ layout_type_max
Definition prefs.h:101
WS_DLL_PUBLIC void prefs_register_list_string_preference(module_t *module, const char *name, const char *title, const char *description, wmem_list_t **var)
void prefs_register_custom_preference(module_t *module, const char *name, const char *title, const char *description, struct pref_custom_cbs *custom_cbs, void **custom_data)
WS_DLL_PUBLIC void prefs_register_enum_preference(module_t *module, const char *name, const char *title, const char *description, int *var, const enum_val_t *enumvals, bool radio_buttons)
Definition prefs.c:1352
WS_DLL_PUBLIC module_t * prefs_register_stat(const char *name, const char *title, const char *description, void(*apply_cb)(void))
Definition prefs.c:796
WS_DLL_PUBLIC void prefs_register_int_preference(module_t *module, const char *name, const char *title, const char *description, int *var)
Definition prefs.c:1212
WS_DLL_PUBLIC unsigned prefs_modules_foreach_submodules(const wmem_tree_t *module, module_cb callback, void *user_data)
Definition prefs.c:917
WS_DLL_PUBLIC bool prefs_module_has_submodules(module_t *module)
Definition prefs.c:879
WS_DLL_PUBLIC void prefs_register_custom_preference_TCP_Analysis(module_t *module, const char *name, const char *title, const char *description, int *var, const enum_val_t *enumvals, bool radio_buttons)
Register a preference with an enumerated value.
Definition prefs.c:1975
WS_DLL_PUBLIC bool prefs_is_capture_device_hidden(const char *name)
Checks if the specified capture device is hidden.
Definition prefs.c:5229
WS_DLL_PUBLIC char string_to_name_resolve(const char *string, struct _e_addr_resolve *name_resolve)
Definition prefs.c:5425
WS_DLL_PUBLIC void prefs_register_password_preference(module_t *module, const char *name, const char *title, const char *description, const char **var)
Definition prefs.c:2010
splitter_layout_e
Orientation of a splitter divider between panes.
Definition prefs.h:131
@ layout_horizontal
Definition prefs.h:133
@ layout_vertical
Definition prefs.h:132
Flags to control name resolution.
Definition addr_resolv.h:49
Global Wireshark preferences structure holding all persistent configuration settings.
Definition prefs.h:213
unsigned gui_decimal_places1
Definition prefs.h:364
bool gui_plot_enable_legend
Definition prefs.h:280
bool gui_rtp_player_use_disk2
Definition prefs.h:370
unsigned capture_update_interval
Definition prefs.h:301
bool gui_packet_list_copy_text_with_aligned_columns
Definition prefs.h:351
char * capture_devices_linktypes
Definition prefs.h:287
GList * aggregation_fields
Definition prefs.h:304
bool gui_update_enabled
Definition prefs.h:336
bool filter_expressions_old
Definition prefs.h:332
bool gui_packet_list_multi_color_details
Definition prefs.h:360
bool gui_plot_automatic_update
Definition prefs.h:279
char * gui_colorized_fg
Definition prefs.h:225
bool restore_filter_after_following_stream
Definition prefs.h:217
bool gui_packet_list_show_minimap
Definition prefs.h:353
char * capture_devices_monitor_mode
Definition prefs.h:290
bool gui_packet_details_show_byteview
Definition prefs.h:283
bool capture_show_info
Definition prefs.h:310
bool capture_no_interface_load
Definition prefs.h:308
unsigned gui_decimal_places3
Definition prefs.h:366
unsigned gui_decimal_places2
Definition prefs.h:365
char * capture_devices_descr
Definition prefs.h:288
bool gui_welcome_page_show_recent
Definition prefs.h:260
char * capture_device
Definition prefs.h:286
char * gui_window_title
Definition prefs.h:250
unsigned st_burst_windowlen
Definition prefs.h:379
bool capture_pcap_ng
Definition prefs.h:299
char * capture_devices_pmode
Definition prefs.h:293
copy_format_e gui_packet_list_copy_format_options_for_keyboard_shortcut
Definition prefs.h:350
bool capture_no_extcap
Definition prefs.h:309
char * capture_devices_snaplen
Definition prefs.h:292
char * gui_tlskeylog_command
Definition prefs.h:242
software_update_channel_e gui_update_channel
Definition prefs.h:337
bool gui_ask_unsaved
Definition prefs.h:245
int conversation_deinterlacing_key
Definition prefs.h:325
layout_pane_content_e gui_layout_content_3
Definition prefs.h:266
splitter_layout_e gui_packet_dialog_layout
Definition prefs.h:267
unsigned gui_fileopen_preview
Definition prefs.h:240
bool st_burst_showcount
Definition prefs.h:377
char * gui_start_title
Definition prefs.h:252
bool gui_packet_list_show_related
Definition prefs.h:352
char * saved_at_version
Definition prefs.h:341
char * gui_colorized_bg
Definition prefs.h:226
bool gui_interfaces_remote_display
Definition prefs.h:272
bool gui_io_graph_enable_legend
Definition prefs.h:276
int gui_toolbar_main_style
Definition prefs.h:220
char * gui_font_name
Definition prefs.h:221
abs_time_format_e display_abs_time_ascii
Definition prefs.h:319
bool gui_packet_list_hover_style
Definition prefs.h:346
bool gui_show_file_load_time
Definition prefs.h:348
char * capture_devices_filter
Definition prefs.h:294
unsigned st_burst_resolution
Definition prefs.h:378
bool gui_packet_header_column_definition
Definition prefs.h:345
unsigned gui_recent_files_count_max
Definition prefs.h:235
int st_format
Definition prefs.h:388
char * gui_prepend_window_title
Definition prefs.h:251
layout_pane_content_e gui_layout_content_2
Definition prefs.h:265
char * capture_devices_hide
Definition prefs.h:289
unsigned tap_update_interval
Definition prefs.h:314
bool gui_find_wrap
Definition prefs.h:247
gui_packet_list_multi_color_separator_e gui_packet_list_multi_color_separator
Definition prefs.h:361
GList * col_list
Definition prefs.h:214
unsigned gui_update_interval
Definition prefs.h:338
int gui_color_scheme
Definition prefs.h:222
bool gui_autocomplete_filter
Definition prefs.h:246
bool capture_real_time
Definition prefs.h:300
bool gui_show_selected_packet
Definition prefs.h:347
bool incomplete_dissectors_check_debug
Definition prefs.h:323
unsigned gui_max_tree_depth
Definition prefs.h:258
unsigned gui_max_export_objects
Definition prefs.h:256
bool gui_geometry_save_position
Definition prefs.h:229
bool gui_geometry_save_maximized
Definition prefs.h:231
bool gui_packet_list_sortable
Definition prefs.h:354
bool st_sort_showfullname
Definition prefs.h:387
gui_packet_list_multi_color_mode_e gui_packet_list_multi_color_mode
Definition prefs.h:358
bool gui_interfaces_show_hidden
Definition prefs.h:271
bool st_sort_rng_fixorder
Definition prefs.h:383
bool st_sort_rng_nameonly
Definition prefs.h:384
bool display_hidden_proto_items
Definition prefs.h:317
bool gui_geometry_save_size
Definition prefs.h:230
bool gui_rtp_player_use_disk1
Definition prefs.h:369
unsigned num_cols
Definition prefs.h:215
unsigned flow_graph_max_export_items
Definition prefs.h:373
int aggregation_fields_num
Definition prefs.h:305
unsigned gui_packet_list_multi_color_shift_percent
Definition prefs.h:359
bool gui_io_graph_automatic_update
Definition prefs.h:275
char * gui_interfaces_hide_types
Definition prefs.h:270
bool st_sort_defdescending
Definition prefs.h:386
bool extcap_save_on_start
Definition prefs.h:391
char * gui_fileopen_dir
Definition prefs.h:239
bool ignore_dup_frames
Definition prefs.h:328
char * capture_devices_buffersize
Definition prefs.h:291
layout_pane_content_e gui_layout_content_1
Definition prefs.h:264
unsigned ignore_dup_frames_cache_entries
Definition prefs.h:329
bool strict_conversation_tracking_heuristics
Definition prefs.h:324
unsigned gui_fileopen_style
Definition prefs.h:238
bool display_byte_fields_with_spaces
Definition prefs.h:318
unsigned gui_debounce_timer
Definition prefs.h:339
bool st_sort_casesensitve
Definition prefs.h:382
bool gui_packet_list_separator
Definition prefs.h:344
bool gui_plot_enable_auto_scroll
Definition prefs.h:281
bool capture_monitor_mode
Definition prefs.h:298
unsigned gui_packet_list_cached_rows_max
Definition prefs.h:355
unsigned gui_max_tree_items
Definition prefs.h:257
unsigned gui_recent_df_entries_max
Definition prefs.h:234
version_info_e gui_version_placement
Definition prefs.h:253
bool enable_incomplete_dissectors_check
Definition prefs.h:322
int st_sort_defcolflag
Definition prefs.h:385
GList * capture_columns
Definition prefs.h:311
bool st_enable_burstinfo
Definition prefs.h:376
bool capture_prom_mode
Definition prefs.h:297
bool conv_machine_readable
Definition prefs.h:390
layout_type_e gui_layout_type
Definition prefs.h:263
bool cols_hide_new
Definition prefs.h:333
elide_mode_e gui_packet_list_elide_mode
Definition prefs.h:349
Definition wmem_list.c:23
Internal representation of a wmem balanced tree.
Definition wmem_tree-int.h:81
RGB color representation with 16-bit precision per channel.
Definition color.h:27
Definition packet.c:97
Defines a single named value within an enumerated preference or option type.
Definition params.h:16
Definition range.h:42
Represents a User Accessible Table (UAT), managing a set of user-editable records exposed to a dissec...
Definition uat-int.h:44
Callback table for a PREF_CUSTOM preference, providing lifecycle and serialization hooks.
Definition prefs-int.h:116
Represents a preference module grouping related preferences under a named, hierarchical entry in the ...
Definition prefs-int.h:27
bool use_gui
Definition prefs-int.h:42
const char * description
Definition prefs-int.h:30
const char * name
Definition prefs-int.h:28
void(* apply_cb)(void)
Definition prefs-int.h:32
const char * title
Definition prefs-int.h:29
const char * help
Definition prefs-int.h:31
Definition prefs.c:207
unsigned base
Definition prefs.c:252
const char * description
Definition prefs.c:210
const char * title
Definition prefs.c:209
const char * name
Definition prefs.c:208
struct pref_custom_cbs custom_cbs
Definition prefs.c:262
uint32_t max_value
Definition prefs.c:253
const enum_val_t * enumvals
Definition prefs.c:255
bool radio_buttons
Definition prefs.c:256