Edit

kc3-lang/libevent/sample/time-test.c

Branch :

  • Show log

    Commit

  • Author : Nick Mathewson
    Date : 2007-11-26 19:18:49
    Hash : ce4ee418
    Message : r16733@catbus: nickm | 2007-11-26 14:18:25 -0500 Add an --enable-gcc-warnings option (lifted from Tor) to the configure script. When provided, and when we are using GCC, we enable a bunch of extra GCC warnings in the compiler. Also, make the code all build happily with these warnings. svn:r553

  • sample/time-test.c
  • /*
     * Compile with:
     * cc -I/usr/local/include -o time-test time-test.c -L/usr/local/lib -levent
     */
    
    #include <sys/types.h>
    
    #ifdef HAVE_CONFIG_H
    #include "config.h"
    #endif
    
    #include <sys/stat.h>
    #ifndef WIN32
    #include <sys/queue.h>
    #include <unistd.h>
    #endif
    #include <time.h>
    #ifdef HAVE_SYS_TIME_H
    #include <sys/time.h>
    #endif
    #include <fcntl.h>
    #include <stdlib.h>
    #include <stdio.h>
    #include <string.h>
    #include <errno.h>
    
    #include <event.h>
    #include <evutil.h>
    
    int lasttime;
    
    static void
    timeout_cb(int fd, short event, void *arg)
    {
    	struct timeval tv;
    	struct event *timeout = arg;
    	int newtime = time(NULL);
    
    	printf("%s: called at %d: %d\n", __func__, newtime,
    	    newtime - lasttime);
    	lasttime = newtime;
    
    	evutil_timerclear(&tv);
    	tv.tv_sec = 2;
    	event_add(timeout, &tv);
    }
    
    int
    main (int argc, char **argv)
    {
    	struct event timeout;
    	struct timeval tv;
     
    	/* Initalize the event library */
    	event_init();
    
    	/* Initalize one event */
    	evtimer_set(&timeout, timeout_cb, &timeout);
    
    	evutil_timerclear(&tv);
    	tv.tv_sec = 2;
    	event_add(&timeout, &tv);
    
    	lasttime = time(NULL);
    	
    	event_dispatch();
    
    	return (0);
    }