Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
cd7ea4f7
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看板
提交
cd7ea4f7
编写于
8月 14, 2014
作者:
B
Behdad Esfahbod
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Make hb_object_t members private
In preparation for fixing:
https://code.google.com/p/chromium/issues/detail?id=403594
上级
c4308f89
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
22 addition
and
6 deletion
+22
-6
src/hb-object-private.hh
src/hb-object-private.hh
+21
-5
src/hb-set-private.hh
src/hb-set-private.hh
+1
-1
未找到文件。
src/hb-object-private.hh
浏览文件 @
cd7ea4f7
...
@@ -68,8 +68,6 @@ struct hb_reference_count_t
...
@@ -68,8 +68,6 @@ struct hb_reference_count_t
#define HB_USER_DATA_ARRAY_INIT {HB_MUTEX_INIT, HB_LOCKABLE_SET_INIT}
#define HB_USER_DATA_ARRAY_INIT {HB_MUTEX_INIT, HB_LOCKABLE_SET_INIT}
struct
hb_user_data_array_t
struct
hb_user_data_array_t
{
{
/* TODO Add tracing. */
struct
hb_user_data_item_t
{
struct
hb_user_data_item_t
{
hb_user_data_key_t
*
key
;
hb_user_data_key_t
*
key
;
void
*
data
;
void
*
data
;
...
@@ -106,6 +104,9 @@ struct hb_object_header_t
...
@@ -106,6 +104,9 @@ struct hb_object_header_t
#define HB_OBJECT_HEADER_STATIC {HB_REFERENCE_COUNT_INVALID, HB_USER_DATA_ARRAY_INIT}
#define HB_OBJECT_HEADER_STATIC {HB_REFERENCE_COUNT_INVALID, HB_USER_DATA_ARRAY_INIT}
private:
template
<
typename
Type
>
friend
Type
*
hb_object_create
(
void
);
static
inline
void
*
create
(
unsigned
int
size
)
{
static
inline
void
*
create
(
unsigned
int
size
)
{
hb_object_header_t
*
obj
=
(
hb_object_header_t
*
)
calloc
(
1
,
size
);
hb_object_header_t
*
obj
=
(
hb_object_header_t
*
)
calloc
(
1
,
size
);
...
@@ -115,21 +116,25 @@ struct hb_object_header_t
...
@@ -115,21 +116,25 @@ struct hb_object_header_t
return
obj
;
return
obj
;
}
}
template
<
typename
Type
>
friend
void
hb_object_init
(
Type
*
obj
);
inline
void
init
(
void
)
{
inline
void
init
(
void
)
{
ref_count
.
init
(
1
);
ref_count
.
init
(
1
);
user_data
.
init
();
user_data
.
init
();
}
}
template
<
typename
Type
>
friend
bool
hb_object_is_inert
(
const
Type
*
obj
);
inline
bool
is_inert
(
void
)
const
{
inline
bool
is_inert
(
void
)
const
{
return
unlikely
(
ref_count
.
is_invalid
());
return
unlikely
(
ref_count
.
is_invalid
());
}
}
template
<
typename
Type
>
friend
Type
*
hb_object_reference
(
Type
*
obj
);
inline
void
reference
(
void
)
{
inline
void
reference
(
void
)
{
if
(
unlikely
(
!
this
||
this
->
is_inert
()))
if
(
unlikely
(
!
this
||
this
->
is_inert
()))
return
;
return
;
ref_count
.
inc
();
ref_count
.
inc
();
}
}
template
<
typename
Type
>
friend
bool
hb_object_destroy
(
Type
*
obj
);
inline
bool
destroy
(
void
)
{
inline
bool
destroy
(
void
)
{
if
(
unlikely
(
!
this
||
this
->
is_inert
()))
if
(
unlikely
(
!
this
||
this
->
is_inert
()))
return
false
;
return
false
;
...
@@ -142,6 +147,11 @@ struct hb_object_header_t
...
@@ -142,6 +147,11 @@ struct hb_object_header_t
return
true
;
return
true
;
}
}
template
<
typename
Type
>
friend
bool
hb_object_set_user_data
(
Type
*
obj
,
hb_user_data_key_t
*
key
,
void
*
data
,
hb_destroy_func_t
destroy
,
hb_bool_t
replace
);
inline
bool
set_user_data
(
hb_user_data_key_t
*
key
,
inline
bool
set_user_data
(
hb_user_data_key_t
*
key
,
void
*
data
,
void
*
data
,
hb_destroy_func_t
destroy_func
,
hb_destroy_func_t
destroy_func
,
...
@@ -152,6 +162,8 @@ struct hb_object_header_t
...
@@ -152,6 +162,8 @@ struct hb_object_header_t
return
user_data
.
set
(
key
,
data
,
destroy_func
,
replace
);
return
user_data
.
set
(
key
,
data
,
destroy_func
,
replace
);
}
}
template
<
typename
type
>
friend
void
*
hb_object_get_user_data
(
type
*
obj
,
hb_user_data_key_t
*
key
);
inline
void
*
get_user_data
(
hb_user_data_key_t
*
key
)
{
inline
void
*
get_user_data
(
hb_user_data_key_t
*
key
)
{
if
(
unlikely
(
!
this
||
this
->
is_inert
()))
if
(
unlikely
(
!
this
||
this
->
is_inert
()))
return
NULL
;
return
NULL
;
...
@@ -159,17 +171,15 @@ struct hb_object_header_t
...
@@ -159,17 +171,15 @@ struct hb_object_header_t
return
user_data
.
get
(
key
);
return
user_data
.
get
(
key
);
}
}
template
<
typename
Type
>
friend
void
hb_object_trace
(
const
Type
*
obj
,
const
char
*
function
);
inline
void
trace
(
const
char
*
function
)
const
{
inline
void
trace
(
const
char
*
function
)
const
{
if
(
unlikely
(
!
this
))
return
;
if
(
unlikely
(
!
this
))
return
;
/* TODO We cannot use DEBUG_MSG_FUNC here since that one currently only
* prints the class name and throws away the template info. */
DEBUG_MSG
(
OBJECT
,
(
void
*
)
this
,
DEBUG_MSG
(
OBJECT
,
(
void
*
)
this
,
"%s refcount=%d"
,
"%s refcount=%d"
,
function
,
function
,
this
?
ref_count
.
ref_count
:
0
);
this
?
ref_count
.
ref_count
:
0
);
}
}
private:
ASSERT_POD
();
ASSERT_POD
();
};
};
...
@@ -181,6 +191,7 @@ static inline void hb_object_trace (const Type *obj, const char *function)
...
@@ -181,6 +191,7 @@ static inline void hb_object_trace (const Type *obj, const char *function)
{
{
obj
->
header
.
trace
(
function
);
obj
->
header
.
trace
(
function
);
}
}
template
<
typename
Type
>
template
<
typename
Type
>
static
inline
Type
*
hb_object_create
(
void
)
static
inline
Type
*
hb_object_create
(
void
)
{
{
...
@@ -189,6 +200,11 @@ static inline Type *hb_object_create (void)
...
@@ -189,6 +200,11 @@ static inline Type *hb_object_create (void)
return
obj
;
return
obj
;
}
}
template
<
typename
Type
>
template
<
typename
Type
>
static
inline
void
hb_object_init
(
Type
*
obj
)
{
obj
->
header
.
init
();
}
template
<
typename
Type
>
static
inline
bool
hb_object_is_inert
(
const
Type
*
obj
)
static
inline
bool
hb_object_is_inert
(
const
Type
*
obj
)
{
{
return
unlikely
(
obj
->
header
.
is_inert
());
return
unlikely
(
obj
->
header
.
is_inert
());
...
...
src/hb-set-private.hh
浏览文件 @
cd7ea4f7
...
@@ -150,7 +150,7 @@ struct hb_set_t
...
@@ -150,7 +150,7 @@ struct hb_set_t
bool
in_error
;
bool
in_error
;
inline
void
init
(
void
)
{
inline
void
init
(
void
)
{
h
eader
.
init
(
);
h
b_object_init
(
this
);
clear
();
clear
();
}
}
inline
void
fini
(
void
)
{
inline
void
fini
(
void
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录