Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
hanoi2005
redis
提交
75d8978e
R
redis
项目概览
hanoi2005
/
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,发现更多精彩内容 >>
提交
75d8978e
编写于
5月 22, 2010
作者:
P
Pieter Noordhuis
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
updated iteration code to work well with different encodings
上级
37fff074
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
62 addition
and
28 deletion
+62
-28
ziplist.c
ziplist.c
+62
-28
未找到文件。
ziplist.c
浏览文件 @
75d8978e
...
...
@@ -296,18 +296,31 @@ unsigned char *ziplistIndex(unsigned char *zl, unsigned int index) {
return
p
;
}
/* Store entry at current position in sds *value and return pointer
* to the next entry. */
unsigned
char
*
ziplistNext
(
unsigned
char
*
p
,
unsigned
char
**
q
,
unsigned
char
**
entry
,
unsigned
int
*
elen
)
{
unsigned
int
lensize
;
if
(
*
p
==
ZIP_END
)
return
NULL
;
if
(
entry
)
{
*
elen
=
zipDecodeLength
(
p
,
&
lensize
);
*
entry
=
p
+
lensize
;
/* Return pointer to next entry in ziplist. */
unsigned
char
*
ziplistNext
(
unsigned
char
*
p
)
{
return
*
p
==
ZIP_END
?
p
:
p
+
zipRawEntryLength
(
p
);
}
/* Get entry pointer to by 'p' and store in either 'e' or 'v' depending
* on the encoding of the entry. 'e' is always set to NULL to be able
* to find out whether the string pointer or the integer value was set.
* Return 0 if 'p' points to the end of the zipmap, 1 otherwise. */
unsigned
int
ziplistGet
(
unsigned
char
*
p
,
unsigned
char
**
e
,
unsigned
int
*
elen
,
long
long
*
v
)
{
unsigned
int
len
,
lensize
;
if
(
*
p
==
ZIP_END
)
return
0
;
if
(
e
)
*
e
=
NULL
;
len
=
zipDecodeLength
(
p
,
&
lensize
);
if
(
ZIP_ENCODING
(
p
)
==
ZIP_ENC_RAW
)
{
if
(
e
)
{
*
elen
=
len
;
*
e
=
p
+
lensize
;
}
}
else
{
if
(
v
)
{
*
v
=
zipLoadInteger
(
p
+
lensize
,
ZIP_ENCODING
(
p
));
}
}
if
(
q
!=
NULL
)
*
q
=
p
;
p
+=
zipRawEntryLength
(
p
);
return
p
;
return
1
;
}
/* Delete a range of entries from the ziplist. */
...
...
@@ -382,6 +395,7 @@ unsigned char *createList() {
zl
=
ziplistPush
(
zl
,
(
unsigned
char
*
)
"foo"
,
3
,
ZIPLIST_TAIL
);
zl
=
ziplistPush
(
zl
,
(
unsigned
char
*
)
"quux"
,
4
,
ZIPLIST_TAIL
);
zl
=
ziplistPush
(
zl
,
(
unsigned
char
*
)
"hello"
,
5
,
ZIPLIST_HEAD
);
zl
=
ziplistPush
(
zl
,
(
unsigned
char
*
)
"1024"
,
4
,
ZIPLIST_TAIL
);
return
zl
;
}
...
...
@@ -407,6 +421,7 @@ unsigned char *createIntList() {
int
main
(
int
argc
,
char
**
argv
)
{
unsigned
char
*
zl
,
*
p
,
*
q
,
*
entry
;
unsigned
int
elen
;
long
long
value
;
sds
s
;
zl
=
createIntList
();
...
...
@@ -427,10 +442,15 @@ int main(int argc, char **argv) {
{
zl
=
createList
();
p
=
ziplistIndex
(
zl
,
0
);
while
(
(
p
=
ziplistNext
(
p
,
NULL
,
&
entry
,
&
elen
))
!=
NULL
)
{
while
(
ziplistGet
(
p
,
&
entry
,
&
elen
,
&
value
)
)
{
printf
(
"Entry: "
);
fwrite
(
entry
,
elen
,
1
,
stdout
);
printf
(
" (length %d)
\n
"
,
elen
);
if
(
entry
)
{
fwrite
(
entry
,
elen
,
1
,
stdout
);
}
else
{
printf
(
"%lld"
,
value
);
}
p
=
ziplistNext
(
p
);
printf
(
"
\n
"
);
}
printf
(
"
\n
"
);
}
...
...
@@ -439,10 +459,15 @@ int main(int argc, char **argv) {
{
zl
=
createList
();
p
=
ziplistIndex
(
zl
,
1
);
while
(
(
p
=
ziplistNext
(
p
,
NULL
,
&
entry
,
&
elen
))
!=
NULL
)
{
while
(
ziplistGet
(
p
,
&
entry
,
&
elen
,
&
value
)
)
{
printf
(
"Entry: "
);
fwrite
(
entry
,
elen
,
1
,
stdout
);
printf
(
" (length %d)
\n
"
,
elen
);
if
(
entry
)
{
fwrite
(
entry
,
elen
,
1
,
stdout
);
}
else
{
printf
(
"%lld"
,
value
);
}
p
=
ziplistNext
(
p
);
printf
(
"
\n
"
);
}
printf
(
"
\n
"
);
}
...
...
@@ -451,10 +476,15 @@ int main(int argc, char **argv) {
{
zl
=
createList
();
p
=
ziplistIndex
(
zl
,
2
);
while
(
(
p
=
ziplistNext
(
p
,
NULL
,
&
entry
,
&
elen
))
!=
NULL
)
{
while
(
ziplistGet
(
p
,
&
entry
,
&
elen
,
&
value
)
)
{
printf
(
"Entry: "
);
fwrite
(
entry
,
elen
,
1
,
stdout
);
printf
(
" (length %d)
\n
"
,
elen
);
if
(
entry
)
{
fwrite
(
entry
,
elen
,
1
,
stdout
);
}
else
{
printf
(
"%lld"
,
value
);
}
p
=
ziplistNext
(
p
);
printf
(
"
\n
"
);
}
printf
(
"
\n
"
);
}
...
...
@@ -462,8 +492,8 @@ int main(int argc, char **argv) {
printf
(
"Iterate starting out of range:
\n
"
);
{
zl
=
createList
();
p
=
ziplistIndex
(
zl
,
3
);
if
(
ziplistNext
(
p
,
&
entry
,
NULL
,
&
elen
)
==
NULL
)
{
p
=
ziplistIndex
(
zl
,
4
);
if
(
!
ziplistGet
(
p
,
&
entry
,
&
elen
,
&
value
)
)
{
printf
(
"No entry
\n
"
);
}
else
{
printf
(
"ERROR
\n
"
);
...
...
@@ -510,15 +540,19 @@ int main(int argc, char **argv) {
{
zl
=
createList
();
p
=
ziplistIndex
(
zl
,
0
);
while
(
(
p
=
ziplistNext
(
p
,
&
q
,
&
entry
,
&
elen
))
!=
NULL
)
{
if
(
strncmp
(
"foo"
,
entry
,
elen
)
==
0
)
{
while
(
ziplistGet
(
p
,
&
entry
,
&
elen
,
&
value
)
)
{
if
(
entry
&&
strncmp
(
"foo"
,
entry
,
elen
)
==
0
)
{
printf
(
"Delete foo
\n
"
);
zl
=
ziplistDelete
(
zl
,
&
q
);
p
=
q
;
zl
=
ziplistDelete
(
zl
,
&
p
);
}
else
{
printf
(
"Entry: "
);
fwrite
(
entry
,
elen
,
1
,
stdout
);
printf
(
" (length %d)
\n
"
,
elen
);
if
(
entry
)
{
fwrite
(
entry
,
elen
,
1
,
stdout
);
}
else
{
printf
(
"%lld"
,
value
);
}
p
=
ziplistNext
(
p
);
printf
(
"
\n
"
);
}
}
printf
(
"
\n
"
);
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录