1
0
mirror of https://github.com/Tha14/toxic.git synced 2024-11-26 22:43:26 +01:00

message queue improvements

This commit is contained in:
Jfreegman 2014-09-09 14:06:28 -04:00
parent 09f90d095b
commit bcf4a5af90
No known key found for this signature in database
GPG Key ID: 3627F3144076AE63
4 changed files with 55 additions and 37 deletions

View File

@ -1093,7 +1093,6 @@ static void chat_onInit(ToxWindow *self, Tox *m)
exit_toxic_err("failed in chat_onInit", FATALERR_MEMORY); exit_toxic_err("failed in chat_onInit", FATALERR_MEMORY);
line_info_init(ctx->hst); line_info_init(ctx->hst);
ctx->cqueue->friendnum = self->num;
if (Friends.list[self->num].logging_on) if (Friends.list[self->num].logging_on)
log_enable(nick, Friends.list[self->num].pub_key, ctx->log); log_enable(nick, Friends.list[self->num].pub_key, ctx->log);

View File

@ -43,7 +43,7 @@ void cqueue_cleanup(struct chat_queue *q)
void cqueue_add(struct chat_queue *q, const char *msg, int len, uint8_t type, uint32_t line_id) void cqueue_add(struct chat_queue *q, const char *msg, int len, uint8_t type, uint32_t line_id)
{ {
struct cqueue_msg *new_m = calloc(1, sizeof(struct cqueue_msg)); struct cqueue_msg *new_m = malloc(sizeof(struct cqueue_msg));
if (new_m == NULL) if (new_m == NULL)
exit_toxic_err("failed in cqueue_message", FATALERR_MEMORY); exit_toxic_err("failed in cqueue_message", FATALERR_MEMORY);
@ -52,11 +52,17 @@ void cqueue_add(struct chat_queue *q, const char *msg, int len, uint8_t type, ui
new_m->len = len; new_m->len = len;
new_m->type = type; new_m->type = type;
new_m->line_id = line_id; new_m->line_id = line_id;
new_m->last_send_try = 0;
new_m->receipt = 0;
new_m->next = NULL;
if (q->root == NULL) if (q->root == NULL) {
new_m->prev = NULL;
q->root = new_m; q->root = new_m;
else } else {
new_m->prev = q->end;
q->end->next = new_m; q->end->next = new_m;
}
q->end = new_m; q->end = new_m;
} }
@ -82,44 +88,57 @@ static void cqueue_mark_read(ToxWindow *self, uint32_t id, uint8_t type)
} }
} }
/* removes root from queue and updates line to show the message was received. /* removes message with matching receipt from queue and updates line to show the message was received. */
receipt should always be equal to queue root's receipt */
void cqueue_remove(ToxWindow *self, struct chat_queue *q, uint32_t receipt) void cqueue_remove(ToxWindow *self, struct chat_queue *q, uint32_t receipt)
{ {
struct cqueue_msg *root = q->root; struct cqueue_msg *msg = q->root;
if (root->receipt != receipt) while (msg) {
return; if (msg->receipt != receipt) {
msg = msg->next;
cqueue_mark_read(self, root->line_id, root->type); continue;
struct cqueue_msg *next = root->next;
free(q->root);
q->root = next;
} }
/* Tries to send oldest message in queue. If fails, tries again in CQUEUE_TRY_SEND_INTERVAL seconds */ cqueue_mark_read(self, msg->line_id, msg->type);
void cqueue_try_send(ToxWindow *self, Tox *m) struct cqueue_msg *next = msg->next;
if (msg->prev == NULL) { /* root */
if (next)
next->prev = NULL;
free(msg);
q->root = next;
} else {
msg->prev->next = next;
free(msg);
}
return;
}
}
/* Tries to send the oldest unsent message in queue. */
void cqueue_try_send(ToxWindow *self, Tox *m, int32_t friendnum)
{ {
struct chat_queue *q = self->chatwin->cqueue; struct chat_queue *q = self->chatwin->cqueue;
struct cqueue_msg *msg = q->root;
if (q->root == NULL)
return;
struct cqueue_msg *q_msg = q->root;
uint64_t curtime = get_unix_time(); uint64_t curtime = get_unix_time();
/* allow some time for a laggy read receipt before resending while (msg) {
TODO: timeout should be removed when receipts are fixed in core) */ if (msg->receipt != 0 && !timed_out(msg->last_send_try, curtime, CQUEUE_TRY_SEND_INTERVAL)) {
if (q_msg->receipt != 0 && !timed_out(q_msg->last_send_try, curtime, CQUEUE_TRY_SEND_INTERVAL)) msg = msg->next;
return; continue;
}
uint32_t receipt = 0; uint32_t receipt = 0;
if (q_msg->type == OUT_MSG) if (msg->type == OUT_MSG)
receipt = tox_send_message(m, q->friendnum, (uint8_t *) q_msg->message, q_msg->len); receipt = tox_send_message(m, friendnum, (uint8_t *) msg->message, msg->len);
else else
receipt = tox_send_action(m, q->friendnum, (uint8_t *) q_msg->message, q_msg->len); receipt = tox_send_action(m, friendnum, (uint8_t *) msg->message, msg->len);
q->root->last_send_try = curtime; msg->last_send_try = curtime;
q->root->receipt = receipt; msg->receipt = receipt;
return;
}
} }

View File

@ -30,19 +30,19 @@ struct cqueue_msg {
uint32_t receipt; uint32_t receipt;
uint64_t last_send_try; uint64_t last_send_try;
struct cqueue_msg *next; struct cqueue_msg *next;
struct cqueue_msg *prev;
}; };
struct chat_queue { struct chat_queue {
struct cqueue_msg *root; struct cqueue_msg *root;
struct cqueue_msg *end; struct cqueue_msg *end;
int friendnum;
}; };
void cqueue_cleanup(struct chat_queue *q); void cqueue_cleanup(struct chat_queue *q);
void cqueue_add(struct chat_queue *q, const char *msg, int len, uint8_t type, uint32_t line_id); void cqueue_add(struct chat_queue *q, const char *msg, int len, uint8_t type, uint32_t line_id);
/* Tries to send oldest message in queue. If fails, tries again in CQUEUE_TRY_SEND_INTERVAL seconds */ /* Tries to send oldest message in queue. If fails, tries again in CQUEUE_TRY_SEND_INTERVAL seconds */
void cqueue_try_send(ToxWindow *self, Tox *m); void cqueue_try_send(ToxWindow *self, Tox *m, int32_t friendnum);
/* removes root from queue and updates line to show the message was received. /* removes root from queue and updates line to show the message was received.
receipt should always be equal to queue root's receipt */ receipt should always be equal to queue root's receipt */

View File

@ -588,11 +588,11 @@ void *thread_cqueue(void *data)
ToxWindow *toxwin = get_window_ptr(i); ToxWindow *toxwin = get_window_ptr(i);
if (toxwin != NULL && toxwin->is_chat && tox_get_friend_connection_status(m, toxwin->num) == 1) if (toxwin != NULL && toxwin->is_chat && tox_get_friend_connection_status(m, toxwin->num) == 1)
cqueue_try_send(toxwin, m); cqueue_try_send(toxwin, m, toxwin->num);
} }
pthread_mutex_unlock(&Winthread.lock); pthread_mutex_unlock(&Winthread.lock);
usleep(50000); usleep(7000);
} }
} }