Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
10823385
T
Third Party Harfbuzz
项目概览
OpenHarmony
/
Third Party Harfbuzz
接近 2 年 前同步成功
通知
1
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看板
提交
10823385
编写于
11月 12, 2018
作者:
B
Behdad Esfahbod
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[shape-plan] Only use shape-plan key to initialize hb_ot_shape_plan_t
Such that we don't accidentally use info not in the cache key.
上级
7ac03f88
变更
3
隐藏空白更改
内联
并排
Showing
3 changed file
with
15 addition
and
25 deletion
+15
-25
src/hb-ot-shape.cc
src/hb-ot-shape.cc
+11
-14
src/hb-ot-shape.hh
src/hb-ot-shape.hh
+3
-5
src/hb-shape-plan.cc
src/hb-shape-plan.cc
+1
-6
未找到文件。
src/hb-ot-shape.cc
浏览文件 @
10823385
...
@@ -53,7 +53,6 @@
...
@@ -53,7 +53,6 @@
static
void
static
void
hb_ot_shape_collect_features
(
hb_ot_shape_planner_t
*
planner
,
hb_ot_shape_collect_features
(
hb_ot_shape_planner_t
*
planner
,
const
hb_segment_properties_t
*
props
,
const
hb_feature_t
*
user_features
,
const
hb_feature_t
*
user_features
,
unsigned
int
num_user_features
);
unsigned
int
num_user_features
);
...
@@ -150,21 +149,20 @@ hb_ot_shape_planner_t::compile (hb_ot_shape_plan_t &plan,
...
@@ -150,21 +149,20 @@ hb_ot_shape_planner_t::compile (hb_ot_shape_plan_t &plan,
bool
bool
hb_ot_shape_plan_t
::
init0
(
hb_face_t
*
face
,
hb_ot_shape_plan_t
::
init0
(
hb_face_t
*
face
,
const
hb_segment_properties_t
*
props
,
const
hb_shape_plan_key_t
*
key
)
const
hb_feature_t
*
user_features
,
unsigned
int
num_user_features
,
const
int
*
coords
,
unsigned
int
num_coords
)
{
{
map
.
init
();
map
.
init
();
aat_map
.
init
();
aat_map
.
init
();
hb_ot_shape_planner_t
planner
(
face
,
props
);
hb_ot_shape_planner_t
planner
(
face
,
&
key
->
props
);
hb_ot_shape_collect_features
(
&
planner
,
key
->
user_features
,
key
->
num_user_features
);
hb_ot_shape_collect_features
(
&
planner
,
props
,
planner
.
compile
(
*
this
,
user_features
,
num_user_features
);
key
->
coords
,
key
->
num_coords
);
planner
.
compile
(
*
this
,
coords
,
num_coords
);
if
(
shaper
->
data_create
)
if
(
shaper
->
data_create
)
{
{
...
@@ -211,7 +209,6 @@ horizontal_features[] =
...
@@ -211,7 +209,6 @@ horizontal_features[] =
static
void
static
void
hb_ot_shape_collect_features
(
hb_ot_shape_planner_t
*
planner
,
hb_ot_shape_collect_features
(
hb_ot_shape_planner_t
*
planner
,
const
hb_segment_properties_t
*
props
,
const
hb_feature_t
*
user_features
,
const
hb_feature_t
*
user_features
,
unsigned
int
num_user_features
)
unsigned
int
num_user_features
)
{
{
...
@@ -220,7 +217,7 @@ hb_ot_shape_collect_features (hb_ot_shape_planner_t *planner,
...
@@ -220,7 +217,7 @@ hb_ot_shape_collect_features (hb_ot_shape_planner_t *planner,
map
->
enable_feature
(
HB_TAG
(
'r'
,
'v'
,
'r'
,
'n'
));
map
->
enable_feature
(
HB_TAG
(
'r'
,
'v'
,
'r'
,
'n'
));
map
->
add_gsub_pause
(
nullptr
);
map
->
add_gsub_pause
(
nullptr
);
switch
(
p
rops
->
direction
)
{
switch
(
p
lanner
->
props
.
direction
)
{
case
HB_DIRECTION_LTR
:
case
HB_DIRECTION_LTR
:
map
->
enable_feature
(
HB_TAG
(
'l'
,
't'
,
'r'
,
'a'
));
map
->
enable_feature
(
HB_TAG
(
'l'
,
't'
,
'r'
,
'a'
));
map
->
enable_feature
(
HB_TAG
(
'l'
,
't'
,
'r'
,
'm'
));
map
->
enable_feature
(
HB_TAG
(
'l'
,
't'
,
'r'
,
'm'
));
...
@@ -259,7 +256,7 @@ hb_ot_shape_collect_features (hb_ot_shape_planner_t *planner,
...
@@ -259,7 +256,7 @@ hb_ot_shape_collect_features (hb_ot_shape_planner_t *planner,
for
(
unsigned
int
i
=
0
;
i
<
ARRAY_LENGTH
(
common_features
);
i
++
)
for
(
unsigned
int
i
=
0
;
i
<
ARRAY_LENGTH
(
common_features
);
i
++
)
map
->
add_feature
(
common_features
[
i
]);
map
->
add_feature
(
common_features
[
i
]);
if
(
HB_DIRECTION_IS_HORIZONTAL
(
p
rops
->
direction
))
if
(
HB_DIRECTION_IS_HORIZONTAL
(
p
lanner
->
props
.
direction
))
for
(
unsigned
int
i
=
0
;
i
<
ARRAY_LENGTH
(
horizontal_features
);
i
++
)
for
(
unsigned
int
i
=
0
;
i
<
ARRAY_LENGTH
(
horizontal_features
);
i
++
)
map
->
add_feature
(
horizontal_features
[
i
]);
map
->
add_feature
(
horizontal_features
[
i
]);
else
else
...
...
src/hb-ot-shape.hh
浏览文件 @
10823385
...
@@ -33,6 +33,8 @@
...
@@ -33,6 +33,8 @@
#include "hb-aat-map.hh"
#include "hb-aat-map.hh"
struct
hb_shape_plan_key_t
;
struct
hb_ot_shape_plan_t
struct
hb_ot_shape_plan_t
{
{
hb_segment_properties_t
props
;
hb_segment_properties_t
props
;
...
@@ -74,11 +76,7 @@ struct hb_ot_shape_plan_t
...
@@ -74,11 +76,7 @@ struct hb_ot_shape_plan_t
inline
void
position
(
hb_font_t
*
font
,
hb_buffer_t
*
buffer
)
const
{
map
.
position
(
this
,
font
,
buffer
);
}
inline
void
position
(
hb_font_t
*
font
,
hb_buffer_t
*
buffer
)
const
{
map
.
position
(
this
,
font
,
buffer
);
}
HB_INTERNAL
bool
init0
(
hb_face_t
*
face
,
HB_INTERNAL
bool
init0
(
hb_face_t
*
face
,
const
hb_segment_properties_t
*
props
,
const
hb_shape_plan_key_t
*
key
);
const
hb_feature_t
*
user_features
,
unsigned
int
num_user_features
,
const
int
*
coords
,
unsigned
int
num_coords
);
HB_INTERNAL
void
fini
(
void
);
HB_INTERNAL
void
fini
(
void
);
};
};
...
...
src/hb-shape-plan.cc
浏览文件 @
10823385
...
@@ -194,12 +194,7 @@ hb_shape_plan_create2 (hb_face_t *face,
...
@@ -194,12 +194,7 @@ hb_shape_plan_create2 (hb_face_t *face,
num_coords
,
num_coords
,
shaper_list
)))
shaper_list
)))
goto
bail2
;
goto
bail2
;
if
(
unlikely
(
!
shape_plan
->
ot
.
init0
(
face
,
if
(
unlikely
(
!
shape_plan
->
ot
.
init0
(
face
,
&
shape_plan
->
key
)))
props
,
user_features
,
num_user_features
,
coords
,
num_coords
)))
goto
bail3
;
goto
bail3
;
return
shape_plan
;
return
shape_plan
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录