Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Harfbuzz
提交
c09a607a
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看板
体验新版 GitCode,发现更多精彩内容 >>
提交
c09a607a
编写于
7月 11, 2014
作者:
B
Behdad Esfahbod
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Use hb_in_range() for arabic and indic tables
Though, looks like gcc was smart enough to produce the same code before...
上级
7627100f
变更
4
展开全部
隐藏空白更改
内联
并排
Showing
4 changed file
with
268 addition
and
268 deletion
+268
-268
src/gen-arabic-table.py
src/gen-arabic-table.py
+9
-9
src/gen-indic-table.py
src/gen-indic-table.py
+5
-5
src/hb-ot-shape-complex-arabic-table.hh
src/hb-ot-shape-complex-arabic-table.hh
+210
-210
src/hb-ot-shape-complex-indic-table.cc
src/hb-ot-shape-complex-indic-table.cc
+44
-44
未找到文件。
src/gen-arabic-table.py
浏览文件 @
c09a607a
...
...
@@ -90,7 +90,7 @@ def print_joining_table(f):
for
start
,
end
in
ranges
:
print
print
"#define joining_offset_0x%04x %d"
%
(
start
,
offset
)
print
"#define joining_offset_0x%04x
u
%d"
%
(
start
,
offset
)
for
u
in
range
(
start
,
end
+
1
):
...
...
@@ -130,11 +130,11 @@ def print_joining_table(f):
print
" {"
pages
=
set
([
u
>>
page_bits
for
u
in
[
s
for
s
,
e
in
ranges
]
+
[
e
for
s
,
e
in
ranges
]])
for
p
in
sorted
(
pages
):
print
" case 0x%0X:"
%
p
print
" case 0x%0X
u
:"
%
p
for
(
start
,
end
)
in
ranges
:
if
p
not
in
[
start
>>
page_bits
,
end
>>
page_bits
]:
continue
offset
=
"joining_offset_0x%04x"
%
start
print
" if (
0x%04X <= u && u <= 0x%04X) return joining_table[u - 0x%04X
+ %s];"
%
(
start
,
end
,
start
,
offset
)
offset
=
"joining_offset_0x%04x
u
"
%
start
print
" if (
hb_in_range (u, 0x%04Xu, 0x%04Xu)) return joining_table[u - 0x%04Xu
+ %s];"
%
(
start
,
end
,
start
,
offset
)
print
" break;"
print
""
print
" default:"
...
...
@@ -195,13 +195,13 @@ def print_shaping_table(f):
for
u
in
range
(
min_u
,
max_u
+
1
):
s
=
[
shapes
[
u
][
shape
]
if
u
in
shapes
and
shape
in
shapes
[
u
]
else
0
for
shape
in
[
'initial'
,
'medial'
,
'final'
,
'isolated'
]]
value
=
', '
.
join
(
"0x%04X"
%
c
for
c
in
s
)
value
=
', '
.
join
(
"0x%04X
u
"
%
c
for
c
in
s
)
print
" {%s}, /* U+%04X %s */"
%
(
value
,
u
,
names
[
u
]
if
u
in
names
else
""
)
print
"};"
print
print
"#define SHAPING_TABLE_FIRST 0x%04X"
%
min_u
print
"#define SHAPING_TABLE_LAST 0x%04X"
%
max_u
print
"#define SHAPING_TABLE_FIRST 0x%04X
u
"
%
min_u
print
"#define SHAPING_TABLE_LAST 0x%04X
u
"
%
max_u
print
ligas
=
{}
...
...
@@ -231,9 +231,9 @@ def print_shaping_table(f):
keys
.
sort
()
for
first
in
keys
:
print
" { 0x%04X, {"
%
(
first
)
print
" { 0x%04X
u
, {"
%
(
first
)
for
liga
in
ligas
[
first
]:
print
" { 0x%04X
, 0x%04X
}, /* %s */"
%
(
liga
[
0
],
liga
[
1
],
names
[
liga
[
1
]])
print
" { 0x%04X
u, 0x%04Xu
}, /* %s */"
%
(
liga
[
0
],
liga
[
1
],
names
[
liga
[
1
]])
print
" }},"
print
"};"
...
...
src/gen-indic-table.py
浏览文件 @
c09a607a
...
...
@@ -185,7 +185,7 @@ for u in uu:
offset
+=
ends
[
-
1
]
-
starts
[
-
1
]
print
print
print
"#define indic_offset_0x%04x %d"
%
(
start
,
offset
)
print
"#define indic_offset_0x%04x
u
%d"
%
(
start
,
offset
)
starts
.
append
(
start
)
print_block
(
block
,
start
,
end
,
data
)
...
...
@@ -205,14 +205,14 @@ print " switch (u >> %d)" % page_bits
print
" {"
pages
=
set
([
u
>>
page_bits
for
u
in
starts
+
ends
+
singles
.
keys
()])
for
p
in
sorted
(
pages
):
print
" case 0x%0X:"
%
p
print
" case 0x%0X
u
:"
%
p
for
(
start
,
end
)
in
zip
(
starts
,
ends
):
if
p
not
in
[
start
>>
page_bits
,
end
>>
page_bits
]:
continue
offset
=
"indic_offset_0x%04x"
%
start
print
" if (
0x%04X <= u && u <= 0x%04X) return indic_table[u - 0x%04X
+ %s];"
%
(
start
,
end
,
start
,
offset
)
offset
=
"indic_offset_0x%04x
u
"
%
start
print
" if (
hb_in_range (u, 0x%04Xu, 0x%04Xu)) return indic_table[u - 0x%04Xu
+ %s];"
%
(
start
,
end
,
start
,
offset
)
for
u
,
d
in
singles
.
items
():
if
p
!=
u
>>
page_bits
:
continue
print
" if (unlikely (u == 0x%04X)) return _(%s,%s);"
%
(
u
,
short
[
0
][
d
[
0
]],
short
[
1
][
d
[
1
]])
print
" if (unlikely (u == 0x%04X
u
)) return _(%s,%s);"
%
(
u
,
short
[
0
][
d
[
0
]],
short
[
1
][
d
[
1
]])
print
" break;"
print
""
print
" default:"
...
...
src/hb-ot-shape-complex-arabic-table.hh
浏览文件 @
c09a607a
此差异已折叠。
点击以展开。
src/hb-ot-shape-complex-indic-table.cc
浏览文件 @
c09a607a
...
...
@@ -70,7 +70,7 @@
static
const
INDIC_TABLE_ELEMENT_TYPE
indic_table
[]
=
{
#define indic_offset_0x0028 0
#define indic_offset_0x0028
u
0
/* Basic Latin */
...
...
@@ -79,14 +79,14 @@ static const INDIC_TABLE_ELEMENT_TYPE indic_table[] = {
/* 0030 */
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
/* 0038 */
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
#define indic_offset_0x00d0 24
#define indic_offset_0x00d0
u
24
/* Latin-1 Supplement */
/* 00D0 */
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
CP
,
x
),
#define indic_offset_0x0900 32
#define indic_offset_0x0900
u
32
/* Devanagari */
...
...
@@ -278,7 +278,7 @@ static const INDIC_TABLE_ELEMENT_TYPE indic_table[] = {
/* 0DE8 */
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
/* 0DF0 */
_
(
x
,
x
),
_
(
x
,
x
),
_
(
M
,
R
),
_
(
M
,
R
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
#define indic_offset_0x1000 1304
#define indic_offset_0x1000
u
1304
/* Myanmar */
...
...
@@ -304,7 +304,7 @@ static const INDIC_TABLE_ELEMENT_TYPE indic_table[] = {
/* 1090 */
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
/* 1098 */
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
TM
,
x
),
_
(
TM
,
x
),
_
(
M
,
R
),
_
(
M
,
T
),
_
(
x
,
x
),
_
(
x
,
x
),
#define indic_offset_0x1700 1464
#define indic_offset_0x1700
u
1464
/* Tagalog */
...
...
@@ -352,7 +352,7 @@ static const INDIC_TABLE_ELEMENT_TYPE indic_table[] = {
/* 17E0 */
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
/* 17E8 */
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
#define indic_offset_0x1900 1704
#define indic_offset_0x1900
u
1704
/* Limbu */
...
...
@@ -422,7 +422,7 @@ static const INDIC_TABLE_ELEMENT_TYPE indic_table[] = {
/* 1A90 */
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
/* 1A98 */
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
#define indic_offset_0x1b00 2120
#define indic_offset_0x1b00
u
2120
/* Balinese */
...
...
@@ -479,7 +479,7 @@ static const INDIC_TABLE_ELEMENT_TYPE indic_table[] = {
/* 1C40 */
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
/* 1C48 */
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
C
,
x
),
_
(
C
,
x
),
_
(
C
,
x
),
#define indic_offset_0x1cd0 2456
#define indic_offset_0x1cd0
u
2456
/* Vedic Extensions */
...
...
@@ -490,7 +490,7 @@ static const INDIC_TABLE_ELEMENT_TYPE indic_table[] = {
/* 1CE8 */
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
/* 1CF0 */
_
(
x
,
x
),
_
(
x
,
x
),
_
(
Vs
,
x
),
_
(
Vs
,
x
),
_
(
TM
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
#define indic_offset_0x2008 2496
#define indic_offset_0x2008
u
2496
/* General Punctuation */
...
...
@@ -498,7 +498,7 @@ static const INDIC_TABLE_ELEMENT_TYPE indic_table[] = {
/* 2008 */
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
ZWNJ
,
x
),
_
(
ZWJ
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
/* 2010 */
_
(
x
,
x
),
_
(
x
,
x
),
_
(
CP
,
x
),
_
(
CP
,
x
),
_
(
CP
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
#define indic_offset_0xa800 2512
#define indic_offset_0xa800
u
2512
/* Syloti Nagri */
...
...
@@ -632,7 +632,7 @@ static const INDIC_TABLE_ELEMENT_TYPE indic_table[] = {
/* AAE8 */
_
(
C
,
x
),
_
(
C
,
x
),
_
(
C
,
x
),
_
(
M
,
L
),
_
(
M
,
B
),
_
(
M
,
T
),
_
(
M
,
L
),
_
(
M
,
R
),
/* AAF0 */
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
Vs
,
x
),
_
(
IS
,
x
),
_
(
x
,
x
),
#define indic_offset_0xabc0 3272
#define indic_offset_0xabc0
u
3272
/* Meetei Mayek */
...
...
@@ -646,7 +646,7 @@ static const INDIC_TABLE_ELEMENT_TYPE indic_table[] = {
/* ABF0 */
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
/* ABF8 */
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
#define indic_offset_0x10a00 3336
#define indic_offset_0x10a00
u
3336
/* Kharoshthi */
...
...
@@ -661,7 +661,7 @@ static const INDIC_TABLE_ELEMENT_TYPE indic_table[] = {
/* 10A38 */
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
IS
,
x
),
/* 10A40 */
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
#define indic_offset_0x11000 3408
#define indic_offset_0x11000
u
3408
/* Brahmi */
...
...
@@ -694,7 +694,7 @@ static const INDIC_TABLE_ELEMENT_TYPE indic_table[] = {
/* 110B0 */
_
(
M
,
R
),
_
(
M
,
L
),
_
(
M
,
R
),
_
(
M
,
B
),
_
(
M
,
B
),
_
(
M
,
T
),
_
(
M
,
T
),
_
(
M
,
R
),
/* 110B8 */
_
(
M
,
R
),
_
(
V
,
B
),
_
(
N
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
#define indic_offset_0x11100 3600
#define indic_offset_0x11100
u
3600
/* Chakma */
...
...
@@ -751,7 +751,7 @@ static const INDIC_TABLE_ELEMENT_TYPE indic_table[] = {
/* 11228 */
_
(
C
,
x
),
_
(
C
,
x
),
_
(
C
,
x
),
_
(
C
,
x
),
_
(
M
,
R
),
_
(
M
,
R
),
_
(
M
,
R
),
_
(
M
,
B
),
/* 11230 */
_
(
M
,
T
),
_
(
M
,
T
),
_
(
M
,
TR
),
_
(
M
,
TR
),
_
(
Bi
,
x
),
_
(
V
,
R
),
_
(
N
,
x
),
_
(
GM
,
T
),
#define indic_offset_0x112b0 3912
#define indic_offset_0x112b0
u
3912
/* Khudawadi */
...
...
@@ -785,7 +785,7 @@ static const INDIC_TABLE_ELEMENT_TYPE indic_table[] = {
/* 11368 */
_
(
Ca
,
x
),
_
(
Ca
,
x
),
_
(
Ca
,
x
),
_
(
Ca
,
x
),
_
(
Ca
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
/* 11370 */
_
(
Ca
,
x
),
_
(
Ca
,
x
),
_
(
Ca
,
x
),
_
(
Ca
,
x
),
_
(
Ca
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
#define indic_offset_0x11480 4112
#define indic_offset_0x11480
u
4112
/* Tirhuta */
...
...
@@ -803,7 +803,7 @@ static const INDIC_TABLE_ELEMENT_TYPE indic_table[] = {
/* 114D0 */
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
Nd
,
x
),
/* 114D8 */
_
(
Nd
,
x
),
_
(
Nd
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
#define indic_offset_0x11580 4208
#define indic_offset_0x11580
u
4208
/* Siddham */
...
...
@@ -818,7 +818,7 @@ static const INDIC_TABLE_ELEMENT_TYPE indic_table[] = {
/* 115B8 */
_
(
M
,
L
),
_
(
M
,
TL
),
_
(
M
,
LR
),
_
(
M
,
TLR
),
_
(
Bi
,
x
),
_
(
Bi
,
x
),
_
(
Vs
,
x
),
_
(
V
,
B
),
/* 115C0 */
_
(
N
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
_
(
x
,
x
),
#define indic_offset_0x11600 4280
#define indic_offset_0x11600
u
4280
/* Modi */
...
...
@@ -860,42 +860,42 @@ hb_indic_get_categories (hb_codepoint_t u)
{
switch
(
u
>>
12
)
{
case
0x0
:
if
(
0x0028
<=
u
&&
u
<=
0x0040
)
return
indic_table
[
u
-
0x0028
+
indic_offset_0x0028
];
if
(
0x00D0
<=
u
&&
u
<=
0x00D8
)
return
indic_table
[
u
-
0x00D0
+
indic_offset_0x00d0
];
if
(
0x0900
<=
u
&&
u
<=
0x0DF8
)
return
indic_table
[
u
-
0x0900
+
indic_offset_0x0900
];
if
(
unlikely
(
u
==
0x00A0
))
return
_
(
CP
,
x
);
case
0x0
u
:
if
(
hb_in_range
(
u
,
0x0028u
,
0x0040u
))
return
indic_table
[
u
-
0x0028u
+
indic_offset_0x0028u
];
if
(
hb_in_range
(
u
,
0x00D0u
,
0x00D8u
))
return
indic_table
[
u
-
0x00D0u
+
indic_offset_0x00d0u
];
if
(
hb_in_range
(
u
,
0x0900u
,
0x0DF8u
))
return
indic_table
[
u
-
0x0900u
+
indic_offset_0x0900u
];
if
(
unlikely
(
u
==
0x00A0
u
))
return
_
(
CP
,
x
);
break
;
case
0x1
:
if
(
0x1000
<=
u
&&
u
<=
0x10A0
)
return
indic_table
[
u
-
0x1000
+
indic_offset_0x1000
];
if
(
0x1700
<=
u
&&
u
<=
0x17F0
)
return
indic_table
[
u
-
0x1700
+
indic_offset_0x1700
];
if
(
0x1900
<=
u
&&
u
<=
0x1AA0
)
return
indic_table
[
u
-
0x1900
+
indic_offset_0x1900
];
if
(
0x1B00
<=
u
&&
u
<=
0x1C50
)
return
indic_table
[
u
-
0x1B00
+
indic_offset_0x1b00
];
if
(
0x1CD0
<=
u
&&
u
<=
0x1CF8
)
return
indic_table
[
u
-
0x1CD0
+
indic_offset_0x1cd0
];
case
0x1
u
:
if
(
hb_in_range
(
u
,
0x1000u
,
0x10A0u
))
return
indic_table
[
u
-
0x1000u
+
indic_offset_0x1000u
];
if
(
hb_in_range
(
u
,
0x1700u
,
0x17F0u
))
return
indic_table
[
u
-
0x1700u
+
indic_offset_0x1700u
];
if
(
hb_in_range
(
u
,
0x1900u
,
0x1AA0u
))
return
indic_table
[
u
-
0x1900u
+
indic_offset_0x1900u
];
if
(
hb_in_range
(
u
,
0x1B00u
,
0x1C50u
))
return
indic_table
[
u
-
0x1B00u
+
indic_offset_0x1b00u
];
if
(
hb_in_range
(
u
,
0x1CD0u
,
0x1CF8u
))
return
indic_table
[
u
-
0x1CD0u
+
indic_offset_0x1cd0u
];
break
;
case
0x2
:
if
(
0x2008
<=
u
&&
u
<=
0x2018
)
return
indic_table
[
u
-
0x2008
+
indic_offset_0x2008
];
if
(
unlikely
(
u
==
0x25CC
))
return
_
(
CP
,
x
);
case
0x2
u
:
if
(
hb_in_range
(
u
,
0x2008u
,
0x2018u
))
return
indic_table
[
u
-
0x2008u
+
indic_offset_0x2008u
];
if
(
unlikely
(
u
==
0x25CC
u
))
return
_
(
CP
,
x
);
break
;
case
0xA
:
if
(
0xA800
<=
u
&&
u
<=
0xAAF8
)
return
indic_table
[
u
-
0xA800
+
indic_offset_0xa800
];
if
(
0xABC0
<=
u
&&
u
<=
0xAC00
)
return
indic_table
[
u
-
0xABC0
+
indic_offset_0xabc0
];
case
0xA
u
:
if
(
hb_in_range
(
u
,
0xA800u
,
0xAAF8u
))
return
indic_table
[
u
-
0xA800u
+
indic_offset_0xa800u
];
if
(
hb_in_range
(
u
,
0xABC0u
,
0xAC00u
))
return
indic_table
[
u
-
0xABC0u
+
indic_offset_0xabc0u
];
break
;
case
0x10
:
if
(
0x10A00
<=
u
&&
u
<=
0x10A48
)
return
indic_table
[
u
-
0x10A00
+
indic_offset_0x10a00
];
case
0x10
u
:
if
(
hb_in_range
(
u
,
0x10A00u
,
0x10A48u
))
return
indic_table
[
u
-
0x10A00u
+
indic_offset_0x10a00u
];
break
;
case
0x11
:
if
(
0x11000
<=
u
&&
u
<=
0x110C0
)
return
indic_table
[
u
-
0x11000
+
indic_offset_0x11000
];
if
(
0x11100
<=
u
&&
u
<=
0x11238
)
return
indic_table
[
u
-
0x11100
+
indic_offset_0x11100
];
if
(
0x112B0
<=
u
&&
u
<=
0x11378
)
return
indic_table
[
u
-
0x112B0
+
indic_offset_0x112b0
];
if
(
0x11480
<=
u
&&
u
<=
0x114E0
)
return
indic_table
[
u
-
0x11480
+
indic_offset_0x11480
];
if
(
0x11580
<=
u
&&
u
<=
0x115C8
)
return
indic_table
[
u
-
0x11580
+
indic_offset_0x11580
];
if
(
0x11600
<=
u
&&
u
<=
0x116D0
)
return
indic_table
[
u
-
0x11600
+
indic_offset_0x11600
];
case
0x11
u
:
if
(
hb_in_range
(
u
,
0x11000u
,
0x110C0u
))
return
indic_table
[
u
-
0x11000u
+
indic_offset_0x11000u
];
if
(
hb_in_range
(
u
,
0x11100u
,
0x11238u
))
return
indic_table
[
u
-
0x11100u
+
indic_offset_0x11100u
];
if
(
hb_in_range
(
u
,
0x112B0u
,
0x11378u
))
return
indic_table
[
u
-
0x112B0u
+
indic_offset_0x112b0u
];
if
(
hb_in_range
(
u
,
0x11480u
,
0x114E0u
))
return
indic_table
[
u
-
0x11480u
+
indic_offset_0x11480u
];
if
(
hb_in_range
(
u
,
0x11580u
,
0x115C8u
))
return
indic_table
[
u
-
0x11580u
+
indic_offset_0x11580u
];
if
(
hb_in_range
(
u
,
0x11600u
,
0x116D0u
))
return
indic_table
[
u
-
0x11600u
+
indic_offset_0x11600u
];
break
;
default:
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录