Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
eca8e337
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看板
提交
eca8e337
编写于
5月 17, 2009
作者:
B
Behdad Esfahbod
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[GSUB] Further optimize the main switch
上级
13068232
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
17 addition
and
14 deletion
+17
-14
src/hb-ot-layout-gsub-private.h
src/hb-ot-layout-gsub-private.h
+17
-14
未找到文件。
src/hb-ot-layout-gsub-private.h
浏览文件 @
eca8e337
...
...
@@ -735,11 +735,8 @@ struct SubstLookupSubTable {
friend
struct
SubstLookup
;
inline
bool
substitute
(
LOOKUP_ARGS_DEF
,
unsigned
int
lookup_type
)
const
{
unsigned
int
property
;
if
(
!
_hb_ot_layout_check_glyph_property
(
layout
,
IN_CURITEM
(),
lookup_flag
,
&
property
))
return
false
;
unsigned
int
property
,
unsigned
int
lookup_type
)
const
{
switch
(
lookup_type
)
{
case
GSUB_Single
:
return
u
.
single
.
substitute
(
LOOKUP_ARGS
,
property
);
...
...
@@ -805,23 +802,21 @@ struct SubstLookup : Lookup {
}
}
bool
substitute_once
(
hb_ot_layout_t
*
layout
,
hb_buffer_t
*
buffer
,
unsigned
int
context_length
,
unsigned
int
nesting_level_left
)
const
{
inline
bool
substitute_once
(
hb_ot_layout_t
*
layout
,
hb_buffer_t
*
buffer
,
unsigned
int
context_length
,
unsigned
int
nesting_level_left
)
const
{
unsigned
int
lookup_type
=
get_type
();
unsigned
int
lookup_flag
=
get_flag
();
if
(
HB_UNLIKELY
(
nesting_level_left
==
0
))
return
false
;
nesting_level_left
--
;
if
(
HB_UNLIKELY
(
context_length
<
1
))
unsigned
int
property
;
if
(
!
_hb_ot_layout_check_glyph_property
(
layout
,
IN_CURITEM
(),
lookup_flag
,
&
property
))
return
false
;
for
(
unsigned
int
i
=
0
;
i
<
get_subtable_count
();
i
++
)
if
(
get_subtable
(
i
).
substitute
(
LOOKUP_ARGS
,
property
,
lookup_type
))
return
true
;
...
...
@@ -903,6 +898,7 @@ inline bool ExtensionSubstFormat1::substitute (LOOKUP_ARGS_DEF, unsigned int pro
/* XXX either check in sanitize or here that the lookuptype is not 7 again,
* or we can loop indefinitely. */
return
(
*
(
SubstLookupSubTable
*
)(((
char
*
)
this
)
+
extensionOffset
)).
substitute
(
LOOKUP_ARGS
,
property
,
get_type
());
}
...
...
@@ -910,6 +906,13 @@ static inline bool substitute_lookup (LOOKUP_ARGS_DEF, unsigned int lookup_index
const
GSUB
&
gsub
=
*
(
layout
->
gsub
);
const
SubstLookup
&
l
=
gsub
.
get_lookup
(
lookup_index
);
if
(
HB_UNLIKELY
(
nesting_level_left
==
0
))
return
false
;
nesting_level_left
--
;
if
(
HB_UNLIKELY
(
context_length
<
1
))
return
false
;
return
l
.
substitute_once
(
layout
,
buffer
,
context_length
,
nesting_level_left
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录