Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
Turbo码先生
redis
提交
07329369
R
redis
项目概览
Turbo码先生
/
redis
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
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,发现更多精彩内容 >>
提交
07329369
编写于
11月 08, 2018
作者:
A
antirez
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
RESP3: Use new deferred len API in server.c.
上级
57c5a766
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
13 addition
and
8 deletion
+13
-8
src/server.c
src/server.c
+7
-7
src/server.h
src/server.h
+6
-1
未找到文件。
src/server.c
浏览文件 @
07329369
...
...
@@ -2940,7 +2940,7 @@ void timeCommand(client *c) {
/* gettimeofday() can only fail if &tv is a bad address so we
* don't check for errors. */
gettimeofday
(
&
tv
,
NULL
);
addReply
MultiBulk
Len
(
c
,
2
);
addReply
Array
Len
(
c
,
2
);
addReplyBulkLongLong
(
c
,
tv
.
tv_sec
);
addReplyBulkLongLong
(
c
,
tv
.
tv_usec
);
}
...
...
@@ -2960,12 +2960,12 @@ void addReplyCommand(client *c, struct redisCommand *cmd) {
addReply
(
c
,
shared
.
nullbulk
);
}
else
{
/* We are adding: command name, arg count, flags, first, last, offset */
addReply
MultiBulk
Len
(
c
,
6
);
addReply
Array
Len
(
c
,
6
);
addReplyBulkCString
(
c
,
cmd
->
name
);
addReplyLongLong
(
c
,
cmd
->
arity
);
int
flagcount
=
0
;
void
*
flaglen
=
add
DeferredMultiBulkLength
(
c
);
void
*
flaglen
=
add
ReplyDeferredLen
(
c
);
flagcount
+=
addReplyCommandFlag
(
c
,
cmd
,
CMD_WRITE
,
"write"
);
flagcount
+=
addReplyCommandFlag
(
c
,
cmd
,
CMD_READONLY
,
"readonly"
);
flagcount
+=
addReplyCommandFlag
(
c
,
cmd
,
CMD_DENYOOM
,
"denyoom"
);
...
...
@@ -2985,7 +2985,7 @@ void addReplyCommand(client *c, struct redisCommand *cmd) {
addReplyStatus
(
c
,
"movablekeys"
);
flagcount
+=
1
;
}
setDeferred
MultiBulkLength
(
c
,
flaglen
,
flagcount
);
setDeferred
SetLen
(
c
,
flaglen
,
flagcount
);
addReplyLongLong
(
c
,
cmd
->
firstkey
);
addReplyLongLong
(
c
,
cmd
->
lastkey
);
...
...
@@ -3008,7 +3008,7 @@ NULL
};
addReplyHelp
(
c
,
help
);
}
else
if
(
c
->
argc
==
1
)
{
addReply
MultiBulk
Len
(
c
,
dictSize
(
server
.
commands
));
addReply
Array
Len
(
c
,
dictSize
(
server
.
commands
));
di
=
dictGetIterator
(
server
.
commands
);
while
((
de
=
dictNext
(
di
))
!=
NULL
)
{
addReplyCommand
(
c
,
dictGetVal
(
de
));
...
...
@@ -3016,7 +3016,7 @@ NULL
dictReleaseIterator
(
di
);
}
else
if
(
!
strcasecmp
(
c
->
argv
[
1
]
->
ptr
,
"info"
))
{
int
i
;
addReply
MultiBulk
Len
(
c
,
c
->
argc
-
2
);
addReply
Array
Len
(
c
,
c
->
argc
-
2
);
for
(
i
=
2
;
i
<
c
->
argc
;
i
++
)
{
addReplyCommand
(
c
,
dictFetchValue
(
server
.
commands
,
c
->
argv
[
i
]
->
ptr
));
}
...
...
@@ -3043,7 +3043,7 @@ NULL
if
(
!
keys
)
{
addReplyError
(
c
,
"Invalid arguments specified for command"
);
}
else
{
addReply
MultiBulk
Len
(
c
,
numkeys
);
addReply
Array
Len
(
c
,
numkeys
);
for
(
j
=
0
;
j
<
numkeys
;
j
++
)
addReplyBulk
(
c
,
c
->
argv
[
keys
[
j
]
+
2
]);
getKeysFreeResult
(
keys
);
}
...
...
src/server.h
浏览文件 @
07329369
...
...
@@ -1450,7 +1450,12 @@ void addReplyStatus(client *c, const char *status);
void
addReplyDouble
(
client
*
c
,
double
d
);
void
addReplyHumanLongDouble
(
client
*
c
,
long
double
d
);
void
addReplyLongLong
(
client
*
c
,
long
long
ll
);
void
addReplyMultiBulkLen
(
client
*
c
,
long
length
);
void
addReplyArrayLen
(
client
*
c
,
long
length
);
void
addReplyMapLen
(
client
*
c
,
long
length
);
void
addReplySetLen
(
client
*
c
,
long
length
);
void
addReplyAttributeLen
(
client
*
c
,
long
length
);
void
addReplyPushLen
(
client
*
c
,
long
length
);
void
addReplyHelloLen
(
client
*
c
,
long
length
);
void
addReplyHelp
(
client
*
c
,
const
char
**
help
);
void
addReplySubcommandSyntaxError
(
client
*
c
);
void
copyClientOutputBuffer
(
client
*
dst
,
client
*
src
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录