Dean Karn 71201497ba Update README.md | 7 years ago | |
---|---|---|
examples | 7 years ago | |
testdata | 7 years ago | |
.gitignore | 7 years ago | |
LICENSE | 7 years ago | |
README.md | 7 years ago | |
benchmarks_test.go | 8 years ago | |
errors.go | 7 years ago | |
import_export.go | 7 years ago | |
import_export_test.go | 7 years ago | |
logo.png | 8 years ago | |
translator.go | 7 years ago | |
translator_test.go | 7 years ago | |
universal_translator.go | 7 years ago |
Universal Translator is an i18n Translator for Go/Golang using CLDR data + pluralization rules
Because none of the plural rules seem to be correct out there, including the previous implementation of this package, so I took it upon myself to create locales for everyone to use; this package is a thin wrapper around locales in order to store and translate text for use in your applications.
Use go get
go get github.com/go-playground/universal-translator
Please see https://godoc.org/github.com/go-playground/universal-translator for usage docs
All types, Plain substitution, Cardinal, Ordinal and Range translations can all be contained withing the same file(s); they are only separated for easy viewing.
NOTE: not all fields are needed for all translation types, see examples
{
"locale": "en",
"key": "days-left",
"trans": "You have {0} day left.",
"type": "Cardinal",
"rule": "One",
"override": false
}
Field | Description |
---|---|
locale | The locale for which the translation is for. |
key | The translation key that will be used to store and lookup each translation; normally it is a string or integer. |
trans | The actual translation text. |
type | The type of translation Cardinal, Ordinal, Range or "" for a plain substitution(not required to be defined if plain used) |
rule | The plural rule for which the translation is for eg. One, Two, Few, Many or Other.(not required to be defined if plain used) |
override | If you wish to override an existing translation that has already been registered, set this to 'true'. 99% of the time there is no need to define it. |
To anyone interesting in helping or contributing, I sure could use some help creating tests for each language. Please see issue here for details.
Distributed under MIT License, please see license file in code for more details.