]> git.ozlabs.org Git - ccan-lca-2011.git/blobdiff - ccan/oserver/oserver.h
lca2011: don't use void * for the handle.
[ccan-lca-2011.git] / ccan / oserver / oserver.h
index fa214b4c951db53f78a8d0ecba418e03a3b02856..6b9a3e75c0ddce73d0d583ae28ab8af9b9694f59 100644 (file)
@@ -1,9 +1,30 @@
 #ifndef CCAN_OSERVER_H
 #define CCAN_OSERVER_H
-#include <ccan/compiler/compiler.h>
+#include <stdbool.h>
+#include <ccan/tevent/tevent.h>
 
-void NORETURN oserver_serve(int fd);
-int oserver_setup(void);
+/**
+ * oserver_setup - set up an oserver
+ * @ev: tevent context to use.
+ * @port: port to use (usually OSERVER_PORT)
+ *
+ * Opens a socket and binds it to @port, then sets it up to listen
+ * for connections.  talloc_free() the pointer returned to shut it down
+ * (its parent is the tevent_context).
+ *
+ * Example:
+ *     struct oserver *oserver;
+ *     struct tevent_context *ev;
+ *
+ *     ev = tevent_context_init(NULL);
+ *     oserver = oserver_setup(ev, OSERVER_PORT);
+ *     if (!oserver)
+ *             err(1, "Failed to set up server");
+ *
+ *     while (tevent_loop_wait(ev) == 0);
+ *     err(1, "Event loop failed");
+ */
+struct oserver *oserver_setup(struct tevent_context *ev, unsigned short port);
 
 #define OSERVER_PORT 2727
 #endif /* CCAN_OSERVER_H */