wireshark/epan/dfilter
Jeff Morriss 4a8c8e4d7f Fix up indentation a bit
svn path=/trunk/; revision=32617
2010-04-30 21:40:57 +00:00
..
Makefile.am Add Makefile.common files for epan/dfilter and epan/ftypes. 2008-07-02 01:44:30 +00:00
Makefile.common Get rid of unused routine (which gets errors when compiled on Win64). 2009-03-16 16:49:47 +00:00
Makefile.nmake Move th /MP flag setting to LOCAL_CFLAGS set in configure.nmake 2009-07-16 08:27:18 +00:00
README.dfilter ethereal to wireshark changes 2006-06-17 12:04:30 +00:00
dfilter-int.h Neither num_registers nor max_registers in a dfilter_t are ever 2009-10-18 23:25:33 +00:00
dfilter-macro.c From LEGO via bug 3459: 2010-03-04 12:50:18 +00:00
dfilter-macro.h As per Ulf's request add ${proto.field} macros that will use the value of the given field has in the last selected packet. 2007-07-30 23:32:47 +00:00
dfilter.c Fixed a data type and removed a shadowed variable. 2009-10-18 21:30:39 +00:00
dfilter.h From Kovarththanan Rajaratnam: avoid circular dependency. 2009-07-23 11:19:05 +00:00
dfunctions.c use an ep allocated temporary string when creating the string for a FT_STRING value and call fvalue_set with already_copied==FALSE so the string gets allocated in ftype-string.c instead 2006-12-29 22:55:13 +00:00
dfunctions.h Add some GCC warnings to the standard set, and add some others to the 2007-04-23 10:59:26 +00:00
dfvm.c Use more unique names for certain enum constants. 2010-01-19 19:37:03 +00:00
dfvm.h From Didier Gautheron: Bug #2042: Move constants initialisation at compile time. 2007-11-28 22:44:37 +00:00
drange.c Use more unique names for certain enum constants. 2010-01-19 19:37:03 +00:00
drange.h Use more unique names for certain enum constants. 2010-01-19 19:37:03 +00:00
gencode.c If "!=" or "ne" are used in a display filter, warn the user that the results 2008-01-31 19:50:38 +00:00
gencode.h Add missing $Id$ and copyright notice. 2009-01-09 18:33:34 +00:00
grammar.lemon Implement a proposal from Elefterios Gabriel for SCCP: 2007-04-03 19:08:00 +00:00
scanner.l Fix up indentation a bit 2010-04-30 21:40:57 +00:00
semcheck.c From Jakub Zawadzki: 2010-04-27 10:32:34 +00:00
semcheck.h Changed email address for Gerald from zing.org to wireshark.org 2008-01-08 22:54:51 +00:00
sttype-function.c name change 2006-05-21 05:12:17 +00:00
sttype-function.h Added missing "svn:keywords Id" and "svn:eol-style native" for some 2008-02-08 09:45:36 +00:00
sttype-integer.c Changed email address for Gerald from zing.org to wireshark.org 2008-01-08 22:54:51 +00:00
sttype-pointer.c Changed email address for Gerald from zing.org to wireshark.org 2008-01-08 22:54:51 +00:00
sttype-range.c name change 2006-05-21 05:12:17 +00:00
sttype-range.h Changed email address for Gerald from zing.org to wireshark.org 2008-01-08 22:54:51 +00:00
sttype-string.c Changed email address for Gerald from zing.org to wireshark.org 2008-01-08 22:54:51 +00:00
sttype-test.c Changed email address for Gerald from zing.org to wireshark.org 2008-01-08 22:54:51 +00:00
sttype-test.h Changed email address for Gerald from zing.org to wireshark.org 2008-01-08 22:54:51 +00:00
syntax-tree.c Hmmm. Second try to fix the const problems. 2008-01-31 23:10:09 +00:00
syntax-tree.h Revert r29614 until I figure out why buildbot doesn't like it 2009-08-29 07:53:48 +00:00

README.dfilter

$Id$

How does the display filter logic work?
=======================================

