As one of the core components of the framework, inheriting the consistent convenience design philosophy of goframe, the configuration management of the I18N internationalization component is very simple.

File Formats

The gi18n internationalization component supports five common configuration file formats: xml/ini/yaml/toml/json/properties (for a more detailed list of file supports, please refer to the configuration management section: Configuration). Similarly, like the configuration management module, the framework recommends using the toml file format.

Reading Path

By default, gi18n will automatically look for and read the following directories under the source root directory of the current project (or the current PWD run directory):

  • manifest/i18n
  • i18n

The found directory is used as the storage directory for international translation files by default. Developers can also customize the storage directory path of i18n files through the SetPath method.

File Storage

In the i18n directory, you can directly name files according to internationalization names such as en.toml/ja.toml/zh-CN.toml; you can also give a directory with the internationalization name and freely customize configuration files under that directory, such as en/editor.toml/en/user.toml, zh-CN/editor.toml/zh-CN/user.toml. You can manage with pure file management or add an additional directory level, and gi18n can intelligently recognize and load.

I18N - Configuration - 图1tip

Internationalized file/directory names can be defined and maintained by developers, primarily for settings and use in the program. It is recommended to name them according to standardized international regional language codes. For more details, refer to WIKI: https://zh.wikipedia.org/wiki/ISO_639-1

For example, the following i18n directory structure and file format are supported.

Distinguish different languages through separate i18n files

  1. └── i18n
  2. ├── en.toml
  3. ├── ja.toml
  4. ├── ru.toml
  5. ├── zh-CN.toml
  6. └── zh-TW.toml

Distinguish different languages through different directory names

  1. └── i18n
  2. ├── en
  3. ├── hello.toml
  4. └── world.toml
  5. ├── ja
  6. ├── hello.yaml
  7. └── world.yaml
  8. ├── ru
  9. ├── hello.ini
  10. └── world.ini
  11. ├── zh-CN
  12. ├── hello.json
  13. └── world.json
  14. └── zh-TW
  15. ├── hello.xml
  16. └── world.xml

Different languages can have different file formats

  1. └── i18n
  2. ├── en.toml
  3. ├── ja.yaml
  4. ├── ru.ini
  5. ├── zh-CN.json
  6. └── zh-TW.xml

Resource Manager

gi18n supports the resource manager by default (for more details, refer to the section: Resource). By default, it will retrieve the manifest/i18n and i18n directories from the gres configuration manager, or the i18n directory path set by the developer.