Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
openeuler
libvirt
提交
da094fe2
L
libvirt
项目概览
openeuler
/
libvirt
通知
3
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
L
libvirt
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
da094fe2
编写于
1月 23, 2012
作者:
S
Stefan Berger
提交者:
Stefan Berger
1月 23, 2012
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Compare two hash tables for equality
Add function to compare two hash tables for equality.
上级
4c18acff
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
58 addition
and
0 deletion
+58
-0
src/util/hash.c
src/util/hash.c
+46
-0
src/util/hash.h
src/util/hash.h
+12
-0
未找到文件。
src/util/hash.c
浏览文件 @
da094fe2
...
...
@@ -663,3 +663,49 @@ virHashKeyValuePairPtr virHashGetItems(virHashTablePtr table,
return
iter
.
sortArray
;
}
struct
virHashEqualData
{
bool
equal
;
const
virHashTablePtr
table2
;
virHashValueComparator
compar
;
};
static
int
virHashEqualSearcher
(
const
void
*
payload
,
const
void
*
name
,
const
void
*
data
)
{
struct
virHashEqualData
*
vhed
=
(
void
*
)
data
;
const
void
*
value
;
value
=
virHashLookup
(
vhed
->
table2
,
name
);
if
(
!
value
||
vhed
->
compar
(
value
,
payload
)
!=
0
)
{
/* key is missing in 2nd table or values are different */
vhed
->
equal
=
false
;
/* stop 'iteration' */
return
1
;
}
return
0
;
}
bool
virHashEqual
(
const
virHashTablePtr
table1
,
const
virHashTablePtr
table2
,
virHashValueComparator
compar
)
{
struct
virHashEqualData
data
=
{
.
equal
=
true
,
.
table2
=
table2
,
.
compar
=
compar
,
};
if
(
table1
==
table2
)
return
true
;
if
(
!
table1
||
!
table2
||
virHashSize
(
table1
)
!=
virHashSize
(
table2
))
return
false
;
virHashSearch
(
table1
,
virHashEqualSearcher
,
&
data
);
return
data
.
equal
;
}
src/util/hash.h
浏览文件 @
da094fe2
...
...
@@ -153,6 +153,18 @@ typedef int (*virHashKeyComparator)(const virHashKeyValuePairPtr,
virHashKeyValuePairPtr
virHashGetItems
(
virHashTablePtr
table
,
virHashKeyComparator
compar
);
/*
* Compare two tables for equality: the lookup of a key's value in
* both tables must result in an equivalent value.
* The caller must pass in a comparator function for comparing the values
* of two keys.
*/
typedef
int
(
*
virHashValueComparator
)(
const
void
*
value1
,
const
void
*
value2
);
bool
virHashEqual
(
const
virHashTablePtr
table1
,
const
virHashTablePtr
table2
,
virHashValueComparator
compar
);
/*
* Iterators
*/
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录