# Conflicts: # src/autoreplace_gui.cpp # src/build_vehicle_gui.cpp # src/cheat_gui.cpp # src/company_gui.cpp # src/debug.cpp # src/engine_gui.h # src/error_gui.cpp # src/group_gui.cpp # src/industry_cmd.cpp # src/industry_gui.cpp # src/misc_gui.cpp # src/network/network_gui.cpp # src/newgrf.cpp # src/newgrf_debug_gui.cpp # src/newgrf_gui.cpp # src/order_gui.cpp # src/rail_gui.cpp # src/road_gui.cpp # src/saveload/saveload.cpp # src/screenshot_gui.cpp # src/sound/win32_s.cpp # src/statusbar_gui.cpp # src/strgen/strgen.cpp # src/table/newgrf_debug_data.h # src/timetable_gui.cpp # src/toolbar_gui.cpp # src/town_gui.cpp # src/vehicle_gui.cpp # src/video/sdl2_v.cpp # src/video/sdl_v.cpp # src/viewport.cpp
		
			
				
	
	
		
			83 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			83 lines
		
	
	
		
			4.1 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
/*
 | 
						|
 * This file is part of OpenTTD.
 | 
						|
 * OpenTTD is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation, version 2.
 | 
						|
 * OpenTTD is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
 | 
						|
 * See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with OpenTTD. If not, see <http://www.gnu.org/licenses/>.
 | 
						|
 */
 | 
						|
 | 
						|
/** @file newgrf_text.h Header of Action 04 "universal holder" structure and functions */
 | 
						|
 | 
						|
#ifndef NEWGRF_TEXT_H
 | 
						|
#define NEWGRF_TEXT_H
 | 
						|
 | 
						|
#include "string_type.h"
 | 
						|
#include "strings_type.h"
 | 
						|
#include "table/control_codes.h"
 | 
						|
#include <utility>
 | 
						|
#include <vector>
 | 
						|
#include <string>
 | 
						|
 | 
						|
/** This character, the thorn ('þ'), indicates a unicode string to NFO. */
 | 
						|
static const char32_t NFO_UTF8_IDENTIFIER = 0x00DE;
 | 
						|
 | 
						|
/** A GRF text with associated language ID. */
 | 
						|
struct GRFText {
 | 
						|
	uint8_t langid;      ///< The language associated with this GRFText.
 | 
						|
	std::string text; ///< The actual (translated) text.
 | 
						|
};
 | 
						|
 | 
						|
/** A GRF text with a list of translations. */
 | 
						|
typedef std::vector<GRFText> GRFTextList;
 | 
						|
/** Reference counted wrapper around a GRFText pointer. */
 | 
						|
typedef std::shared_ptr<GRFTextList> GRFTextWrapper;
 | 
						|
 | 
						|
StringID AddGRFString(uint32_t grfid, uint16_t stringid, uint8_t langid, bool new_scheme, bool allow_newlines, std::string_view text_to_add, StringID def_string);
 | 
						|
StringID GetGRFStringID(uint32_t grfid, StringID stringid);
 | 
						|
const char *GetGRFStringFromGRFText(const GRFTextList &text_list);
 | 
						|
const char *GetGRFStringFromGRFText(const GRFTextWrapper &text);
 | 
						|
const char *GetDefaultLangGRFStringFromGRFText(const GRFTextList &text_list);
 | 
						|
const char *GetDefaultLangGRFStringFromGRFText(const GRFTextWrapper &text);
 | 
						|
const char *GetGRFStringPtr(uint32_t stringid);
 | 
						|
void CleanUpStrings();
 | 
						|
void SetCurrentGrfLangID(uint8_t language_id);
 | 
						|
std::string TranslateTTDPatchCodes(uint32_t grfid, uint8_t language_id, bool allow_newlines, std::string_view str, StringControlCode byte80 = SCC_NEWGRF_PRINT_WORD_STRING_ID);
 | 
						|
void AddGRFTextToList(GRFTextList &list, uint8_t langid, uint32_t grfid, bool allow_newlines, std::string_view text_to_add);
 | 
						|
void AddGRFTextToList(GRFTextWrapper &list, uint8_t langid, uint32_t grfid, bool allow_newlines, std::string_view text_to_add);
 | 
						|
void AddGRFTextToList(GRFTextWrapper &list, std::string_view text_to_add);
 | 
						|
 | 
						|
bool CheckGrfLangID(uint8_t lang_id, uint8_t grf_version);
 | 
						|
 | 
						|
void StartTextRefStackUsage(const struct GRFFile *grffile, uint8_t numEntries, const uint32_t *values = nullptr);
 | 
						|
void StopTextRefStackUsage();
 | 
						|
bool UsingNewGRFTextStack();
 | 
						|
struct TextRefStack *CreateTextRefStackBackup();
 | 
						|
void RestoreTextRefStackBackup(struct TextRefStack *backup);
 | 
						|
 | 
						|
class StringParameters;
 | 
						|
uint RemapNewGRFStringControlCode(uint scc, std::string *buffer, const char **str, StringParameters ¶meters, bool modify_parameters);
 | 
						|
 | 
						|
/** Mapping of language data between a NewGRF and OpenTTD. */
 | 
						|
struct LanguageMap {
 | 
						|
	/** Mapping between NewGRF and OpenTTD IDs. */
 | 
						|
	struct Mapping {
 | 
						|
		uint8_t newgrf_id;  ///< NewGRF's internal ID for a case/gender.
 | 
						|
		uint8_t openttd_id; ///< OpenTTD's internal ID for a case/gender.
 | 
						|
	};
 | 
						|
 | 
						|
	/* We need a vector and can't use SmallMap due to the fact that for "setting" a
 | 
						|
	 * gender of a string or requesting a case for a substring we want to map from
 | 
						|
	 * the NewGRF's internal ID to OpenTTD's ID whereas for the choice lists we map
 | 
						|
	 * the genders/cases/plural OpenTTD IDs to the NewGRF's internal IDs. In this
 | 
						|
	 * case a NewGRF developer/translator might want a different translation for
 | 
						|
	 * both cases. Thus we are basically implementing a multi-map. */
 | 
						|
	std::vector<Mapping> gender_map; ///< Mapping of NewGRF and OpenTTD IDs for genders.
 | 
						|
	std::vector<Mapping> case_map;   ///< Mapping of NewGRF and OpenTTD IDs for cases.
 | 
						|
	int plural_form;                 ///< The plural form used for this language.
 | 
						|
 | 
						|
	int GetMapping(int newgrf_id, bool gender) const;
 | 
						|
	int GetReverseMapping(int openttd_id, bool gender) const;
 | 
						|
	static const LanguageMap *GetLanguageMap(uint32_t grfid, uint8_t language_id);
 | 
						|
};
 | 
						|
 | 
						|
#endif /* NEWGRF_TEXT_H */
 |