xref: /freebsd-src/contrib/libevent/include/event2/bufferevent_struct.h (revision c6879c6c14eedbd060ba588a3129a6c60ebbe783)
1*c43e99fdSEd Maste /*
2*c43e99fdSEd Maste  * Copyright (c) 2000-2007 Niels Provos <provos@citi.umich.edu>
3*c43e99fdSEd Maste  * Copyright (c) 2007-2012 Niels Provos and Nick Mathewson
4*c43e99fdSEd Maste  *
5*c43e99fdSEd Maste  * Redistribution and use in source and binary forms, with or without
6*c43e99fdSEd Maste  * modification, are permitted provided that the following conditions
7*c43e99fdSEd Maste  * are met:
8*c43e99fdSEd Maste  * 1. Redistributions of source code must retain the above copyright
9*c43e99fdSEd Maste  *    notice, this list of conditions and the following disclaimer.
10*c43e99fdSEd Maste  * 2. Redistributions in binary form must reproduce the above copyright
11*c43e99fdSEd Maste  *    notice, this list of conditions and the following disclaimer in the
12*c43e99fdSEd Maste  *    documentation and/or other materials provided with the distribution.
13*c43e99fdSEd Maste  * 3. The name of the author may not be used to endorse or promote products
14*c43e99fdSEd Maste  *    derived from this software without specific prior written permission.
15*c43e99fdSEd Maste  *
16*c43e99fdSEd Maste  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
17*c43e99fdSEd Maste  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
18*c43e99fdSEd Maste  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
19*c43e99fdSEd Maste  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
20*c43e99fdSEd Maste  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
21*c43e99fdSEd Maste  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
22*c43e99fdSEd Maste  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
23*c43e99fdSEd Maste  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24*c43e99fdSEd Maste  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
25*c43e99fdSEd Maste  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26*c43e99fdSEd Maste  */
27*c43e99fdSEd Maste #ifndef EVENT2_BUFFEREVENT_STRUCT_H_INCLUDED_
28*c43e99fdSEd Maste #define EVENT2_BUFFEREVENT_STRUCT_H_INCLUDED_
29*c43e99fdSEd Maste 
30*c43e99fdSEd Maste /** @file event2/bufferevent_struct.h
31*c43e99fdSEd Maste 
32*c43e99fdSEd Maste   Data structures for bufferevents.  Using these structures may hurt forward
33*c43e99fdSEd Maste   compatibility with later versions of Libevent: be careful!
34*c43e99fdSEd Maste 
35*c43e99fdSEd Maste   @deprecated Use of bufferevent_struct.h is completely deprecated; these
36*c43e99fdSEd Maste     structures are only exposed for backward compatibility with programs
37*c43e99fdSEd Maste     written before Libevent 2.0 that used them.
38*c43e99fdSEd Maste  */
39*c43e99fdSEd Maste 
40*c43e99fdSEd Maste #ifdef __cplusplus
41*c43e99fdSEd Maste extern "C" {
42*c43e99fdSEd Maste #endif
43*c43e99fdSEd Maste 
44*c43e99fdSEd Maste #include <event2/event-config.h>
45*c43e99fdSEd Maste #ifdef EVENT__HAVE_SYS_TYPES_H
46*c43e99fdSEd Maste #include <sys/types.h>
47*c43e99fdSEd Maste #endif
48*c43e99fdSEd Maste #ifdef EVENT__HAVE_SYS_TIME_H
49*c43e99fdSEd Maste #include <sys/time.h>
50*c43e99fdSEd Maste #endif
51*c43e99fdSEd Maste 
52*c43e99fdSEd Maste /* For int types. */
53*c43e99fdSEd Maste #include <event2/util.h>
54*c43e99fdSEd Maste /* For struct event */
55*c43e99fdSEd Maste #include <event2/event_struct.h>
56*c43e99fdSEd Maste 
57*c43e99fdSEd Maste struct event_watermark {
58*c43e99fdSEd Maste 	size_t low;
59*c43e99fdSEd Maste 	size_t high;
60*c43e99fdSEd Maste };
61*c43e99fdSEd Maste 
62*c43e99fdSEd Maste /**
63*c43e99fdSEd Maste   Shared implementation of a bufferevent.
64*c43e99fdSEd Maste 
65*c43e99fdSEd Maste   This type is exposed only because it was exposed in previous versions,
66*c43e99fdSEd Maste   and some people's code may rely on manipulating it.  Otherwise, you
67*c43e99fdSEd Maste   should really not rely on the layout, size, or contents of this structure:
68*c43e99fdSEd Maste   it is fairly volatile, and WILL change in future versions of the code.
69*c43e99fdSEd Maste **/
70*c43e99fdSEd Maste struct bufferevent {
71*c43e99fdSEd Maste 	/** Event base for which this bufferevent was created. */
72*c43e99fdSEd Maste 	struct event_base *ev_base;
73*c43e99fdSEd Maste 	/** Pointer to a table of function pointers to set up how this
74*c43e99fdSEd Maste 	    bufferevent behaves. */
75*c43e99fdSEd Maste 	const struct bufferevent_ops *be_ops;
76*c43e99fdSEd Maste 
77*c43e99fdSEd Maste 	/** A read event that triggers when a timeout has happened or a socket
78*c43e99fdSEd Maste 	    is ready to read data.  Only used by some subtypes of
79*c43e99fdSEd Maste 	    bufferevent. */
80*c43e99fdSEd Maste 	struct event ev_read;
81*c43e99fdSEd Maste 	/** A write event that triggers when a timeout has happened or a socket
82*c43e99fdSEd Maste 	    is ready to write data.  Only used by some subtypes of
83*c43e99fdSEd Maste 	    bufferevent. */
84*c43e99fdSEd Maste 	struct event ev_write;
85*c43e99fdSEd Maste 
86*c43e99fdSEd Maste 	/** An input buffer. Only the bufferevent is allowed to add data to
87*c43e99fdSEd Maste 	    this buffer, though the user is allowed to drain it. */
88*c43e99fdSEd Maste 	struct evbuffer *input;
89*c43e99fdSEd Maste 
90*c43e99fdSEd Maste 	/** An input buffer. Only the bufferevent is allowed to drain data
91*c43e99fdSEd Maste 	    from this buffer, though the user is allowed to add it. */
92*c43e99fdSEd Maste 	struct evbuffer *output;
93*c43e99fdSEd Maste 
94*c43e99fdSEd Maste 	struct event_watermark wm_read;
95*c43e99fdSEd Maste 	struct event_watermark wm_write;
96*c43e99fdSEd Maste 
97*c43e99fdSEd Maste 	bufferevent_data_cb readcb;
98*c43e99fdSEd Maste 	bufferevent_data_cb writecb;
99*c43e99fdSEd Maste 	/* This should be called 'eventcb', but renaming it would break
100*c43e99fdSEd Maste 	 * backward compatibility */
101*c43e99fdSEd Maste 	bufferevent_event_cb errorcb;
102*c43e99fdSEd Maste 	void *cbarg;
103*c43e99fdSEd Maste 
104*c43e99fdSEd Maste 	struct timeval timeout_read;
105*c43e99fdSEd Maste 	struct timeval timeout_write;
106*c43e99fdSEd Maste 
107*c43e99fdSEd Maste 	/** Events that are currently enabled: currently EV_READ and EV_WRITE
108*c43e99fdSEd Maste 	    are supported. */
109*c43e99fdSEd Maste 	short enabled;
110*c43e99fdSEd Maste };
111*c43e99fdSEd Maste 
112*c43e99fdSEd Maste #ifdef __cplusplus
113*c43e99fdSEd Maste }
114*c43e99fdSEd Maste #endif
115*c43e99fdSEd Maste 
116*c43e99fdSEd Maste #endif /* EVENT2_BUFFEREVENT_STRUCT_H_INCLUDED_ */
117