3 * Wireshark - Network traffic analyzer
4 * By Gerald Combs <gerald@wireshark.org>
5 * Copyright 1998 Gerald Combs
7 * This program is free software; you can redistribute it and/or
8 * modify it under the terms of the GNU General Public License
9 * as published by the Free Software Foundation; either version 2
10 * of the License, or (at your option) any later version.
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
17 * You should have received a copy of the GNU General Public License
18 * along with this program; if not, write to the Free Software
19 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
22 #ifndef __EXTCAP_PARSER_H__
23 #define __EXTCAP_PARSER_H__
30 EXTCAP_SENTENCE_UNKNOWN,
32 EXTCAP_SENTENCE_VALUE,
34 EXTCAP_SENTENCE_INTERFACE,
36 } extcap_sentence_type;
48 /* Complex GUI types which are populated with value sentences */
52 EXTCAP_ARG_MULTICHECK,
70 EXTCAP_PARAM_FILE_MUSTEXIST,
74 /* Values for a given sentence; values are all stored as a call
75 * and a value string, or a valid range, so we only need to store
76 * those and repeat them */
77 typedef struct _extcap_value {
87 /* Complex-ish struct for storing complex values */
88 typedef struct _extcap_complex {
89 extcap_arg_type complex_type;
92 unsigned int uint_value;
98 gboolean value_filled;
101 /* An argument sentence and accompanying options */
102 typedef struct _extcap_arg {
110 extcap_arg_type arg_type;
112 extcap_complex *range_start;
113 extcap_complex *range_end;
114 extcap_complex *default_complex;
119 typedef struct _extcap_if {
124 typedef struct _extcap_interface {
128 struct _extcap_interface *next_interface;
131 extcap_interface *extcap_new_interface(void);
132 void extcap_free_interface(extcap_interface *interface);
134 typedef struct _extcap_dlt {
139 struct _extcap_dlt *next_dlt;
142 extcap_dlt *extcap_new_dlt(void);
143 void extcap_free_dlt(extcap_dlt *dlt);
145 /* Parser internals */
146 typedef struct _extcap_token_param {
150 extcap_param_type param_type;
152 struct _extcap_token_param *next_token;
153 } extcap_token_param;
155 typedef struct _extcap_token_sentence {
158 extcap_token_param *param_list;
160 struct _extcap_token_sentence *next_sentence;
161 } extcap_token_sentence;
163 /* Parse a string into a complex type */
164 extcap_complex *extcap_parse_complex(extcap_arg_type complex_type,
168 void extcap_free_complex(extcap_complex *comp);
170 /* Print a complex value out for debug */
171 void extcap_printf_complex(extcap_complex *comp);
174 * Return a string representation of a complex type
175 * Caller is responsible for calling g_free on the returned string
177 gchar *extcap_get_complex_as_string(extcap_complex *comp);
179 int extcap_complex_get_int(extcap_complex *comp);
180 unsigned int extcap_complex_get_uint(extcap_complex *comp);
181 long extcap_complex_get_long(extcap_complex *comp);
182 double extcap_complex_get_double(extcap_complex *comp);
183 gboolean extcap_complex_get_bool(extcap_complex *comp);
184 gchar *extcap_complex_get_string(extcap_complex *comp);
186 /* compares the default value of an element with a given parameter */
187 gboolean extcap_compare_is_default(extcap_arg *element, extcap_complex *test);
189 void extcap_free_tokenized_param(extcap_token_param *v);
190 void extcap_free_tokenized_sentence(extcap_token_sentence *s);
191 void extcap_free_tokenized_sentence_list(extcap_token_sentence *f);
193 /* Turn a sentence into logical tokens, don't validate beyond basic syntax */
194 extcap_token_sentence *extcap_tokenize_sentence(const gchar *s);
196 /* Tokenize a set of sentences (such as the output of a g_spawn_sync) */
197 extcap_token_sentence *extcap_tokenize_sentences(const gchar *s);
199 /* Find an argument in the extcap_arg list which matches the given arg=X number */
200 extcap_arg *extcap_find_numbered_arg(extcap_arg *first, int number);
202 /* Find the first occurrence in a parameter list of a parameter of the given type */
203 extcap_token_param *extcap_find_param_by_type(extcap_token_param *first,
204 extcap_param_type t);
206 void extcap_free_value(extcap_value *v);
208 extcap_arg *extcap_new_arg(void);
210 /* Free a single argument */
211 void extcap_free_arg(extcap_arg *a);
213 /* Free an entire arg list */
214 void extcap_free_arg_list(GList *a);
217 * Parse a tokenized sentence and validate. If a new sentence is created, the result
218 * is returned in 'ra'. On error, < 0 is returned. Not all sentences will create a
219 * new returned sentence (VALUE sentences, for example)
221 extcap_arg * extcap_parse_arg_sentence(GList * args, extcap_token_sentence *s);
223 /* Parse all sentences for args and values */
224 GList * extcap_parse_args(extcap_token_sentence *first_s);
227 * Parse a tokenized set of sentences and validate, looking for interface definitions.
229 int extcap_parse_interface_sentence(extcap_token_sentence *s,
230 extcap_interface **ri);
232 /* Parse all sentences for interfaces */
233 int extcap_parse_interfaces(extcap_token_sentence *first_s,
234 extcap_interface **first_int);
236 /* Parse a tokenized set of sentences and validate, looking for DLT definitions */
237 int extcap_parse_dlt_sentence(extcap_token_sentence *s, extcap_dlt **ri);
239 /* Parse all sentences for DLTs */
240 int extcap_parse_dlts(extcap_token_sentence *first_s, extcap_dlt **first_dlt);
245 * Editor modelines - http://www.wireshark.org/tools/modelines.html
250 * indent-tabs-mode: nil
253 * vi: set shiftwidth=4 tabstop=8 expandtab:
254 * :indentSize=4:tabSize=8:noTabs=true: