abouttreesummaryrefslogcommitdiff
path: root/gen_emoji.py
diff options
context:
space:
mode:
Diffstat (limited to 'gen_emoji.py')
-rw-r--r--gen_emoji.py38
1 files changed, 38 insertions, 0 deletions
diff --git a/gen_emoji.py b/gen_emoji.py
new file mode 100644
index 0000000..bb1ef8e
--- /dev/null
+++ b/gen_emoji.py
@@ -0,0 +1,38 @@
+import urllib.request
+import os.path
+
+EMOJIS_PATH = 'res/raw/emojis.txt'
+EMOJI_TEST_PATH = 'emoji-test.txt'
+EMOJI_TEST_URL = 'https://unicode.org/Public/emoji/latest/emoji-test.txt'
+
+def rawEmojiFromCodes(codes):
+ return ''.join([chr(int(c, 16)) for c in codes])
+
+def getEmojiTestContents():
+ if os.path.exists(EMOJI_TEST_PATH):
+ print(f'Using existing {EMOJI_TEST_PATH}')
+ else:
+ print(f'Downloading {EMOJI_TEST_URL}')
+ urllib.request.urlretrieve(EMOJI_TEST_URL, EMOJI_TEST_PATH)
+ return open(EMOJI_TEST_PATH, mode='r', encoding='UTF-8').read()
+
+
+emoji_list = []
+group_indices = []
+for line in getEmojiTestContents().splitlines():
+ if line.startswith('# group:'):
+ if len(group_indices) == 0 or len(emoji_list) > group_indices[-1]:
+ group_indices.append(len(emoji_list))
+ elif not line.startswith('#') and 'fully-qualified' in line:
+ codes = line.split(';')[0].split()
+ emoji_list.append(rawEmojiFromCodes(codes))
+
+with open(EMOJIS_PATH, 'w', encoding='UTF-8') as emojis:
+ for e in emoji_list:
+ emojis.write(f'{e}\n')
+ emojis.write('\n')
+
+ emojis.write(' '.join([str(g) for g in group_indices]))
+ emojis.write('\n')
+
+print(f'Parsed {len(emoji_list)} emojis in {len(group_indices)}')