ddnet/scripts/update_localization.py
2012-10-03 19:27:50 +02:00

102 lines
2.7 KiB
Python

import os, re, sys
match = re.search('(.*)/', sys.argv[0])
if match != None:
os.chdir(match.group(1))
source_exts = [".c", ".cpp", ".h"]
content_author = "##### authors #####\n#originally created by:\n#\n#modified by:\n#\n##### /authors #####\n".encode()
def parse_source():
stringtable = {}
def process_line(line):
if 'Localize("'.encode() in line:
fields = line.split('Localize("'.encode(), 1)[1].split('"'.encode(), 1)
stringtable[fields[0]] = ""
process_line(fields[1])
for root, dirs, files in os.walk("src"):
for name in files:
filename = os.path.join(root, name)
if os.sep + "external" + os.sep in filename:
continue
if filename[-2:] in source_exts or filename[-4:] in source_exts:
for line in open(filename, "rb"):
process_line(line)
return stringtable
def load_languagefile(filename):
f = open(filename, "rb")
lines = f.readlines()
f.close()
stringtable = {}
authorpart = 0
global content_author
for i in range(0, len(lines)-1):
l = lines[i].strip()
if authorpart == 0 and l == "##### authors #####".encode():
authorpart = 1
content_author = l + "\n".encode()
elif authorpart == 1:
if l == "##### /authors #####".encode():
authorpart = 2
content_author += l + "\n".encode()
elif len(l) and not l[0:1] == "=".encode() and not l[0:1] == "#".encode():
stringtable[l] = lines[i+1][3:].rstrip()
return stringtable
def generate_languagefile(outputfilename, srctable, loctable):
f = open(outputfilename, "wb")
num_items = 0
new_items = 0
old_items = 0
srctable_keys = []
for key in srctable:
srctable_keys.append(key)
srctable_keys.sort()
content = content_author
content += "\n##### translated strings #####\n\n".encode()
for k in srctable_keys:
if k in loctable and len(loctable[k]):
content += k + "\n== ".encode() + loctable[k] + "\n\n".encode()
num_items += 1
content += "##### needs translation #####\n\n".encode()
for k in srctable_keys:
if not k in loctable or len(loctable[k]) == 0:
content += k + "\n== \n\n".encode()
num_items += 1
new_items += 1
content += "##### old translations #####\n\n".encode()
for k in loctable:
if not k in srctable:
content += k + "\n== ".encode() + loctable[k] + "\n\n".encode()
num_items += 1
old_items += 1
f.write(content)
f.close()
print("%-40s %8d %8d %8d" % (outputfilename, num_items, new_items, old_items))
srctable = parse_source()
print("%-40s %8s %8s %8s" % ("filename", "total", "new", "old"))
for filename in os.listdir("data/languages"):
if not ".txt" in filename:
continue
if filename == "index.txt" or filename == "license.txt" or filename == "readme.txt":
continue
filename = "data/languages/" + filename
generate_languagefile(filename, srctable, load_languagefile(filename))