From cab1dfd25c129b324b6840e71ec2feaf9fb53693 Mon Sep 17 00:00:00 2001 From: root Date: Sat, 24 Nov 2007 10:10:26 +0000 Subject: include embedding doc in main doc --- ev.pod | 276 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 276 insertions(+) diff --git a/ev.pod b/ev.pod index 5440be5..05bac98 100644 --- a/ev.pod +++ b/ev.pod @@ -1416,6 +1416,282 @@ the constructor. io.start (fd, ev::READ); } +=head1 EMBEDDING + +Libev can (and often is) directly embedded into host +applications. Examples of applications that embed it include the Deliantra +Game Server, the EV perl module, the GNU Virtual Private Ethernet (gvpe) +and rxvt-unicode. + +The goal is to enable you to just copy the neecssary files into your +source directory without having to change even a single line in them, so +you can easily upgrade by simply copying (or having a checked-out copy of +libev somewhere in your source tree). + +=head2 FILESETS + +Depending on what features you need you need to include one or more sets of files +in your app. + +=head3 CORE EVENT LOOP + +To include only the libev core (all the C functions), with manual +configuration (no autoconf): + + #define EV_STANDALONE 1 + #include "ev.c" + +This will automatically include F, too, and should be done in a +single C source file only to provide the function implementations. To use +it, do the same for F in all files wishing to use this API (best +done by writing a wrapper around F that you can include instead and +where you can put other configuration options): + + #define EV_STANDALONE 1 + #include "ev.h" + +Both header files and implementation files can be compiled with a C++ +compiler (at least, thats a stated goal, and breakage will be treated +as a bug). + +You need the following files in your source tree, or in a directory +in your include path (e.g. in libev/ when using -Ilibev): + + ev.h + ev.c + ev_vars.h + ev_wrap.h + + ev_win32.c required on win32 platforms only + + ev_select.c only when select backend is enabled (which is is by default) + ev_poll.c only when poll backend is enabled (disabled by default) + ev_epoll.c only when the epoll backend is enabled (disabled by default) + ev_kqueue.c only when the kqueue backend is enabled (disabled by default) + ev_port.c only when the solaris port backend is enabled (disabled by default) + +F includes the backend files directly when enabled, so you only need +to compile a single file. + +=head3 LIBEVENT COMPATIBILITY API + +To include the libevent compatibility API, also include: + + #include "event.c" + +in the file including F, and: + + #include "event.h" + +in the files that want to use the libevent API. This also includes F. + +You need the following additional files for this: + + event.h + event.c + +=head3 AUTOCONF SUPPORT + +Instead of using C and providing your config in +whatever way you want, you can also C in your +F and leave C off. F will then include +F and configure itself accordingly. + +For this of course you need the m4 file: + + libev.m4 + +=head2 PREPROCESSOR SYMBOLS/MACROS + +Libev can be configured via a variety of preprocessor symbols you have to define +before including any of its files. The default is not to build for multiplicity +and only include the select backend. + +=over 4 + +=item EV_STANDALONE + +Must always be C<1> if you do not use autoconf configuration, which +keeps libev from including F, and it also defines dummy +implementations for some libevent functions (such as logging, which is not +supported). It will also not define any of the structs usually found in +F that are not directly supported by the libev core alone. + +=item EV_USE_MONOTONIC + +If defined to be C<1>, libev will try to detect the availability of the +monotonic clock option at both compiletime and runtime. Otherwise no use +of the monotonic clock option will be attempted. If you enable this, you +usually have to link against librt or something similar. Enabling it when +the functionality isn't available is safe, though, althoguh you have +to make sure you link against any libraries where the C +function is hiding in (often F<-lrt>). + +=item EV_USE_REALTIME + +If defined to be C<1>, libev will try to detect the availability of the +realtime clock option at compiletime (and assume its availability at +runtime if successful). Otherwise no use of the realtime clock option will +be attempted. This effectively replaces C by C and will not normally affect correctness. See tzhe note about libraries +in the description of C, though. + +=item EV_USE_SELECT + +If undefined or defined to be C<1>, libev will compile in support for the +C