Mercurial > MadButterfly
diff src/X_supp.c @ 989:7a727ba3f441 refine_backend_if
Implement functions of timer manager for X support
author | Thinker K.F. Li <thinker@codemud.net> |
---|---|
date | Mon, 22 Nov 2010 00:42:29 +0800 |
parents | bc8cfcd40d0e |
children | 8dd42310dd79 |
line wrap: on
line diff
--- a/src/X_supp.c Mon Nov 22 00:42:29 2010 +0800 +++ b/src/X_supp.c Mon Nov 22 00:42:29 2010 +0800 @@ -82,16 +82,52 @@ mb_tman_t *tman; }; -static struct _X_supp_timer_man _X_supp_default_timer_man = { +int _x_supp_timer_man_timeout(struct _mb_timer_man *tm_man, + mbsec_t sec, mbusec_t usec, + mb_timer_cb_t cb, void *data); +void _x_supp_timer_man_remove(struct _mb_timer_man *tm_man, int tm_hdl); +mb_timer_man_t *_x_supp_timer_fact_new(void); +void _x_supp_timer_fact_free(mb_timer_man_t *timer_man); + +static struct _X_supp_timer_man _x_supp_default_timer_man = { {_x_supp_timer_man_timeout, _x_supp_timer_man_remove}, NULL }; -static mb_timer_factory_t _X_supp_default_timer_factory = { - _X_supp_timer_fact_new, - _X_supp_timer_fact_free +static mb_timer_factory_t _x_supp_default_timer_factory = { + _x_supp_timer_fact_new, + _x_supp_timer_fact_free +}; + +static mb_timer_factory_t *_timer_factory = &_x_supp_default_timer_factory; + +static int +_x_supp_timer_man_timeout(struct _mb_timer_man *tm_man, + mbsec_t sec, mbusec_t usec, + mb_timer_cb_t cb, void *data) { + struct _X_supp_timer_man *timer_man = (struct _X_supp_timer_man *)tm_man; + mb_timer_t *timer; + mb_timeval_t tmo; + + timer = mb_tman_timeout(timer_man->tman, &tmo, cb, data); } +static void +_x_supp_timer_man_remove(struct _mb_timer_man *tm_man, int tm_hdl) { +} + +static mb_timer_man_t * +_x_supp_timer_fact_new(void) { + if(_x_supp_default_timer_man.tman == NULL) + _x_supp_default_timer_man.tman = mb_tman_new(); + return (mb_timer_man_t *)&_x_supp_default_timer_man; +} + +static void +_x_supp_timer_fact_free(mb_timer_man_t *timer_man) { +} + + /* @} */ /*! \defgroup x_mb_io IO manager for X.