--- mqtt/src/daemon.c 2012/05/28 08:08:21 1.2.2.34 +++ mqtt/src/daemon.c 2012/06/26 08:05:58 1.2.2.38 @@ -155,6 +155,7 @@ dispatchSession(sched_task_t *task) finiSession(sess); return NULL; } + ioDEBUG(0, "++++++ret=%d\n", ret); do { /* dispatch message type */ @@ -252,7 +253,8 @@ startSession(sched_task_t *task) TAILQ_FOREACH(s, &Sessions, sess_node) if (!strcmp(s->sess_cid, sess->sess_cid)) { /* found stale session & disconnect it! */ - schedWrite(root, leaveClient, sess, TASK_FD(task), NULL, 0); + schedCancelby(root, taskMAX, CRITERIA_FD, (void*) s->sess_sock, NULL); + schedWrite(root, leaveClient, s, s->sess_sock, NULL, 0); break; } } @@ -274,7 +276,7 @@ startSession(sched_task_t *task) if (call.WipePUB_topic) call.WipePUB_topic(&cfg, pub, sess->sess_cid, sess->sess_user, -1); } else { - // todo: read_sql subs and prepare publish + // TODO: read_sql subs and prepare publish } /* Start session task OK ... */