mirror of
https://github.com/cesanta/mongoose.git
synced 2025-01-01 19:17:48 +08:00
6e3e5560d0
PUBLISHED_FROM=ebf5568abe82952ab2751298185a10189098013f
1.3 KiB
1.3 KiB
Event handler function
Each connection has an event handler function associated with it. That function must be implemented by the user. Event handler is the key element of the Mongoose application, since it defines the application's behaviour. This is what an event handler function looks like:
static void ev_handler(struct mg_connection *nc, int ev, void *ev_data) {
switch (ev) {
/* Event handler code that defines behavior of the connection */
...
}
}
struct mg_connection *nc
: Connection that has received an event.int ev
: Event number, defined inmongoose.h
. For example, when data arrives on an inbound connection,ev
would beMG_EV_RECV
.void *ev_data
: This pointer points to the event-specific data, and it has a different meaning for different events. For example, for anMG_EV_RECV
event,ev_data
is anint *
pointer, pointing to the number of bytes received from the remote peer and saved into the receive IO buffer. The exact meaning ofev_data
is described for each event. Protocol-specific events usually haveev_data
pointing to structures that hold protocol-specific information.
NOTE: struct mg_connection
has void *user_data
which is a placeholder for
application-specific data. Mongoose does not use that pointer. Event handler
can store any kind of information there.