Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
e799004e
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看板
提交
e799004e
编写于
1月 29, 2019
作者:
B
Behdad Esfahbod
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[iter] Whitespace
上级
849a0f17
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
14 addition
and
9 deletion
+14
-9
src/hb-iter.hh
src/hb-iter.hh
+14
-9
未找到文件。
src/hb-iter.hh
浏览文件 @
e799004e
...
...
@@ -240,7 +240,8 @@ operator | (Lhs lhs, const Rhs &rhs) { return rhs (lhs); }
template
<
typename
Iter
,
typename
Proj
,
hb_enable_if
(
hb_is_iterator
(
Iter
))>
struct
hb_map_iter_t
:
hb_iter_t
<
hb_map_iter_t
<
Iter
,
Proj
>
,
decltype
(
hb_declval
(
Proj
)
(
hb_declval
(
typename
Iter
::
item_t
)))
>
hb_iter_t
<
hb_map_iter_t
<
Iter
,
Proj
>
,
decltype
(
hb_declval
(
Proj
)
(
hb_declval
(
typename
Iter
::
item_t
)))
>
{
hb_map_iter_t
(
const
Iter
&
it
,
Proj
&&
f
)
:
it
(
it
),
f
(
f
)
{}
...
...
@@ -267,7 +268,8 @@ struct hb_map_iter_factory_t
template
<
typename
Iterable
,
hb_enable_if
(
hb_is_iterable
(
Iterable
))>
hb_map_iter_t
<
hb_iter_t
(
Iterable
),
Proj
>
operator
()
(
const
Iterable
&
c
)
const
hb_map_iter_t
<
hb_iter_t
(
Iterable
),
Proj
>
operator
()
(
const
Iterable
&
c
)
const
{
return
hb_map_iter_t
<
hb_iter_t
(
Iterable
),
Proj
>
(
c
.
iter
(),
f
);
}
private:
...
...
@@ -306,14 +308,16 @@ struct hb_filter_iter_factory_t
template
<
typename
Iterable
,
hb_enable_if
(
hb_is_iterable
(
Iterable
))>
hb_filter_iter_t
<
hb_iter_t
(
Iterable
),
Pred
,
Proj
>
operator
()
(
const
Iterable
&
c
)
const
hb_filter_iter_t
<
hb_iter_t
(
Iterable
),
Pred
,
Proj
>
operator
()
(
const
Iterable
&
c
)
const
{
return
hb_filter_iter_t
<
hb_iter_t
(
Iterable
),
Pred
,
Proj
>
(
c
.
iter
(),
p
,
f
);
}
private:
Pred
p
;
Proj
f
;
};
template
<
typename
Pred
=
decltype
((
hb_bool
)),
typename
Proj
=
decltype
((
hb_identity
))>
template
<
typename
Pred
=
decltype
((
hb_bool
)),
typename
Proj
=
decltype
((
hb_identity
))>
inline
hb_filter_iter_factory_t
<
Pred
,
Proj
>
hb_filter
(
Pred
&&
p
=
hb_bool
,
Proj
&&
f
=
hb_identity
)
{
return
hb_filter_iter_factory_t
<
Pred
,
Proj
>
(
p
,
f
);
}
...
...
@@ -322,18 +326,19 @@ hb_filter (Pred&& p = hb_bool, Proj&& f = hb_identity)
template
<
typename
A
,
typename
B
>
struct
hb_zip_iter_t
:
hb_iter_t
<
hb_zip_iter_t
<
A
,
B
>
,
hb_pair_t
<
typename
A
::
item_t
,
typename
B
::
item_t
>
>
hb_iter_t
<
hb_zip_iter_t
<
A
,
B
>
,
hb_pair_t
<
typename
A
::
item_t
,
typename
B
::
item_t
>
>
{
hb_zip_iter_t
()
{}
hb_zip_iter_t
(
A
a
,
B
b
)
:
a
(
a
),
b
(
b
)
{}
typedef
hb_pair_t
<
typename
A
::
item_t
,
typename
B
::
item_t
>
__item_t__
;
static
constexpr
bool
is_random_access_iterator
=
A
::
is_random_access_iterator
&&
B
::
is_random_access_iterator
;
A
::
is_random_access_iterator
&&
B
::
is_random_access_iterator
;
static
constexpr
bool
is_sorted_iterator
=
A
::
is_sorted_iterator
&&
B
::
is_sorted_iterator
;
A
::
is_sorted_iterator
&&
B
::
is_sorted_iterator
;
__item_t__
__item__
()
const
{
return
__item_t__
(
*
a
,
*
b
);
}
__item_t__
__item_at__
(
unsigned
i
)
const
{
return
__item_t__
(
a
[
i
],
b
[
i
]);
}
bool
__more__
()
const
{
return
a
&&
b
;
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录