]> git.saurik.com Git - redis.git/commitdiff
rewrite INCRBYFLOAT as SETs for AOF/replication
authorantirez <antirez@gmail.com>
Mon, 14 Nov 2011 09:15:13 +0000 (10:15 +0100)
committerantirez <antirez@gmail.com>
Mon, 14 Nov 2011 09:15:13 +0000 (10:15 +0100)
src/t_string.c

index 1f0b1fbcc44b49c60a4065c52f40bd53496e01d0..2bd1646e305627ecab073893553a40f48444c2bf 100644 (file)
@@ -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) {