Skip to content

open-contracting/ocds-extensions-translations

Repository files navigation

OCDS Extensions Translations

Setup

Install requirements:

pip install -r requirements.txt

Install gettext and translate-toolkit for the manage.py add-and-remove command. With Homebrew:

brew install gettext translate-toolkit

Install python-Levenshtein to silence warning from translate-toolkit (WARNING:root:Python-Levenshtein not found. Continuing with built-in (slower) fuzzy matching.):

eval $(brew --prefix translate-toolkit)/libexec/bin/python -m pip install python-Levenshtein

Tasks

Push source strings to Transifex

./manage.py update open-contracting-partnership-1 ocds-extensions

Pretranslate and push translated strings to Transifex

WARNING:

  • Translated strings are first pulled from Transifex, before pretranslation. Therefore, changes made to PO files outside Transifex are lost.
  • If different resources translate the same string in different ways, the translated strings will change to that of the last alphabetically sorted extension.
  1. Push source strings to Transifex:

    ./manage.py update open-contracting-partnership-1 ocds-extensions
  2. Pretranslate and push translated strings to Transifex:

    ./manage.py pretranslate open-contracting-partnership-1 ocds-extensions

Add new extensions to, and remove yanked extensions from, Transifex

./manage.py add-and-remove open-contracting-partnership-1 ocds-extensions

Pull translations from Transifex

tx pull -w 20 -f -a
sphinx-intl build -d locale

Add new versions of core extensions

Note: This section has not yet been added to manage.py. These commands are in fish.

Set environment variables as appropriate (using the fish shell):

set old_version v1.1.3
set new_version v1.1.4
set new_version_underscored v1_1_4

Generate POT files for the new versions of core extensions:

ocdsextensionregistry generate-pot-files build/locale bids==$new_version enquiries==$new_version location==$new_version lots==$new_version milestone_documents==$new_version participation_fee==$new_version process_title==$new_version

Pre-populate the PO files:

for extension in bids enquiries location lots milestone_documents participation_fee process_title
  for lang in (ls locale)
    mkdir -p locale/$lang/LC_MESSAGES/$extension/$new_version
    for domain in docs schema codelists
      if [ -f locale/$lang/LC_MESSAGES/$extension/$old_version/$domain.po ]
        pretranslate --nofuzzymatching -t locale/$lang/LC_MESSAGES/$extension/$old_version/$domain.po build/locale/$extension/$new_version/$domain.pot locale/$lang/LC_MESSAGES/$extension/$new_version/$domain.po
      end
    end
  end
end

Update the .tx/config file:

sphinx-intl update-txconfig-resources --transifex-organization-name open-contracting-partnership-1 --transifex-project-name ocds-extensions --pot-dir build/locale --locale-dir locale 

Push the new source files:

for i in (grep $new_version_underscored .tx/config | tr -d '[]')
  tx push -s $i
end

Push the pre-populated translation files:

for i in (grep $new_version_underscored .tx/config | tr -d '[]')
  tx push -f -t $i
end

Find stale extensions

You can exclude from Transifex any extensions whose source strings haven't changed in many years.

  1. Download registered extensions

  2. Update local repositories:

    ./manage.py git-pull path/to/directory/of/extensions
  3. Find stale extensions:

    ./manage.py stale path/to/directory/of/extensions 3

You can now delete these extensions from Transifex, if the account is near its limits.

Note: At present, manage.py update will re-add these extensions to Transifex.

Compare different versions of PO/POT files

Change the two paths below, and change .po to .pot if appropriate:

cd path/to/locale/es
for i in **.po; do
  msgcmp $i relative/path/to/another/locale/es/$i
done

About

Translations of OCDS extensions, in gettext message catalog format

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages