mirror of
https://github.com/fluencelabs/redis
synced 2025-04-02 15:51:05 +00:00
command postprocessing implemented into RubyRedis
This commit is contained in:
parent
3f32f1f691
commit
3ba37089b5
1
TODO
1
TODO
@ -1,6 +1,5 @@
|
|||||||
BEFORE REDIS 1.0.0-rc1
|
BEFORE REDIS 1.0.0-rc1
|
||||||
|
|
||||||
* S*STORE should allow as dest key one of the source keys
|
|
||||||
* Warning if using default config, with hint about 'redis-server redis.conf'
|
* Warning if using default config, with hint about 'redis-server redis.conf'
|
||||||
* Add number of keys for every DB in INFO
|
* Add number of keys for every DB in INFO
|
||||||
* maxmemory support
|
* maxmemory support
|
||||||
|
@ -14,6 +14,35 @@ class RedisClient
|
|||||||
"echo"=>true, "getset"=>true, "smove"=>true
|
"echo"=>true, "getset"=>true, "smove"=>true
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ConvertToBool = lambda{|r| r == 0 ? false : r}
|
||||||
|
|
||||||
|
ReplyProcessor = {
|
||||||
|
"exists" => ConvertToBool,
|
||||||
|
"sismember"=> ConvertToBool,
|
||||||
|
"sadd"=> ConvertToBool,
|
||||||
|
"srem"=> ConvertToBool,
|
||||||
|
"smove"=> ConvertToBool,
|
||||||
|
"move"=> ConvertToBool,
|
||||||
|
"setnx"=> ConvertToBool,
|
||||||
|
"del"=> ConvertToBool,
|
||||||
|
"renamenx"=> ConvertToBool,
|
||||||
|
"expire"=> ConvertToBool,
|
||||||
|
"keys" => lambda{|r| r.split(" ")},
|
||||||
|
"info" => lambda{|r|
|
||||||
|
info = {}
|
||||||
|
r.each_line {|kv|
|
||||||
|
k,v = kv.split(':', 2)
|
||||||
|
k,v = k.chomp, v = v.chomp
|
||||||
|
info[k.to_sym] = v
|
||||||
|
}
|
||||||
|
info
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
def convert_to_bool(r)
|
||||||
|
r == 0 ? false : r
|
||||||
|
end
|
||||||
|
|
||||||
def initialize(opts={})
|
def initialize(opts={})
|
||||||
opts = {:host => 'localhost', :port => '6379', :db => 0}.merge(opts)
|
opts = {:host => 'localhost', :port => '6379', :db => 0}.merge(opts)
|
||||||
@host = opts[:host]
|
@host = opts[:host]
|
||||||
@ -52,12 +81,15 @@ class RedisClient
|
|||||||
bulk = nil
|
bulk = nil
|
||||||
argv[0] = argv[0].to_s.downcase
|
argv[0] = argv[0].to_s.downcase
|
||||||
if BulkCommands[argv[0]]
|
if BulkCommands[argv[0]]
|
||||||
bulk = argv[-1]
|
bulk = argv[-1].to_s
|
||||||
argv[-1] = bulk.length
|
argv[-1] = bulk.length
|
||||||
end
|
end
|
||||||
@sock.write(argv.join(" ")+"\r\n")
|
@sock.write(argv.join(" ")+"\r\n")
|
||||||
@sock.write(bulk+"\r\n") if bulk
|
@sock.write(bulk+"\r\n") if bulk
|
||||||
read_reply
|
|
||||||
|
# Post process the reply if needed
|
||||||
|
processor = ReplyProcessor[argv[0]]
|
||||||
|
processor ? processor.call(read_reply) : read_reply
|
||||||
end
|
end
|
||||||
|
|
||||||
def select(*args)
|
def select(*args)
|
||||||
|
3
redis.c
3
redis.c
@ -2973,7 +2973,7 @@ static void sinterGenericCommand(redisClient *c, robj **setskeys, int setsnum, r
|
|||||||
robj *lenobj = NULL, *dstset = NULL;
|
robj *lenobj = NULL, *dstset = NULL;
|
||||||
int j, cardinality = 0;
|
int j, cardinality = 0;
|
||||||
|
|
||||||
if (!dv) oom("sinterCommand");
|
if (!dv) oom("sinterGenericCommand");
|
||||||
for (j = 0; j < setsnum; j++) {
|
for (j = 0; j < setsnum; j++) {
|
||||||
robj *setobj;
|
robj *setobj;
|
||||||
|
|
||||||
@ -3151,7 +3151,6 @@ static void sunionDiffGenericCommand(redisClient *c, robj **setskeys, int setsnu
|
|||||||
deleteKey(c->db,dstkey);
|
deleteKey(c->db,dstkey);
|
||||||
dictAdd(c->db->dict,dstkey,dstset);
|
dictAdd(c->db->dict,dstkey,dstset);
|
||||||
incrRefCount(dstkey);
|
incrRefCount(dstkey);
|
||||||
server.dirty++;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Cleanup */
|
/* Cleanup */
|
||||||
|
Loading…
x
Reference in New Issue
Block a user