Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
83e1ef92
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,发现更多精彩内容 >>
提交
83e1ef92
编写于
2月 12, 2018
作者:
G
Garret Rieger
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[subset] Set the new number of glyphs in maxp.
上级
427f9e4b
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
37 addition
and
5 deletion
+37
-5
src/hb-ot-maxp-table.hh
src/hb-ot-maxp-table.hh
+5
-0
src/hb-subset.cc
src/hb-subset.cc
+32
-5
未找到文件。
src/hb-ot-maxp-table.hh
浏览文件 @
83e1ef92
...
...
@@ -48,6 +48,11 @@ struct maxp
return
numGlyphs
;
}
inline
void
set_num_glyphs
(
uint16_t
count
)
{
numGlyphs
.
set
(
count
);
}
inline
bool
sanitize
(
hb_sanitize_context_t
*
c
)
const
{
TRACE_SANITIZE
(
this
);
...
...
src/hb-subset.cc
浏览文件 @
83e1ef92
...
...
@@ -36,6 +36,8 @@
#include "hb-open-file-private.hh"
#include "hb-ot-cmap-table.hh"
#include "hb-ot-glyf-table.hh"
#include "hb-ot-head-table.hh"
#include "hb-ot-maxp-table.hh"
#ifndef HB_NO_VISIBILITY
...
...
@@ -265,19 +267,42 @@ _add_head_and_set_loca_version (hb_face_t *source, bool use_short_loca, hb_face_
hb_blob_t
*
head_prime_blob
=
hb_blob_create
((
const
char
*
)
head_prime
,
OT
::
head
::
static_size
,
HB_MEMORY_MODE_
WRITABLE
,
HB_MEMORY_MODE_
READONLY
,
head_prime
,
free
);
has_head
=
has_head
&&
hb_subset_face_add_table
(
dest
,
HB_OT_TAG_head
,
head_prime_blob
);
has_head
=
hb_subset_face_add_table
(
dest
,
HB_OT_TAG_head
,
head_prime_blob
);
hb_blob_destroy
(
head_prime_blob
);
}
hb_blob_destroy
(
head_blob
);
return
has_head
;
}
static
bool
_add_maxp_and_set_glyph_count
(
hb_subset_plan_t
*
plan
,
hb_face_t
*
source
,
hb_face_t
*
dest
)
{
hb_blob_t
*
maxp_blob
=
OT
::
Sanitizer
<
OT
::
maxp
>
().
sanitize
(
hb_face_reference_table
(
source
,
HB_OT_TAG_maxp
));
const
OT
::
maxp
*
maxp
=
OT
::
Sanitizer
<
OT
::
maxp
>::
lock_instance
(
maxp_blob
);
bool
has_maxp
=
(
maxp
!=
nullptr
);
if
(
has_maxp
)
{
unsigned
int
length
=
hb_blob_get_length
(
maxp_blob
);
OT
::
maxp
*
maxp_prime
=
(
OT
::
maxp
*
)
calloc
(
length
,
1
);
memcpy
(
maxp_prime
,
maxp
,
length
);
maxp_prime
->
set_num_glyphs
(
plan
->
gids_to_retain_sorted
.
len
);
hb_blob_t
*
maxp_prime_blob
=
hb_blob_create
((
const
char
*
)
maxp_prime
,
length
,
HB_MEMORY_MODE_READONLY
,
maxp_prime
,
free
);
has_maxp
=
hb_subset_face_add_table
(
dest
,
HB_OT_TAG_maxp
,
maxp_prime_blob
);
hb_blob_destroy
(
maxp_prime_blob
);
}
hb_blob_destroy
(
maxp_blob
);
return
has_maxp
;
}
static
bool
_subset_glyf
(
hb_subset_plan_t
*
plan
,
hb_face_t
*
source
,
hb_face_t
*
dest
)
{
...
...
@@ -316,6 +341,8 @@ _subset_table (hb_subset_plan_t *plan,
case
HB_OT_TAG_head
:
// SKIP head, it's handled by glyf
return
true
;
case
HB_OT_TAG_maxp
:
return
_add_maxp_and_set_glyph_count
(
plan
,
source
,
dest
);
case
HB_OT_TAG_loca
:
// SKIP loca, it's handle by glyf
return
true
;
...
...
@@ -325,7 +352,7 @@ _subset_table (hb_subset_plan_t *plan,
default:
dest_blob
=
source_blob
;
break
;
}
}
DEBUG_MSG
(
SUBSET
,
nullptr
,
"subset %c%c%c%c %s"
,
HB_UNTAG
(
tag
),
dest_blob
?
"ok"
:
"FAILED"
);
if
(
unlikely
(
!
dest_blob
))
return
false
;
if
(
unlikely
(
!
hb_subset_face_add_table
(
dest
,
tag
,
dest_blob
)))
return
false
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录