// -*- c-basic-offset: 4; tab-width: 8; indent-tabs-mode: t -*- // Copyright (c) 2001-2007 International Computer Science Institute // // Permission is hereby granted, free of charge, to any person obtaining a // copy of this software and associated documentation files (the "Software") // to deal in the Software without restriction, subject to the conditions // listed in the XORP LICENSE file. These conditions include: you must // preserve this copyright notice, and you cannot mention the copyright // holders in advertising related to the Software without their permission. // The Software is provided WITHOUT ANY WARRANTY, EXPRESS OR IMPLIED. This // notice is a summary of the XORP LICENSE file; the license in that file is // legally binding. #ident "$XORP: xorp/libxorp/test_timer.cc,v 1.16 2007/02/16 22:46:26 pavlin Exp $" // // demo program to test timers and event loops (and show // how to use them // #include #include "libxorp_module.h" #include "libxorp/timer.hh" #include "libxorp/eventloop.hh" #include "libxorp/xlog.h" int fired = 0 ; // callback for non-periodic timer. Does not need to return a value static void some_foo() { fired++; printf("O"); fflush(stdout); } // callback for a periodic timer. If true, the timer is rescheduled. static bool print_dot() { printf("."); fflush(stdout); return true; } static void test_many(EventLoop& e) { #define N 100 int i; XorpTimer a[N]; fired = 0 ; fprintf(stderr, "++ create a bunch of timers to fire in about 2s\n"); for (i=0; i