Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
fe14a400
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,发现更多精彩内容 >>
提交
fe14a400
编写于
5月 08, 2019
作者:
B
Behdad Esfahbod
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Adjust hb_all/any/none
上级
4a101d8f
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
15 addition
and
13 deletion
+15
-13
src/hb-iter.hh
src/hb-iter.hh
+9
-9
src/test-iter.cc
src/test-iter.cc
+6
-4
未找到文件。
src/hb-iter.hh
浏览文件 @
fe14a400
...
...
@@ -649,15 +649,15 @@ HB_FUNCOBJ (hb_unzip);
struct
{
template
<
typename
Iterable
,
typename
Val
=
bool
,
typename
Pred
=
decltype
((
hb_bool
))
,
typename
Proj
=
decltype
((
hb_identity
)),
hb_requires
(
hb_is_iterable
(
Iterable
))>
bool
operator
()
(
Iterable
&&
c
,
Val
v
=
true
,
Pred
&&
p
=
hb_bool
,
Proj
&&
f
=
hb_identity
)
const
{
for
(
auto
it
=
hb_iter
(
c
);
it
;
++
it
)
if
(
!
((
Val
)
hb_get
(
hb_forward
<
Proj
>
(
f
),
*
it
)
==
v
))
if
(
!
hb_match
(
hb_forward
<
Pred
>
(
p
),
hb_get
(
hb_forward
<
Proj
>
(
f
),
*
it
)
))
return
false
;
return
true
;
}
...
...
@@ -666,15 +666,15 @@ HB_FUNCOBJ (hb_all);
struct
{
template
<
typename
Iterable
,
typename
Val
=
bool
,
typename
Pred
=
decltype
((
hb_bool
))
,
typename
Proj
=
decltype
((
hb_identity
)),
hb_requires
(
hb_is_iterable
(
Iterable
))>
bool
operator
()
(
Iterable
&&
c
,
Val
v
=
true
,
Pred
&&
p
=
hb_bool
,
Proj
&&
f
=
hb_identity
)
const
{
for
(
auto
it
=
hb_iter
(
c
);
it
;
++
it
)
if
(
((
Val
)
hb_get
(
hb_forward
<
Proj
>
(
f
),
*
it
)
==
v
))
if
(
hb_match
(
hb_forward
<
Pred
>
(
p
),
hb_get
(
hb_forward
<
Proj
>
(
f
),
*
it
)
))
return
true
;
return
false
;
}
...
...
@@ -683,15 +683,15 @@ HB_FUNCOBJ (hb_any);
struct
{
template
<
typename
Iterable
,
typename
Val
=
bool
,
typename
Pred
=
decltype
((
hb_bool
))
,
typename
Proj
=
decltype
((
hb_identity
)),
hb_requires
(
hb_is_iterable
(
Iterable
))>
bool
operator
()
(
Iterable
&&
c
,
Val
v
=
true
,
Pred
&&
p
=
hb_bool
,
Proj
&&
f
=
hb_identity
)
const
{
for
(
auto
it
=
hb_iter
(
c
);
it
;
++
it
)
if
(
((
Val
)
hb_get
(
hb_forward
<
Proj
>
(
f
),
*
it
)
==
v
))
if
(
hb_match
(
hb_forward
<
Pred
>
(
p
),
hb_get
(
hb_forward
<
Proj
>
(
f
),
*
it
)
))
return
false
;
return
true
;
}
...
...
src/test-iter.cc
浏览文件 @
fe14a400
...
...
@@ -166,11 +166,13 @@ main (int argc, char **argv)
assert
(
true
==
hb_all
(
st
));
assert
(
false
==
hb_all
(
st
,
42u
));
assert
(
true
==
hb_any
(
st
));
assert
(
false
==
hb_any
(
st
,
14
));
assert
(
true
==
hb_any
(
st
,
15
));
assert
(
false
==
hb_any
(
st
,
14u
));
assert
(
true
==
hb_any
(
st
,
14u
,
[]
(
unsigned
_
)
{
return
_
-
1u
;
}));
assert
(
true
==
hb_any
(
st
,
[]
(
unsigned
_
)
{
return
_
==
15u
;
}));
assert
(
true
==
hb_any
(
st
,
15u
));
assert
(
false
==
hb_none
(
st
));
assert
(
false
==
hb_none
(
st
,
15
));
assert
(
true
==
hb_none
(
st
,
17
));
assert
(
false
==
hb_none
(
st
,
15
u
));
assert
(
true
==
hb_none
(
st
,
17
u
));
hb_array_t
<
hb_vector_t
<
int
>>
pa
;
pa
->
as_array
();
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录