Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
c4e71ff3
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看板
提交
c4e71ff3
编写于
10月 17, 2013
作者:
B
Behdad Esfahbod
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[indic] Clean up Khmer and Sinhala base finding algorithm
上级
e10453e6
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
11 addition
and
13 deletion
+11
-13
src/hb-ot-shape-complex-indic.cc
src/hb-ot-shape-complex-indic.cc
+11
-13
未找到文件。
src/hb-ot-shape-complex-indic.cc
浏览文件 @
c4e71ff3
...
...
@@ -128,14 +128,6 @@ static const hb_codepoint_t ra_chars[] = {
0x179A
,
/* Khmer */
/* No Reph, Visual Repha */
};
static
inline
indic_position_t
consonant_position
(
hb_codepoint_t
u
)
{
if
((
u
&
~
0x007F
)
==
0x1780
)
return
POS_BELOW_C
;
/* In Khmer coeng model, post and below forms should not be reordered. */
return
POS_BASE_C
;
/* Will recategorize later based on font lookups. */
}
static
inline
bool
is_ra
(
hb_codepoint_t
u
)
{
...
...
@@ -241,7 +233,7 @@ set_indic_properties (hb_glyph_info_t &info)
if
((
FLAG
(
cat
)
&
CONSONANT_FLAGS
))
{
pos
=
consonant_position
(
u
)
;
pos
=
POS_BASE_C
;
if
(
is_ra
(
u
))
cat
=
OT_Ra
;
}
...
...
@@ -654,6 +646,9 @@ update_consonant_positions (const hb_ot_shape_plan_t *plan,
{
const
indic_shape_plan_t
*
indic_plan
=
(
const
indic_shape_plan_t
*
)
plan
->
data
;
if
(
indic_plan
->
config
->
base_pos
!=
BASE_POS_LAST
)
return
;
hb_codepoint_t
glyphs
[
2
];
if
(
indic_plan
->
get_virama_glyph
(
font
,
&
glyphs
[
0
]))
{
...
...
@@ -786,7 +781,10 @@ initial_reordering_consonant_syllable (const hb_ot_shape_plan_t *plan,
case
BASE_POS_LAST_SINHALA
:
{
/* In scripts without half forms (eg. Khmer), the first consonant is always the base. */
/* Sinhala base positioning is slightly different from main Indic, in that:
* 1. It's ZWJ behavior is different,
* 2. We don't need to look into the font for consonant positions.
*/
if
(
!
has_reph
)
base
=
limit
;
...
...
@@ -794,7 +792,7 @@ initial_reordering_consonant_syllable (const hb_ot_shape_plan_t *plan,
/* Find the last base consonant that is not blocked by ZWJ. If there is
* a ZWJ right before a base consonant, that would request a subjoined form. */
for
(
unsigned
int
i
=
limit
;
i
<
end
;
i
++
)
if
(
is_consonant
(
info
[
i
])
&&
info
[
i
].
indic_position
()
==
POS_BASE_C
)
if
(
is_consonant
(
info
[
i
]))
{
if
(
limit
<
i
&&
info
[
i
-
1
].
indic_category
()
==
OT_ZWJ
)
break
;
...
...
@@ -804,7 +802,7 @@ initial_reordering_consonant_syllable (const hb_ot_shape_plan_t *plan,
/* Mark all subsequent consonants as below. */
for
(
unsigned
int
i
=
base
+
1
;
i
<
end
;
i
++
)
if
(
is_consonant
(
info
[
i
])
&&
info
[
i
].
indic_position
()
==
POS_BASE_C
)
if
(
is_consonant
(
info
[
i
]))
info
[
i
].
indic_position
()
=
POS_BELOW_C
;
}
break
;
...
...
@@ -819,7 +817,7 @@ initial_reordering_consonant_syllable (const hb_ot_shape_plan_t *plan,
/* Mark all subsequent consonants as below. */
for
(
unsigned
int
i
=
base
+
1
;
i
<
end
;
i
++
)
if
(
is_consonant
(
info
[
i
])
&&
info
[
i
].
indic_position
()
==
POS_BASE_C
)
if
(
is_consonant
(
info
[
i
]))
info
[
i
].
indic_position
()
=
POS_BELOW_C
;
}
break
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录