From: Teodor Sigaev Date: Wed, 1 Jun 2005 11:46:09 +0000 (+0000) Subject: Prevent to divide by zero and range out of 0..1 X-Git-Tag: REL7_4_9~38 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=1891938e9c7765cb59515483576b2e07f508e385;p=thirdparty%2Fpostgresql.git Prevent to divide by zero and range out of 0..1 --- diff --git a/contrib/tsearch2/rank.c b/contrib/tsearch2/rank.c index c6cbd1c9591..9098cc9ed60 100644 --- a/contrib/tsearch2/rank.c +++ b/contrib/tsearch2/rank.c @@ -288,6 +288,7 @@ calc_rank(float *w, tsvector * t, QUERYTYPE * q, int4 method) { ITEM *item = GETQUERY(q); float res = 0.0; + int len; if (!t->size || !q->size) return 0.0; @@ -303,10 +304,11 @@ calc_rank(float *w, tsvector * t, QUERYTYPE * q, int4 method) case 0: break; case 1: - res /= log((float) cnt_length(t)); + res /= log( (float)(cnt_length(t)+1) ) / log(2.0); break; case 2: - res /= (float) cnt_length(t); + len = cnt_length(t); + if ( len > 0 ) res /= (float)len; break; default: /* internal error */ @@ -607,10 +609,11 @@ rank_cd(PG_FUNCTION_ARGS) case 0: break; case 1: - res /= log((float) cnt_length(txt)); + res /= log( (float)(cnt_length(txt)+1) ); break; case 2: - res /= (float) cnt_length(txt); + len = cnt_length(txt); + if ( len > 0 ) res /= (float)len; break; default: /* internal error */