Workflow summary
kisvegabor opened this issue · 5 comments
According to my current understanding, the workflow is something like this:
First translation
- The user uses
_
and_p
in the code - Create some
yaml
files to indicate which languages are required (e.g.en_gb.yaml
,ru_ru.yaml
) - Runs the
extract
script to fill theyaml
files withmsgid
s and add placeholders for the translations. For pluralmsgid
s the correct number of translation placeholders will be inserted because theextract
knows the rules (based on theyaml
file's name, e.g.en_gb
). - Send the
yaml
files for translation - When received the
compile
script is called to generate the C file(s). The generated C file(s) will contain the plural rules and other language-specific things because this information is known bycompile
.
Update with new msgids
- Add/remove/delete some
msgid
s - Run
merge
to update theyaml
files - Send the
yaml
files for translation - Run
compile
to update the C file(s)
Am I seeing well?
2. Create some
yaml
files to indicate which languages are required (e.g.en_gb.yaml
,ru_ru.yaml
)
That's not required. Scanner create it automatically if not exists. You only need to pass destination and default locale in options.
4. Send the
yaml
files for translation
I'd say publish on github & compile immediately. Then recompine when yaml files updated somehow.
Am I seeing well?
Yes.
That's not required. Scanner create it automatically if not exists. You only need to pass destination and default locale in options.
Can you write an example use of the extract
script? Just to be sure we think about the same thing.
Splited to multiple lines for convenience
lv-i18n extract
--source ./src
--source ./src2/**.cpp
--outfiles ./i18n/*.yml
--deflocale en-US
--outnew new_phrases.yml
That's only a very preliminary sample. Everything may be changed.
With high probability, users will store each locale in separate file (en-GB.yml
). Script will detect locale name in yaml and merge data to proper place. If you have nothing at all, it will create <default_locale>.yml
.
If --outnew
exists - new phrases will go to separate file instead of merge. Not sure if needed. We still have git diff
...
Every non-default locale will be extended automatically with missed translations (null-filled keys). To create new locale - just add file like ru-RU.yml
with content ru-RU: {}
(or empty at all)
Clear, thanks!
Close - details landed to docs (readme)