W3C Lib Using

The Event Manager

The W3C Reference Library can be used in either a single-threaded or the multi-threaded programming style. In this section we will havea look at how to enable this functionality and what the API is for applications to use it. We will not describe the underlying design model as thsi is described in detail in the Library Architecture documentation.

If you are working on a MSWindows platform then you have the possibility of using asynchronous socket management (proactive mode) instead of typical Unix select based I/O (reactive mode). Please read the Windows documentation for more details.

Event Handlers

The appplication registers a set of event handlers to be used on a specified set of sockets. An event handler is a function of type
typedef int HTEventCallback (SOCKET, HTRequest *, SockOps);

Register a TTY Event Handler

Register the tty (console) as having events. If the TTY is select()-able (as is true under Unix), then we treat it as just another socket. Otherwise, take steps depending on the platform. This is the function to use to register user events!
extern int HTEvent_RegisterTTY	(SOCKET, HTRequest *, SockOps, HTEventCallback *, HTPriority);

Unregister a TTY Event Handler

Unregisters TTY I/O channel. If the TTY is select()-able (as is true under Unix), then we treat it as just another socket.
extern int HTEvent_UnRegisterTTY (SOCKET, SockOps);

Register an Event Handler

For a given socket, reqister a request structure, a set of operations, a HTEventCallback function, and a priority. For this implementation, we allow only a single HTEventCallback function for all operations. and the priority field is ignored.
extern int HTEvent_Register	(SOCKET, HTRequest *, SockOps, HTEventCallback *, HTPriority);

Unregister an Event Handler

Remove the registered information for the specified socket for the actions specified in ops. if no actions remain after the unregister, the registered info is deleted, and, if the socket has been registered for notification, the HTEventCallback will be invoked.
extern int HTEvent_UnRegister	(SOCKET, SockOps);

Unregister ALL Event Handlers

Unregister all sockets. N.B. we just remove them for our internal data structures: it is up to the application to actually close the socket.
extern int HTEvent_UnregisterAll (void);

Handler for Timeout on Sockets

This function sets the timeout for sockets in the select() call and registers a timeout function that is called if select times out. This does only works on NON windows platforms as we need to poll for the console on windows If tv = NULL then timeout is disabled. Default is no timeout. If always=YES then the callback is called at all times, if NO then only when Library sockets are active. Returns YES if OK else NO.
typedef int HTEventTimeout (HTRequest *);

extern BOOL HTEvent_registerTimeout (struct timeval *tp, HTRequest * request,
				     HTEventTimeout *tcbf, BOOL always);

Start the Event Loop

That is, we wait for activity from one of our registered channels, and dispatch on that. Under Windows/NT, we must treat the console and sockets as distinct. That means we can't avoid a busy wait, but we do our best.
extern int HTEvent_Loop (HTRequest * request);

Stop the Event Loop

Stops the (select based) event loop. The function does not guarantee that all requests have terminated. This is for the app to do
extern void HTEvent_stopLoop (void);


Henrik Frystyk, libwww@w3.org, December 1995