Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
7e2839c4
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,发现更多精彩内容 >>
提交
7e2839c4
编写于
11月 14, 2017
作者:
B
Behdad Esfahbod
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[ot] Move hb_ot_face_glyf_accelerator_t
上级
c4e18e54
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
90 addition
and
88 deletion
+90
-88
src/hb-ot-font.cc
src/hb-ot-font.cc
+1
-74
src/hb-ot-glyf-table.hh
src/hb-ot-glyf-table.hh
+89
-14
未找到文件。
src/hb-ot-font.cc
浏览文件 @
7e2839c4
...
@@ -144,79 +144,6 @@ struct hb_ot_face_metrics_accelerator_t
...
@@ -144,79 +144,6 @@ struct hb_ot_face_metrics_accelerator_t
}
}
};
};
struct
hb_ot_face_glyf_accelerator_t
{
bool
short_offset
;
unsigned
int
num_glyphs
;
const
OT
::
loca
*
loca
;
const
OT
::
glyf
*
glyf
;
hb_blob_t
*
loca_blob
;
hb_blob_t
*
glyf_blob
;
unsigned
int
glyf_len
;
inline
void
init
(
hb_face_t
*
face
)
{
hb_blob_t
*
head_blob
=
OT
::
Sanitizer
<
OT
::
head
>::
sanitize
(
face
->
reference_table
(
HB_OT_TAG_head
));
const
OT
::
head
*
head
=
OT
::
Sanitizer
<
OT
::
head
>::
lock_instance
(
head_blob
);
if
((
unsigned
int
)
head
->
indexToLocFormat
>
1
||
head
->
glyphDataFormat
!=
0
)
{
/* Unknown format. Leave num_glyphs=0, that takes care of disabling us. */
hb_blob_destroy
(
head_blob
);
return
;
}
this
->
short_offset
=
0
==
head
->
indexToLocFormat
;
hb_blob_destroy
(
head_blob
);
this
->
loca_blob
=
OT
::
Sanitizer
<
OT
::
loca
>::
sanitize
(
face
->
reference_table
(
HB_OT_TAG_loca
));
this
->
loca
=
OT
::
Sanitizer
<
OT
::
loca
>::
lock_instance
(
this
->
loca_blob
);
this
->
glyf_blob
=
OT
::
Sanitizer
<
OT
::
glyf
>::
sanitize
(
face
->
reference_table
(
HB_OT_TAG_glyf
));
this
->
glyf
=
OT
::
Sanitizer
<
OT
::
glyf
>::
lock_instance
(
this
->
glyf_blob
);
this
->
num_glyphs
=
MAX
(
1u
,
hb_blob_get_length
(
this
->
loca_blob
)
/
(
this
->
short_offset
?
2
:
4
))
-
1
;
this
->
glyf_len
=
hb_blob_get_length
(
this
->
glyf_blob
);
}
inline
void
fini
(
void
)
{
hb_blob_destroy
(
this
->
loca_blob
);
hb_blob_destroy
(
this
->
glyf_blob
);
}
inline
bool
get_extents
(
hb_codepoint_t
glyph
,
hb_glyph_extents_t
*
extents
)
const
{
if
(
unlikely
(
glyph
>=
this
->
num_glyphs
))
return
false
;
unsigned
int
start_offset
,
end_offset
;
if
(
this
->
short_offset
)
{
start_offset
=
2
*
this
->
loca
->
u
.
shortsZ
[
glyph
];
end_offset
=
2
*
this
->
loca
->
u
.
shortsZ
[
glyph
+
1
];
}
else
{
start_offset
=
this
->
loca
->
u
.
longsZ
[
glyph
];
end_offset
=
this
->
loca
->
u
.
longsZ
[
glyph
+
1
];
}
if
(
start_offset
>
end_offset
||
end_offset
>
this
->
glyf_len
)
return
false
;
if
(
end_offset
-
start_offset
<
OT
::
glyfGlyphHeader
::
static_size
)
return
true
;
/* Empty glyph; zero extents. */
const
OT
::
glyfGlyphHeader
&
glyph_header
=
OT
::
StructAtOffset
<
OT
::
glyfGlyphHeader
>
(
this
->
glyf
,
start_offset
);
extents
->
x_bearing
=
MIN
(
glyph_header
.
xMin
,
glyph_header
.
xMax
);
extents
->
y_bearing
=
MAX
(
glyph_header
.
yMin
,
glyph_header
.
yMax
);
extents
->
width
=
MAX
(
glyph_header
.
xMin
,
glyph_header
.
xMax
)
-
extents
->
x_bearing
;
extents
->
height
=
MIN
(
glyph_header
.
yMin
,
glyph_header
.
yMax
)
-
extents
->
y_bearing
;
return
true
;
}
};
typedef
bool
(
*
hb_cmap_get_glyph_func_t
)
(
const
void
*
obj
,
typedef
bool
(
*
hb_cmap_get_glyph_func_t
)
(
const
void
*
obj
,
hb_codepoint_t
codepoint
,
hb_codepoint_t
codepoint
,
hb_codepoint_t
*
glyph
);
hb_codepoint_t
*
glyph
);
...
@@ -350,7 +277,7 @@ struct hb_ot_font_t
...
@@ -350,7 +277,7 @@ struct hb_ot_font_t
hb_ot_face_cmap_accelerator_t
cmap
;
hb_ot_face_cmap_accelerator_t
cmap
;
hb_ot_face_metrics_accelerator_t
h_metrics
;
hb_ot_face_metrics_accelerator_t
h_metrics
;
hb_ot_face_metrics_accelerator_t
v_metrics
;
hb_ot_face_metrics_accelerator_t
v_metrics
;
OT
::
hb_lazy_loader_t
<
hb_ot_face_glyf_
accelerator_t
>
glyf
;
OT
::
hb_lazy_loader_t
<
OT
::
glyf
::
accelerator_t
>
glyf
;
OT
::
hb_lazy_loader_t
<
OT
::
CBDT
::
accelerator_t
>
cbdt
;
OT
::
hb_lazy_loader_t
<
OT
::
CBDT
::
accelerator_t
>
cbdt
;
OT
::
hb_lazy_loader_t
<
OT
::
post
::
accelerator_t
>
post
;
OT
::
hb_lazy_loader_t
<
OT
::
post
::
accelerator_t
>
post
;
OT
::
hb_lazy_loader_t
<
OT
::
kern
::
accelerator_t
>
kern
;
OT
::
hb_lazy_loader_t
<
OT
::
kern
::
accelerator_t
>
kern
;
...
...
src/hb-ot-glyf-table.hh
浏览文件 @
7e2839c4
...
@@ -28,6 +28,7 @@
...
@@ -28,6 +28,7 @@
#define HB_OT_GLYF_TABLE_HH
#define HB_OT_GLYF_TABLE_HH
#include "hb-open-type-private.hh"
#include "hb-open-type-private.hh"
#include "hb-ot-head-table.hh"
namespace
OT
{
namespace
OT
{
...
@@ -78,26 +79,100 @@ struct glyf
...
@@ -78,26 +79,100 @@ struct glyf
return_trace
(
true
);
return_trace
(
true
);
}
}
struct
GlyphHeader
{
SHORT
numberOfContours
;
/* If the number of contours is
* greater than or equal to zero,
* this is a simple glyph; if negative,
* this is a composite glyph. */
FWORD
xMin
;
/* Minimum x for coordinate data. */
FWORD
yMin
;
/* Minimum y for coordinate data. */
FWORD
xMax
;
/* Maximum x for coordinate data. */
FWORD
yMax
;
/* Maximum y for coordinate data. */
DEFINE_SIZE_STATIC
(
10
);
};
struct
accelerator_t
{
inline
void
init
(
hb_face_t
*
face
)
{
hb_blob_t
*
head_blob
=
Sanitizer
<
head
>::
sanitize
(
face
->
reference_table
(
HB_OT_TAG_head
));
const
head
*
head_table
=
Sanitizer
<
head
>::
lock_instance
(
head_blob
);
if
((
unsigned
int
)
head_table
->
indexToLocFormat
>
1
||
head_table
->
glyphDataFormat
!=
0
)
{
/* Unknown format. Leave num_glyphs=0, that takes care of disabling us. */
hb_blob_destroy
(
head_blob
);
return
;
}
short_offset
=
0
==
head_table
->
indexToLocFormat
;
hb_blob_destroy
(
head_blob
);
loca_blob
=
Sanitizer
<
loca
>::
sanitize
(
face
->
reference_table
(
HB_OT_TAG_loca
));
loca_table
=
Sanitizer
<
loca
>::
lock_instance
(
loca_blob
);
glyf_blob
=
Sanitizer
<
glyf
>::
sanitize
(
face
->
reference_table
(
HB_OT_TAG_glyf
));
glyf_table
=
Sanitizer
<
glyf
>::
lock_instance
(
glyf_blob
);
num_glyphs
=
MAX
(
1u
,
hb_blob_get_length
(
loca_blob
)
/
(
short_offset
?
2
:
4
))
-
1
;
glyf_len
=
hb_blob_get_length
(
glyf_blob
);
}
inline
void
fini
(
void
)
{
hb_blob_destroy
(
loca_blob
);
hb_blob_destroy
(
glyf_blob
);
}
inline
bool
get_extents
(
hb_codepoint_t
glyph
,
hb_glyph_extents_t
*
extents
)
const
{
if
(
unlikely
(
glyph
>=
num_glyphs
))
return
false
;
unsigned
int
start_offset
,
end_offset
;
if
(
short_offset
)
{
start_offset
=
2
*
loca_table
->
u
.
shortsZ
[
glyph
];
end_offset
=
2
*
loca_table
->
u
.
shortsZ
[
glyph
+
1
];
}
else
{
start_offset
=
loca_table
->
u
.
longsZ
[
glyph
];
end_offset
=
loca_table
->
u
.
longsZ
[
glyph
+
1
];
}
if
(
start_offset
>
end_offset
||
end_offset
>
glyf_len
)
return
false
;
if
(
end_offset
-
start_offset
<
GlyphHeader
::
static_size
)
return
true
;
/* Empty glyph; zero extents. */
const
GlyphHeader
&
glyph_header
=
StructAtOffset
<
GlyphHeader
>
(
glyf_table
,
start_offset
);
extents
->
x_bearing
=
MIN
(
glyph_header
.
xMin
,
glyph_header
.
xMax
);
extents
->
y_bearing
=
MAX
(
glyph_header
.
yMin
,
glyph_header
.
yMax
);
extents
->
width
=
MAX
(
glyph_header
.
xMin
,
glyph_header
.
xMax
)
-
extents
->
x_bearing
;
extents
->
height
=
MIN
(
glyph_header
.
yMin
,
glyph_header
.
yMax
)
-
extents
->
y_bearing
;
return
true
;
}
private:
bool
short_offset
;
unsigned
int
num_glyphs
;
const
loca
*
loca_table
;
const
glyf
*
glyf_table
;
hb_blob_t
*
loca_blob
;
hb_blob_t
*
glyf_blob
;
unsigned
int
glyf_len
;
};
public:
public:
BYTE
dataX
[
VAR
];
/* Glyphs data. */
BYTE
dataX
[
VAR
];
/* Glyphs data. */
DEFINE_SIZE_ARRAY
(
0
,
dataX
);
DEFINE_SIZE_ARRAY
(
0
,
dataX
);
};
};
struct
glyfGlyphHeader
{
SHORT
numberOfContours
;
/* If the number of contours is
* greater than or equal to zero,
* this is a simple glyph; if negative,
* this is a composite glyph. */
FWORD
xMin
;
/* Minimum x for coordinate data. */
FWORD
yMin
;
/* Minimum y for coordinate data. */
FWORD
xMax
;
/* Maximum x for coordinate data. */
FWORD
yMax
;
/* Maximum y for coordinate data. */
DEFINE_SIZE_STATIC
(
10
);
};
}
/* namespace OT */
}
/* namespace OT */
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录