Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
551fa2d2
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看板
提交
551fa2d2
编写于
2月 25, 2018
作者:
B
Behdad Esfahbod
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
[BASE] Minor
上级
05699fd9
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
105 addition
and
92 deletion
+105
-92
src/Makefile.sources
src/Makefile.sources
+0
-1
src/hb-ot-base.cc
src/hb-ot-base.cc
+0
-58
src/hb-ot-layout-base-table.hh
src/hb-ot-layout-base-table.hh
+70
-33
src/hb-ot-layout.cc
src/hb-ot-layout.cc
+34
-0
src/hb-ot-layout.h
src/hb-ot-layout.h
+1
-0
未找到文件。
src/Makefile.sources
浏览文件 @
551fa2d2
...
@@ -87,7 +87,6 @@ HB_OT_sources = \
...
@@ -87,7 +87,6 @@ HB_OT_sources = \
hb-aat-layout-kerx-table.hh
\
hb-aat-layout-kerx-table.hh
\
hb-aat-layout-trak-table.hh
\
hb-aat-layout-trak-table.hh
\
hb-aat-layout-private.hh
\
hb-aat-layout-private.hh
\
hb-ot-base.cc
\
hb-ot-font.cc
\
hb-ot-font.cc
\
hb-ot-layout.cc
\
hb-ot-layout.cc
\
hb-ot-layout-base-table.hh
\
hb-ot-layout-base-table.hh
\
...
...
src/hb-ot-base.cc
已删除
100644 → 0
浏览文件 @
05699fd9
/*
* Copyright © 2017 Elie Roux<elie.roux@telecom-bretagne.eu>
*
* This is part of HarfBuzz, a text shaping library.
*
* Permission is hereby granted, without written agreement and without
* license or royalty fees, to use, copy, modify, and distribute this
* software and its documentation for any purpose, provided that the
* above copyright notice and the following two paragraphs appear in
* all copies of this software.
*
* IN NO EVENT SHALL THE COPYRIGHT HOLDER BE LIABLE TO ANY PARTY FOR
* DIRECT, INDIRECT, SPECIAL, INCIDENTAL, OR CONSEQUENTIAL DAMAGES
* ARISING OUT OF THE USE OF THIS SOFTWARE AND ITS DOCUMENTATION, EVEN
* IF THE COPYRIGHT HOLDER HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH
* DAMAGE.
*
* THE COPYRIGHT HOLDER SPECIFICALLY DISCLAIMS ANY WARRANTIES, INCLUDING,
* BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND
* FITNESS FOR A PARTICULAR PURPOSE. THE SOFTWARE PROVIDED HEREUNDER IS
* ON AN "AS IS" BASIS, AND THE COPYRIGHT HOLDER HAS NO OBLIGATION TO
* PROVIDE MAINTENANCE, SUPPORT, UPDATES, ENHANCEMENTS, OR MODIFICATIONS.
*
*/
#include "hb-open-type-private.hh"
#include "hb-ot-layout-private.hh"
#include "hb-ot-layout-base-table.hh"
static
inline
const
OT
::
BASE
&
_get_base
(
hb_face_t
*
face
)
{
if
(
unlikely
(
!
hb_ot_shaper_face_data_ensure
(
face
)))
return
OT
::
Null
(
OT
::
BASE
);
hb_ot_layout_t
*
layout
=
hb_ot_layout_from_face
(
face
);
return
*
(
layout
->
base
.
get
());
}
/*
* OT::BASE
*/
/**
* hb_ot_base_has_data:
* @face: #hb_face_t to test
*
* This function allows to verify the presence of an OpenType BASE table on the
* face.
*
* Return value: true if face has a BASE table, false otherwise
*
* Since: XXX
**/
hb_bool_t
hb_ot_base_has_data
(
hb_face_t
*
face
)
{
return
&
_get_base
(
face
)
!=
&
OT
::
Null
(
OT
::
BASE
);
}
src/hb-ot-layout-base-table.hh
浏览文件 @
551fa2d2
...
@@ -221,40 +221,39 @@ struct MinMax {
...
@@ -221,40 +221,39 @@ struct MinMax {
};
};
struct
BaseLangSysRecord
{
struct
BaseLangSysRecord
{
inline
Tag
get_tag
(
void
)
const
inline
Tag
get_tag
(
void
)
const
{
return
baseLangSysTag
;
}
{
return
baseLangSysTag
;
}
inline
unsigned
int
get_feature_tag_index
(
Tag
featureTableTag
)
const
inline
unsigned
int
get_feature_tag_index
(
Tag
featureTableTag
)
const
{
(
this
+
minMax
).
get_feature_tag_index
(
featureTableTag
);
}
{
return
(
this
+
minMax
).
get_feature_tag_index
(
featureTableTag
);
}
inline
HBINT16
get_min_value
(
unsigned
int
featureTableTagIndex
)
const
inline
HBINT16
get_min_value
(
unsigned
int
featureTableTagIndex
)
const
{
(
this
+
minMax
).
get_min_value
(
featureTableTagIndex
);
}
{
return
(
this
+
minMax
).
get_min_value
(
featureTableTagIndex
);
}
inline
HBINT16
get_max_value
(
unsigned
int
featureTableTagIndex
)
const
inline
HBINT16
get_max_value
(
unsigned
int
featureTableTagIndex
)
const
{
(
this
+
minMax
).
get_max_value
(
featureTableTagIndex
);
}
{
return
(
this
+
minMax
).
get_max_value
(
featureTableTagIndex
);
}
inline
bool
sanitize
(
hb_sanitize_context_t
*
c
,
const
void
*
base
)
const
inline
bool
sanitize
(
hb_sanitize_context_t
*
c
,
const
void
*
base
)
const
{
{
TRACE_SANITIZE
(
this
);
TRACE_SANITIZE
(
this
);
return_trace
(
c
->
check_struct
(
this
)
&&
return_trace
(
c
->
check_struct
(
this
)
&&
minMax
!=
Null
(
OffsetTo
<
MinMax
>
)
&&
minMax
!=
Null
(
OffsetTo
<
MinMax
>
)
&&
minMax
.
sanitize
(
c
,
base
));
minMax
.
sanitize
(
c
,
base
));
}
}
protected:
protected:
Tag
baseLangSysTag
;
Tag
baseLangSysTag
;
OffsetTo
<
MinMax
>
minMax
;
// not supposed to be NULL
OffsetTo
<
MinMax
>
minMax
;
public:
public:
DEFINE_SIZE_STATIC
(
6
);
DEFINE_SIZE_STATIC
(
6
);
};
};
struct
BaseValues
{
struct
BaseValues
{
inline
const
unsigned
int
get_default_base_tag_index
(
void
)
const
inline
unsigned
int
get_default_base_tag_index
(
void
)
const
{
return
defaultIndex
;
}
{
return
defaultIndex
;
}
inline
HBINT16
get_base_coord
(
unsigned
int
baselineTagIndex
)
const
inline
HBINT16
get_base_coord
(
unsigned
int
baselineTagIndex
)
const
...
@@ -272,10 +271,9 @@ struct BaseValues {
...
@@ -272,10 +271,9 @@ struct BaseValues {
}
}
protected:
protected:
Index
defaultIndex
;
Index
defaultIndex
;
HBUINT16
baseCoordCount
;
HBUINT16
baseCoordCount
;
OffsetArrayOf
<
BaseCoord
>
baseCoords
;
OffsetArrayOf
<
BaseCoord
>
baseCoords
;
public:
public:
DEFINE_SIZE_ARRAY
(
6
,
baseCoords
);
DEFINE_SIZE_ARRAY
(
6
,
baseCoords
);
...
@@ -711,26 +709,66 @@ struct BASE
...
@@ -711,26 +709,66 @@ struct BASE
inline
unsigned
int
get_horiz_lang_tag_index
(
unsigned
int
baseScriptIndex
,
Tag
baseLangSysTag
)
const
inline
unsigned
int
get_horiz_lang_tag_index
(
unsigned
int
baseScriptIndex
,
Tag
baseLangSysTag
)
const
{
return
u
.
format1_0
.
get_horiz_lang_tag_index
(
baseScriptIndex
,
baseLangSysTag
);
}
{
return
u
.
format1_0
.
get_horiz_lang_tag_index
(
baseScriptIndex
,
baseLangSysTag
);
}
inline
unsigned
int
get_horiz_feature_tag_index
(
unsigned
int
baseScriptIndex
,
unsigned
int
baseLangSysIndex
,
Tag
featureTableTag
)
const
inline
unsigned
int
get_horiz_feature_tag_index
(
unsigned
int
baseScriptIndex
,
{
return
u
.
format1_0
.
get_horiz_feature_tag_index
(
baseScriptIndex
,
baseLangSysIndex
,
featureTableTag
);
}
unsigned
int
baseLangSysIndex
,
Tag
featureTableTag
)
const
{
return
u
.
format1_0
.
get_horiz_feature_tag_index
(
baseScriptIndex
,
baseLangSysIndex
,
featureTableTag
);
}
inline
HBINT16
get_horiz_max_value
(
unsigned
int
baseScriptIndex
,
unsigned
int
baseLangSysIndex
,
unsigned
int
featureTableTagIndex
)
const
inline
HBINT16
get_horiz_max_value
(
unsigned
int
baseScriptIndex
,
{
return
u
.
format1_0
.
get_horiz_max_value
(
baseScriptIndex
,
baseLangSysIndex
,
featureTableTagIndex
);
}
unsigned
int
baseLangSysIndex
,
unsigned
int
featureTableTagIndex
)
const
{
return
u
.
format1_0
.
get_horiz_max_value
(
baseScriptIndex
,
baseLangSysIndex
,
featureTableTagIndex
);
}
inline
HBINT16
get_horiz_min_value
(
unsigned
int
baseScriptIndex
,
unsigned
int
baseLangSysIndex
,
unsigned
int
featureTableTagIndex
)
const
inline
HBINT16
get_horiz_min_value
(
unsigned
int
baseScriptIndex
,
{
return
u
.
format1_0
.
get_horiz_min_value
(
baseScriptIndex
,
baseLangSysIndex
,
featureTableTagIndex
);
}
unsigned
int
baseLangSysIndex
,
unsigned
int
featureTableTagIndex
)
const
{
return
u
.
format1_0
.
get_horiz_min_value
(
baseScriptIndex
,
baseLangSysIndex
,
featureTableTagIndex
);
}
inline
unsigned
int
get_vert_lang_tag_index
(
unsigned
int
baseScriptIndex
,
Tag
baseLangSysTag
)
const
inline
unsigned
int
get_vert_lang_tag_index
(
unsigned
int
baseScriptIndex
,
{
return
u
.
format1_0
.
get_vert_lang_tag_index
(
baseScriptIndex
,
baseLangSysTag
);
}
Tag
baseLangSysTag
)
const
{
return
u
.
format1_0
.
get_vert_lang_tag_index
(
baseScriptIndex
,
baseLangSysTag
);
}
inline
unsigned
int
get_vert_feature_tag_index
(
unsigned
int
baseScriptIndex
,
unsigned
int
baseLangSysIndex
,
Tag
featureTableTag
)
const
inline
unsigned
int
get_vert_feature_tag_index
(
unsigned
int
baseScriptIndex
,
{
return
u
.
format1_0
.
get_vert_feature_tag_index
(
baseScriptIndex
,
baseLangSysIndex
,
featureTableTag
);
}
unsigned
int
baseLangSysIndex
,
Tag
featureTableTag
)
const
{
return
u
.
format1_0
.
get_vert_feature_tag_index
(
baseScriptIndex
,
baseLangSysIndex
,
featureTableTag
);
}
inline
HBINT16
get_vert_max_value
(
unsigned
int
baseScriptIndex
,
unsigned
int
baseLangSysIndex
,
unsigned
int
featureTableTagIndex
)
const
inline
HBINT16
get_vert_max_value
(
unsigned
int
baseScriptIndex
,
{
return
u
.
format1_0
.
get_vert_max_value
(
baseScriptIndex
,
baseLangSysIndex
,
featureTableTagIndex
);
}
unsigned
int
baseLangSysIndex
,
unsigned
int
featureTableTagIndex
)
const
{
return
u
.
format1_0
.
get_vert_max_value
(
baseScriptIndex
,
baseLangSysIndex
,
featureTableTagIndex
);
}
inline
HBINT16
get_vert_min_value
(
unsigned
int
baseScriptIndex
,
unsigned
int
baseLangSysIndex
,
unsigned
int
featureTableTagIndex
)
const
inline
HBINT16
get_vert_min_value
(
unsigned
int
baseScriptIndex
,
{
return
u
.
format1_0
.
get_vert_min_value
(
baseScriptIndex
,
baseLangSysIndex
,
featureTableTagIndex
);
}
unsigned
int
baseLangSysIndex
,
unsigned
int
featureTableTagIndex
)
const
{
return
u
.
format1_0
.
get_vert_min_value
(
baseScriptIndex
,
baseLangSysIndex
,
featureTableTagIndex
);
}
inline
bool
sanitize
(
hb_sanitize_context_t
*
c
)
const
inline
bool
sanitize
(
hb_sanitize_context_t
*
c
)
const
{
{
...
@@ -750,7 +788,6 @@ struct BASE
...
@@ -750,7 +788,6 @@ struct BASE
BASEFormat1_0
format1_0
;
BASEFormat1_0
format1_0
;
BASEFormat1_1
format1_1
;
BASEFormat1_1
format1_1
;
}
u
;
}
u
;
public:
public:
DEFINE_SIZE_UNION
(
4
,
version
);
DEFINE_SIZE_UNION
(
4
,
version
);
};
};
...
...
src/hb-ot-layout.cc
浏览文件 @
551fa2d2
...
@@ -222,6 +222,14 @@ _hb_ot_layout_destroy (hb_ot_layout_t *layout)
...
@@ -222,6 +222,14 @@ _hb_ot_layout_destroy (hb_ot_layout_t *layout)
free
(
layout
);
free
(
layout
);
}
}
static
inline
const
OT
::
BASE
&
_get_base
(
hb_face_t
*
face
)
{
if
(
unlikely
(
!
hb_ot_shaper_face_data_ensure
(
face
)))
return
OT
::
Null
(
OT
::
BASE
);
hb_ot_layout_t
*
layout
=
hb_ot_layout_from_face
(
face
);
return
*
(
layout
->
base
.
get
());
}
static
inline
const
OT
::
GDEF
&
static
inline
const
OT
::
GDEF
&
_get_gdef
(
hb_face_t
*
face
)
_get_gdef
(
hb_face_t
*
face
)
{
{
...
@@ -1267,3 +1275,29 @@ hb_ot_layout_substitute_lookup (OT::hb_ot_apply_context_t *c,
...
@@ -1267,3 +1275,29 @@ hb_ot_layout_substitute_lookup (OT::hb_ot_apply_context_t *c,
{
{
apply_string
<
GSUBProxy
>
(
c
,
lookup
,
accel
);
apply_string
<
GSUBProxy
>
(
c
,
lookup
,
accel
);
}
}
/*
* OT::BASE
*/
#if 0
/**
* hb_ot_base_has_data:
* @face: #hb_face_t to test
*
* This function allows to verify the presence of an OpenType BASE table on the
* face.
*
* Return value: true if face has a BASE table, false otherwise
*
* Since: XXX
**/
hb_bool_t
hb_ot_base_has_data (hb_face_t *face)
{
return &_get_base (face) != &OT::Null(OT::BASE);
}
#endif
src/hb-ot-layout.h
浏览文件 @
551fa2d2
...
@@ -38,6 +38,7 @@
...
@@ -38,6 +38,7 @@
HB_BEGIN_DECLS
HB_BEGIN_DECLS
#define HB_OT_TAG_BASE HB_TAG('B','A','S','E')
#define HB_OT_TAG_GDEF HB_TAG('G','D','E','F')
#define HB_OT_TAG_GDEF HB_TAG('G','D','E','F')
#define HB_OT_TAG_GSUB HB_TAG('G','S','U','B')
#define HB_OT_TAG_GSUB HB_TAG('G','S','U','B')
#define HB_OT_TAG_GPOS HB_TAG('G','P','O','S')
#define HB_OT_TAG_GPOS HB_TAG('G','P','O','S')
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录