mirror of https://github.com/OpenTTD/OpenTTD
(svn r4550) - NewGRF: update string system to new rules: a grf version of less than 6 uses the old scheme, of 7 or more uses the new scheme. (Moving targets, yay...)
parent
b54ebaba70
commit
baebc8d47e
3
newgrf.c
3
newgrf.c
|
@ -1725,6 +1725,7 @@ static void VehicleNewName(byte *buf, int len)
|
||||||
uint16 id;
|
uint16 id;
|
||||||
uint16 endid;
|
uint16 endid;
|
||||||
const char* name;
|
const char* name;
|
||||||
|
bool new_scheme = _cur_grffile->grf_version < 7;
|
||||||
|
|
||||||
check_length(len, 6, "VehicleNewName");
|
check_length(len, 6, "VehicleNewName");
|
||||||
buf++;
|
buf++;
|
||||||
|
@ -1754,7 +1755,7 @@ static void VehicleNewName(byte *buf, int len)
|
||||||
case GSF_ROAD:
|
case GSF_ROAD:
|
||||||
case GSF_SHIP:
|
case GSF_SHIP:
|
||||||
case GSF_AIRCRAFT: {
|
case GSF_AIRCRAFT: {
|
||||||
StringID string = AddGRFString(_cur_grffile->grfid, id, lang, name);
|
StringID string = AddGRFString(_cur_grffile->grfid, id, lang, new_scheme, name);
|
||||||
if (id < TOTAL_NUM_ENGINES) SetCustomEngineName(id, string);
|
if (id < TOTAL_NUM_ENGINES) SetCustomEngineName(id, string);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
|
@ -64,6 +64,7 @@ typedef enum grf_extended_languages {
|
||||||
GRFLX_PORTUGUESE = 0x36,
|
GRFLX_PORTUGUESE = 0x36,
|
||||||
GRFLX_BRAZILIAN = 0x37,
|
GRFLX_BRAZILIAN = 0x37,
|
||||||
GRFLX_TURKISH = 0x3E,
|
GRFLX_TURKISH = 0x3E,
|
||||||
|
GRFLX_UNSPECIFIED = 0x7F,
|
||||||
} grf_language;
|
} grf_language;
|
||||||
|
|
||||||
|
|
||||||
|
@ -119,28 +120,27 @@ static byte _currentLangID = GRFLX_ENGLISH; //by default, english is used.
|
||||||
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add the new read stirng into our structure.
|
* Add the new read string into our structure.
|
||||||
* TODO : ajust the old scheme to the new one for german,french and spanish
|
|
||||||
*/
|
*/
|
||||||
StringID AddGRFString(uint32 grfid, uint16 stringid, byte langid_to_add, const char *text_to_add)
|
StringID AddGRFString(uint32 grfid, uint16 stringid, byte langid_to_add, bool new_scheme, const char *text_to_add)
|
||||||
{
|
{
|
||||||
GRFText *newtext;
|
GRFText *newtext;
|
||||||
uint id;
|
uint id;
|
||||||
|
|
||||||
/* When working with the old language scheme (bit 6 of langid is clear) and
|
/* When working with the old language scheme (grf_version is less than 7) and
|
||||||
* English or American is among the set bits, simply add it as English in
|
* English or American is among the set bits, simply add it as English in
|
||||||
* the new scheme, i.e. as langid = 1.
|
* the new scheme, i.e. as langid = 1.
|
||||||
* If English is set, it is pretty safe to assume the translations are not
|
* If English is set, it is pretty safe to assume the translations are not
|
||||||
* actually translated.
|
* actually translated.
|
||||||
*/
|
*/
|
||||||
if (!HASBIT(langid_to_add, 6)) {
|
if (!new_scheme) {
|
||||||
if (HASBITS(langid_to_add, GRFLB_AMERICAN | GRFLB_ENGLISH)) {
|
if (HASBITS(langid_to_add, GRFLB_AMERICAN | GRFLB_ENGLISH)) {
|
||||||
langid_to_add = GRFLX_ENGLISH;
|
langid_to_add = GRFLX_ENGLISH;
|
||||||
} else {
|
} else {
|
||||||
StringID ret = STR_EMPTY;
|
StringID ret = STR_EMPTY;
|
||||||
if (langid_to_add & GRFLB_GERMAN) ret = AddGRFString(grfid, stringid, 1 << 6 | GRFLX_GERMAN, text_to_add);
|
if (langid_to_add & GRFLB_GERMAN) ret = AddGRFString(grfid, stringid, 1 << 6 | GRFLX_GERMAN, true, text_to_add);
|
||||||
if (langid_to_add & GRFLB_FRENCH) ret = AddGRFString(grfid, stringid, 1 << 6 | GRFLX_FRENCH, text_to_add);
|
if (langid_to_add & GRFLB_FRENCH) ret = AddGRFString(grfid, stringid, 1 << 6 | GRFLX_FRENCH, true, text_to_add);
|
||||||
if (langid_to_add & GRFLB_SPANISH) ret = AddGRFString(grfid, stringid, 1 << 6 | GRFLX_SPANISH, text_to_add);
|
if (langid_to_add & GRFLB_SPANISH) ret = AddGRFString(grfid, stringid, 1 << 6 | GRFLX_SPANISH, true, text_to_add);
|
||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -30,7 +30,7 @@ typedef struct GRFTextEntry {
|
||||||
} GRFTextEntry;
|
} GRFTextEntry;
|
||||||
|
|
||||||
|
|
||||||
StringID AddGRFString(uint32 grfid, uint16 stringid, byte langid, const char *text_to_add);
|
StringID AddGRFString(uint32 grfid, uint16 stringid, byte langid, bool new_scheme, const char *text_to_add);
|
||||||
StringID GetGRFStringID(uint32 grfid, uint16 stringid);
|
StringID GetGRFStringID(uint32 grfid, uint16 stringid);
|
||||||
char *GetGRFString(char *buff, uint16 stringid);
|
char *GetGRFString(char *buff, uint16 stringid);
|
||||||
void CleanUpStrings(void);
|
void CleanUpStrings(void);
|
||||||
|
|
Loading…
Reference in New Issue