X-Git-Url: https://git.llucax.com/software/eventxx.git/blobdiff_plain/2be5a2e8f3eb90f2f6da62c0fd81c7e3b3e62f0c..05c87a8111143c57ddf2f2111a4e2d0240a6a49e:/README diff --git a/README b/README index 2348412..e448f9d 100644 --- a/README +++ b/README @@ -7,6 +7,9 @@ @section Introduction +@warning This project is not maintained anymore, it is kept alive just to +historical/educational reasons. + @libevent is a popular API that provides a mechanism to execute a callback function when a specific event occurs on a file descriptor or after a timeout has been reached. Furthermore, @libevent also support callbacks due @@ -25,20 +28,16 @@ possible. Please, visit the @eventxx website for the latest version of this documentation. -You can always get the current -release from the -release -directory or grab the -most up to date -sources from the darcs repository. +@section Download + +You can always get the current +release from the release directory or +grab the most up to date sources from +the git repository. -You can also take a look the the darcsweb interface to see -the latest -changes online or subscribe to its -RSS -feed to follow the development. +You can also take a look the the eventxx gitweb +interface to see the latest changes online or subscribe to its +Atom feed to follow the development. @section Usage @@ -93,6 +92,7 @@ struct handler handler(eventxx::dispatcher& d): d(d), i(0) {} void operator() (int signum, eventxx::type event) { + std::cout << ++i << " interrupts, "; if (i < 5) std::cout << "keep going...\n"; else { @@ -102,19 +102,18 @@ struct handler } }; -void sighandler(int signum, short event, void* data) +void timer_handler(int, short, void*) { - int& i = *static_cast< int* >(data); - std::cout << ++i << " interrupts, "; + std::cout << "Press Ctrl-C 5 times to quit.\n"; } int main() { eventxx::dispatcher d; handler h(d); - eventxx::csignal sigev(SIGINT, sighandler, &h.i); + eventxx::ctimer t(timer_handler); eventxx::signal< handler > e(SIGINT, h); - d.add(sigev); + d.add(t, eventxx::time(1)); // 1 second d.add(e); d.dispatch(); return 0; @@ -127,20 +126,18 @@ examples related page. @section Status -This library has not been widely used yet, but it's used in some serious -projects, so I think it's moderately stable now. The library has no support -for buffered events yet, but patches are welcome. It doesn't support the -HTTP stuff, and probably never will because that has nothing to do with -event handling. +I think the library is stable now. The library has no support for buffered +events yet, but patches are welcome. It doesn't support the HTTP stuff, and +probably never will because that has nothing to do with event handling. @libevent had a memory leak before version 1.3b (before 1.2 it didn't even had a way free that memory, from version 1.2 to 1.3a, if you tried to free the memory the program @c abort() because a failed assertion). Because of that, there is a way to disable the @link eventxx::dispatcher::~dispatcher() dispatcher destructor @endlink (which calls the inexistent/broken -@c event_base_free() function). So if you use a @libevent version previous -to 1.3b, you have to compile your programs defining the -@c EVENTXX_NO_EVENT_BASE_FREE macro. +@c event_base_free() function in the broken versions). So if you use a +@libevent version previous to 1.3b, you have to compile your programs +defining the @c EVENTXX_NO_EVENT_BASE_FREE macro. If something is broken it would be really easy to fix because @eventxx is just a simple wrapper around @libevent. So, please try it out, and if you @@ -154,13 +151,14 @@ it. @author Leandro Lucarella -@version 0.6 +@version 1.0.1 @par License -This program is under the BOLA license (see -http://auriga.wearlab.de/~alb/bola/ for more details or read the -LICENSE -file itself, it's very short and it basically says it's Public Domain). +This program is under the BOLA +License (see the license website or the +LICENSE +file itself for more details, it's very short and it basically says it's +Public Domain). */