(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...)
This commit is contained in:
		
							
								
								
									
										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);
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user