Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/scala-network/scala-v7

A cryptocurrency aiming to use blockchain technologies to globally distribute wealth.
https://github.com/scala-network/scala-v7

Last synced: 3 months ago
JSON representation

A cryptocurrency aiming to use blockchain technologies to globally distribute wealth.

Awesome Lists containing this project

README

        

Scala daemon internationalization
==================================

The Scala command line tools can be translated in various languages. If you wish to contribute and need help/support, contact the [Scala Localization Workgroup on Taiga](https://taiga.getscala.org/project/erciccione-scala-localization/) or come chat on `#scala-translations` (Freenode/IRC, riot/matrix, MatterMost)

In order to use the same translation workflow as the [Scala Core GUI](https://github.com/scala-project/scala-gui), they use Qt Linguist translation files. However, to avoid the dependencies on Qt this normally implies, they use a custom loader to read those files at runtime.

### Tools for translators

In order to create, update or build translations files, you need to have Qt tools installed. For translating, you need either the **Qt Linguist GUI** ([part of Qt Creator](https://www.qt.io/download) or a [3rd-party standalone version](https://github.com/lelegard/qtlinguist-installers/releases)), or another tool that supports Qt ts files, such as Transifex. The files are XML, so they can be edited in any plain text editor if needed.

### Creating / modifying translations

You do not need anything from Qt in order to use the final translations.

To update ts files after changing source code:

```bash
./utils/translations/update-translations.sh
```

To add a new language, eg Spanish (ISO code es):

```bash
cp translations/scala.ts translations/scala_es.ts
```

To edit translations for Spanish:

```bash
linguist translations/scala_es.ts
```

To build translations after modifying them:

```bash
./utils/translations/build-translations.sh
```

To test a translation:

```bash
LANG=es ./build/release/bin/scala-wallet-cli
```

To add new translatable strings in the source code:

Use the `tr(string)` function if possible. If the code is in a class, and this class doesn't already have a `tr()` static function, add one, which uses a context named after what `lupdate` uses for the context, usually the fully qualified class name (eg, `cryptonote::simple_wallet`). If you need to use `tr()` in code that's not in a class, you can use the fully qualified version (eg, `simple_wallet::tr`) of the one matching the context you want. Use `QT_TRANSLATE_NOOP(string)` if you want to specify a context manually.

If you're getting messages of the form:

```
Class 'cryptonote::simple_wallet' lacks Q_OBJECT macro
```

all is fine, we don't actually need that here.