Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
20cbc1f8
T
Third Party Harfbuzz
项目概览
OpenHarmony
/
Third Party Harfbuzz
大约 1 年 前同步成功
通知
0
Star
18
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
Third Party Harfbuzz
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
20cbc1f8
编写于
9月 06, 2013
作者:
B
Behdad Esfahbod
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Annotate hb-set a bit; add HB_SET_VALUE_INVALID
上级
c44b8183
变更
5
显示空白变更内容
内联
并排
Showing
5 changed file
with
276 addition
and
22 deletion
+276
-22
src/hb-set-private.hh
src/hb-set-private.hh
+13
-7
src/hb-set.cc
src/hb-set.cc
+244
-0
src/hb-set.h
src/hb-set.h
+2
-0
src/hb-version.h.in
src/hb-version.h.in
+4
-2
test/api/test-set.c
test/api/test-set.c
+13
-13
未找到文件。
src/hb-set-private.hh
浏览文件 @
20cbc1f8
...
@@ -171,7 +171,7 @@ struct hb_set_t
...
@@ -171,7 +171,7 @@ struct hb_set_t
inline
void
add
(
hb_codepoint_t
g
)
inline
void
add
(
hb_codepoint_t
g
)
{
{
if
(
unlikely
(
in_error
))
return
;
if
(
unlikely
(
in_error
))
return
;
if
(
unlikely
(
g
==
SENTINEL
))
return
;
if
(
unlikely
(
g
==
INVALID
))
return
;
if
(
unlikely
(
g
>
MAX_G
))
return
;
if
(
unlikely
(
g
>
MAX_G
))
return
;
elt
(
g
)
|=
mask
(
g
);
elt
(
g
)
|=
mask
(
g
);
}
}
...
@@ -256,19 +256,22 @@ struct hb_set_t
...
@@ -256,19 +256,22 @@ struct hb_set_t
}
}
inline
bool
next
(
hb_codepoint_t
*
codepoint
)
const
inline
bool
next
(
hb_codepoint_t
*
codepoint
)
const
{
{
if
(
unlikely
(
*
codepoint
==
SENTINEL
))
{
if
(
unlikely
(
*
codepoint
==
INVALID
))
{
hb_codepoint_t
i
=
get_min
();
hb_codepoint_t
i
=
get_min
();
if
(
i
!=
SENTINEL
)
{
if
(
i
!=
INVALID
)
{
*
codepoint
=
i
;
*
codepoint
=
i
;
return
true
;
return
true
;
}
else
}
else
{
*
codepoint
=
INVALID
;
return
false
;
return
false
;
}
}
}
for
(
hb_codepoint_t
i
=
*
codepoint
+
1
;
i
<
MAX_G
+
1
;
i
++
)
for
(
hb_codepoint_t
i
=
*
codepoint
+
1
;
i
<
MAX_G
+
1
;
i
++
)
if
(
has
(
i
))
{
if
(
has
(
i
))
{
*
codepoint
=
i
;
*
codepoint
=
i
;
return
true
;
return
true
;
}
}
*
codepoint
=
INVALID
;
return
false
;
return
false
;
}
}
inline
bool
next_range
(
hb_codepoint_t
*
first
,
hb_codepoint_t
*
last
)
const
inline
bool
next_range
(
hb_codepoint_t
*
first
,
hb_codepoint_t
*
last
)
const
...
@@ -277,7 +280,10 @@ struct hb_set_t
...
@@ -277,7 +280,10 @@ struct hb_set_t
i
=
*
last
;
i
=
*
last
;
if
(
!
next
(
&
i
))
if
(
!
next
(
&
i
))
{
*
last
=
*
first
=
INVALID
;
return
false
;
return
false
;
}
*
last
=
*
first
=
i
;
*
last
=
*
first
=
i
;
while
(
next
(
&
i
)
&&
i
==
*
last
+
1
)
while
(
next
(
&
i
)
&&
i
==
*
last
+
1
)
...
@@ -300,7 +306,7 @@ struct hb_set_t
...
@@ -300,7 +306,7 @@ struct hb_set_t
for
(
unsigned
int
j
=
0
;
j
<
BITS
;
j
++
)
for
(
unsigned
int
j
=
0
;
j
<
BITS
;
j
++
)
if
(
elts
[
i
]
&
(
1
<<
j
))
if
(
elts
[
i
]
&
(
1
<<
j
))
return
i
*
BITS
+
j
;
return
i
*
BITS
+
j
;
return
SENTINEL
;
return
INVALID
;
}
}
inline
hb_codepoint_t
get_max
(
void
)
const
inline
hb_codepoint_t
get_max
(
void
)
const
{
{
...
@@ -309,7 +315,7 @@ struct hb_set_t
...
@@ -309,7 +315,7 @@ struct hb_set_t
for
(
unsigned
int
j
=
BITS
;
j
;
j
--
)
for
(
unsigned
int
j
=
BITS
;
j
;
j
--
)
if
(
elts
[
i
-
1
]
&
(
1
<<
(
j
-
1
)))
if
(
elts
[
i
-
1
]
&
(
1
<<
(
j
-
1
)))
return
(
i
-
1
)
*
BITS
+
(
j
-
1
);
return
(
i
-
1
)
*
BITS
+
(
j
-
1
);
return
SENTINEL
;
return
INVALID
;
}
}
typedef
uint32_t
elt_t
;
typedef
uint32_t
elt_t
;
...
@@ -318,7 +324,7 @@ struct hb_set_t
...
@@ -318,7 +324,7 @@ struct hb_set_t
static
const
unsigned
int
BITS
=
(
1
<<
SHIFT
);
static
const
unsigned
int
BITS
=
(
1
<<
SHIFT
);
static
const
unsigned
int
MASK
=
BITS
-
1
;
static
const
unsigned
int
MASK
=
BITS
-
1
;
static
const
unsigned
int
ELTS
=
(
MAX_G
+
1
+
(
BITS
-
1
))
/
BITS
;
static
const
unsigned
int
ELTS
=
(
MAX_G
+
1
+
(
BITS
-
1
))
/
BITS
;
static
const
hb_codepoint_t
SENTINEL
=
(
hb_codepoint_t
)
-
1
;
static
const
hb_codepoint_t
INVALID
=
HB_SET_VALUE_INVALID
;
elt_t
&
elt
(
hb_codepoint_t
g
)
{
return
elts
[
g
>>
SHIFT
];
}
elt_t
&
elt
(
hb_codepoint_t
g
)
{
return
elts
[
g
>>
SHIFT
];
}
elt_t
elt
(
hb_codepoint_t
g
)
const
{
return
elts
[
g
>>
SHIFT
];
}
elt_t
elt
(
hb_codepoint_t
g
)
const
{
return
elts
[
g
>>
SHIFT
];
}
...
...
src/hb-set.cc
浏览文件 @
20cbc1f8
...
@@ -30,6 +30,13 @@
...
@@ -30,6 +30,13 @@
/* Public API */
/* Public API */
/**
* hb_set_create: (constructor)
*
* Return value: (transfer full):
*
* Since: 1.0
**/
hb_set_t
*
hb_set_t
*
hb_set_create
(
void
)
hb_set_create
(
void
)
{
{
...
@@ -43,6 +50,13 @@ hb_set_create (void)
...
@@ -43,6 +50,13 @@ hb_set_create (void)
return
set
;
return
set
;
}
}
/**
* hb_set_get_empty:
*
* Return value: (transfer none):
*
* Since: 1.0
**/
hb_set_t
*
hb_set_t
*
hb_set_get_empty
(
void
)
hb_set_get_empty
(
void
)
{
{
...
@@ -56,12 +70,26 @@ hb_set_get_empty (void)
...
@@ -56,12 +70,26 @@ hb_set_get_empty (void)
return
const_cast
<
hb_set_t
*>
(
&
_hb_set_nil
);
return
const_cast
<
hb_set_t
*>
(
&
_hb_set_nil
);
}
}
/**
* hb_set_reference: (skip)
* @set: a set.
*
* Return value: (transfer full):
*
* Since: 1.0
**/
hb_set_t
*
hb_set_t
*
hb_set_reference
(
hb_set_t
*
set
)
hb_set_reference
(
hb_set_t
*
set
)
{
{
return
hb_object_reference
(
set
);
return
hb_object_reference
(
set
);
}
}
/**
* hb_set_destroy: (skip)
* @set: a set.
*
* Since: 1.0
**/
void
void
hb_set_destroy
(
hb_set_t
*
set
)
hb_set_destroy
(
hb_set_t
*
set
)
{
{
...
@@ -72,6 +100,18 @@ hb_set_destroy (hb_set_t *set)
...
@@ -72,6 +100,18 @@ hb_set_destroy (hb_set_t *set)
free
(
set
);
free
(
set
);
}
}
/**
* hb_set_set_user_data: (skip)
* @set: a set.
* @key:
* @data:
* @destroy (closure data):
* @replace:
*
* Return value:
*
* Since: 1.0
**/
hb_bool_t
hb_bool_t
hb_set_set_user_data
(
hb_set_t
*
set
,
hb_set_set_user_data
(
hb_set_t
*
set
,
hb_user_data_key_t
*
key
,
hb_user_data_key_t
*
key
,
...
@@ -82,6 +122,15 @@ hb_set_set_user_data (hb_set_t *set,
...
@@ -82,6 +122,15 @@ hb_set_set_user_data (hb_set_t *set,
return
hb_object_set_user_data
(
set
,
key
,
data
,
destroy
,
replace
);
return
hb_object_set_user_data
(
set
,
key
,
data
,
destroy
,
replace
);
}
}
/**
* hb_set_get_user_data: (skip)
* @set: a set.
* @key:
*
* Return value: (transfer none):
*
* Since: 1.0
**/
void
*
void
*
hb_set_get_user_data
(
hb_set_t
*
set
,
hb_set_get_user_data
(
hb_set_t
*
set
,
hb_user_data_key_t
*
key
)
hb_user_data_key_t
*
key
)
...
@@ -90,24 +139,63 @@ hb_set_get_user_data (hb_set_t *set,
...
@@ -90,24 +139,63 @@ hb_set_get_user_data (hb_set_t *set,
}
}
/**
* hb_set_allocation_successful:
* @set: a set.
*
*
*
* Return value:
*
* Since: 1.0
**/
hb_bool_t
hb_bool_t
hb_set_allocation_successful
(
const
hb_set_t
*
set
HB_UNUSED
)
hb_set_allocation_successful
(
const
hb_set_t
*
set
HB_UNUSED
)
{
{
return
!
set
->
in_error
;
return
!
set
->
in_error
;
}
}
/**
* hb_set_clear:
* @set: a set.
*
*
*
* Since: 1.0
**/
void
void
hb_set_clear
(
hb_set_t
*
set
)
hb_set_clear
(
hb_set_t
*
set
)
{
{
set
->
clear
();
set
->
clear
();
}
}
/**
* hb_set_is_empty:
* @set: a set.
*
*
*
* Return value:
*
* Since: 1.0
**/
hb_bool_t
hb_bool_t
hb_set_is_empty
(
const
hb_set_t
*
set
)
hb_set_is_empty
(
const
hb_set_t
*
set
)
{
{
return
set
->
is_empty
();
return
set
->
is_empty
();
}
}
/**
* hb_set_has:
* @set: a set.
* @codepoint:
*
*
*
* Return value:
*
* Since: 1.0
**/
hb_bool_t
hb_bool_t
hb_set_has
(
const
hb_set_t
*
set
,
hb_set_has
(
const
hb_set_t
*
set
,
hb_codepoint_t
codepoint
)
hb_codepoint_t
codepoint
)
...
@@ -115,6 +203,15 @@ hb_set_has (const hb_set_t *set,
...
@@ -115,6 +203,15 @@ hb_set_has (const hb_set_t *set,
return
set
->
has
(
codepoint
);
return
set
->
has
(
codepoint
);
}
}
/**
* hb_set_add:
* @set: a set.
* @codepoint:
*
*
*
* Since: 1.0
**/
void
void
hb_set_add
(
hb_set_t
*
set
,
hb_set_add
(
hb_set_t
*
set
,
hb_codepoint_t
codepoint
)
hb_codepoint_t
codepoint
)
...
@@ -122,6 +219,16 @@ hb_set_add (hb_set_t *set,
...
@@ -122,6 +219,16 @@ hb_set_add (hb_set_t *set,
set
->
add
(
codepoint
);
set
->
add
(
codepoint
);
}
}
/**
* hb_set_add_range:
* @set: a set.
* @first:
* @last:
*
*
*
* Since: 1.0
**/
void
void
hb_set_add_range
(
hb_set_t
*
set
,
hb_set_add_range
(
hb_set_t
*
set
,
hb_codepoint_t
first
,
hb_codepoint_t
first
,
...
@@ -130,6 +237,15 @@ hb_set_add_range (hb_set_t *set,
...
@@ -130,6 +237,15 @@ hb_set_add_range (hb_set_t *set,
set
->
add_range
(
first
,
last
);
set
->
add_range
(
first
,
last
);
}
}
/**
* hb_set_del:
* @set: a set.
* @codepoint:
*
*
*
* Since: 1.0
**/
void
void
hb_set_del
(
hb_set_t
*
set
,
hb_set_del
(
hb_set_t
*
set
,
hb_codepoint_t
codepoint
)
hb_codepoint_t
codepoint
)
...
@@ -137,6 +253,16 @@ hb_set_del (hb_set_t *set,
...
@@ -137,6 +253,16 @@ hb_set_del (hb_set_t *set,
set
->
del
(
codepoint
);
set
->
del
(
codepoint
);
}
}
/**
* hb_set_del_range:
* @set: a set.
* @first:
* @last:
*
*
*
* Since: 1.0
**/
void
void
hb_set_del_range
(
hb_set_t
*
set
,
hb_set_del_range
(
hb_set_t
*
set
,
hb_codepoint_t
first
,
hb_codepoint_t
first
,
...
@@ -145,6 +271,17 @@ hb_set_del_range (hb_set_t *set,
...
@@ -145,6 +271,17 @@ hb_set_del_range (hb_set_t *set,
set
->
del_range
(
first
,
last
);
set
->
del_range
(
first
,
last
);
}
}
/**
* hb_set_is_equal:
* @set: a set.
* @other:
*
*
*
* Return value:
*
* Since: 1.0
**/
hb_bool_t
hb_bool_t
hb_set_is_equal
(
const
hb_set_t
*
set
,
hb_set_is_equal
(
const
hb_set_t
*
set
,
const
hb_set_t
*
other
)
const
hb_set_t
*
other
)
...
@@ -152,6 +289,15 @@ hb_set_is_equal (const hb_set_t *set,
...
@@ -152,6 +289,15 @@ hb_set_is_equal (const hb_set_t *set,
return
set
->
is_equal
(
other
);
return
set
->
is_equal
(
other
);
}
}
/**
* hb_set_set:
* @set: a set.
* @other:
*
*
*
* Since: 1.0
**/
void
void
hb_set_set
(
hb_set_t
*
set
,
hb_set_set
(
hb_set_t
*
set
,
const
hb_set_t
*
other
)
const
hb_set_t
*
other
)
...
@@ -159,6 +305,15 @@ hb_set_set (hb_set_t *set,
...
@@ -159,6 +305,15 @@ hb_set_set (hb_set_t *set,
set
->
set
(
other
);
set
->
set
(
other
);
}
}
/**
* hb_set_union:
* @set: a set.
* @other:
*
*
*
* Since: 1.0
**/
void
void
hb_set_union
(
hb_set_t
*
set
,
hb_set_union
(
hb_set_t
*
set
,
const
hb_set_t
*
other
)
const
hb_set_t
*
other
)
...
@@ -166,6 +321,15 @@ hb_set_union (hb_set_t *set,
...
@@ -166,6 +321,15 @@ hb_set_union (hb_set_t *set,
set
->
union_
(
other
);
set
->
union_
(
other
);
}
}
/**
* hb_set_intersect:
* @set: a set.
* @other:
*
*
*
* Since: 1.0
**/
void
void
hb_set_intersect
(
hb_set_t
*
set
,
hb_set_intersect
(
hb_set_t
*
set
,
const
hb_set_t
*
other
)
const
hb_set_t
*
other
)
...
@@ -173,6 +337,15 @@ hb_set_intersect (hb_set_t *set,
...
@@ -173,6 +337,15 @@ hb_set_intersect (hb_set_t *set,
set
->
intersect
(
other
);
set
->
intersect
(
other
);
}
}
/**
* hb_set_subtract:
* @set: a set.
* @other:
*
*
*
* Since: 1.0
**/
void
void
hb_set_subtract
(
hb_set_t
*
set
,
hb_set_subtract
(
hb_set_t
*
set
,
const
hb_set_t
*
other
)
const
hb_set_t
*
other
)
...
@@ -180,6 +353,15 @@ hb_set_subtract (hb_set_t *set,
...
@@ -180,6 +353,15 @@ hb_set_subtract (hb_set_t *set,
set
->
subtract
(
other
);
set
->
subtract
(
other
);
}
}
/**
* hb_set_symmetric_difference:
* @set: a set.
* @other:
*
*
*
* Since: 1.0
**/
void
void
hb_set_symmetric_difference
(
hb_set_t
*
set
,
hb_set_symmetric_difference
(
hb_set_t
*
set
,
const
hb_set_t
*
other
)
const
hb_set_t
*
other
)
...
@@ -187,30 +369,79 @@ hb_set_symmetric_difference (hb_set_t *set,
...
@@ -187,30 +369,79 @@ hb_set_symmetric_difference (hb_set_t *set,
set
->
symmetric_difference
(
other
);
set
->
symmetric_difference
(
other
);
}
}
/**
* hb_set_invert:
* @set: a set.
*
*
*
* Since: 1.0
**/
void
void
hb_set_invert
(
hb_set_t
*
set
)
hb_set_invert
(
hb_set_t
*
set
)
{
{
set
->
invert
();
set
->
invert
();
}
}
/**
* hb_set_get_population:
* @set: a set.
*
* Returns the number of numbers in the set.
*
* Return value: set population.
*
* Since: 1.0
**/
unsigned
int
unsigned
int
hb_set_get_population
(
const
hb_set_t
*
set
)
hb_set_get_population
(
const
hb_set_t
*
set
)
{
{
return
set
->
get_population
();
return
set
->
get_population
();
}
}
/**
* hb_set_get_min:
* @set: a set.
*
* Finds the minimum number in the set.
*
* Return value: minimum of the set, or %HB_SET_VALUE_INVALID if set is empty.
*
* Since: 1.0
**/
hb_codepoint_t
hb_codepoint_t
hb_set_get_min
(
const
hb_set_t
*
set
)
hb_set_get_min
(
const
hb_set_t
*
set
)
{
{
return
set
->
get_min
();
return
set
->
get_min
();
}
}
/**
* hb_set_get_max:
* @set: a set.
*
* Finds the maximum number in the set.
*
* Return value: minimum of the set, or %HB_SET_VALUE_INVALID if set is empty.
*
* Since: 1.0
**/
hb_codepoint_t
hb_codepoint_t
hb_set_get_max
(
const
hb_set_t
*
set
)
hb_set_get_max
(
const
hb_set_t
*
set
)
{
{
return
set
->
get_max
();
return
set
->
get_max
();
}
}
/**
* hb_set_next:
* @set: a set.
* @codepoint: (inout):
*
*
*
* Return value: whether there was a next value.
*
* Since: 1.0
**/
hb_bool_t
hb_bool_t
hb_set_next
(
const
hb_set_t
*
set
,
hb_set_next
(
const
hb_set_t
*
set
,
hb_codepoint_t
*
codepoint
)
hb_codepoint_t
*
codepoint
)
...
@@ -218,6 +449,19 @@ hb_set_next (const hb_set_t *set,
...
@@ -218,6 +449,19 @@ hb_set_next (const hb_set_t *set,
return
set
->
next
(
codepoint
);
return
set
->
next
(
codepoint
);
}
}
/**
* hb_set_next_range:
* @set: a set.
* @first: (out): output first codepoint in the range.
* @last: (inout): input current last and output last codepoint in the range.
*
* Gets the next consecutive range of numbers in @set that
* are greater than current value of @last.
*
* Return value: whether there was a next range.
*
* Since: 1.0
**/
hb_bool_t
hb_bool_t
hb_set_next_range
(
const
hb_set_t
*
set
,
hb_set_next_range
(
const
hb_set_t
*
set
,
hb_codepoint_t
*
first
,
hb_codepoint_t
*
first
,
...
...
src/hb-set.h
浏览文件 @
20cbc1f8
...
@@ -36,6 +36,8 @@
...
@@ -36,6 +36,8 @@
HB_BEGIN_DECLS
HB_BEGIN_DECLS
#define HB_SET_VALUE_INVALID ((hb_codepoint_t) -1)
typedef
struct
hb_set_t
hb_set_t
;
typedef
struct
hb_set_t
hb_set_t
;
...
...
src/hb-version.h.in
浏览文件 @
20cbc1f8
...
@@ -56,7 +56,7 @@ HB_BEGIN_DECLS
...
@@ -56,7 +56,7 @@ HB_BEGIN_DECLS
* Returns library version as three integer components.
* Returns library version as three integer components.
*
*
* Since: 1.0
* Since: 1.0
*/
*
*
/
void
void
hb_version (unsigned int *major,
hb_version (unsigned int *major,
unsigned int *minor,
unsigned int *minor,
...
@@ -67,8 +67,10 @@ hb_version (unsigned int *major,
...
@@ -67,8 +67,10 @@ hb_version (unsigned int *major,
*
*
* Returns library version as a string with three components.
* Returns library version as a string with three components.
*
*
* Return value: library version string.
*
* Since: 1.0
* Since: 1.0
*/
*
*
/
const char *
const char *
hb_version_string (void);
hb_version_string (void);
...
...
test/api/test-set.c
浏览文件 @
20cbc1f8
...
@@ -32,24 +32,24 @@
...
@@ -32,24 +32,24 @@
static
void
static
void
test_empty
(
hb_set_t
*
s
)
test_empty
(
hb_set_t
*
s
)
{
{
hb_codepoint_t
next
=
(
hb_codepoint_t
)
-
1
;
hb_codepoint_t
next
=
HB_SET_VALUE_INVALID
;
g_assert_cmpint
(
hb_set_get_population
(
s
),
==
,
0
);
g_assert_cmpint
(
hb_set_get_population
(
s
),
==
,
0
);
g_assert_cmpint
(
hb_set_get_min
(
s
),
==
,
(
hb_codepoint_t
)
-
1
);
g_assert_cmpint
(
hb_set_get_min
(
s
),
==
,
HB_SET_VALUE_INVALID
);
g_assert_cmpint
(
hb_set_get_max
(
s
),
==
,
(
hb_codepoint_t
)
-
1
);
g_assert_cmpint
(
hb_set_get_max
(
s
),
==
,
HB_SET_VALUE_INVALID
);
g_assert
(
!
hb_set_has
(
s
,
13
));
g_assert
(
!
hb_set_has
(
s
,
13
));
g_assert
(
!
hb_set_next
(
s
,
&
next
));
g_assert
(
!
hb_set_next
(
s
,
&
next
));
g_assert_cmpint
(
next
,
==
,
(
hb_codepoint_t
)
-
1
);
g_assert_cmpint
(
next
,
==
,
HB_SET_VALUE_INVALID
);
}
}
static
void
static
void
test_not_empty
(
hb_set_t
*
s
)
test_not_empty
(
hb_set_t
*
s
)
{
{
hb_codepoint_t
next
=
(
hb_codepoint_t
)
-
1
;
hb_codepoint_t
next
=
HB_SET_VALUE_INVALID
;
g_assert_cmpint
(
hb_set_get_population
(
s
),
!=
,
0
);
g_assert_cmpint
(
hb_set_get_population
(
s
),
!=
,
0
);
g_assert_cmpint
(
hb_set_get_min
(
s
),
!=
,
(
hb_codepoint_t
)
-
1
);
g_assert_cmpint
(
hb_set_get_min
(
s
),
!=
,
HB_SET_VALUE_INVALID
);
g_assert_cmpint
(
hb_set_get_max
(
s
),
!=
,
(
hb_codepoint_t
)
-
1
);
g_assert_cmpint
(
hb_set_get_max
(
s
),
!=
,
HB_SET_VALUE_INVALID
);
g_assert
(
hb_set_next
(
s
,
&
next
));
g_assert
(
hb_set_next
(
s
,
&
next
));
g_assert_cmpint
(
next
,
!=
,
(
hb_codepoint_t
)
-
1
);
g_assert_cmpint
(
next
,
!=
,
HB_SET_VALUE_INVALID
);
}
}
static
void
static
void
...
@@ -166,7 +166,7 @@ test_set_iter (void)
...
@@ -166,7 +166,7 @@ test_set_iter (void)
test_not_empty
(
s
);
test_not_empty
(
s
);
next
=
(
hb_codepoint_t
)
-
1
;
next
=
HB_SET_VALUE_INVALID
;
g_assert
(
hb_set_next
(
s
,
&
next
));
g_assert
(
hb_set_next
(
s
,
&
next
));
g_assert_cmpint
(
next
,
==
,
6
);
g_assert_cmpint
(
next
,
==
,
6
);
g_assert
(
hb_set_next
(
s
,
&
next
));
g_assert
(
hb_set_next
(
s
,
&
next
));
...
@@ -181,9 +181,9 @@ test_set_iter (void)
...
@@ -181,9 +181,9 @@ test_set_iter (void)
g_assert
(
hb_set_next
(
s
,
&
next
));
g_assert
(
hb_set_next
(
s
,
&
next
));
g_assert_cmpint
(
next
,
==
,
20005
);
g_assert_cmpint
(
next
,
==
,
20005
);
g_assert
(
!
hb_set_next
(
s
,
&
next
));
g_assert
(
!
hb_set_next
(
s
,
&
next
));
g_assert_cmpint
(
next
,
==
,
20005
);
g_assert_cmpint
(
next
,
==
,
HB_SET_VALUE_INVALID
);
first
=
last
=
(
hb_codepoint_t
)
-
1
;
first
=
last
=
HB_SET_VALUE_INVALID
;
g_assert
(
hb_set_next_range
(
s
,
&
first
,
&
last
));
g_assert
(
hb_set_next_range
(
s
,
&
first
,
&
last
));
g_assert_cmpint
(
first
,
==
,
6
);
g_assert_cmpint
(
first
,
==
,
6
);
g_assert_cmpint
(
last
,
==
,
6
);
g_assert_cmpint
(
last
,
==
,
6
);
...
@@ -194,8 +194,8 @@ test_set_iter (void)
...
@@ -194,8 +194,8 @@ test_set_iter (void)
g_assert_cmpint
(
first
,
==
,
20005
);
g_assert_cmpint
(
first
,
==
,
20005
);
g_assert_cmpint
(
last
,
==
,
20005
);
g_assert_cmpint
(
last
,
==
,
20005
);
g_assert
(
!
hb_set_next_range
(
s
,
&
first
,
&
last
));
g_assert
(
!
hb_set_next_range
(
s
,
&
first
,
&
last
));
g_assert_cmpint
(
first
,
==
,
20005
);
g_assert_cmpint
(
first
,
==
,
HB_SET_VALUE_INVALID
);
g_assert_cmpint
(
last
,
==
,
20005
);
g_assert_cmpint
(
last
,
==
,
HB_SET_VALUE_INVALID
);
}
}
static
void
static
void
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录