Locale improvements #21

Closed
opened 2024-04-07 10:19:11 +03:00 by Exynox · 5 comments
Owner
  • Change locale_service.cpp so that the proper locale_string file is automatically read
  • Remove the locale/country_here/ strings, in order to uniformly treat all locales
  • Remove locales for unsupported countries
  • Make GF/EU the default behaviour
- Change locale_service.cpp so that the proper locale_string file is automatically read - Remove the locale/country_here/ strings, in order to uniformly treat all locales - Remove locales for unsupported countries - Make GF/EU the default behaviour
Exynox added the
enhancement
label 2024-04-07 10:19:11 +03:00
Contributor
  • Make GF/EU the default behaviour

Do you still want to keep all the local variation in the code? Or should that all be removed?

  • Remove locales for unsupported countries
  • Change locale_service.cpp so that the proper locale_string file is automatically read
  • Remove the locale/country_here/ strings, in order to uniformly treat all locales

So you want to keep supporting some locales? Or do you want to yeet everything that's not English?

> - Make GF/EU the default behaviour Do you still want to keep all the local variation in the code? Or should that all be removed? > - Remove locales for unsupported countries > - Change locale_service.cpp so that the proper locale_string file is automatically read > - Remove the locale/country_here/ strings, in order to uniformly treat all locales So you want to keep supporting _some_ locales? Or do you want to yeet everything that's not English?
Author
Owner

Sorry for the confusion, this was more of a rudimentary list so I had a rough idea what I should do.

  • Make GF/EU the default behaviour

Do you still want to keep all the local variation in the code? Or should that all be removed?

I meant that the server behaviour should be the same across locales: for example, there are checks like these below that should be removed. The behaviour after removal should be identical to the one of an European, Gameforge locale. This removal should also be done on the client side.
image
image

  • Remove locales for unsupported countries
  • Change locale_service.cpp so that the proper locale_string file is automatically read
  • Remove the locale/country_here/ strings, in order to uniformly treat all locales

So you want to keep supporting some locales? Or do you want to yeet everything that's not English?

The plan is to support as many languages as possible, while keeping an identical game experience. Ideally, all translations will end up being client-side, by using systems such as this one: https://metin2.dev/topic/29790-official-client-locale-stringreversed/. I intend to remove the locales that present little interest (China), are no longer being published (Japan, Korea, Vietnam, Thailand), or can be replaced pretty smoothly with a GF locale (USA, Singapore). Essentially, we shouldn't have country locales, but language locales, therefore supporting Spanish from both Spain and Mexico, Portuguese from both Portugal and Brazil, etc.

Also, there are locales that were never used, such as the one for Bulgaria.

I also meant that locale_service should be changed accordingly, as to have an uniform file structure, for example:

Before:
image

After:
image

We should also push for UTF-8 strings, even though that would require some rewriting in the client, as text rendering pretty much would only work for fixed-length encodings.

Another idea I have is to encourage community translations, especially for languages that have never been supported (Serbian, Bulgarian, etc.). This would require that all localization files be on the client-side first, in an easy-to-translate format; maybe gettext? It would also be interesting to see if machine translation is passable enough in a few years so that we could do this without much human effort.

