mirror of
https://github.com/matrix-construct/construct
synced 2025-01-14 16:46:50 +01:00
ircd: Update include README.
This commit is contained in:
parent
62caa95ec8
commit
926c24ac7d
1 changed files with 59 additions and 15 deletions
|
@ -9,34 +9,47 @@ handles requests from end-users. The library hosts a set of pluggable modules
|
|||
which may introduce the actual application features (or the "business logic")
|
||||
of the server. These additional modules are found in the `modules/` directory;
|
||||
|
||||
### Using libircd
|
||||
### Things to know about libircd
|
||||
|
||||
##### libircd can be embedded in your application with very minimal overhead.
|
||||
|
||||
This allows you to customize and extend the functionality of the server and have
|
||||
control over its execution, or, simply use library routines provided by the library
|
||||
without any daemonization. Including libircd headers will not include any other
|
||||
headers beyond those in the standard library, with minimal impact on your project's
|
||||
compile complexity. The prototypical embedding of `libircd` is `charybdis` found in
|
||||
the `charybdis/` directory.
|
||||
Linking to libircd from your executable allows you to customize and extend the
|
||||
functionality of the server and have control over its execution, or, simply use
|
||||
library routines provided by the library without any daemonization. Including
|
||||
libircd headers will not include any other headers beyond those in the standard
|
||||
library, with minimal impact on your project's compile complexity. The
|
||||
prototypical embedding of `libircd` is `construct` found in the `construct/`
|
||||
directory.
|
||||
|
||||
##### libircd runs only one server at a time.
|
||||
|
||||
Keeping with the spirit of simplicity of the original architecture, `libircd`
|
||||
continues to be a "singleton" object which uses globals and keeps actual server
|
||||
state in the library itself. In other words, **only one IRC daemon can exist
|
||||
within a process's address space at a time.** This is actually a profitable
|
||||
design decision for making IRCd easier to understand for contributors.
|
||||
within a process's address space at a time.** Whether or not this was a pitfall
|
||||
of the original design, it has emerged over the decades as a very profitable
|
||||
decision for making IRCd an accessible open source internet project.
|
||||
|
||||
##### libircd is single-threaded✝
|
||||
|
||||
The library is based around the `boost::asio::io_service` event loop. It is still
|
||||
an asynchronous event-based system. We process one event at a time; developers must
|
||||
not block execution. Events are never processed concurrently on different threads.
|
||||
The library is based around the `boost::asio::io_service` event loop. It is
|
||||
still an asynchronous event-based system. We process one event at a time;
|
||||
developers must not block execution. While the `io_service` can be run safely
|
||||
on multiple threads by the embedder's application, libircd will use a single
|
||||
`io_service::strand`.
|
||||
|
||||
✝ If there is ever a truly long-running computation or a call to a 3rd party
|
||||
library which will do IO and block the event loop, we may use an additional
|
||||
`std::thread` to "offload" this operation.
|
||||
This methodology ensures there is an uninterrupted execution working through
|
||||
a single event queue providing service which is not otherwise computationally
|
||||
bound. Even if there are periods of execution which are computationally intense
|
||||
like parsing, hashing, signature verification etc -- this is insignificant
|
||||
compared to the amortized cost of thread synchronization and bus contention
|
||||
for a network application.
|
||||
|
||||
✝ However, don't start assuming a truly threadless execution. If there is
|
||||
ever a truly long-running background computation or a call to a 3rd
|
||||
party library which will do IO and block the event loop, we may use an
|
||||
additional `std::thread` to "offload" such an operation. Thus we do have
|
||||
a threading model, but it is heterogeneous.
|
||||
|
||||
##### libircd introduces userspace threading✝
|
||||
|
||||
|
@ -57,4 +70,35 @@ drop-in for ::sprintf(), but accepting objects like std::string without .c_str()
|
|||
and prevention of outputting unprintable/unwanted characters that may have been
|
||||
injected into the system somewhere prior.
|
||||
|
||||
### Developing libircd
|
||||
|
||||
##### libircd headers are organized into several aggregate "stacks"
|
||||
|
||||
As a C++ project there are a lot of header files. Header files depend on other
|
||||
header files. We don't expect the developer of a compilation unit to figure out
|
||||
an exact list of header files necessary to include for that unit. Instead we
|
||||
have aggregated groups of header files which are then precompiled. These
|
||||
aggregations are mostly oriented around a specific project dependency.
|
||||
|
||||
- Standard Include stack <ircd/ircd.h> is the main header group. This stack
|
||||
involves the standard library and most of libircd. This is what an embedder
|
||||
will be working with. These headers will expose our own interfaces wrapping
|
||||
3rd party dependencies which are not included there. Note that the actual file
|
||||
to properly include this stack is <ircd/ircd.h> (not stdinc.h).
|
||||
|
||||
- Boost ASIO include stack <ircd/asio.h> is a header group exposing the
|
||||
boost::asio library. We only involve this header in compilation units working
|
||||
directly with asio for networking et al. Involving this header file slows down
|
||||
compilation compared with the standard stack.
|
||||
|
||||
- Boost Spirit include stack <ircd/spirit.h> is a header group exposing the
|
||||
spirit parser framework to compilation units which involve formal grammars.
|
||||
Involving this header is a *monumental* slowdown when compiling.
|
||||
|
||||
- JavaScript include stack <ircd/js/js.h> is a header group exposing symbols
|
||||
from the SpiderMonkey JS engine. Alternatively, <ircd/js.h> is part of the
|
||||
standard include stack which includes any wrapping to hide SpiderMonkey.
|
||||
|
||||
- MAPI include stack <ircd/mapi.h> is the standard header group for modules.
|
||||
This stack is an extension to the standard include stack but has specific
|
||||
tools for pluggable modules which are not part of the libircd core.
|
||||
|
|
Loading…
Reference in a new issue