2017-11-30 10:30:19 -08:00
|
|
|
# IRCd Library API
|
2017-09-12 09:37:44 -07:00
|
|
|
|
2018-01-04 13:34:32 -08:00
|
|
|
#### Project Namespaces
|
2017-11-25 15:18:01 -07:00
|
|
|
|
2018-12-28 13:36:23 -08:00
|
|
|
* `IRCD_` Preprocessor #define and macros.
|
2018-01-23 06:12:35 -08:00
|
|
|
* `RB_` Build system related preprocessor #defines and macros (legacy).
|
2018-01-04 13:34:32 -08:00
|
|
|
* `ircd_` C namespace and demangled bindings.
|
|
|
|
* `ircd::` C++ namespace scope.
|
2018-01-19 04:07:12 -08:00
|
|
|
* `X-IRCd-` HTTP header key namespace.
|
|
|
|
* `ircd.` Matrix event type namespace.
|
2018-12-28 13:36:23 -08:00
|
|
|
* `ircd_` Environmental variables (see: conf.h).
|
2018-01-04 13:34:32 -08:00
|
|
|
|
|
|
|
#### What To Include
|
|
|
|
|
|
|
|
##### libircd headers are organized into several aggregates groups
|
2017-11-25 15:18:01 -07:00
|
|
|
|
|
|
|
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.
|
|
|
|
|
2018-01-04 13:34:32 -08:00
|
|
|
> Note: The term 'stack' may be found in place of the preferred term 'group'
|
|
|
|
in other documentation.
|
|
|
|
|
|
|
|
- Standard Include group `<ircd/ircd.h>` is the main header group. This group
|
2017-11-25 15:18:01 -07:00
|
|
|
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
|
2018-01-04 13:34:32 -08:00
|
|
|
3rd party dependencies which are not included there.
|
|
|
|
|
2018-06-15 16:13:18 -06:00
|
|
|
There are actually two files in play here: `<ircd/ircd.h>` and
|
|
|
|
`<ircd/ircd.pic.h>`. The latter is generated dynamically and will not
|
|
|
|
exist until `make` creates it. We have to offer two different
|
|
|
|
pre-compilations: one with `-fPIC` and one without.
|
2017-11-25 15:18:01 -07:00
|
|
|
|
2018-01-04 13:34:32 -08:00
|
|
|
- Boost ASIO include group `<ircd/asio.h>` is a header group exposing the
|
2017-11-25 15:18:01 -07:00
|
|
|
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
|
2018-01-04 13:34:32 -08:00
|
|
|
compilation compared with the standard group.
|
2017-11-25 15:18:01 -07:00
|
|
|
|
2018-01-04 13:34:32 -08:00
|
|
|
- Boost Spirit include group `<ircd/spirit.h>` is a header group exposing the
|
2017-11-25 15:18:01 -07:00
|
|
|
spirit parser framework to compilation units which involve formal grammars.
|
|
|
|
Involving this header is a *monumental* slowdown when compiling.
|
|
|
|
|
2018-01-04 13:34:32 -08:00
|
|
|
- JavaScript include group `<ircd/js/js.h>` is a header group exposing symbols
|
2017-11-25 15:18:01 -07:00
|
|
|
from the SpiderMonkey JS engine. Alternatively, <ircd/js.h> is part of the
|
2018-01-04 13:34:32 -08:00
|
|
|
standard include group which includes any wrapping to hide SpiderMonkey.
|
2017-09-12 09:37:44 -07:00
|
|
|
|
2018-01-04 13:34:32 -08:00
|
|
|
- MAPI include group `<ircd/mapi.h>` is the standard header group for modules.
|
|
|
|
This group is an extension to the standard include group but has specific
|
2017-11-25 15:18:01 -07:00
|
|
|
tools for pluggable modules which are not part of the libircd core.
|
2018-12-19 12:24:16 -08:00
|
|
|
|
|
|
|
#### Invocation
|
|
|
|
|
|
|
|
> `libircd` is **not thread-safe**. It does not protect exposed interfaces with
|
|
|
|
locks. Embedders must access `libircd` from a single thread.
|
|
|
|
|
|
|
|
Initialize the library with a call to `ircd::init()`.
|