From 311be04d6155226b5bbdd8f7616d7df0647c2a0d Mon Sep 17 00:00:00 2001 From: nicm Date: Fri, 1 Jan 2016 08:04:20 +0000 Subject: [PATCH] Don't rely on a calculation wrapping when applying message-limit, and break out of the loop early. From Nicolas Viennot. --- status.c | 7 +++---- 1 file changed, 3 insertions(+), 4 deletions(-) diff --git a/status.c b/status.c index ca78bd53..cbacfe4c 100644 --- a/status.c +++ b/status.c @@ -547,7 +547,7 @@ status_message_set(struct client *c, const char *fmt, ...) struct message_entry *msg, *msg1; va_list ap; int delay; - u_int first, limit; + u_int limit; limit = options_get_number(global_options, "message-limit"); @@ -564,10 +564,9 @@ status_message_set(struct client *c, const char *fmt, ...) msg->msg = xstrdup(c->message_string); TAILQ_INSERT_TAIL(&c->message_log, msg, entry); - first = c->message_next - limit; TAILQ_FOREACH_SAFE(msg, &c->message_log, entry, msg1) { - if (msg->msg_num >= first) - continue; + if (msg->msg_num + limit >= c->message_next) + break; free(msg->msg); TAILQ_REMOVE(&c->message_log, msg, entry); free(msg);