Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
d5f0d7c9
T
Third Party Harfbuzz
项目概览
OpenHarmony
/
Third Party Harfbuzz
2 年多 前同步成功
通知
1
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看板
提交
d5f0d7c9
编写于
11月 07, 2015
作者:
B
Behdad Esfahbod
浏览文件
操作
浏览文件
下载
差异文件
Merge pull request #167 from KonstantinRitt/unicode_cp_opt
Micro optimizations to UTF-16 and UTF-32 codecs
上级
04ff23e7
529a9331
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
25 addition
and
21 deletion
+25
-21
src/hb-utf-private.hh
src/hb-utf-private.hh
+25
-21
未找到文件。
src/hb-utf-private.hh
浏览文件 @
d5f0d7c9
...
...
@@ -146,11 +146,11 @@ struct hb_utf16_t
return
text
;
}
if
(
likely
(
hb_in_range
(
c
,
0xD800u
,
0xDBFFu
)
))
if
(
likely
(
c
<=
0xDBFFu
&&
text
<
end
))
{
/* High-surrogate in c */
hb_codepoint_t
l
;
if
(
text
<
end
&&
((
l
=
*
text
),
likely
(
hb_in_range
(
l
,
0xDC00u
,
0xDFFFu
)
)))
hb_codepoint_t
l
=
*
text
;
if
(
likely
(
hb_in_range
(
l
,
0xDC00u
,
0xDFFFu
)))
{
/* Low-surrogate in l */
*
unicode
=
(
c
<<
10
)
+
l
-
((
0xD800u
<<
10
)
-
0x10000u
+
0xDC00u
);
...
...
@@ -170,8 +170,7 @@ struct hb_utf16_t
hb_codepoint_t
*
unicode
,
hb_codepoint_t
replacement
)
{
const
uint16_t
*
end
=
text
--
;
hb_codepoint_t
c
=
*
text
;
hb_codepoint_t
c
=
*--
text
;
if
(
likely
(
!
hb_in_range
(
c
,
0xD800u
,
0xDFFFu
)))
{
...
...
@@ -179,14 +178,22 @@ struct hb_utf16_t
return
text
;
}
if
(
likely
(
start
<
text
&&
hb_in_range
(
c
,
0xDC00u
,
0xDFFFu
)))
text
--
;
if
(
likely
(
next
(
text
,
end
,
unicode
,
replacement
)
==
end
))
return
text
;
if
(
likely
(
c
>=
0xDC00u
&&
start
<
text
))
{
/* Low-surrogate in c */
hb_codepoint_t
h
=
text
[
-
1
];
if
(
likely
(
hb_in_range
(
h
,
0xD800u
,
0xDBFFu
)))
{
/* High-surrogate in h */
*
unicode
=
(
h
<<
10
)
+
c
-
((
0xD800u
<<
10
)
-
0x10000u
+
0xDC00u
);
text
--
;
return
text
;
}
}
/* Lonely / out-of-order surrogate. */
*
unicode
=
replacement
;
return
end
-
1
;
return
text
;
}
...
...
@@ -211,14 +218,9 @@ struct hb_utf32_t
hb_codepoint_t
*
unicode
,
hb_codepoint_t
replacement
)
{
hb_codepoint_t
c
=
*
text
++
;
if
(
validate
&&
unlikely
(
c
>
0x10FFFFu
||
hb_in_range
(
c
,
0xD800u
,
0xDFFFu
)))
goto
error
;
*
unicode
=
c
;
return
text
;
error:
*
unicode
=
replacement
;
hb_codepoint_t
c
=
*
unicode
=
*
text
++
;
if
(
validate
&&
unlikely
(
c
>=
0xD800u
&&
(
c
<=
0xDFFFu
||
c
>
0x10FFFFu
)))
*
unicode
=
replacement
;
return
text
;
}
...
...
@@ -228,8 +230,10 @@ struct hb_utf32_t
hb_codepoint_t
*
unicode
,
hb_codepoint_t
replacement
)
{
next
(
text
-
1
,
text
,
unicode
,
replacement
);
return
text
-
1
;
hb_codepoint_t
c
=
*
unicode
=
*--
text
;
if
(
validate
&&
unlikely
(
c
>=
0xD800u
&&
(
c
<=
0xDFFFu
||
c
>
0x10FFFFu
)))
*
unicode
=
replacement
;
return
text
;
}
static
inline
unsigned
int
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录