From 256356ffd83b93abe49911a4b4bae020d5149348 Mon Sep 17 00:00:00 2001 From: antirez Date: Fri, 23 Dec 2011 09:27:31 +0100 Subject: [PATCH] Prevent NaN scores in sorted sets resulting from calls to ZUNIONSTORE and ZINTERSTORE. --- src/t_zset.c | 3 +++ 1 file changed, 3 insertions(+) diff --git a/src/t_zset.c b/src/t_zset.c index 7008f0c4a..f42e5a318 100644 --- a/src/t_zset.c +++ b/src/t_zset.c @@ -1545,6 +1545,8 @@ void zunionInterGenericCommand(redisClient *c, robj *dstkey, int op) { double score, value; score = src[0].weight * zval.score; + if (isnan(score)) score = 0; + for (j = 1; j < setnum; j++) { /* It is not safe to access the zset we are * iterating, so explicitly check for equal object. */ @@ -1587,6 +1589,7 @@ void zunionInterGenericCommand(redisClient *c, robj *dstkey, int op) { /* Initialize score */ score = src[i].weight * zval.score; + if (isnan(score)) score = 0; /* Because the inputs are sorted by size, it's only possible * for sets at larger indices to hold this element. */