#include "hloop.h" #include "hbase.h" void on_timer(htimer_t* timer) { printf("time=%lus on_timer\n", hloop_now(timer->loop)); } void on_timer_add(htimer_t* timer) { printf("time=%lus on_timer_add\n", hloop_now(timer->loop)); htimer_add(timer->loop, on_timer_add, 1000, 1); } void on_timer_del(htimer_t* timer) { printf("time=%lus on_timer_del\n", hloop_now(timer->loop)); htimer_del(timer); } void on_timer_reset(htimer_t* timer) { printf("time=%lus on_timer_reset\n", hloop_now(timer->loop)); htimer_reset((htimer_t*)timer->userdata); } void on_timer_quit(htimer_t* timer) { printf("time=%lus on_timer_quit\n", hloop_now(timer->loop)); hloop_stop(timer->loop); } void cron_hourly(htimer_t* timer) { time_t tt; time(&tt); printf("time=%lus cron_hourly: %s\n", hloop_now(timer->loop), ctime(&tt)); } int main() { MEMCHECK; hloop_t loop; hloop_init(&loop); // on_timer_add triggered forever htimer_add(&loop, on_timer_add, 1000, 1); // on_timer_del triggered just once htimer_add(&loop, on_timer_del, 1000, 10); // on_timer triggered after 10s htimer_t* reseted = htimer_add(&loop, on_timer, 5000, 1); htimer_t* reset = htimer_add(&loop, on_timer_reset, 1000, 5); reset->userdata = reseted; // cron_hourly next triggered in one minute int minute = time(NULL)%3600/60; htimer_add_period(&loop, cron_hourly, minute+1, -1, -1, -1, -1, INFINITE); // quit application after 1 min htimer_add(&loop, on_timer_quit, 60000, 1); printf("time=%lus begin\n", hloop_now(&loop)); hloop_run(&loop); printf("time=%lus stop\n", hloop_now(&loop)); return 0; }