Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
别团等shy哥发育
redis
提交
4a1f1cc0
R
redis
项目概览
别团等shy哥发育
/
redis
与 Fork 源项目一致
从无法访问的项目Fork
通知
2
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
redis
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
4a1f1cc0
编写于
10月 28, 2013
作者:
A
antirez
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
SSCAN implemented.
上级
dfeaa84d
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
13 addition
and
1 deletion
+13
-1
src/redis.c
src/redis.c
+2
-0
src/redis.h
src/redis.h
+3
-1
src/t_set.c
src/t_set.c
+8
-0
未找到文件。
src/redis.c
浏览文件 @
4a1f1cc0
...
...
@@ -165,6 +165,7 @@ struct redisCommand redisCommandTable[] = {
{
"sdiff"
,
sdiffCommand
,
-
2
,
"rS"
,
0
,
NULL
,
1
,
-
1
,
1
,
0
,
0
},
{
"sdiffstore"
,
sdiffstoreCommand
,
-
3
,
"wm"
,
0
,
NULL
,
1
,
-
1
,
1
,
0
,
0
},
{
"smembers"
,
sinterCommand
,
2
,
"rS"
,
0
,
NULL
,
1
,
1
,
1
,
0
,
0
},
{
"sscan"
,
sscanCommand
,
-
3
,
"rR"
,
0
,
NULL
,
1
,
1
,
1
,
0
,
0
},
{
"zadd"
,
zaddCommand
,
-
4
,
"wm"
,
0
,
NULL
,
1
,
1
,
1
,
0
,
0
},
{
"zincrby"
,
zincrbyCommand
,
4
,
"wm"
,
0
,
NULL
,
1
,
1
,
1
,
0
,
0
},
{
"zrem"
,
zremCommand
,
-
3
,
"w"
,
0
,
NULL
,
1
,
1
,
1
,
0
,
0
},
...
...
@@ -1227,6 +1228,7 @@ void createSharedObjects(void) {
shared
.
emptymultibulk
=
createObject
(
REDIS_STRING
,
sdsnew
(
"*0
\r\n
"
));
shared
.
pong
=
createObject
(
REDIS_STRING
,
sdsnew
(
"+PONG
\r\n
"
));
shared
.
queued
=
createObject
(
REDIS_STRING
,
sdsnew
(
"+QUEUED
\r\n
"
));
shared
.
emptyscan
=
createObject
(
REDIS_STRING
,
sdsnew
(
"*2
\r\n
$1
\r\n
0
\r\n
*0
\r\n
"
));
shared
.
wrongtypeerr
=
createObject
(
REDIS_STRING
,
sdsnew
(
"-WRONGTYPE Operation against a key holding the wrong kind of value
\r\n
"
));
shared
.
nokeyerr
=
createObject
(
REDIS_STRING
,
sdsnew
(
...
...
src/redis.h
浏览文件 @
4a1f1cc0
...
...
@@ -504,7 +504,7 @@ struct sharedObjectsStruct {
*
masterdownerr
,
*
roslaveerr
,
*
execaborterr
,
*
noautherr
,
*
noreplicaserr
,
*
oomerr
,
*
plus
,
*
messagebulk
,
*
pmessagebulk
,
*
subscribebulk
,
*
unsubscribebulk
,
*
psubscribebulk
,
*
punsubscribebulk
,
*
del
,
*
rpop
,
*
lpop
,
*
lpush
,
*
lpush
,
*
emptyscan
,
*
select
[
REDIS_SHARED_SELECT_CMDS
],
*
integers
[
REDIS_SHARED_INTEGERS
],
*
mbulkhdr
[
REDIS_SHARED_BULKHDR_LEN
],
/* "*<value>\r\n" */
...
...
@@ -1194,6 +1194,7 @@ void signalFlushedDb(int dbid);
unsigned
int
getKeysInSlot
(
unsigned
int
hashslot
,
robj
**
keys
,
unsigned
int
count
);
unsigned
int
countKeysInSlot
(
unsigned
int
hashslot
);
int
verifyClusterConfigWithData
(
void
);
void
scanGenericCommand
(
redisClient
*
c
,
robj
*
o
);
/* API to get key arguments from commands */
#define REDIS_GETKEYS_ALL 0
...
...
@@ -1286,6 +1287,7 @@ void sunionCommand(redisClient *c);
void
sunionstoreCommand
(
redisClient
*
c
);
void
sdiffCommand
(
redisClient
*
c
);
void
sdiffstoreCommand
(
redisClient
*
c
);
void
sscanCommand
(
redisClient
*
c
);
void
syncCommand
(
redisClient
*
c
);
void
flushdbCommand
(
redisClient
*
c
);
void
flushallCommand
(
redisClient
*
c
);
...
...
src/t_set.c
浏览文件 @
4a1f1cc0
...
...
@@ -906,3 +906,11 @@ void sdiffCommand(redisClient *c) {
void
sdiffstoreCommand
(
redisClient
*
c
)
{
sunionDiffGenericCommand
(
c
,
c
->
argv
+
2
,
c
->
argc
-
2
,
c
->
argv
[
1
],
REDIS_OP_DIFF
);
}
void
sscanCommand
(
redisClient
*
c
)
{
robj
*
set
;
if
((
set
=
lookupKeyReadOrReply
(
c
,
c
->
argv
[
1
],
shared
.
emptyscan
))
==
NULL
||
checkType
(
c
,
set
,
REDIS_SET
))
return
;
scanGenericCommand
(
c
,
set
);
}
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录