Skip to main content

strsync - Automatically translate and synchronize localizable resource files from defined base language for Xcode.

Project description

Automatically translate and synchronize ‘.strings’ files from defined base language.

The basic concept of this tool is simple file name based one-way synchronizer. While the actual translation work, My biggest desire was to just fill an empty strings easily. In a normal project, automatic translation is sufficient. Because They are always simple sentences. Yes, No, Do it, Not agree, etc..

If you are running, other localized resources will have exactly the same key with automatically translated strings. Of course, String on the key that already exists will not be modified at all.

Requirements

Install

pip install strsync

Getting your client id/secret id to use Microsoft Translation API

Try accordance with this explanation

Update Python SSL packages if needed

this is not required for python-2.7.9+

pip install requests[security]

Usage

Naturally, this tool follow standard ISO639 1~2 codes or apple’s official document or csv file

usage: strsync    [-h] [-b BASE_LANG_NAME]
                   [-x [EXCLUDING_LANG_NAMES ...]] -c
                   CLIENT_ID -s CLIENT_SECRET
                   [-f [FORCE_TRANSLATE_KEYS ...]]
                   [target path]

Automatically translate and synchronize .strings files from defined base
language.

positional arguments:
  target path           Target localizable resource path. (root path of
                        Base.lproj, default=./)

optional arguments:
  -h, --help            show this help message and exit
  -b BASE_LANG_NAME, --base-lang-name BASE_LANG_NAME
                        A base(or source) localizable resource
                        name.(default='Base'), (e.g. "Base" via 'Base.lproj',
                        "en" via 'en.lproj')
  -x [EXCLUDING_LANG_NAMES ...], --excluding-lang-names [EXCLUDING_LANG_NAMES ...]
                        A localizable resource name that you want to exclude.
                        (e.g. "Base" via 'Base.lproj', "en" via 'en.lproj')
  -c CLIENT_ID, --client-id CLIENT_ID
                        Client ID for MS Translation API
  -s CLIENT_SECRET, --client-secret CLIENT_SECRET
                        Client Secret key for MS Translation API
  -f [FORCE_TRANSLATE_KEYS ...], --force-translate-keys [FORCE_TRANSLATE_KEYS ...]
                        Keys in the strings to update and translate by force.

Examples to use

$ strsync -c clien_idXXXX -s clien_secretXXXX

Define specific path you want.

$ strsync ./myXcodeProj/Resources/Localizations -c clien_idXXXX -s clien_secretXXXX

Excluding japanese, spanish, finnish

$ strsync ./myXcodeProj/Resources/Localizations -c clien_idXXXX -s clien_secretXXXX -x ja es fi

Forcefully translate and update by specific keys you want.

$ strsync -c clien_idXXXX -s clien_secretXXXX -f Common.OK Common.Undo

Forcefully translate and update by specific keys you want.

$ strsync -c clien_idXXXX -s clien_secretXXXX -f   (input nothing.)

When you want to accept the values in the ‘Base’.

$ strsync -c clien_idXXXX -s clien_secretXXXX -fb autoenhance flashmode

#before
"flashmode" = "وضع الفلاش";
"flashmode.auto" = "السيارات";
"flashmode.on" = "على";
"autoenhance" = "تعزيز السيارات";

#after
"flashmode" = "Flash Mode";
"flashmode.auto" = "السيارات";
"flashmode.on" = "على";
"autoenhance" = "Auto-Enhance";

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

strsync-1.1.3.tar.gz (21.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

strsync-1.1.3-py2-none-any.whl (21.2 kB view details)

Uploaded Python 2

File details

Details for the file strsync-1.1.3.tar.gz.

File metadata

  • Download URL: strsync-1.1.3.tar.gz
  • Upload date:
  • Size: 21.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for strsync-1.1.3.tar.gz
Algorithm Hash digest
SHA256 789ad6102612bcc3d82cd5a6b4f00f298eed3a3c56cdd927461331045d554844
MD5 4f65157f9566522408aab163697755ac
BLAKE2b-256 175a1a306795ac347b775a8ccb216003bb3e5a61671ae7fc5b4c8edd72a41d7e

See more details on using hashes here.

File details

Details for the file strsync-1.1.3-py2-none-any.whl.

File metadata

File hashes

Hashes for strsync-1.1.3-py2-none-any.whl
Algorithm Hash digest
SHA256 47cac4826f67242225cbc3c530588b5fa447311df992edd8b5597d6f0b1effa7
MD5 06f53774160d548a2afcacccf5a9f715
BLAKE2b-256 c9d750778f2a8e0b81d39b19ba4916d4c991e9005f85ae82f842af990ea95db6

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page