File: event_parser.xml

package info (click to toggle)
kamailio 5.6.3-2
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 68,332 kB
  • sloc: ansic: 744,091; xml: 196,848; cpp: 14,471; makefile: 8,859; sh: 8,814; sql: 7,844; yacc: 3,863; perl: 2,955; python: 2,710; java: 449; javascript: 269; php: 258; ruby: 225; cs: 40; awk: 27
file content (55 lines) | stat: -rw-r--r-- 2,040 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE section PUBLIC "-//OASIS//DTD DocBook XML V4.2//EN" 
   "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd">

<section id="event_parser" xmlns:xi="http://www.w3.org/2001/XInclude">
    <sectioninfo>
	<revhistory>
	    <revision>
		<revnumber>$Revision$</revnumber>
		<date>$Date$</date>
	    </revision>
	</revhistory>
    </sectioninfo>

    <title>Event Body Parser</title>
    <para>
	Purpose of this parser is to parse body of an Event Header field. The
	parser can be found in file <filename>parse_event.c</filename> under
	<filename>parser</filename> subdirectory.
    </para>
    <note>
	<para>
	    This is <emphasis>NOT</emphasis> fully featured Event body parser !
	    The parser was written for Presence Agent module only and thus can
	    recognize Presence package only. No subpackages will be
	    recognized. All other packages will be marked as "OTHER".
	</para>
	<para>
	    The parser should be replace by a more generic parser if
	    subpackages or parameters should be parsed too.
	</para>
    </note>
    <para>
	Main function is <function>parse_event</function> in file
	<filename>parse_event.c</filename>. The function will create an
	instance of <structname>event_t</structname> structure and call the
	parser. If everything went OK, pointer to the newly created structure
	will be stored in <structfield>parsed</structfield> field of
	<structname>hdr_field</structname> structure representing the parsed
	header field.
    </para>
    <para>
	As usually, the newly created structure will be freed when the whole
	message is being destroyed.  See function
	<function>clean_hdr_field</function> in file <filename>hf.c</filename>.
    </para>
    <para>
	The parser will be not called automatically when the main parser finds
	an Event header field.  It is up to you to call the parser when you
	really need the body of the header field to be parsed (call
	<function>parse_event</function> function).
    </para>

    <xi:include href="event_t.xml"/>
</section>