Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
13068232
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,发现更多精彩内容 >>
提交
13068232
编写于
5月 17, 2009
作者:
B
Behdad Esfahbod
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[HB] Unify first glyph property checking
上级
66bf7ce4
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
35 addition
and
58 deletion
+35
-58
src/hb-ot-layout-gsub-private.h
src/hb-ot-layout-gsub-private.h
+35
-46
src/hb-ot-layout-gsubgpos-private.h
src/hb-ot-layout-gsubgpos-private.h
+0
-12
未找到文件。
src/hb-ot-layout-gsub-private.h
浏览文件 @
13068232
...
...
@@ -98,11 +98,7 @@ struct SingleSubst {
}
}
inline
bool
substitute
(
LOOKUP_ARGS_DEF
)
const
{
unsigned
int
property
;
if
(
!
_hb_ot_layout_check_glyph_property
(
layout
,
IN_CURITEM
(),
lookup_flag
,
&
property
))
return
false
;
inline
bool
substitute
(
LOOKUP_ARGS_DEF
,
unsigned
int
property
)
const
{
hb_codepoint_t
glyph_id
=
IN_CURGLYPH
();
...
...
@@ -177,11 +173,7 @@ struct MultipleSubstFormat1 {
private:
inline
bool
substitute
(
LOOKUP_ARGS_DEF
)
const
{
unsigned
int
property
;
if
(
!
_hb_ot_layout_check_glyph_property
(
layout
,
IN_CURITEM
(),
lookup_flag
,
&
property
))
return
false
;
inline
bool
substitute
(
LOOKUP_ARGS_DEF
,
unsigned
int
property
)
const
{
unsigned
int
index
=
(
this
+
coverage
)
(
IN_CURGLYPH
());
return
(
this
+
sequence
[
index
]).
substitute_sequence
(
LOOKUP_ARGS
,
property
);
...
...
@@ -204,9 +196,9 @@ struct MultipleSubst {
private:
inline
bool
substitute
(
LOOKUP_ARGS_DEF
)
const
{
inline
bool
substitute
(
LOOKUP_ARGS_DEF
,
unsigned
int
property
)
const
{
switch
(
u
.
substFormat
)
{
case
1
:
return
u
.
format1
.
substitute
(
LOOKUP_ARGS
);
case
1
:
return
u
.
format1
.
substitute
(
LOOKUP_ARGS
,
property
);
default:
return
false
;
}
}
...
...
@@ -230,11 +222,7 @@ struct AlternateSubstFormat1 {
private:
inline
bool
substitute
(
LOOKUP_ARGS_DEF
)
const
{
unsigned
int
property
;
if
(
!
_hb_ot_layout_check_glyph_property
(
layout
,
IN_CURITEM
(),
lookup_flag
,
&
property
))
return
false
;
inline
bool
substitute
(
LOOKUP_ARGS_DEF
,
unsigned
int
property
)
const
{
hb_codepoint_t
glyph_id
=
IN_CURGLYPH
();
...
...
@@ -286,9 +274,9 @@ struct AlternateSubst {
private:
inline
bool
substitute
(
LOOKUP_ARGS_DEF
)
const
{
inline
bool
substitute
(
LOOKUP_ARGS_DEF
,
unsigned
int
property
)
const
{
switch
(
u
.
substFormat
)
{
case
1
:
return
u
.
format1
.
substitute
(
LOOKUP_ARGS
);
case
1
:
return
u
.
format1
.
substitute
(
LOOKUP_ARGS
,
property
);
default:
return
false
;
}
}
...
...
@@ -415,11 +403,7 @@ struct LigatureSubstFormat1 {
private:
inline
bool
substitute
(
LOOKUP_ARGS_DEF
)
const
{
unsigned
int
property
;
if
(
!
_hb_ot_layout_check_glyph_property
(
layout
,
IN_CURITEM
(),
lookup_flag
,
&
property
))
return
false
;
inline
bool
substitute
(
LOOKUP_ARGS_DEF
,
unsigned
int
property
)
const
{
hb_codepoint_t
glyph_id
=
IN_CURGLYPH
();
...
...
@@ -448,9 +432,9 @@ struct LigatureSubst {
private:
inline
bool
substitute
(
LOOKUP_ARGS_DEF
)
const
{
inline
bool
substitute
(
LOOKUP_ARGS_DEF
,
unsigned
int
property
)
const
{
switch
(
u
.
substFormat
)
{
case
1
:
return
u
.
format1
.
substitute
(
LOOKUP_ARGS
);
case
1
:
return
u
.
format1
.
substitute
(
LOOKUP_ARGS
,
property
);
default:
return
false
;
}
}
...
...
@@ -469,7 +453,7 @@ static inline bool substitute_lookup (LOOKUP_ARGS_DEF, unsigned int lookup_index
struct
ContextSubst
:
Context
{
inline
bool
substitute
(
LOOKUP_ARGS_DEF
)
const
{
inline
bool
substitute
(
LOOKUP_ARGS_DEF
,
unsigned
int
property
)
const
{
return
this
->
apply
(
LOOKUP_ARGS
,
substitute_lookup
);
}
};
...
...
@@ -516,7 +500,7 @@ ASSERT_SIZE (ChainSubRuleSet, 2);
struct
ChainContextSubstFormat1
{
/* TODO */
inline
bool
substitute
(
LOOKUP_ARGS_DEF
)
const
{
inline
bool
substitute
(
LOOKUP_ARGS_DEF
,
unsigned
int
property
)
const
{
return
false
;
}
...
...
@@ -576,7 +560,7 @@ ASSERT_SIZE (ChainSubClassSet, 2);
struct
ChainContextSubstFormat2
{
/* TODO */
inline
bool
substitute
(
LOOKUP_ARGS_DEF
)
const
{
inline
bool
substitute
(
LOOKUP_ARGS_DEF
,
unsigned
int
property
)
const
{
return
false
;
}
...
...
@@ -606,7 +590,7 @@ ASSERT_SIZE (ChainContextSubstFormat2, 12);
struct
ChainContextSubstFormat3
{
/* TODO */
inline
bool
substitute
(
LOOKUP_ARGS_DEF
)
const
{
inline
bool
substitute
(
LOOKUP_ARGS_DEF
,
unsigned
int
property
)
const
{
return
false
;
}
...
...
@@ -638,11 +622,11 @@ struct ChainContextSubst {
private:
inline
bool
substitute
(
LOOKUP_ARGS_DEF
)
const
{
inline
bool
substitute
(
LOOKUP_ARGS_DEF
,
unsigned
int
property
)
const
{
switch
(
u
.
substFormat
)
{
case
1
:
return
u
.
format1
.
substitute
(
LOOKUP_ARGS
);
case
2
:
return
u
.
format2
.
substitute
(
LOOKUP_ARGS
);
case
3
:
return
u
.
format3
.
substitute
(
LOOKUP_ARGS
);
case
1
:
return
u
.
format1
.
substitute
(
LOOKUP_ARGS
,
property
);
case
2
:
return
u
.
format2
.
substitute
(
LOOKUP_ARGS
,
property
);
case
3
:
return
u
.
format3
.
substitute
(
LOOKUP_ARGS
,
property
);
default:
return
false
;
}
}
...
...
@@ -664,7 +648,7 @@ struct ExtensionSubstFormat1 {
private:
inline
unsigned
int
get_type
(
void
)
const
{
return
extensionLookupType
;
}
inline
bool
substitute
(
LOOKUP_ARGS_DEF
)
const
;
inline
bool
substitute
(
LOOKUP_ARGS_DEF
,
unsigned
int
property
)
const
;
private:
USHORT
substFormat
;
/* Format identifier. Set to 1. */
...
...
@@ -690,9 +674,9 @@ struct ExtensionSubst {
}
}
inline
bool
substitute
(
LOOKUP_ARGS_DEF
)
const
{
inline
bool
substitute
(
LOOKUP_ARGS_DEF
,
unsigned
int
property
)
const
{
switch
(
u
.
substFormat
)
{
case
1
:
return
u
.
format1
.
substitute
(
LOOKUP_ARGS
);
case
1
:
return
u
.
format1
.
substitute
(
LOOKUP_ARGS
,
property
);
default:
return
false
;
}
}
...
...
@@ -752,18 +736,23 @@ struct SubstLookupSubTable {
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
;
switch
(
lookup_type
)
{
case
GSUB_Single
:
return
u
.
single
.
substitute
(
LOOKUP_ARGS
);
case
GSUB_Multiple
:
return
u
.
multiple
.
substitute
(
LOOKUP_ARGS
);
case
GSUB_Alternate
:
return
u
.
alternate
.
substitute
(
LOOKUP_ARGS
);
case
GSUB_Ligature
:
return
u
.
ligature
.
substitute
(
LOOKUP_ARGS
);
case
GSUB_Context
:
return
u
.
context
.
substitute
(
LOOKUP_ARGS
);
case
GSUB_Single
:
return
u
.
single
.
substitute
(
LOOKUP_ARGS
,
property
);
case
GSUB_Multiple
:
return
u
.
multiple
.
substitute
(
LOOKUP_ARGS
,
property
);
case
GSUB_Alternate
:
return
u
.
alternate
.
substitute
(
LOOKUP_ARGS
,
property
);
case
GSUB_Ligature
:
return
u
.
ligature
.
substitute
(
LOOKUP_ARGS
,
property
);
case
GSUB_Context
:
return
u
.
context
.
substitute
(
LOOKUP_ARGS
,
property
);
/*
case GSUB_ChainingContext: return u.chainingContext.substitute (LOOKUP_ARGS);
case GSUB_ChainingContext: return u.chainingContext.substitute (LOOKUP_ARGS
, property
);
*/
case
GSUB_Extension
:
return
u
.
extension
.
substitute
(
LOOKUP_ARGS
);
case
GSUB_Extension
:
return
u
.
extension
.
substitute
(
LOOKUP_ARGS
,
property
);
/*
case GSUB_ReverseChainingContextSingle: return u.reverseChainingContextSingle.substitute (LOOKUP_ARGS);
case GSUB_ReverseChainingContextSingle: return u.reverseChainingContextSingle.substitute (LOOKUP_ARGS
, property
);
*/
default:
return
false
;
}
...
...
@@ -910,7 +899,7 @@ struct GSUB : GSUBGPOS {
/* Out-of-class implementation for methods chaining */
inline
bool
ExtensionSubstFormat1
::
substitute
(
LOOKUP_ARGS_DEF
)
const
{
inline
bool
ExtensionSubstFormat1
::
substitute
(
LOOKUP_ARGS_DEF
,
unsigned
int
property
)
const
{
/* 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
,
...
...
src/hb-ot-layout-gsubgpos-private.h
浏览文件 @
13068232
...
...
@@ -198,10 +198,6 @@ struct ContextFormat1 {
inline
bool
apply
(
LOOKUP_ARGS_DEF
,
apply_lookup_func_t
apply_func
)
const
{
unsigned
int
property
;
if
(
!
_hb_ot_layout_check_glyph_property
(
layout
,
IN_CURITEM
(),
lookup_flag
,
&
property
))
return
false
;
unsigned
int
index
=
(
this
+
coverage
)
(
IN_CURGLYPH
());
const
RuleSet
&
rule_set
=
this
+
ruleSet
[
index
];
struct
ContextLookupContext
context
=
{
...
...
@@ -236,10 +232,6 @@ struct ContextFormat2 {
inline
bool
apply
(
LOOKUP_ARGS_DEF
,
apply_lookup_func_t
apply_func
)
const
{
unsigned
int
property
;
if
(
!
_hb_ot_layout_check_glyph_property
(
layout
,
IN_CURITEM
(),
lookup_flag
,
&
property
))
return
false
;
unsigned
int
index
=
(
this
+
coverage
)
(
IN_CURGLYPH
());
const
RuleSet
&
rule_set
=
this
+
ruleSet
[
index
];
/* LONGTERMTODO: Old code fetches glyph classes at most once and caches
...
...
@@ -297,10 +289,6 @@ struct ContextFormat3 {
inline
bool
apply
(
LOOKUP_ARGS_DEF
,
apply_lookup_func_t
apply_func
)
const
{
unsigned
int
property
;
if
(
!
_hb_ot_layout_check_glyph_property
(
layout
,
IN_CURITEM
(),
lookup_flag
,
&
property
))
return
false
;
if
((
*
this
)[
0
].
get_coverage
(
IN_CURGLYPH
()
==
NOT_COVERED
))
return
false
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录