-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathmake_wide_table.py
43 lines (35 loc) · 1.46 KB
/
make_wide_table.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
import wcwidth
import collections
def fetch_wide_data():
"List new WIDE characters at each unicode version."
table = wcwidth.WIDE_EASTASIAN
versions = wcwidth.list_versions()
results = collections.defaultdict(list)
## begin table with all characters of the oldest version
# for value_pair in table[versions[0]]:
# for value in range(value_pair[0], value_pair[1]):
# results[versions[0]].append(value)
# calculate incremental differences for each codepoint of each subsequent version
for version in versions[1:]:
prev_idx = versions.index(version) - 1
previous_version = versions[prev_idx]
previous_table = table[previous_version]
for value_pair in table[version]:
for value in range(value_pair[0], value_pair[1]):
if not wcwidth._bisearch(value, previous_table):
results[version].append(value)
return [(version, results[version]) for version in reversed(versions) if results[version]]
def main():
# create basic python code, skipping all that jinja stuff
print("WIDE_CHARACTERS = (") # 3MB mega-tuple !!
for key, sequences in fetch_wide_data():
print(f" ('{key}', (")
for seq in sequences:
print(f" {seq},")
print(" ),")
print(" ),")
print(")")
if __name__ == "__main__":
# minimal wide table parser, for use:
# $ python make_wide_table.py > ucs_detect/table_wide.py
main()