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).
*/