matching en translations desktop to android & scripts to verify

pull/1306/head
Audric Ackermann 5 years ago
parent 133d541a48
commit a1824215d4
No known key found for this signature in database
GPG Key ID: 999F434D76324AD4

@ -95,7 +95,8 @@
"editMenuSelectAll": { "editMenuSelectAll": {
"message": "Select All", "message": "Select All",
"description": "Edit menu comand to select all of the text in selected text box", "description": "Edit menu comand to select all of the text in selected text box",
"androidKey": "conversation_list_batch__menu_select_all" "androidKey": "conversation_list_batch__menu_select_all",
"wordCapitalize": true
}, },
"editMenuStartSpeaking": { "editMenuStartSpeaking": {
"message": "Start speaking", "message": "Start speaking",
@ -240,7 +241,7 @@
"androidKey": "MessageRecord_left_group" "androidKey": "MessageRecord_left_group"
}, },
"youGotKickedFromGroup": { "youGotKickedFromGroup": {
"message": "You were removed from the group", "message": "You were removed from the group.",
"description": "Displayed when a user can't send a message because they have left the group", "description": "Displayed when a user can't send a message because they have left the group",
"androidKey": "GroupUtil_you_were_removed_from_group" "androidKey": "GroupUtil_you_were_removed_from_group"
}, },
@ -254,7 +255,11 @@
} }
}, },
"androidKey": "ConversationAdapter_n_unread_messages", "androidKey": "ConversationAdapter_n_unread_messages",
"androidKeyCount": "one" "androidKeyCount": "one",
"androidReplace": {
"%d": "$count$"
},
"wordCapitalize": true
}, },
"unreadMessages": { "unreadMessages": {
"message": "$count$ Unread Messages", "message": "$count$ Unread Messages",
@ -266,7 +271,11 @@
} }
}, },
"androidKey": "ConversationAdapter_n_unread_messages", "androidKey": "ConversationAdapter_n_unread_messages",
"androidKeyCount": "other" "androidKeyCount": "other",
"androidReplace": {
"%d": "$count$"
},
"wordCapitalize": true
}, },
"youMarkedAsVerified": { "youMarkedAsVerified": {
"message": "You marked your safety number with $name$ verified", "message": "You marked your safety number with $name$ verified",
@ -338,7 +347,7 @@
"description": "Shown on confirmation dialog when user attempts to send a message" "description": "Shown on confirmation dialog when user attempts to send a message"
}, },
"changedSinceVerified": { "changedSinceVerified": {
"message": "Your safety number with $name$ has changed and is no longer verified. This could either mean that someone is trying to intercept your communication, or that $name$ simply reinstalled Session", "message": "Your safety number with $name$ has changed and is no longer verified. This could either mean that someone is trying to intercept your communication, or that $name$ simply reinstalled Session.",
"description": "Shown on confirmation dialog when user attempts to send a message", "description": "Shown on confirmation dialog when user attempts to send a message",
"placeholders": { "placeholders": {
"name": { "name": {
@ -513,12 +522,14 @@
"thisWeek": { "thisWeek": {
"message": "This Week", "message": "This Week",
"description": "Section header in the media gallery", "description": "Section header in the media gallery",
"androidKey": "BucketedThreadMedia_This_week" "androidKey": "BucketedThreadMedia_This_week",
"wordCapitalize": true
}, },
"thisMonth": { "thisMonth": {
"message": "This Month", "message": "This Month",
"description": "Section header in the media gallery", "description": "Section header in the media gallery",
"androidKey": "BucketedThreadMedia_This_month" "androidKey": "BucketedThreadMedia_This_month",
"wordCapitalize": true
}, },
"voiceMessage": { "voiceMessage": {
"message": "Voice Message", "message": "Voice Message",
@ -734,7 +745,7 @@
"description": "Shown in a message's triple-dot menu if there isn't room for a dedicated download button" "description": "Shown in a message's triple-dot menu if there isn't room for a dedicated download button"
}, },
"replyToMessage": { "replyToMessage": {
"message": "Reply to Message", "message": "Reply to message",
"description": "Shown in triple-dot menu next to message to allow user to start crafting a message with a quotation", "description": "Shown in triple-dot menu next to message to allow user to start crafting a message with a quotation",
"androidKey": "conversation_context__menu_reply_to_message" "androidKey": "conversation_context__menu_reply_to_message"
}, },
@ -978,7 +989,8 @@
"deleteMessage": { "deleteMessage": {
"message": "Delete Message", "message": "Delete Message",
"description": "Shown on the drop-down menu for an individual message, deletes single message", "description": "Shown on the drop-down menu for an individual message, deletes single message",
"androidKey": "conversation_context__menu_delete_message" "androidKey": "conversation_context__menu_delete_message",
"wordCapitalize": true
}, },
"deleteMessages": { "deleteMessages": {
"message": "Delete Messages", "message": "Delete Messages",
@ -1010,7 +1022,7 @@
"androidKey": "dialog_clear_all_data_title" "androidKey": "dialog_clear_all_data_title"
}, },
"deleteAccountWarning": { "deleteAccountWarning": {
"message": "This will permanently delete your messages, sessions, and contacts. These cannot be restored", "message": "This will permanently delete your messages, sessions, and contacts.",
"description": "Warning for account deletion in settings view", "description": "Warning for account deletion in settings view",
"androidKey": "dialog_clear_all_data_explanation" "androidKey": "dialog_clear_all_data_explanation"
}, },
@ -1053,7 +1065,7 @@
}, },
"addACaption": { "addACaption": {
"message": "Add a caption...", "message": "Add a caption...",
"descripton": "Used as the placeholder text in the caption editor text field", "description": "Used as the placeholder text in the caption editor text field",
"androidKey": "MediaSendActivity_add_a_caption" "androidKey": "MediaSendActivity_add_a_caption"
}, },
"copy": { "copy": {
@ -1063,7 +1075,7 @@
}, },
"save": { "save": {
"message": "Save", "message": "Save",
"descripton": "Used as a 'commit changes' button in the Caption Editor for outgoing image attachments", "description": "Used as a 'commit changes' button in the Caption Editor for outgoing image attachments",
"androidKey": "media_preview__save_title" "androidKey": "media_preview__save_title"
}, },
"emojiAlt": { "emojiAlt": {
@ -1079,7 +1091,8 @@
"linkNewDevice": { "linkNewDevice": {
"message": "Link New Device", "message": "Link New Device",
"description": "The menu option shown in Signal iOS to add a new linked device", "description": "The menu option shown in Signal iOS to add a new linked device",
"androidKey": "device_list_fragment__link_new_device" "androidKey": "device_list_fragment__link_new_device",
"wordCapitalize": true
}, },
"permissions": { "permissions": {
"message": "Permissions", "message": "Permissions",
@ -1134,7 +1147,8 @@
"readReceiptSettingTitle": { "readReceiptSettingTitle": {
"message": "Read Receipts", "message": "Read Receipts",
"description": "Title of the read receipts setting", "description": "Title of the read receipts setting",
"androidKey": "preferences__read_receipts" "androidKey": "preferences__read_receipts",
"wordCapitalize": true
}, },
"typingIndicatorsSettingDescription": { "typingIndicatorsSettingDescription": {
"message": "See and share when messages are being typed (applies to all sessions).", "message": "See and share when messages are being typed (applies to all sessions).",
@ -1206,9 +1220,10 @@
"description": "Displayed in notifications when setting is 'name and message' and more than one message is waiting" "description": "Displayed in notifications when setting is 'name and message' and more than one message is waiting"
}, },
"sendFailed": { "sendFailed": {
"message": "Send failed", "message": "Send Failed",
"description": "Shown on outgoing message if it fails to send", "description": "Shown on outgoing message if it fails to send",
"androidKey": "conversation_item_sent__send_failed_indicator_description" "androidKey": "conversation_item_sent__send_failed_indicator_description",
"wordCapitalize": true
}, },
"learnMore": { "learnMore": {
"message": "Learn more about verifying safety numbers", "message": "Learn more about verifying safety numbers",
@ -1232,9 +1247,10 @@
"androidKey": "ThreadRecord_media_message" "androidKey": "ThreadRecord_media_message"
}, },
"timestamp_s": { "timestamp_s": {
"message": "now", "message": "Now",
"description": "Brief timestamp for messages sent less than a minute ago. Displayed in the conversation list and message bubble.", "description": "Brief timestamp for messages sent less than a minute ago. Displayed in the conversation list and message bubble.",
"androidKey": "DateUtils_just_now" "androidKey": "DateUtils_just_now",
"wordCapitalize": true
}, },
"timestamp_m": { "timestamp_m": {
"message": "1 minute", "message": "1 minute",
@ -1420,7 +1436,7 @@
"androidKey": "ThreadRecord_disappearing_messages_disabled" "androidKey": "ThreadRecord_disappearing_messages_disabled"
}, },
"disabledDisappearingMessages": { "disabledDisappearingMessages": {
"message": "$name$ disabled disappearing messages", "message": "$name$ disabled disappearing messages.",
"description": "Displayed in the conversation list when the timer is turned off", "description": "Displayed in the conversation list when the timer is turned off",
"placeholders": { "placeholders": {
"name": { "name": {
@ -1434,7 +1450,7 @@
} }
}, },
"youDisabledDisappearingMessages": { "youDisabledDisappearingMessages": {
"message": "You disabled disappearing messages", "message": "You disabled disappearing messages.",
"description": "Displayed in the conversation list when the timer is turned off", "description": "Displayed in the conversation list when the timer is turned off",
"androidKey": "MessageRecord_you_disabled_disappearing_messages" "androidKey": "MessageRecord_you_disabled_disappearing_messages"
}, },
@ -1474,7 +1490,8 @@
"verifyNewNumber": { "verifyNewNumber": {
"message": "Verify Safety Number", "message": "Verify Safety Number",
"description": "Label on button included with safety number change notification in the conversation", "description": "Label on button included with safety number change notification in the conversation",
"androidKey": "AndroidManifest__verify_safety_number" "androidKey": "AndroidManifest__verify_safety_number",
"wordCapitalize": true
}, },
"yourSafetyNumberWith": { "yourSafetyNumberWith": {
"message": "Your safety number with $name$:", "message": "Your safety number with $name$:",
@ -1611,10 +1628,10 @@
} }
}, },
"multipleJoinedTheGroup": { "multipleJoinedTheGroup": {
"message": "$names$ joined the group.", "message": "$name$ joined the group.",
"description": "Shown in the conversation history when more than one person joins the group", "description": "Shown in the conversation history when more than one person joins the group",
"placeholders": { "placeholders": {
"names": { "name": {
"content": "$1", "content": "$1",
"example": "Alice, Bob" "example": "Alice, Bob"
} }
@ -1641,7 +1658,7 @@
} }
}, },
"multipleKickedFromTheGroup": { "multipleKickedFromTheGroup": {
"message": "$names$ were removed from the group", "message": "$name$ were removed from the group.",
"description": "Shown in the conversation history when more than one person is removed from the group", "description": "Shown in the conversation history when more than one person is removed from the group",
"placeholders": { "placeholders": {
"names": { "names": {
@ -1775,7 +1792,7 @@
"description": "Request for user to enter password to show recovery phrase." "description": "Request for user to enter password to show recovery phrase."
}, },
"recoveryPhraseSavePromptMain": { "recoveryPhraseSavePromptMain": {
"message": "Your recovery phrase is the master key to your Session ID — you can use it to restore your Session ID if you lose access to your device. Store your recovery phrase in a safe place, and dont give it to anyone.", "message": "Your recovery phrase is the master key to your Session ID — you can use it to restore your Session ID if you lose access to your device. Store your recovery phrase in a safe place, and don't give it to anyone.",
"description": "Prompt on recovery phrase modal requesting user to save their recovery phrase. Line one", "description": "Prompt on recovery phrase modal requesting user to save their recovery phrase. Line one",
"androidKey": "activity_seed_explanation" "androidKey": "activity_seed_explanation"
}, },
@ -1982,8 +1999,7 @@
} }
}, },
"createAccount": { "createAccount": {
"message": "Create Account", "message": "Create Account"
"androidKey": "activity_display_name_title"
}, },
"signIn": { "signIn": {
"message": "Sign In" "message": "Sign In"
@ -2008,7 +2024,7 @@
"androidKey": "activity_settings_recovery_phrase_button_title" "androidKey": "activity_settings_recovery_phrase_button_title"
}, },
"enterRecoveryPhrase": { "enterRecoveryPhrase": {
"message": "Enter Recovery Phrase", "message": "Enter your recovery phrase",
"androidKey": "activity_restore_seed_edit_text_hint" "androidKey": "activity_restore_seed_edit_text_hint"
}, },
"displayName": { "displayName": {
@ -2154,7 +2170,8 @@
}, },
"createClosedGroupNamePrompt": { "createClosedGroupNamePrompt": {
"message": "Group Name", "message": "Group Name",
"androidKey": "GroupCreateActivity_group_name_hint" "androidKey": "GroupCreateActivity_group_name_hint",
"wordCapitalize": true
}, },
"createClosedGroupPlaceholder": { "createClosedGroupPlaceholder": {
"message": "Enter a group name", "message": "Enter a group name",
@ -2181,7 +2198,8 @@
}, },
"pairingDevice": { "pairingDevice": {
"message": "Linking Device", "message": "Linking Device",
"androidKey": "DeviceProvisioningActivity_content_progress_title" "androidKey": "DeviceProvisioningActivity_content_progress_title",
"wordCapitalize": true
}, },
"devicePairedSuccessfully": { "devicePairedSuccessfully": {
"message": "Your device has been linked successfully", "message": "Your device has been linked successfully",

@ -0,0 +1,139 @@
#!/bin/python3
import re
import os
from glob import glob
import json
import sys
import xmltodict
# androidKey
# "androidKeyCount": "one" or "other" used to find matching key with quantity
# replace \\' with '
# replace \\\" with \"
# "wordCapitalize": true capitalize each words (must be called before addStart)
# "addStart": "&" char to add as start char
# "androidReplace": replace all occurences of key value pair
allowedItemKeys = ['message', 'description', 'comment', 'placeholders', 'androidKey', 'wordCapitalize', 'androidKeyCount', 'androidReplace', 'addStart']
if len(sys.argv) != 3:
print(f"usage: {sys.argv[0]} <dst language i.e. 'de'> <android_root folder>")
sys.exit(1)
dest = sys.argv[1]
androidRoot = sys.argv[2]
desktopSrc = json.loads(open(f"_locales/en/messages.json",
"r").read())
desktopDst = json.loads(open(f"_locales/{dest}/messages.json",
"r").read())
androidEnValueFile = f"{androidRoot}/res/values/strings.xml"
androidTranslatedValueFile = f"{androidRoot}/res/values-{dest}/strings.xml"
print(f"androidEnValueFile {androidEnValueFile}")
print(f"androidTranslatedValueFile {androidTranslatedValueFile}")
androidEnXml = open(androidEnValueFile, "r").read()
androidTranslatedXml = open(androidTranslatedValueFile, "r").read()
androidEnJsonSingular = xmltodict.parse(androidEnXml)['resources']['string']
androidEnJsonPlurals = xmltodict.parse(androidEnXml)['resources']['plurals']
androidEnJsonSingular = [dict(item) for item in androidEnJsonSingular]
androidEnJsonPlurals = [dict(item) for item in androidEnJsonPlurals]
androidTranslatedJson = xmltodict.parse(androidTranslatedXml)
# print(f"androidTranslatedXml {androidTranslatedXml}")
# print(f"\n\n\n\n androidEnJsonSingular {androidEnJsonSingular}")
# print(f"\n\n\n\n androidEnJsonPlurals {androidEnJsonPlurals}")
missingAndroidKeyCount = 0
def findCountInItem(quantityStr, items):
found = [item for item in items if item['@quantity'] == quantityStr]
# print(f'findCountInItem: {found}, quantityStr: {quantityStr}')
if len(found) != 1:
raise Exception(f'quantityStr not found: {quantityStr} ')
return dict(found[0])
def findByNameSingular(keySearchedFor, singularString):
found = [item for item in singularString if item['@name'] == keySearchedFor]
if len(found) != 1:
raise Exception(f'android key not found: {keySearchedFor} but should have been found')
return found[0]
def findByNamePlurals(keySearchedFor, pluralsString, quantityStr):
found = [item for item in pluralsString if item['@name'] == keySearchedFor]
if len(found) != 1:
raise Exception(f'android key not found: {keySearchedFor} but should have been found')
found = findCountInItem(quantityStr, found[0]['item'])
return found
def validateKeysPresent(items):
for keyItem, valueItem in items:
if keyItem not in allowedItemKeys:
print(f"Invalid key item: {keyItem}")
exit(1)
# print(f"keyItem: '{keyItem}', valueItem: '{valueItem}'")
def morphToDesktopSyntax(androidString, desktopItem):
# print(f"androidString: '{androidString}', desktopItem: '{desktopItem}'")
replaced = androidString.replace(r"\'", "'")
# replaced = androidString.replace(r"\", "'")
# replaced = androidString.replace('', )
if('wordCapitalize' in desktopItem.keys() and desktopItem['wordCapitalize']):
replaced = replaced.title()
if ('androidReplace' in desktopItem.keys()):
for key, value in desktopItem['androidReplace'].items():
replaced = replaced.replace(key.title(), value)
replaced = replaced.replace(key, value)
# print(f"androidString: '{androidString}', replaced: '{replaced}'")
if ('addStart' in desktopItem.keys()):
toAdd = desktopItem['addStart']
replaced = f'{toAdd}{replaced}'
return replaced
notMatching = 0
for key, value in desktopSrc.items():
# print(f"key: '{key}', value: '{value}'")
items = value.items()
validateKeysPresent(items)
if 'androidKey' not in value.keys():
# print('androidKey not found for {key}')
missingAndroidKeyCount = missingAndroidKeyCount + 1
continue
androidKey = value['androidKey']
androidKeyCount = None
if 'androidKeyCount' in value.keys():
androidKeyCount = value['androidKeyCount']
# print(f'key: {key}, androidKey: {androidKey}, androidKeyCount: {androidKeyCount}')
itemEnDesktop = desktopSrc[key]
txtEnDesktop = itemEnDesktop['message']
if androidKeyCount:
itemEnAndroid = findByNamePlurals(androidKey, androidEnJsonPlurals, androidKeyCount)
else:
itemEnAndroid = findByNameSingular(androidKey, androidEnJsonSingular)
txtEnAndroid = itemEnAndroid['#text']
morphedEnAndroid = morphToDesktopSyntax(txtEnAndroid, itemEnDesktop)
if (txtEnDesktop != morphedEnAndroid):
print(f'\t\tDOES NOT MATCH: "{txtEnDesktop}" vs "{morphedEnAndroid}", itemEnDesktop: {itemEnDesktop}\n\n')
notMatching = notMatching + 1
# else:
# print(f'MATCH: "{txtEnDesktop}" vs "{morphedEnAndroid}"')
print(f"total keys missing {missingAndroidKeyCount}") # androidKey set on desktop but not found on android EN resources
print(f"total text not matching EN to EN {notMatching}")
Loading…
Cancel
Save