Sorry for the confusion, this was more of a rudimentary list so I had a rough idea what I should do. > > - Make GF/EU the default behaviour > > Do you still want to keep all the local variation in the code? Or should that all be removed? I meant that the server behaviour should be the same across locales: for example, there are checks like these below that should be removed. The behaviour after removal should be identical to the one of an European, Gameforge locale. This removal should also be done on the client side. ![image](/attachments/4f25181a-9075-418c-8cf7-ed1d1c7d91cf) ![image](/attachments/d51695dd-01fb-4996-9e8b-e87ece30129b) > > - Remove locales for unsupported countries > > - Change locale_service.cpp so that the proper locale_string file is automatically read > > - Remove the locale/country_here/ strings, in order to uniformly treat all locales > > So you want to keep supporting _some_ locales? Or do you want to yeet everything that's not English? The plan is to support as many languages as possible, while keeping an identical game experience. Ideally, all translations will end up being client-side, by using systems such as this one: https://metin2.dev/topic/29790-official-client-locale-stringreversed/. I intend to remove the locales that present little interest (China), are no longer being published (Japan, Korea, Vietnam, Thailand), or can be replaced pretty smoothly with a GF locale (USA, Singapore). Essentially, we shouldn't have *country* locales, but *language* locales, therefore supporting Spanish from both Spain and Mexico, Portuguese from both Portugal and Brazil, etc. Also, there are locales that were never used, such as the one for Bulgaria. I also meant that locale_service should be changed accordingly, as to have an uniform file structure, for example: Before: ![image](/attachments/6e70ca72-d4a3-44d9-bea1-04befcbabd5e) After: ![image](/attachments/1214d361-b58c-49e3-91d1-df71a6e71f94) We should also push for UTF-8 strings, even though that would require some rewriting in the client, as text rendering pretty much would only work for fixed-length encodings. Another idea I have is to encourage community translations, especially for languages that have never been supported (Serbian, Bulgarian, etc.). This would require that all localization files be on the client-side first, in an easy-to-translate format; maybe gettext? It would also be interesting to see if machine translation is passable enough in a few years so that we could do this without much human effort.
Contributor

Phew. Glad we had the same goal (again) :D
I yeeted everything (except for 6/7 bonus, which was disabled in EU) in a branch on my fork #22.

Phew. Glad we had the same goal (again) :D I yeeted everything (except for 6/7 bonus, which was disabled in EU) in a branch on my fork #22.

Hi, regarding a similar goal, but for readability, would it be better to refactor the codebase such that there are no variables or strings in korean language (translating everything except maybe the comments to the english variants)? For example the skills enum (renaming the symbols):

enum ESkillIndexes
{
	SKILL_RESERVED = 0,

	// ¹«»ç Àü»ç °è¿­
	// A
	SKILL_SAMYEON = 1,		// »ï¿¬Âü(¼¼¹øº£±â)
	SKILL_PALBANG,		// Æȹædz¿ì
	// S
	SKILL_JEONGWI,		// Àü±ÍÈ¥
	SKILL_GEOMKYUNG,		// °Ë°æ
	SKILL_TANHWAN,		// źȯ°Ý

Also some flags in the "affects" are stored in korean in the DB...

or the localization used in things like the chat packets (using the english string as the base instead):

		ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("착용 중인 용혼석은 추출할 수 없습니다."));
Hi, regarding a similar goal, but for readability, would it be better to refactor the codebase such that there are no variables or strings in korean language (translating everything except maybe the comments to the english variants)? For example the skills enum (renaming the symbols): ``` enum ESkillIndexes { SKILL_RESERVED = 0, // ¹«»ç Àü»ç °è¿­ // A SKILL_SAMYEON = 1, // »ï¿¬Âü(¼¼¹øº£±â) SKILL_PALBANG, // Æȹædz¿ì // S SKILL_JEONGWI, // Àü±ÍÈ¥ SKILL_GEOMKYUNG, // °Ë°æ SKILL_TANHWAN, // źȯ°Ý ``` Also some flags in the "affects" are stored in korean in the DB... or the localization used in things like the chat packets (using the english string as the base instead): ``` ch->ChatPacket(CHAT_TYPE_INFO, LC_TEXT("착용 중인 용혼석은 추출할 수 없습니다.")); ```
Author
Owner

Hi, the localization was already converted to English in the nightly branch (due to be merged/released into master soon). This was done by @Tr0n in commits 9b7536ee9a, 326c134f9e and some others; I forgot to close this issue.

Renaming the skills/affects indeed sounds like a good idea, but it should be opened into its own issue.

Hi, the localization was already converted to English in the nightly branch (due to be merged/released into master soon). This was done by @Tr0n in commits 9b7536ee9a9441fc894fa702bb09c6a9e260cf8a, 326c134f9ee0920c51e6d713f92e734506b9b477 and some others; I forgot to close this issue. Renaming the skills/affects indeed sounds like a good idea, but it should be opened into its own issue.
Sign in to join this conversation.
No Milestone
No project
No Assignees
3 Participants
Notifications
Due Date
The due date is invalid or out of range. Please use the format 'yyyy-mm-dd'.

No due date set.

Dependencies

No dependencies set.

Reference: metin2/server#21
No description provided.