From 74c19b1b44589d171d0f043f52b4fe439aec1593 Mon Sep 17 00:00:00 2001 From: ampli Date: Fri, 3 May 2024 04:33:15 +0300 Subject: [PATCH] count.c: Bugfix count ovfl in recent refactoring Introduced in 6c4283ae3e. --- link-grammar/parse/count.c | 14 +++++++++----- 1 file changed, 9 insertions(+), 5 deletions(-) diff --git a/link-grammar/parse/count.c b/link-grammar/parse/count.c index 4573dbfcc..8f90fe44f 100644 --- a/link-grammar/parse/count.c +++ b/link-grammar/parse/count.c @@ -1079,14 +1079,18 @@ static Count_bin do_count(const char dlabel[], count_context_t *ctxt, * the scenario of using two "multi" end connectors simultaneously * has not been encountered with the included dictionaries. * + * To enable 31-bit overflow detection, totcount is signed 64-bit. The + * ccount array values are already clamped values. So the result will + * never be more than 4*2^31 which is less than 2^63-1. + * * @return Sum of the counts as mentioned above. */ -static Count_bin scount(const char dlabel[], count_context_t *ctxt, - Count_bin ccount[4], int lw, int rw, - Connector *le, Connector *re, - unsigned int null_count) +static w_Count_bin scount(const char dlabel[], count_context_t *ctxt, + Count_bin ccount[4], int lw, int rw, + Connector *le, Connector *re, + unsigned int null_count) { - Count_bin totcount; + w_Count_bin totcount; CACHE_COUNT(ccount[0], totcount = count, do_count(dlabel, ctxt, lw, rw, le->next, re->next, null_count));