epan/dissectors/pidl/samr/samr.cnf cnf_dissect_lsa_BinaryString => lsarpc_dissect_str...
[wireshark-sm.git] / epan / decode_as.h
blob92b5b3ae4a0b59447317087db8450e2c4e15a3fa
1 /* decode_as.h
2 * Routines for dissector Decode As handlers
4 * Wireshark - Network traffic analyzer
5 * By Gerald Combs <gerald@wireshark.org>
6 * Copyright 1998 Gerald Combs
8 * SPDX-License-Identifier: GPL-2.0-or-later
9 */
11 #ifndef __DECODE_AS_H__
12 #define __DECODE_AS_H__
14 #include "ws_symbol_export.h"
16 #include "ftypes/ftypes.h"
17 #include "packet_info.h"
19 #ifdef __cplusplus
20 extern "C" {
21 #endif /* __cplusplus */
23 /** @file
26 #define MAX_DECODE_AS_PROMPT_LEN 200
27 #define DECODE_AS_ENTRY "decode_as_entry"
28 #define DECODE_AS_NONE "(none)"
31 * Filename of the "decode as" entry preferences
33 #define DECODE_AS_ENTRIES_FILE_NAME "decode_as_entries"
36 /** callback function definition: return formatted label string */
37 typedef void (*build_label_func)(packet_info *pinfo, char* result);
39 /** callback function definition: return value used to pass to dissector table */
40 typedef void * (*build_valid_func)(packet_info *pinfo);
42 typedef void (*decode_as_add_to_list_func)(const char *table_name, const char *proto_name, void *value, void *user_data);
43 typedef void (*decode_as_populate_list_func)(const char *table_name, decode_as_add_to_list_func add_to_list, void *ui_element);
44 typedef void (*decode_as_free_func)(void *value);
46 /** callback function definition: Clear value from dissector table */
47 typedef bool (*decode_as_reset_func)(const char *name, const void *pattern);
48 /** callback function definition: Apply value to dissector table */
49 typedef bool (*decode_as_change_func)(const char *name, const void *pattern, const void *handle, const char *list_name);
51 /**
52 Contains all of the function pointers (typically just 1) that
53 provide the text explaining the name and use of the value field that will
54 be passed to the dissector table to change the dissection output.
56 typedef struct decode_as_value_s {
57 build_label_func label_func; /**< function pointer to the function used to create the label*/
58 unsigned num_values; /**< Number of values */
59 build_valid_func* build_values; /**< Function used to build the value to go into the table. Retrieve from current frame */
60 } decode_as_value_t;
62 /**
63 Pulls everything together including the dissector (protocol) name, the
64 "layer type" of the dissector, the dissector table name, the function pointer
65 values as well as handlers for populating, applying and reseting the changes
66 to the dissector table through Decode As GUI functionality. For dissector
67 tables that are an integer or string type, the provided "default" handling
68 functions should suffice.
71 typedef struct decode_as_s {
72 const char *name; /**< Protocol name */
73 const char *table_name; /**< Disector table name */
74 unsigned num_items; /**< Number of index in the decode_as_value_t struct */
75 unsigned default_index_value; /**< Which display function to use first, set to zero if only one function*/
76 decode_as_value_t* values; /**< The array of function pointers, see decode_as_value_t */
77 const char* pre_value_str; /**< String to prepend the value, NULL if none */
78 const char* post_value_str; /**< String to append the value, NULL if none */
79 decode_as_populate_list_func populate_list; /**< function pointer to the function used to populate the list, NULL if none */
80 decode_as_reset_func reset_value; /**< function pointer to the function used resetting the value, NULL if none */
81 decode_as_change_func change_value; /**< function pointer to the function used resetting the value, NULL if none */
82 decode_as_free_func free_func; /**< function pointer to the function used freeing the entry, NULL if none */
84 } decode_as_t;
86 /** register a "Decode As". A copy of the decode_as_t will be maintained by the decode_as module */
87 WS_DLL_PUBLIC void register_decode_as(decode_as_t* reg);
89 /* Forward declaration to prevent requiring packet.h */
90 struct dissector_table;
92 /** Register a "Decode As" entry for the special case where there is no
93 * indication for the next protocol (such as port number etc.).
94 * For now, this will use a uint32 dissector table internally and
95 * assign all registered protocols to 0. The framework to do this can
96 * be kept internal to epan.
98 * @param proto The protocol ID to create the dissector table.
99 * @param table_name The table name in which this dissector is found.
100 * @param ui_name UI name for created dissector table.
101 * @param label_func Pointer to optional function to generate prompt text
102 * for dissector. If NULL, "Next level protocol as" is used.
104 * @return Created dissector table with Decode As support
106 WS_DLL_PUBLIC struct dissector_table* register_decode_as_next_proto(int proto, const char *table_name, const char *ui_name, build_label_func label_func);
108 /* Walk though the dissector table and provide dissector_handle_t for each item in the table */
109 WS_DLL_PUBLIC void decode_as_default_populate_list(const char *table_name, decode_as_add_to_list_func add_to_list, void *ui_element);
110 /* Clear a FT_UINT32 value from dissector table list */
111 WS_DLL_PUBLIC bool decode_as_default_reset(const char *name, const void *pattern);
112 /* Add a FT_UINT32 value to dissector table list */
113 WS_DLL_PUBLIC bool decode_as_default_change(const char *name, const void *pattern, const void *handle, const char *list_name);
115 /** List of registered decode_as_t structs.
116 * For UI code only. Should not be directly accessed by dissectors.
118 WS_DLL_PUBLIC GList *decode_as_list;
120 /* Some useful utilities for Decode As */
122 /** Reset the "decode as" entries and reload ones of the current profile.
123 * This is called by epan_load_settings(); programs should call that
124 * rather than individually calling the routines it calls.
126 extern void load_decode_as_entries(void);
128 /** Write out the "decode as" entries of the current profile.
130 WS_DLL_PUBLIC int save_decode_as_entries(char** err);
132 /** Clear all "decode as" settings.
134 WS_DLL_PUBLIC void decode_clear_all(void);
136 /** Frees memory used by "decode as" routines. Called at program shutdown.
138 WS_DLL_PUBLIC void decode_cleanup(void);
140 /** This routine creates one entry in the list of protocol dissector
141 * that need to be reset. It is called by the g_hash_table_foreach
142 * routine once for each changed entry in a dissector table.
143 * Unfortunately it cannot delete the entry immediately as this screws
144 * up the foreach function, so it builds a list of dissectors to be
145 * reset once the foreach routine finishes.
147 * @param table_name The table name in which this dissector is found.
149 * @param selector_type The type of the selector in that dissector table
151 * @param key A pointer to the key for this entry in the dissector
152 * hash table. This is generally the numeric selector of the
153 * protocol, i.e. the ethernet type code, IP port number, TCP port
154 * number, etc.
156 * @param value A pointer to the value for this entry in the dissector
157 * hash table. This is an opaque pointer that can only be handed back
158 * to routine in the file packet.c - but it's unused.
160 * @param user_data Unused.
162 WS_DLL_PUBLIC void decode_build_reset_list (const char *table_name, ftenum_t selector_type,
163 void *key, void *value,
164 void *user_data);
167 #ifdef __cplusplus
169 #endif /* __cplusplus */
171 #endif /* decode_as.h */