Concerning pull requests with new strings in language lump
Moderator: GZDoom Developers
-
- Lead GZDoom+Raze Developer
- Posts: 49117
- Joined: Sat Jul 19, 2003 10:19 am
- Location: Germany
Concerning pull requests with new strings in language lump
GZDoom is in the transition of its localized string handling right now.
The goal is to have the language resources in a place where it can be edited by external contributors that do not use the GZDoom Github project directly - they are hosted on Google Docs so that anyone with interest to contribute can request access to edit.
In the future the language.enu lump will no longer exist, instead, all texts will be read from a spreadsheet file within gzdoom.pk3 which is periodically updated from the public versions mentioned above.
This has a few implications on how text content needs to be handled - editing the language files within the GZDoom project is no longer possible because they no longer represent the master version of the text resources. For pull requests this means that they have to do a minor bit of added work to get the newly added strings to where they belong: Instead of editing language.enu, the new texts will have to be added to the PR as a comment, outside the actual changeset so that if the PR gets merged they can be added to the spreadsheet easily.
Please note that since the text data in the Github repo is not the master resource, any alteration of it by a PR needs to be rejected without exception.
The goal is to have the language resources in a place where it can be edited by external contributors that do not use the GZDoom Github project directly - they are hosted on Google Docs so that anyone with interest to contribute can request access to edit.
In the future the language.enu lump will no longer exist, instead, all texts will be read from a spreadsheet file within gzdoom.pk3 which is periodically updated from the public versions mentioned above.
This has a few implications on how text content needs to be handled - editing the language files within the GZDoom project is no longer possible because they no longer represent the master version of the text resources. For pull requests this means that they have to do a minor bit of added work to get the newly added strings to where they belong: Instead of editing language.enu, the new texts will have to be added to the PR as a comment, outside the actual changeset so that if the PR gets merged they can be added to the spreadsheet easily.
Please note that since the text data in the Github repo is not the master resource, any alteration of it by a PR needs to be rejected without exception.
-
- Posts: 1606
- Joined: Mon Jun 12, 2017 12:57 am
Re: Concerning pull requests with new strings in language lu
This means "in the future you cant add new custom translations to gzdoom"? Or language lump is just for "default" translations?In the future the language.enu lump will no longer exist
-
- Posts: 7402
- Joined: Fri Oct 22, 2004 9:22 am
- Graphics Processor: nVidia with Vulkan support
- Location: MAP33
Re: Concerning pull requests with new strings in language lu
Presumably it's just for the default translations.Apeirogon wrote:This means "in the future you cant add new custom translations to gzdoom"? Or language lump is just for "default" translations?In the future the language.enu lump will no longer exist
-
- Lead GZDoom+Raze Developer
- Posts: 49117
- Joined: Sat Jul 19, 2003 10:19 am
- Location: Germany
Re: Concerning pull requests with new strings in language lu
The language lump as-is will be removed. The only piece that will remain in the old format is the untranslatable content that Dehacked needs to access.
Since the text needs to be hosted outside of Github to allow translators access to it, pull requests cannot just add text to the repo - I'd have to manually take it out again and copy to the translation spreadsheet. This is why text needs to be provided separately from the code changes.
Since the text needs to be hosted outside of Github to allow translators access to it, pull requests cannot just add text to the repo - I'd have to manually take it out again and copy to the translation spreadsheet. This is why text needs to be provided separately from the code changes.
-
- Posts: 13696
- Joined: Tue Jan 13, 2004 1:31 pm
- Preferred Pronouns: She/Her
Re: Concerning pull requests with new strings in language lu
This is very likely not going to appear in a pull request, so I may as well ask for it, here:
The Vulkan branch is very likely going to need a backend switcher in the menu, under the video menu.
I will suggest the names be as follows (and can be altered as you please):
For reference, the CVAR that does this is vid_backend. Right now it only works on Windows, but I do plan to change that; I just haven't gotten around to it.
The Vulkan branch is very likely going to need a backend switcher in the menu, under the video menu.
I will suggest the names be as follows (and can be altered as you please):
Code: Select all
VIDMNU_BACKEND = "Rendering Backend";
VIDMNU_BACKEND_VULKAN = "Vulkan (if available)";
VIDMNU_BACKEND_OPENGL = "OpenGL only";
-
- Lead GZDoom+Raze Developer
- Posts: 49117
- Joined: Sat Jul 19, 2003 10:19 am
- Location: Germany
Re: Concerning pull requests with new strings in language lu
This also needs to be disabled if initializing Vulkan fails, so the '(if available)' and 'only' parts are not needed.
-
-
- Posts: 3814
- Joined: Sun Aug 07, 2011 4:32 am
Re: Concerning pull requests with new strings in language lu
I added this CVAR to other backends.Rachael wrote:Right now it only works on Windows
-
- Posts: 13696
- Joined: Tue Jan 13, 2004 1:31 pm
- Preferred Pronouns: She/Her
Re: Concerning pull requests with new strings in language lu
Oh, I didn't realize you did that. I suppose I should look at the commits log occasionally._mental_ wrote:I added this CVAR to other backends.
Thanks.
-
- Posts: 9696
- Joined: Sun Jan 04, 2004 5:37 pm
- Preferred Pronouns: They/Them
- Operating System Version (Optional): Debian Bullseye
- Location: Gotham City SAR, Wyld-Lands of the Lotus People, Dominionist PetroConfederacy of Saudi Canadia
Re: Concerning pull requests with new strings in language lu
How will this affect mods that use language.en(u) to replace some strings, e.g. default death, etc.?
-
- Lead GZDoom+Raze Developer
- Posts: 49117
- Joined: Sat Jul 19, 2003 10:19 am
- Location: Germany
Re: Concerning pull requests with new strings in language lu
Not at all. The old format can still be read as before. The main issue here is not the format but that with the master string tables being outside the repo, any change to the text files in there is simply not in the right place.
-
-
- Posts: 17454
- Joined: Mon Oct 27, 2003 12:07 am
- Location: Kuala Lumpur, Malaysia
Re: Concerning pull requests with new strings in language lu
For fork developers, what's the recommended workflow?
I have some local engine changes with some new strings that used to be in the language.enu file.
1) Does that mean I have to maintain my own copy of the Google spreadsheets, and periodically merge/sync the master sheet with mine? How do I avoid cell collisions?
2) What's the procedure to turn the Google spreadsheet into the language.csv that the engine can readily use? Is it as simple as File -> Download as -> CSV or is some other post processing tool needed?
I have some local engine changes with some new strings that used to be in the language.enu file.
1) Does that mean I have to maintain my own copy of the Google spreadsheets, and periodically merge/sync the master sheet with mine? How do I avoid cell collisions?
2) What's the procedure to turn the Google spreadsheet into the language.csv that the engine can readily use? Is it as simple as File -> Download as -> CSV or is some other post processing tool needed?
-
- Lead GZDoom+Raze Developer
- Posts: 49117
- Joined: Sat Jul 19, 2003 10:19 am
- Location: Germany
Re: Concerning pull requests with new strings in language lu
What you need to do entirely depends on your needs. If you have your own english.enu file it can remain as such, assuming you do not want to localize your text. If you have text mixed into the main one, I recommend to split them up to avoid clashes.
For updates to the main language resources, normally it should be enough to just pull in the CSVs from the main repo when they get updated. I won't update the repo for each single change, but only if either a new release is due or the changes are significant (like, right now, so I'll update this evening when I am back home.) If you absolutely need to do an update immediately, you can download the Google hosted ones as CSV and use it directly. The ones on Github are unedited Google exports.
For updates to the main language resources, normally it should be enough to just pull in the CSVs from the main repo when they get updated. I won't update the repo for each single change, but only if either a new release is due or the changes are significant (like, right now, so I'll update this evening when I am back home.) If you absolutely need to do an update immediately, you can download the Google hosted ones as CSV and use it directly. The ones on Github are unedited Google exports.
-
-
- Posts: 17454
- Joined: Mon Oct 27, 2003 12:07 am
- Location: Kuala Lumpur, Malaysia
Re: Concerning pull requests with new strings in language lu
For now, I went with language.<my fork name>.csv (yay cumulative lumps!). The list of engine strings I have added is currently very small (only 3 strings so far), I can afford to maintain this file by hand.
Question: if I'm understanding the pattern correctly; when more languages are added to the engine, I have to increase the amount of commas in my language.<my fork name>.csv file, correct?
Question: if I'm understanding the pattern correctly; when more languages are added to the engine, I have to increase the amount of commas in my language.<my fork name>.csv file, correct?
-
- Lead GZDoom+Raze Developer
- Posts: 49117
- Joined: Sat Jul 19, 2003 10:19 am
- Location: Germany
Re: Concerning pull requests with new strings in language lu
You should never - ever - hand-maintain a CSV file, this is far, far too volatile and full of pitfalls.
If you hand-maintain language content, use the old format, which is still the official way to add strings to the game
CSV support is only there for directly reading in spreadsheet exports, I will give no support if you try to do it by hand.
If you hand-maintain language content, use the old format, which is still the official way to add strings to the game
CSV support is only there for directly reading in spreadsheet exports, I will give no support if you try to do it by hand.
-
-
- Posts: 17454
- Joined: Mon Oct 27, 2003 12:07 am
- Location: Kuala Lumpur, Malaysia
Re: Concerning pull requests with new strings in language lu
Okay, noted. Yeah, that's what I thought. It's just too clunky to do by hand anyway.