Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
90645fb2
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看板
提交
90645fb2
编写于
5月 27, 2011
作者:
B
Behdad Esfahbod
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[OT] Separate map_builder from the actual map
Respectively, separate planner from the actual plan.
上级
5560a19e
变更
6
显示空白变更内容
内联
并排
Showing
6 changed file
with
127 addition
and
91 deletion
+127
-91
src/hb-ot-map-private.hh
src/hb-ot-map-private.hh
+66
-55
src/hb-ot-map.cc
src/hb-ot-map.cc
+17
-16
src/hb-ot-shape-complex-arabic.cc
src/hb-ot-shape-complex-arabic.cc
+3
-3
src/hb-ot-shape-complex-private.hh
src/hb-ot-shape-complex-private.hh
+4
-4
src/hb-ot-shape-private.hh
src/hb-ot-shape-private.hh
+22
-0
src/hb-ot-shape.cc
src/hb-ot-shape.cc
+15
-13
未找到文件。
src/hb-ot-map-private.hh
浏览文件 @
90645fb2
...
@@ -38,7 +38,31 @@ HB_BEGIN_DECLS
...
@@ -38,7 +38,31 @@ HB_BEGIN_DECLS
static
const
hb_tag_t
table_tags
[
2
]
=
{
HB_OT_TAG_GSUB
,
HB_OT_TAG_GPOS
};
static
const
hb_tag_t
table_tags
[
2
]
=
{
HB_OT_TAG_GSUB
,
HB_OT_TAG_GPOS
};
struct
hb_ot_map_t
{
struct
hb_ot_map_builder_t
{
public:
inline
void
add_feature
(
hb_tag_t
tag
,
unsigned
int
value
,
bool
global
)
{
feature_info_t
*
info
=
feature_infos
.
push
();
if
(
unlikely
(
!
info
))
return
;
info
->
tag
=
tag
;
info
->
seq
=
feature_infos
.
len
;
info
->
max_value
=
value
;
info
->
global
=
global
;
info
->
default_value
=
global
?
value
:
0
;
}
inline
void
add_bool_feature
(
hb_tag_t
tag
,
bool
global
=
true
)
{
add_feature
(
tag
,
1
,
global
);
}
HB_INTERNAL
void
compile
(
hb_face_t
*
face
,
const
hb_segment_properties_t
*
props
,
struct
hb_ot_map_t
&
m
);
inline
void
finish
(
void
)
{
feature_infos
.
finish
();
}
private:
private:
...
@@ -53,90 +77,77 @@ struct hb_ot_map_t {
...
@@ -53,90 +77,77 @@ struct hb_ot_map_t {
{
return
(
a
->
tag
!=
b
->
tag
)
?
(
a
->
tag
<
b
->
tag
?
-
1
:
1
)
:
(
a
->
seq
<
b
->
seq
?
-
1
:
1
);
}
{
return
(
a
->
tag
!=
b
->
tag
)
?
(
a
->
tag
<
b
->
tag
?
-
1
:
1
)
:
(
a
->
seq
<
b
->
seq
?
-
1
:
1
);
}
};
};
struct
feature_map_t
{
hb_prealloced_array_t
<
feature_info_t
,
16
>
feature_infos
;
/* used before compile() only */
hb_tag_t
tag
;
/* should be first for our bsearch to work */
};
unsigned
int
index
[
2
];
/* GSUB, GPOS */
unsigned
int
shift
;
hb_mask_t
mask
;
hb_mask_t
_1_mask
;
/* mask for value=1, for quick access */
static
int
cmp
(
const
feature_map_t
*
a
,
const
feature_map_t
*
b
)
{
return
a
->
tag
<
b
->
tag
?
-
1
:
a
->
tag
>
b
->
tag
?
1
:
0
;
}
};
struct
lookup_map_t
{
unsigned
int
index
;
hb_mask_t
mask
;
static
int
cmp
(
const
lookup_map_t
*
a
,
const
lookup_map_t
*
b
)
{
return
a
->
index
<
b
->
index
?
-
1
:
a
->
index
>
b
->
index
?
1
:
0
;
}
};
HB_INTERNAL
void
add_lookups
(
hb_face_t
*
face
,
unsigned
int
table_index
,
unsigned
int
feature_index
,
hb_mask_t
mask
);
struct
hb_ot_map_t
{
friend
struct
hb_ot_map_builder_t
;
public:
public:
void
add_feature
(
hb_tag_t
tag
,
unsigned
int
value
,
bool
global
)
{
feature_info_t
*
info
=
feature_infos
.
push
();
if
(
unlikely
(
!
info
))
return
;
info
->
tag
=
tag
;
info
->
seq
=
feature_infos
.
len
;
info
->
max_value
=
value
;
info
->
global
=
global
;
info
->
default_value
=
global
?
value
:
0
;
}
inline
void
add_bool_feature
(
hb_tag_t
tag
,
bool
global
=
true
)
{
add_feature
(
tag
,
1
,
global
);
}
HB_INTERNAL
void
compile
(
hb_face_t
*
face
,
const
hb_segment_properties_t
*
props
);
inline
hb_mask_t
get_global_mask
(
void
)
const
{
return
global_mask
;
}
inline
hb_mask_t
get_global_mask
(
void
)
const
{
return
global_mask
;
}
inline
hb_mask_t
get_mask
(
hb_tag_t
tag
,
unsigned
int
*
shift
=
NULL
)
const
{
inline
hb_mask_t
get_mask
(
hb_tag_t
tag
,
unsigned
int
*
shift
=
NULL
)
const
{
const
feature_map_t
*
map
=
feature
_map
s
.
bsearch
(
&
tag
);
const
feature_map_t
*
map
=
features
.
bsearch
(
&
tag
);
if
(
shift
)
*
shift
=
map
?
map
->
shift
:
0
;
if
(
shift
)
*
shift
=
map
?
map
->
shift
:
0
;
return
map
?
map
->
mask
:
0
;
return
map
?
map
->
mask
:
0
;
}
}
inline
hb_mask_t
get_1_mask
(
hb_tag_t
tag
)
const
{
inline
hb_mask_t
get_1_mask
(
hb_tag_t
tag
)
const
{
const
feature_map_t
*
map
=
feature
_map
s
.
bsearch
(
&
tag
);
const
feature_map_t
*
map
=
features
.
bsearch
(
&
tag
);
return
map
?
map
->
_1_mask
:
0
;
return
map
?
map
->
_1_mask
:
0
;
}
}
inline
void
substitute
(
hb_face_t
*
face
,
hb_buffer_t
*
buffer
)
const
{
inline
void
substitute
(
hb_face_t
*
face
,
hb_buffer_t
*
buffer
)
const
{
for
(
unsigned
int
i
=
0
;
i
<
lookup
_map
s
[
0
].
len
;
i
++
)
for
(
unsigned
int
i
=
0
;
i
<
lookups
[
0
].
len
;
i
++
)
hb_ot_layout_substitute_lookup
(
face
,
buffer
,
lookup
_maps
[
0
][
i
].
index
,
lookup_ma
ps
[
0
][
i
].
mask
);
hb_ot_layout_substitute_lookup
(
face
,
buffer
,
lookup
s
[
0
][
i
].
index
,
looku
ps
[
0
][
i
].
mask
);
}
}
inline
void
position
(
hb_font_t
*
font
,
hb_face_t
*
face
,
hb_buffer_t
*
buffer
)
const
{
inline
void
position
(
hb_font_t
*
font
,
hb_face_t
*
face
,
hb_buffer_t
*
buffer
)
const
{
for
(
unsigned
int
i
=
0
;
i
<
lookup
_map
s
[
1
].
len
;
i
++
)
for
(
unsigned
int
i
=
0
;
i
<
lookups
[
1
].
len
;
i
++
)
hb_ot_layout_position_lookup
(
font
,
buffer
,
lookup
_maps
[
1
][
i
].
index
,
lookup_ma
ps
[
1
][
i
].
mask
);
hb_ot_layout_position_lookup
(
font
,
buffer
,
lookup
s
[
1
][
i
].
index
,
looku
ps
[
1
][
i
].
mask
);
}
}
inline
void
finish
(
void
)
{
inline
void
finish
(
void
)
{
feature_infos
.
finish
();
features
.
finish
();
feature_maps
.
finish
();
lookups
[
0
].
finish
();
lookup_maps
[
0
].
finish
();
lookups
[
1
].
finish
();
lookup_maps
[
1
].
finish
();
}
}
private:
private:
hb_mask_t
global_mask
;
struct
feature_map_t
{
hb_tag_t
tag
;
/* should be first for our bsearch to work */
unsigned
int
index
[
2
];
/* GSUB, GPOS */
unsigned
int
shift
;
hb_mask_t
mask
;
hb_mask_t
_1_mask
;
/* mask for value=1, for quick access */
hb_prealloced_array_t
<
feature_info_t
,
8
>
feature_infos
;
/* used before compile() only */
static
int
cmp
(
const
feature_map_t
*
a
,
const
feature_map_t
*
b
)
hb_prealloced_array_t
<
feature_map_t
,
8
>
feature_maps
;
{
return
a
->
tag
<
b
->
tag
?
-
1
:
a
->
tag
>
b
->
tag
?
1
:
0
;
}
};
hb_prealloced_array_t
<
lookup_map_t
,
32
>
lookup_maps
[
2
];
/* GSUB/GPOS */
struct
lookup_map_t
{
};
unsigned
int
index
;
hb_mask_t
mask
;
static
int
cmp
(
const
lookup_map_t
*
a
,
const
lookup_map_t
*
b
)
{
return
a
->
index
<
b
->
index
?
-
1
:
a
->
index
>
b
->
index
?
1
:
0
;
}
};
HB_INTERNAL
void
add_lookups
(
hb_face_t
*
face
,
unsigned
int
table_index
,
unsigned
int
feature_index
,
hb_mask_t
mask
);
hb_mask_t
global_mask
;
hb_prealloced_array_t
<
feature_map_t
,
8
>
features
;
hb_prealloced_array_t
<
lookup_map_t
,
32
>
lookups
[
2
];
/* GSUB/GPOS */
};
HB_END_DECLS
HB_END_DECLS
...
...
src/hb-ot-map.cc
浏览文件 @
90645fb2
...
@@ -52,7 +52,7 @@ hb_ot_map_t::add_lookups (hb_face_t *face,
...
@@ -52,7 +52,7 @@ hb_ot_map_t::add_lookups (hb_face_t *face,
lookup_indices
);
lookup_indices
);
for
(
unsigned
int
i
=
0
;
i
<
len
;
i
++
)
{
for
(
unsigned
int
i
=
0
;
i
<
len
;
i
++
)
{
lookup_map_t
*
lookup
=
lookup_ma
ps
[
table_index
].
push
();
hb_ot_map_t
::
lookup_map_t
*
lookup
=
looku
ps
[
table_index
].
push
();
if
(
unlikely
(
!
lookup
))
if
(
unlikely
(
!
lookup
))
return
;
return
;
lookup
->
mask
=
mask
;
lookup
->
mask
=
mask
;
...
@@ -65,10 +65,11 @@ hb_ot_map_t::add_lookups (hb_face_t *face,
...
@@ -65,10 +65,11 @@ hb_ot_map_t::add_lookups (hb_face_t *face,
void
void
hb_ot_map_t
::
compile
(
hb_face_t
*
face
,
hb_ot_map_builder_t
::
compile
(
hb_face_t
*
face
,
const
hb_segment_properties_t
*
props
)
const
hb_segment_properties_t
*
props
,
hb_ot_map_t
&
m
)
{
{
global_mask
=
1
;
m
.
global_mask
=
1
;
if
(
!
feature_infos
.
len
)
if
(
!
feature_infos
.
len
)
return
;
return
;
...
@@ -139,7 +140,7 @@ hb_ot_map_t::compile (hb_face_t *face,
...
@@ -139,7 +140,7 @@ hb_ot_map_t::compile (hb_face_t *face,
continue
;
continue
;
feature_map_t
*
map
=
feature_map
s
.
push
();
hb_ot_map_t
::
feature_map_t
*
map
=
m
.
feature
s
.
push
();
if
(
unlikely
(
!
map
))
if
(
unlikely
(
!
map
))
break
;
break
;
...
@@ -155,7 +156,7 @@ hb_ot_map_t::compile (hb_face_t *face,
...
@@ -155,7 +156,7 @@ hb_ot_map_t::compile (hb_face_t *face,
map
->
mask
=
(
1
<<
(
next_bit
+
bits_needed
))
-
(
1
<<
next_bit
);
map
->
mask
=
(
1
<<
(
next_bit
+
bits_needed
))
-
(
1
<<
next_bit
);
next_bit
+=
bits_needed
;
next_bit
+=
bits_needed
;
if
(
info
->
global
)
if
(
info
->
global
)
global_mask
|=
(
info
->
default_value
<<
map
->
shift
)
&
map
->
mask
;
m
.
global_mask
|=
(
info
->
default_value
<<
map
->
shift
)
&
map
->
mask
;
}
}
map
->
_1_mask
=
(
1
<<
map
->
shift
)
&
map
->
mask
;
map
->
_1_mask
=
(
1
<<
map
->
shift
)
&
map
->
mask
;
...
@@ -174,22 +175,22 @@ hb_ot_map_t::compile (hb_face_t *face,
...
@@ -174,22 +175,22 @@ hb_ot_map_t::compile (hb_face_t *face,
script_index
[
table_index
],
script_index
[
table_index
],
language_index
[
table_index
],
language_index
[
table_index
],
&
required_feature_index
))
&
required_feature_index
))
add_lookups
(
face
,
table_index
,
required_feature_index
,
1
);
m
.
add_lookups
(
face
,
table_index
,
required_feature_index
,
1
);
for
(
unsigned
i
=
0
;
i
<
feature_map
s
.
len
;
i
++
)
for
(
unsigned
i
=
0
;
i
<
m
.
feature
s
.
len
;
i
++
)
add_lookups
(
face
,
table_index
,
feature_maps
[
i
].
index
[
table_index
],
feature_map
s
[
i
].
mask
);
m
.
add_lookups
(
face
,
table_index
,
m
.
features
[
i
].
index
[
table_index
],
m
.
feature
s
[
i
].
mask
);
/* Sort lookups and merge duplicates */
/* Sort lookups and merge duplicates */
lookup_ma
ps
[
table_index
].
sort
();
m
.
looku
ps
[
table_index
].
sort
();
if
(
lookup_ma
ps
[
table_index
].
len
)
if
(
m
.
looku
ps
[
table_index
].
len
)
{
{
unsigned
int
j
=
0
;
unsigned
int
j
=
0
;
for
(
unsigned
int
i
=
1
;
i
<
lookup_ma
ps
[
table_index
].
len
;
i
++
)
for
(
unsigned
int
i
=
1
;
i
<
m
.
looku
ps
[
table_index
].
len
;
i
++
)
if
(
lookup_maps
[
table_index
][
i
].
index
!=
lookup_ma
ps
[
table_index
][
j
].
index
)
if
(
m
.
lookups
[
table_index
][
i
].
index
!=
m
.
looku
ps
[
table_index
][
j
].
index
)
lookup_maps
[
table_index
][
++
j
]
=
lookup_ma
ps
[
table_index
][
i
];
m
.
lookups
[
table_index
][
++
j
]
=
m
.
looku
ps
[
table_index
][
i
];
else
else
lookup_maps
[
table_index
][
j
].
mask
|=
lookup_ma
ps
[
table_index
][
i
].
mask
;
m
.
lookups
[
table_index
][
j
].
mask
|=
m
.
looku
ps
[
table_index
][
i
].
mask
;
lookup_ma
ps
[
table_index
].
shrink
(
j
+
1
);
m
.
looku
ps
[
table_index
].
shrink
(
j
+
1
);
}
}
}
}
}
}
...
...
src/hb-ot-shape-complex-arabic.cc
浏览文件 @
90645fb2
...
@@ -152,14 +152,14 @@ static const struct arabic_state_table_entry {
...
@@ -152,14 +152,14 @@ static const struct arabic_state_table_entry {
void
void
_hb_ot_shape_complex_collect_features_arabic
(
hb_ot_shape_plan
_t
*
plan
,
const
hb_segment_properties_t
*
props
)
_hb_ot_shape_complex_collect_features_arabic
(
hb_ot_shape_plan
ner_t
*
planner
,
const
hb_segment_properties_t
*
props
)
{
{
/* ArabicOT spec enables 'cswh' for Arabic where as for basic shaper it's disabled by default. */
/* ArabicOT spec enables 'cswh' for Arabic where as for basic shaper it's disabled by default. */
plan
->
map
.
add_bool_feature
(
HB_TAG
(
'c'
,
's'
,
'w'
,
'h'
));
plan
ner
->
map
.
add_bool_feature
(
HB_TAG
(
'c'
,
's'
,
'w'
,
'h'
));
unsigned
int
num_features
=
props
->
script
==
HB_SCRIPT_SYRIAC
?
SYRIAC_NUM_FEATURES
:
COMMON_NUM_FEATURES
;
unsigned
int
num_features
=
props
->
script
==
HB_SCRIPT_SYRIAC
?
SYRIAC_NUM_FEATURES
:
COMMON_NUM_FEATURES
;
for
(
unsigned
int
i
=
0
;
i
<
num_features
;
i
++
)
for
(
unsigned
int
i
=
0
;
i
<
num_features
;
i
++
)
plan
->
map
.
add_bool_feature
(
arabic_syriac_features
[
i
],
false
);
plan
ner
->
map
.
add_bool_feature
(
arabic_syriac_features
[
i
],
false
);
}
}
void
void
...
...
src/hb-ot-shape-complex-private.hh
浏览文件 @
90645fb2
...
@@ -61,14 +61,14 @@ hb_ot_shape_complex_categorize (const hb_segment_properties_t *props)
...
@@ -61,14 +61,14 @@ hb_ot_shape_complex_categorize (const hb_segment_properties_t *props)
* Shapers should use plan->map to add their features.
* Shapers should use plan->map to add their features.
*/
*/
HB_INTERNAL
void
_hb_ot_shape_complex_collect_features_arabic
(
hb_ot_shape_plan_t
*
plan
,
const
hb_segment_properties_t
*
props
);
HB_INTERNAL
void
_hb_ot_shape_complex_collect_features_arabic
(
hb_ot_shape_plan
ner
_t
*
plan
,
const
hb_segment_properties_t
*
props
);
static
inline
void
static
inline
void
hb_ot_shape_complex_collect_features
(
hb_ot_shape_plan
_t
*
plan
,
hb_ot_shape_complex_collect_features
(
hb_ot_shape_plan
ner_t
*
planner
,
const
hb_segment_properties_t
*
props
)
const
hb_segment_properties_t
*
props
)
{
{
switch
(
plan
->
shaper
)
{
switch
(
plan
ner
->
shaper
)
{
case
hb_ot_complex_shaper_arabic
:
_hb_ot_shape_complex_collect_features_arabic
(
plan
,
props
);
return
;
case
hb_ot_complex_shaper_arabic
:
_hb_ot_shape_complex_collect_features_arabic
(
plan
ner
,
props
);
return
;
case
hb_ot_complex_shaper_none
:
default
:
return
;
case
hb_ot_complex_shaper_none
:
default
:
return
;
}
}
}
}
...
...
src/hb-ot-shape-private.hh
浏览文件 @
90645fb2
...
@@ -49,6 +49,8 @@ enum hb_ot_complex_shaper_t {
...
@@ -49,6 +49,8 @@ enum hb_ot_complex_shaper_t {
struct
hb_ot_shape_plan_t
struct
hb_ot_shape_plan_t
{
{
friend
struct
hb_ot_shape_planner_t
;
hb_ot_map_t
map
;
hb_ot_map_t
map
;
hb_ot_complex_shaper_t
shaper
;
hb_ot_complex_shaper_t
shaper
;
...
@@ -59,6 +61,26 @@ struct hb_ot_shape_plan_t
...
@@ -59,6 +61,26 @@ struct hb_ot_shape_plan_t
NO_COPY
(
hb_ot_shape_plan_t
);
NO_COPY
(
hb_ot_shape_plan_t
);
};
};
struct
hb_ot_shape_planner_t
{
hb_ot_map_builder_t
map
;
hb_ot_complex_shaper_t
shaper
;
hb_ot_shape_planner_t
(
void
)
:
map
()
{}
~
hb_ot_shape_planner_t
(
void
)
{
map
.
finish
();
}
inline
void
compile
(
hb_face_t
*
face
,
const
hb_segment_properties_t
*
props
,
struct
hb_ot_shape_plan_t
&
plan
)
{
plan
.
shaper
=
shaper
;
map
.
compile
(
face
,
props
,
plan
.
map
);
}
private:
NO_COPY
(
hb_ot_shape_planner_t
);
};
struct
hb_ot_shape_context_t
struct
hb_ot_shape_context_t
{
{
...
...
src/hb-ot-shape.cc
浏览文件 @
90645fb2
...
@@ -49,19 +49,19 @@ hb_tag_t default_features[] = {
...
@@ -49,19 +49,19 @@ hb_tag_t default_features[] = {
};
};
static
void
static
void
hb_ot_shape_collect_features
(
hb_ot_shape_plan
_t
*
plan
,
hb_ot_shape_collect_features
(
hb_ot_shape_plan
ner_t
*
planner
,
const
hb_segment_properties_t
*
props
,
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
)
{
{
switch
(
props
->
direction
)
{
switch
(
props
->
direction
)
{
case
HB_DIRECTION_LTR
:
case
HB_DIRECTION_LTR
:
plan
->
map
.
add_bool_feature
(
HB_TAG
(
'l'
,
't'
,
'r'
,
'a'
));
plan
ner
->
map
.
add_bool_feature
(
HB_TAG
(
'l'
,
't'
,
'r'
,
'a'
));
plan
->
map
.
add_bool_feature
(
HB_TAG
(
'l'
,
't'
,
'r'
,
'm'
));
plan
ner
->
map
.
add_bool_feature
(
HB_TAG
(
'l'
,
't'
,
'r'
,
'm'
));
break
;
break
;
case
HB_DIRECTION_RTL
:
case
HB_DIRECTION_RTL
:
plan
->
map
.
add_bool_feature
(
HB_TAG
(
'r'
,
't'
,
'l'
,
'a'
));
plan
ner
->
map
.
add_bool_feature
(
HB_TAG
(
'r'
,
't'
,
'l'
,
'a'
));
plan
->
map
.
add_bool_feature
(
HB_TAG
(
'r'
,
't'
,
'l'
,
'm'
),
false
);
plan
ner
->
map
.
add_bool_feature
(
HB_TAG
(
'r'
,
't'
,
'l'
,
'm'
),
false
);
break
;
break
;
case
HB_DIRECTION_TTB
:
case
HB_DIRECTION_TTB
:
case
HB_DIRECTION_BTT
:
case
HB_DIRECTION_BTT
:
...
@@ -71,13 +71,13 @@ hb_ot_shape_collect_features (hb_ot_shape_plan_t *plan,
...
@@ -71,13 +71,13 @@ hb_ot_shape_collect_features (hb_ot_shape_plan_t *plan,
}
}
for
(
unsigned
int
i
=
0
;
i
<
ARRAY_LENGTH
(
default_features
);
i
++
)
for
(
unsigned
int
i
=
0
;
i
<
ARRAY_LENGTH
(
default_features
);
i
++
)
plan
->
map
.
add_bool_feature
(
default_features
[
i
]);
plan
ner
->
map
.
add_bool_feature
(
default_features
[
i
]);
hb_ot_shape_complex_collect_features
(
plan
,
props
);
hb_ot_shape_complex_collect_features
(
plan
ner
,
props
);
for
(
unsigned
int
i
=
0
;
i
<
num_user_features
;
i
++
)
{
for
(
unsigned
int
i
=
0
;
i
<
num_user_features
;
i
++
)
{
const
hb_feature_t
*
feature
=
&
user_features
[
i
];
const
hb_feature_t
*
feature
=
&
user_features
[
i
];
plan
->
map
.
add_feature
(
feature
->
tag
,
feature
->
value
,
(
feature
->
start
==
0
&&
feature
->
end
==
(
unsigned
int
)
-
1
));
plan
ner
->
map
.
add_feature
(
feature
->
tag
,
feature
->
value
,
(
feature
->
start
==
0
&&
feature
->
end
==
(
unsigned
int
)
-
1
));
}
}
}
}
...
@@ -384,11 +384,13 @@ hb_ot_shape_plan_internal (hb_ot_shape_plan_t *plan,
...
@@ -384,11 +384,13 @@ hb_ot_shape_plan_internal (hb_ot_shape_plan_t *plan,
const
hb_feature_t
*
user_features
,
const
hb_feature_t
*
user_features
,
unsigned
int
num_user_features
)
unsigned
int
num_user_features
)
{
{
plan
->
shaper
=
hb_ot_shape_complex_categorize
(
props
)
;
hb_ot_shape_planner_t
planner
;
hb_ot_shape_collect_features
(
plan
,
props
,
user_features
,
num_user_feature
s
);
planner
.
shaper
=
hb_ot_shape_complex_categorize
(
prop
s
);
plan
->
map
.
compile
(
face
,
props
);
hb_ot_shape_collect_features
(
&
planner
,
props
,
user_features
,
num_user_features
);
planner
.
compile
(
face
,
props
,
*
plan
);
}
}
static
void
static
void
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录