Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
xindoo
redis
提交
cbae1d34
R
redis
项目概览
xindoo
/
redis
通知
2
Star
2
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,体验更适合开发者的 AI 搜索 >>
提交
cbae1d34
编写于
5月 20, 2010
作者:
A
antirez
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix for DEBUG DIGEST
上级
8513a757
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
16 addition
and
8 deletion
+16
-8
redis.c
redis.c
+12
-8
staticsymbols.h
staticsymbols.h
+4
-0
未找到文件。
redis.c
浏览文件 @
cbae1d34
...
...
@@ -27,7 +27,7 @@
* POSSIBILITY OF SUCH DAMAGE.
*/
#define REDIS_VERSION "1.3.1
2
"
#define REDIS_VERSION "1.3.1
3
"
#include "fmacros.h"
#include "config.h"
...
...
@@ -10432,18 +10432,23 @@ static void computeDatasetDigest(unsigned char *final) {
/* Iterate this DB writing every entry */
while
((
de
=
dictNext
(
di
))
!=
NULL
)
{
robj
*
key
,
*
o
;
robj
*
key
,
*
o
,
*
kcopy
;
time_t
expiretime
;
memset
(
digest
,
0
,
20
);
/* This key-val digest */
key
=
dictGetEntryKey
(
de
);
mixObjectDigest
(
digest
,
key
);
if
(
!
server
.
vm_enabled
||
key
->
storage
==
REDIS_VM_MEMORY
||
key
->
storage
==
REDIS_VM_SWAPPING
)
{
if
(
!
server
.
vm_enabled
)
{
mixObjectDigest
(
digest
,
key
);
o
=
dictGetEntryVal
(
de
);
incrRefCount
(
o
);
}
else
{
o
=
vmPreviewObject
(
key
);
/* Don't work with the key directly as when VM is active
* this is unsafe: TODO: fix decrRefCount to check if the
* count really reached 0 to avoid this mess */
kcopy
=
dupStringObject
(
key
);
mixObjectDigest
(
digest
,
kcopy
);
o
=
lookupKeyRead
(
db
,
kcopy
);
decrRefCount
(
kcopy
);
}
aux
=
htonl
(
o
->
type
);
mixDigest
(
digest
,
&
aux
,
sizeof
(
aux
));
...
...
@@ -10512,7 +10517,6 @@ static void computeDatasetDigest(unsigned char *final) {
}
else
{
redisPanic
(
"Unknown object type"
);
}
decrRefCount
(
o
);
/* If the key has an expire, add it to the mix */
if
(
expiretime
!=
-
1
)
xorDigest
(
digest
,
"!!expire!!"
,
10
);
/* We can finally xor the key-val digest to the final digest */
...
...
staticsymbols.h
浏览文件 @
cbae1d34
...
...
@@ -180,6 +180,7 @@ static struct redisFunctionSym symsTable[] = {
{
"oom"
,(
unsigned
long
)
oom
},
{
"pingCommand"
,(
unsigned
long
)
pingCommand
},
{
"popGenericCommand"
,(
unsigned
long
)
popGenericCommand
},
{
"prepareForShutdown"
,(
unsigned
long
)
prepareForShutdown
},
{
"processCommand"
,(
unsigned
long
)
processCommand
},
{
"processInputBuffer"
,(
unsigned
long
)
processInputBuffer
},
{
"psubscribeCommand"
,(
unsigned
long
)
psubscribeCommand
},
...
...
@@ -260,6 +261,7 @@ static struct redisFunctionSym symsTable[] = {
{
"setnxCommand"
,(
unsigned
long
)
setnxCommand
},
{
"setupSigSegvAction"
,(
unsigned
long
)
setupSigSegvAction
},
{
"shutdownCommand"
,(
unsigned
long
)
shutdownCommand
},
{
"sigtermHandler"
,(
unsigned
long
)
sigtermHandler
},
{
"sinterCommand"
,(
unsigned
long
)
sinterCommand
},
{
"sinterGenericCommand"
,(
unsigned
long
)
sinterGenericCommand
},
{
"sinterstoreCommand"
,(
unsigned
long
)
sinterstoreCommand
},
...
...
@@ -272,6 +274,8 @@ static struct redisFunctionSym symsTable[] = {
{
"spopCommand"
,(
unsigned
long
)
spopCommand
},
{
"srandmemberCommand"
,(
unsigned
long
)
srandmemberCommand
},
{
"sremCommand"
,(
unsigned
long
)
sremCommand
},
{
"startAppendOnly"
,(
unsigned
long
)
startAppendOnly
},
{
"stopAppendOnly"
,(
unsigned
long
)
stopAppendOnly
},
{
"stringObjectLen"
,(
unsigned
long
)
stringObjectLen
},
{
"stringmatch"
,(
unsigned
long
)
stringmatch
},
{
"stringmatchlen"
,(
unsigned
long
)
stringmatchlen
},
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录