2018-01-22 13:16:07 +01:00
|
|
|
#!/usr/bin/env python3
|
|
|
|
# updatetranslations.py
|
|
|
|
#
|
|
|
|
# tl;dr this script updates our translation file with the newest, coolest strings we've added!
|
|
|
|
# it manually searches the source code, extracts strings and then updates the language files.
|
|
|
|
|
|
|
|
# Written in 2018 by Daniel Oaks <daniel@danieloaks.net>
|
|
|
|
#
|
|
|
|
# To the extent possible under law, the author(s) have dedicated all copyright
|
|
|
|
# and related and neighboring rights to this software to the public domain
|
|
|
|
# worldwide. This software is distributed without any warranty.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the CC0 Public Domain Dedication along
|
|
|
|
# with this software. If not, see
|
|
|
|
# <http://creativecommons.org/publicdomain/zero/1.0/>.
|
|
|
|
|
|
|
|
"""updatetranslations.py
|
|
|
|
|
|
|
|
Usage:
|
|
|
|
updatetranslations.py run <irc-dir> <languages-dir>
|
|
|
|
updatetranslations.py --version
|
|
|
|
updatetranslations.py (-h | --help)
|
|
|
|
|
|
|
|
Options:
|
|
|
|
<irc-dir> Oragono's irc subdirectory where the Go code is kept.
|
|
|
|
<languages-dir> Languages directory."""
|
|
|
|
import os
|
|
|
|
import re
|
2018-01-23 06:06:55 +01:00
|
|
|
import json
|
2018-01-22 13:16:07 +01:00
|
|
|
|
|
|
|
from docopt import docopt
|
|
|
|
import yaml
|
|
|
|
|
|
|
|
if __name__ == '__main__':
|
|
|
|
arguments = docopt(__doc__, version="0.1.0")
|
|
|
|
|
|
|
|
if arguments['run']:
|
2018-01-23 06:06:55 +01:00
|
|
|
# general IRC strings
|
|
|
|
irc_strings = []
|
2018-01-22 13:16:07 +01:00
|
|
|
|
|
|
|
for subdir, dirs, files in os.walk(arguments['<irc-dir>']):
|
|
|
|
for fname in files:
|
|
|
|
filepath = subdir + os.sep + fname
|
|
|
|
if filepath.endswith('.go'):
|
|
|
|
content = open(filepath, 'r').read()
|
|
|
|
|
|
|
|
matches = re.findall(r'\.t\("((?:[^"]|\\")+)"\)', content)
|
|
|
|
for match in matches:
|
2018-01-23 06:06:55 +01:00
|
|
|
if match not in irc_strings:
|
|
|
|
irc_strings.append(match)
|
2018-01-22 13:16:07 +01:00
|
|
|
|
|
|
|
matches = re.findall(r'\.t\(\`([^\`]+)\`\)', content)
|
|
|
|
for match in matches:
|
2018-01-23 06:06:55 +01:00
|
|
|
if match not in irc_strings:
|
|
|
|
irc_strings.append(match)
|
2018-01-22 13:16:07 +01:00
|
|
|
|
2018-01-23 06:06:55 +01:00
|
|
|
print("irc strings:")
|
|
|
|
print(json.dumps({k:k for k in irc_strings}, sort_keys=True, indent=2, separators=(',', ': ')))
|
|
|
|
|
|
|
|
# help entries
|
|
|
|
help_strings = []
|
|
|
|
|
|
|
|
for subdir, dirs, files in os.walk(arguments['<irc-dir>']):
|
|
|
|
for fname in files:
|
|
|
|
filepath = subdir + os.sep + fname
|
|
|
|
if fname == 'help.go':
|
|
|
|
content = open(filepath, 'r').read()
|
|
|
|
|
|
|
|
matches = re.findall(r'\`([^\`]+)\`', content)
|
|
|
|
for match in matches:
|
|
|
|
if '\n' in match and match not in help_strings:
|
|
|
|
help_strings.append(match)
|
|
|
|
|
|
|
|
print()
|
|
|
|
|
|
|
|
print("help strings:")
|
|
|
|
print(json.dumps({k:k for k in help_strings}, sort_keys=True, indent=2, separators=(',', ': ')))
|
2018-04-01 03:23:14 +02:00
|
|
|
|
|
|
|
# nickserv help entries
|
|
|
|
help_strings = []
|
|
|
|
|
|
|
|
for subdir, dirs, files in os.walk(arguments['<irc-dir>']):
|
|
|
|
for fname in files:
|
|
|
|
filepath = subdir + os.sep + fname
|
|
|
|
if fname == 'nickserv.go':
|
|
|
|
content = open(filepath, 'r').read()
|
|
|
|
|
|
|
|
matches = re.findall(r'\`([^\`]+)\`', content)
|
|
|
|
for match in matches:
|
|
|
|
if '\n' in match and match not in help_strings:
|
|
|
|
help_strings.append(match)
|
|
|
|
|
|
|
|
print()
|
|
|
|
|
|
|
|
print("nickserv help strings:")
|
|
|
|
print(json.dumps({k:k for k in help_strings}, sort_keys=True, indent=2, separators=(',', ': ')))
|