Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
d2db71fd
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看板
提交
d2db71fd
编写于
3月 28, 2019
作者:
B
Behdad Esfahbod
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Use internal bsearch() for language tags
Fixes
https://github.com/harfbuzz/harfbuzz/pull/1639
上级
21bb80eb
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
22 addition
and
24 deletion
+22
-24
src/hb-ot-tag.cc
src/hb-ot-tag.cc
+22
-24
未找到文件。
src/hb-ot-tag.cc
浏览文件 @
d2db71fd
...
...
@@ -171,24 +171,6 @@ hb_ot_tag_to_script (hb_tag_t tag)
/* hb_language_t */
static
int
lang_compare_first_component
(
const
void
*
pa
,
const
void
*
pb
)
{
const
char
*
a
=
(
const
char
*
)
pa
;
const
char
*
b
=
(
const
char
*
)
pb
;
unsigned
int
da
,
db
;
const
char
*
p
;
p
=
strchr
(
a
,
'-'
);
da
=
p
?
(
unsigned
int
)
(
p
-
a
)
:
strlen
(
a
);
p
=
strchr
(
b
,
'-'
);
db
=
p
?
(
unsigned
int
)
(
p
-
b
)
:
strlen
(
b
);
return
strncmp
(
a
,
b
,
MAX
(
da
,
db
));
}
static
bool
subtag_matches
(
const
char
*
lang_str
,
const
char
*
limit
,
...
...
@@ -213,10 +195,28 @@ lang_matches (const char *lang_str, const char *spec)
(
lang_str
[
len
]
==
'\0'
||
lang_str
[
len
]
==
'-'
);
}
typedef
struct
{
struct
LangTag
{
char
language
[
4
];
hb_tag_t
tags
[
HB_OT_MAX_TAGS_PER_LANGUAGE
];
}
LangTag
;
int
cmp
(
const
char
*
a
)
const
{
const
char
*
b
=
this
->
language
;
unsigned
int
da
,
db
;
const
char
*
p
;
p
=
strchr
(
a
,
'-'
);
da
=
p
?
(
unsigned
int
)
(
p
-
a
)
:
strlen
(
a
);
p
=
strchr
(
b
,
'-'
);
db
=
p
?
(
unsigned
int
)
(
p
-
b
)
:
strlen
(
b
);
return
strncmp
(
a
,
b
,
MAX
(
da
,
db
));
}
int
cmp
(
const
LangTag
*
that
)
const
{
return
cmp
(
that
->
language
);
}
};
#include "hb-ot-tag-table.hh"
...
...
@@ -263,9 +263,7 @@ hb_ot_tags_from_language (const char *lang_str,
ISALPHA
(
s
[
1
]))
lang_str
=
s
+
1
;
}
lang_tag
=
(
LangTag
*
)
bsearch
(
lang_str
,
ot_languages
,
ARRAY_LENGTH
(
ot_languages
),
sizeof
(
LangTag
),
lang_compare_first_component
);
lang_tag
=
hb_sorted_array
(
ot_languages
).
bsearch
(
lang_str
);
if
(
lang_tag
)
{
unsigned
int
i
;
...
...
@@ -507,7 +505,7 @@ test_langs_sorted ()
{
for
(
unsigned
int
i
=
1
;
i
<
ARRAY_LENGTH
(
ot_languages
);
i
++
)
{
int
c
=
lang_compare_first_component
(
ot_languages
[
i
-
1
].
language
,
ot_languages
[
i
].
language
);
int
c
=
ot_languages
[
i
].
cmp
(
&
ot_languages
[
i
-
1
]
);
if
(
c
>=
0
)
{
fprintf
(
stderr
,
"ot_languages not sorted at index %d: %s %d %s
\n
"
,
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录