scanner.l looks at the display filter string and finds reserved words,
punctuation, etc. This information gets passed to the parser produced by
grammar.lemon. The grammar's job is to create a syntax-tree out of the
information provided by the scanner. The syntax tree organizes the
information from the scanner into something that is grammatical in the
dfilter language.

The routines in semcheck.c then check the semantics of the syntax tree, and do
any modifications necessary to the syntax tree to make the dfilter work....
things like converting val_strings to integers, etc.

Then gencode.c converts the syntax tree into a list of "dfvm" (display filter
virtual machine) instructions. These dfvm instructions are what runs the
display filter engine.

Example: add an 'in' display filter operation
=============================================

This example has been discussed on wireshark-dev in April 2004. It illustrates
how a more complex operation can be added to the display filter language.

Question:

	If I want to add an 'in' display filter operation, I need to define
	several things. This can happen in different ways. For instance,
	every value from the "in" value collection will result in a test.
	There are 2 options here, either a test for a single value:

		(x in {a b c})

	or a test for a value in a given range:

		(x in {a ... z})

	or even a combination of both. The former example can be reduced to:

		((x == a) or (x == b) or (x == c))

	while the latter can be reduced to

		((x >= MIN(a, z)) and (x <= MAX(a, z)))

	I understand that I can replace "x in {" with the following steps:
	first store x in the "in" test buffer, then add "(" to the display
	filter expression internally.

	Similarly I can replace the closing brace "}" with the following steps:
	release x from the "in" test buffer and then add ")" to the display
	filter expression internally.

	How could I do this?

Answer:

	This could be done in grammar.lemon. The grammar would produce syntax
	tree nodes, combining them with "or", when it is given tokens that
	represent the "in" syntax.

	It could also be done later in the process, maybe in semcheck.c. But
	if you can do it earlier, in grammar.lemon, then you shouldn't have to
	worry about modifying anything in semcheck.c, as the syntax tree that
	is passed to semcheck.c won't contain any new type of operators... just
	lots of nodes combined with "or".

How to add an operator FOO to the display filter language?
==========================================================

Go to wireshark/epan/dfilter/

Edit grammar.lemon and add the operator. Add the operator FOO and the test logic (defining TEST_OP_FOO).

Edit scanner.l and add the operator name(s) hence defining TOKEN_TEST_FOO. Also update the simple() or add the new operand's code.

Edit sttype-test.h and add the TEST_OP_FOO to the list of test operations.

Edit sttype-test.c and add TEST_OP_FOO to the num_operands() method.

Edit gencode.c, add TEST_OP_FOO in the gen_test() method by defining ANY_FOO.

Edit dfvm.h and add ANY_FOO to the enum dfvm_opcode_t structure.

Edit dfvm.c and add ANY_FOO to dfvm_dump() (for the dftest display filter test binary), to dfvm_apply() hence defining the methods fvalue_foo().

Edit semcheck.c and look at the check_relation_XXX() methods if they still apply to the foo operator; if not, amend the code. Start from the check_test() method to discover the logic.

Go to wireshark/epan/ftypes/

Edit ftypes.h and declare the fvalue_foo(), ftype_can_foo() and fvalue_foo() methods. Add the cmp_foo() method to the struct _ftype_t.

This is the first time that a make in wireshark/epan/dfilter/ can succeed. If it fails, then some code in the previously edited files must be corrected.

Edit ftypes.c and define the fvalue_foo() method with its associated logic. Define also the ftype_can_foo() and fvalue_foo() methods.

Edit all ftype-*.c files and add the required fvalue_foo() methods.

This is the point where you should be able to compile without errors in wireshark/epan/ftypes/. If not, first fix the errors.

Go to wireshark/epan/ and run make. If this one succeeds, then we're almost done as no errors should occur here.

Go to wireshark/ and run make. One thing to do is make dftest and see if you can construct valid display filters with your new operator. Or you may want to move directly to the generation of wireshark.

Look also at wireshark/gtk/dfilter_expr_dlg.c and edit the display filter expression generator.