mirror of
https://github.com/cesanta/mongoose.git
synced 2025-01-10 15:20:17 +08:00
1ce4aa81ee
PUBLISHED_FROM=80e77fda1c358294f251ca77d3dd64e8ca9160e5
30 lines
1.3 KiB
Markdown
30 lines
1.3 KiB
Markdown
---
|
|
title: Design Concept
|
|
items:
|
|
- { type: file, name: memory-buffers.md }
|
|
- { type: file, name: event-handler.md }
|
|
- { type: file, name: events.md }
|
|
- { type: file, name: conn-flags.md }
|
|
---
|
|
|
|
Mongoose is a multi-protocol networking library that implements non-blocking,
|
|
asyncronous IO and provides event-based API. It has three basic data
|
|
structures:
|
|
|
|
- `struct mg_mgr` is an event manager that holds all active connections
|
|
- `struct mg_connection` describes a connection
|
|
- `struct mbuf` describes data buffer (received or sent data)
|
|
|
|
Connections could be either *listening*, *outbound* or *inbound*. Outbound
|
|
connections are created by `mg_connect()` call. Listening connections are
|
|
created by `mg_bind()` call. Inbound connections are those accepted by a
|
|
listening connection. Each connection is described by `struct mg_connection`
|
|
structure, which has a number of fields like socket, event handler function,
|
|
send/receive buffer, flags, et cetera.
|
|
|
|
Mongoose usage pattern is to declare and initialize event manager, create
|
|
connections and create an event loop by calling `mg_mgr_poll()` in a loop.
|
|
`mg_mgr_poll()` iterates over all sockets, accepts new connections, sends and
|
|
receives data, closes connections, and calls event handler functions for the
|
|
respective events.
|