2023-06-17 22:52:42 +02:00
|
|
|
/*
|
|
|
|
* MetaString.h, part of VCMI engine
|
|
|
|
*
|
|
|
|
* Authors: listed in file AUTHORS in main folder
|
|
|
|
*
|
|
|
|
* License: GNU General Public License v2.0 or later
|
|
|
|
* Full text of license available in license.txt file, in main folder
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
VCMI_LIB_NAMESPACE_BEGIN
|
|
|
|
|
2023-06-18 17:59:04 +02:00
|
|
|
class JsonNode;
|
2023-06-17 22:52:42 +02:00
|
|
|
class CreatureID;
|
|
|
|
class CStackBasicDescriptor;
|
2023-09-15 10:06:06 +02:00
|
|
|
class JsonSerializeFormat;
|
2023-06-17 22:52:42 +02:00
|
|
|
using TQuantity = si32;
|
|
|
|
|
2023-06-18 12:51:11 +02:00
|
|
|
/// Strings classes that can be used as replacement in MetaString
|
2023-06-18 11:18:25 +02:00
|
|
|
enum class EMetaText : uint8_t
|
|
|
|
{
|
|
|
|
GENERAL_TXT = 1,
|
|
|
|
OBJ_NAMES,
|
|
|
|
RES_NAMES,
|
|
|
|
ART_NAMES,
|
|
|
|
ARRAY_TXT,
|
|
|
|
CRE_PL_NAMES,
|
|
|
|
CREGENS,
|
|
|
|
MINE_NAMES,
|
|
|
|
MINE_EVNTS,
|
|
|
|
ADVOB_TXT,
|
|
|
|
ART_EVNTS,
|
|
|
|
SPELL_NAME,
|
|
|
|
SEC_SKILL_NAME,
|
|
|
|
CRE_SING_NAMES,
|
|
|
|
CREGENS4,
|
|
|
|
COLOR,
|
|
|
|
ART_DESCR,
|
|
|
|
JK_TXT
|
|
|
|
};
|
|
|
|
|
2023-06-18 12:51:11 +02:00
|
|
|
/// Class for string formatting tools that also support transfer over network with localization using language of local install
|
|
|
|
/// Can be used to compose resulting text from multiple line segments and with placeholder replacement
|
2023-06-17 22:52:42 +02:00
|
|
|
class DLL_LINKAGE MetaString
|
|
|
|
{
|
|
|
|
private:
|
2023-06-18 11:18:25 +02:00
|
|
|
enum class EMessage : uint8_t
|
|
|
|
{
|
|
|
|
APPEND_RAW_STRING,
|
|
|
|
APPEND_LOCAL_STRING,
|
2023-06-18 12:51:11 +02:00
|
|
|
APPEND_TEXTID_STRING,
|
2023-06-18 11:18:25 +02:00
|
|
|
APPEND_NUMBER,
|
|
|
|
REPLACE_RAW_STRING,
|
|
|
|
REPLACE_LOCAL_STRING,
|
2023-06-18 12:51:11 +02:00
|
|
|
REPLACE_TEXTID_STRING,
|
2023-06-18 11:18:25 +02:00
|
|
|
REPLACE_NUMBER,
|
|
|
|
REPLACE_POSITIVE_NUMBER
|
|
|
|
};
|
2023-06-17 22:52:42 +02:00
|
|
|
|
2023-06-18 11:18:25 +02:00
|
|
|
std::vector<EMessage> message;
|
2023-06-17 22:52:42 +02:00
|
|
|
|
2023-06-18 11:18:25 +02:00
|
|
|
std::vector<std::pair<EMetaText,ui32> > localStrings;
|
2023-06-17 22:52:42 +02:00
|
|
|
std::vector<std::string> exactStrings;
|
2023-06-18 12:51:11 +02:00
|
|
|
std::vector<std::string> stringsTextID;
|
2023-06-17 22:52:42 +02:00
|
|
|
std::vector<int64_t> numbers;
|
|
|
|
|
2023-06-18 11:18:25 +02:00
|
|
|
std::string getLocalString(const std::pair<EMetaText, ui32> & txt) const;
|
|
|
|
|
|
|
|
public:
|
2023-06-18 12:51:11 +02:00
|
|
|
/// Creates MetaString and appends provided raw string to it
|
|
|
|
static MetaString createFromRawString(const std::string & value);
|
|
|
|
/// Creates MetaString and appends provided text ID string to it
|
|
|
|
static MetaString createFromTextID(const std::string & value);
|
|
|
|
|
2023-06-18 11:18:25 +02:00
|
|
|
/// Appends local string to resulting string
|
|
|
|
void appendLocalString(EMetaText type, ui32 serial);
|
|
|
|
/// Appends raw string, without translation to resulting string
|
2023-06-18 12:51:11 +02:00
|
|
|
void appendRawString(const std::string & value);
|
|
|
|
/// Appends text ID that will be translated in output
|
|
|
|
void appendTextID(const std::string & value);
|
2023-06-18 11:18:25 +02:00
|
|
|
/// Appends specified number to resulting string
|
|
|
|
void appendNumber(int64_t value);
|
|
|
|
|
|
|
|
/// Replaces first '%s' placeholder in string with specified local string
|
|
|
|
void replaceLocalString(EMetaText type, ui32 serial);
|
|
|
|
/// Replaces first '%s' placeholder in string with specified fixed, untranslated string
|
2023-06-18 12:51:11 +02:00
|
|
|
void replaceRawString(const std::string & txt);
|
|
|
|
/// Repalces first '%s' placeholder with string ID that will be translated in output
|
|
|
|
void replaceTextID(const std::string & value);
|
2023-06-18 11:18:25 +02:00
|
|
|
/// Replaces first '%d' placeholder in string with specified number
|
|
|
|
void replaceNumber(int64_t txt);
|
|
|
|
/// Replaces first '%+d' placeholder in string with specified number using '+' sign as prefix
|
|
|
|
void replacePositiveNumber(int64_t txt);
|
|
|
|
|
|
|
|
/// Replaces first '%s' placeholder with singular or plural name depending on creatures count
|
|
|
|
void replaceCreatureName(const CreatureID & id, TQuantity count);
|
|
|
|
/// Replaces first '%s' placeholder with singular or plural name depending on creatures count
|
2023-06-18 12:51:11 +02:00
|
|
|
void replaceCreatureName(const CStackBasicDescriptor & stack);
|
2023-06-18 11:18:25 +02:00
|
|
|
|
|
|
|
/// erases any existing content in the string
|
|
|
|
void clear();
|
|
|
|
|
|
|
|
///used to handle loot from creature bank
|
2023-06-18 12:51:11 +02:00
|
|
|
std::string buildList() const;
|
2023-06-18 11:18:25 +02:00
|
|
|
|
|
|
|
/// Convert all stored values into a single, user-readable string
|
|
|
|
std::string toString() const;
|
|
|
|
|
|
|
|
/// Returns true if current string is empty
|
|
|
|
bool empty() const;
|
|
|
|
|
2023-06-18 23:25:21 +02:00
|
|
|
bool operator == (const MetaString & other) const;
|
|
|
|
|
2023-06-18 17:59:04 +02:00
|
|
|
void jsonSerialize(JsonNode & dest) const;
|
|
|
|
void jsonDeserialize(const JsonNode & dest);
|
2023-09-15 10:06:06 +02:00
|
|
|
|
|
|
|
void serializeJson(JsonSerializeFormat & handler);
|
2023-06-18 17:59:04 +02:00
|
|
|
|
2023-06-17 22:52:42 +02:00
|
|
|
template <typename Handler> void serialize(Handler & h, const int version)
|
|
|
|
{
|
|
|
|
h & exactStrings;
|
|
|
|
h & localStrings;
|
2023-06-18 12:51:11 +02:00
|
|
|
h & stringsTextID;
|
2023-06-17 22:52:42 +02:00
|
|
|
h & message;
|
|
|
|
h & numbers;
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
VCMI_LIB_NAMESPACE_END
|