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:
parent
09f90d095b
commit
bcf4a5af90
@ -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);
|
||||||
|
@ -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;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
@ -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 */
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user