From 5244d6e54ec08666f953124739a498d0537a2bf9 Mon Sep 17 00:00:00 2001 From: antirez Date: Mon, 14 Nov 2011 10:15:13 +0100 Subject: [PATCH] rewrite INCRBYFLOAT as SETs for AOF/replication --- src/t_string.c | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/src/t_string.c b/src/t_string.c index 1f0b1fbc..2bd1646e 100644 --- a/src/t_string.c +++ b/src/t_string.c @@ -385,7 +385,7 @@ void decrbyCommand(redisClient *c) { void incrbyfloatCommand(redisClient *c) { long double incr, value; - robj *o, *new; + robj *o, *new, *aux; o = lookupKeyWrite(c->db,c->argv[1]); if (o != NULL && checkType(c,o,REDIS_STRING)) return; @@ -406,6 +406,14 @@ void incrbyfloatCommand(redisClient *c) { signalModifiedKey(c->db,c->argv[1]); server.dirty++; addReplyBulk(c,new); + + /* Always replicate INCRBYFLOAT as a SET command with the final value + * in order to make sure that differences in float pricision or formatting + * will not create differences in replicas or after an AOF restart. */ + aux = createStringObject("SET",3); + rewriteClientCommandArgument(c,0,aux); + decrRefCount(aux); + rewriteClientCommandArgument(c,2,new); } void appendCommand(redisClient *c) { -- 2.47.2