Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
29c67d3f
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看板
提交
29c67d3f
编写于
4月 27, 2011
作者:
B
Behdad Esfahbod
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add initial implementation of user_data to objects
上级
47e71d96
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
193 addition
and
4 deletion
+193
-4
src/hb-common.h
src/hb-common.h
+9
-2
src/hb-object-private.hh
src/hb-object-private.hh
+184
-2
未找到文件。
src/hb-common.h
浏览文件 @
29c67d3f
...
@@ -68,8 +68,6 @@ typedef union _hb_var_int_t {
...
@@ -68,8 +68,6 @@ typedef union _hb_var_int_t {
int8_t
i8
[
4
];
int8_t
i8
[
4
];
}
hb_var_int_t
;
}
hb_var_int_t
;
typedef
void
(
*
hb_destroy_func_t
)
(
void
*
user_data
);
/* hb_tag_t */
/* hb_tag_t */
...
@@ -287,6 +285,15 @@ hb_direction_t
...
@@ -287,6 +285,15 @@ hb_direction_t
hb_script_get_horizontal_direction
(
hb_script_t
script
);
hb_script_get_horizontal_direction
(
hb_script_t
script
);
/* User data */
typedef
struct
_hb_user_data_key_t
{
char
unused
;
}
hb_user_data_key_t
;
typedef
void
(
*
hb_destroy_func_t
)
(
void
*
user_data
);
HB_END_DECLS
HB_END_DECLS
#endif
/* HB_COMMON_H */
#endif
/* HB_COMMON_H */
src/hb-object-private.hh
浏览文件 @
29c67d3f
...
@@ -44,10 +44,172 @@ HB_BEGIN_DECLS
...
@@ -44,10 +44,172 @@ HB_BEGIN_DECLS
#endif
#endif
/* user_data */
HB_END_DECLS
template
<
typename
Type
,
unsigned
int
StaticSize
>
struct
hb_static_array_t
{
unsigned
int
len
;
unsigned
int
allocated
;
Type
*
array
;
Type
static_array
[
StaticSize
];
void
finish
(
void
)
{
for
(
unsigned
i
=
0
;
i
<
len
;
i
++
)
array
[
i
].
finish
();
}
inline
Type
&
operator
[]
(
unsigned
int
i
)
{
return
array
[
i
];
}
inline
Type
*
push
(
void
)
{
if
(
!
array
)
{
array
=
static_array
;
allocated
=
ARRAY_LENGTH
(
static_array
);
}
if
(
likely
(
len
<
allocated
))
return
&
array
[
len
++
];
/* Need to reallocate */
unsigned
int
new_allocated
=
allocated
+
(
allocated
>>
1
)
+
8
;
Type
*
new_array
;
if
(
array
==
static_array
)
{
new_array
=
(
Type
*
)
calloc
(
new_allocated
,
sizeof
(
Type
));
if
(
new_array
)
{
memcpy
(
new_array
,
array
,
len
*
sizeof
(
Type
));
array
=
new_array
;
}
}
else
{
bool
overflows
=
new_allocated
>=
((
unsigned
int
)
-
1
)
/
sizeof
(
Type
);
if
(
unlikely
(
overflows
))
new_array
=
NULL
;
else
new_array
=
(
Type
*
)
realloc
(
array
,
new_allocated
*
sizeof
(
Type
));
if
(
new_array
)
{
free
(
array
);
array
=
new_array
;
}
}
if
((
len
<
allocated
))
return
&
array
[
len
++
];
else
return
NULL
;
}
inline
void
pop
(
void
)
{
len
--
;
/* TODO: shrink array if needed */
}
};
template
<
typename
Type
>
struct
hb_array_t
:
hb_static_array_t
<
Type
,
2
>
{};
template
<
typename
Key
,
typename
Value
>
struct
hb_map_t
{
struct
item_t
{
Key
key
;
/* unsigned int hash; */
Value
value
;
void
finish
(
void
)
{
value
.
finish
();
}
};
hb_array_t
<
item_t
>
items
;
private:
inline
item_t
*
find
(
Key
key
)
{
if
(
unlikely
(
!
key
))
return
NULL
;
for
(
unsigned
int
i
=
0
;
i
<
items
.
len
;
i
++
)
if
(
key
==
items
[
i
].
key
)
return
&
items
[
i
];
return
NULL
;
}
public:
inline
bool
set
(
Key
key
,
Value
&
value
)
{
if
(
unlikely
(
!
key
))
return
NULL
;
item_t
*
item
;
item
=
find
(
key
);
if
(
item
)
item
->
finish
();
else
item
=
items
.
push
();
if
(
unlikely
(
!
item
))
return
false
;
item
->
key
=
key
;
item
->
value
=
value
;
return
true
;
}
inline
void
unset
(
Key
&
key
)
{
item_t
*
item
;
item
=
find
(
key
);
if
(
!
item
)
return
;
item
->
finish
();
items
[
items
.
len
-
1
]
=
*
item
;
items
.
pop
();
}
inline
Value
*
get
(
Key
key
)
{
item_t
*
item
=
find
(
key
);
return
item
?
&
item
->
value
:
NULL
;
}
void
finish
(
void
)
{
items
.
finish
();
}
};
HB_BEGIN_DECLS
typedef
struct
{
void
*
data
;
hb_destroy_func_t
destroy
;
void
finish
(
void
)
{
if
(
destroy
)
destroy
(
data
);
}
}
hb_user_data_t
;
struct
hb_user_data_array_t
{
hb_map_t
<
hb_user_data_key_t
*
,
hb_user_data_t
>
map
;
inline
bool
set
(
hb_user_data_key_t
*
key
,
void
*
data
,
hb_destroy_func_t
destroy
)
{
if
(
!
data
&&
!
destroy
)
{
map
.
unset
(
key
);
return
true
;
}
hb_user_data_t
user_data
=
{
data
,
destroy
};
return
map
.
set
(
key
,
user_data
);
}
inline
void
*
get
(
hb_user_data_key_t
*
key
)
{
return
map
.
get
(
key
);
}
void
finish
(
void
)
{
map
.
finish
();
}
};
typedef
struct
_hb_object_header_t
hb_object_header_t
;
typedef
struct
_hb_object_header_t
hb_object_header_t
;
struct
_hb_object_header_t
{
struct
_hb_object_header_t
{
hb_reference_count_t
ref_count
;
hb_reference_count_t
ref_count
;
hb_user_data_array_t
user_data
;
#define HB_OBJECT_HEADER_STATIC {HB_REFERENCE_COUNT_INVALID}
#define HB_OBJECT_HEADER_STATIC {HB_REFERENCE_COUNT_INVALID}
...
@@ -64,7 +226,9 @@ struct _hb_object_header_t {
...
@@ -64,7 +226,9 @@ struct _hb_object_header_t {
ref_count
.
init
(
1
);
ref_count
.
init
(
1
);
}
}
inline
bool
is_inert
(
void
)
const
{
return
unlikely
(
ref_count
.
is_invalid
());
}
inline
bool
is_inert
(
void
)
const
{
return
unlikely
(
ref_count
.
is_invalid
());
}
inline
void
reference
(
void
)
{
inline
void
reference
(
void
)
{
if
(
unlikely
(
!
this
||
this
->
is_inert
()))
if
(
unlikely
(
!
this
||
this
->
is_inert
()))
...
@@ -75,7 +239,25 @@ struct _hb_object_header_t {
...
@@ -75,7 +239,25 @@ struct _hb_object_header_t {
inline
bool
destroy
(
void
)
{
inline
bool
destroy
(
void
)
{
if
(
unlikely
(
!
this
||
this
->
is_inert
()))
if
(
unlikely
(
!
this
||
this
->
is_inert
()))
return
false
;
return
false
;
return
ref_count
.
dec
()
==
1
;
if
(
ref_count
.
dec
()
!=
1
)
return
false
;
user_data
.
finish
();
return
true
;
}
inline
bool
set_user_data
(
hb_user_data_key_t
*
key
,
void
*
data
,
hb_destroy_func_t
destroy
)
{
if
(
unlikely
(
!
this
||
this
->
is_inert
()))
return
false
;
return
user_data
.
set
(
key
,
data
,
destroy
);
}
inline
void
*
get_user_data
(
hb_user_data_key_t
*
key
)
{
return
user_data
.
get
(
key
);
}
}
inline
void
trace
(
const
char
*
function
)
const
{
inline
void
trace
(
const
char
*
function
)
const
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录