mirror of
https://github.com/vcmi/vcmi.git
synced 2024-12-24 22:14:36 +02:00
Moved MetaString to a new file
This commit is contained in:
parent
f35b3a0dc3
commit
2636a0dcc3
@ -28,7 +28,7 @@
|
|||||||
#include "../../lib/CConfigHandler.h"
|
#include "../../lib/CConfigHandler.h"
|
||||||
#include "../../lib/CGameState.h"
|
#include "../../lib/CGameState.h"
|
||||||
#include "../../lib/CGeneralTextHandler.h"
|
#include "../../lib/CGeneralTextHandler.h"
|
||||||
#include "../../lib/NetPacksBase.h"
|
#include "../../lib/MetaString.h"
|
||||||
#include "../../lib/mapObjects/CQuest.h"
|
#include "../../lib/mapObjects/CQuest.h"
|
||||||
|
|
||||||
VCMI_LIB_NAMESPACE_BEGIN
|
VCMI_LIB_NAMESPACE_BEGIN
|
||||||
|
@ -238,6 +238,7 @@ macro(add_main_lib TARGET_NAME LIBRARY_TYPE)
|
|||||||
${MAIN_LIB_DIR}/LoadProgress.cpp
|
${MAIN_LIB_DIR}/LoadProgress.cpp
|
||||||
${MAIN_LIB_DIR}/LogicalExpression.cpp
|
${MAIN_LIB_DIR}/LogicalExpression.cpp
|
||||||
${MAIN_LIB_DIR}/NetPacksLib.cpp
|
${MAIN_LIB_DIR}/NetPacksLib.cpp
|
||||||
|
${MAIN_LIB_DIR}/MetaString.cpp
|
||||||
${MAIN_LIB_DIR}/ObstacleHandler.cpp
|
${MAIN_LIB_DIR}/ObstacleHandler.cpp
|
||||||
${MAIN_LIB_DIR}/StartInfo.cpp
|
${MAIN_LIB_DIR}/StartInfo.cpp
|
||||||
${MAIN_LIB_DIR}/ResourceSet.cpp
|
${MAIN_LIB_DIR}/ResourceSet.cpp
|
||||||
@ -560,6 +561,7 @@ macro(add_main_lib TARGET_NAME LIBRARY_TYPE)
|
|||||||
${MAIN_LIB_DIR}/Languages.h
|
${MAIN_LIB_DIR}/Languages.h
|
||||||
${MAIN_LIB_DIR}/LoadProgress.h
|
${MAIN_LIB_DIR}/LoadProgress.h
|
||||||
${MAIN_LIB_DIR}/LogicalExpression.h
|
${MAIN_LIB_DIR}/LogicalExpression.h
|
||||||
|
${MAIN_LIB_DIR}/MetaString.h
|
||||||
${MAIN_LIB_DIR}/NetPacksBase.h
|
${MAIN_LIB_DIR}/NetPacksBase.h
|
||||||
${MAIN_LIB_DIR}/NetPacks.h
|
${MAIN_LIB_DIR}/NetPacks.h
|
||||||
${MAIN_LIB_DIR}/NetPacksLobby.h
|
${MAIN_LIB_DIR}/NetPacksLobby.h
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
VCMI_LIB_NAMESPACE_BEGIN
|
VCMI_LIB_NAMESPACE_BEGIN
|
||||||
|
|
||||||
class PlayerColor;
|
class PlayerColor;
|
||||||
struct MetaString;
|
class MetaString;
|
||||||
class ServerCallback;
|
class ServerCallback;
|
||||||
class CGHeroInstance;
|
class CGHeroInstance;
|
||||||
|
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
|
|
||||||
VCMI_LIB_NAMESPACE_BEGIN
|
VCMI_LIB_NAMESPACE_BEGIN
|
||||||
|
|
||||||
struct MetaString;
|
class MetaString;
|
||||||
|
|
||||||
namespace battle
|
namespace battle
|
||||||
{
|
{
|
||||||
|
@ -68,234 +68,6 @@ public:
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
void MetaString::getLocalString(const std::pair<ui8, ui32> & txt, std::string & dst) const
|
|
||||||
{
|
|
||||||
int type = txt.first;
|
|
||||||
int ser = txt.second;
|
|
||||||
|
|
||||||
if(type == ART_NAMES)
|
|
||||||
{
|
|
||||||
const auto * art = ArtifactID(ser).toArtifact(VLC->artifacts());
|
|
||||||
if(art)
|
|
||||||
dst = art->getNameTranslated();
|
|
||||||
else
|
|
||||||
dst = "#!#";
|
|
||||||
}
|
|
||||||
else if(type == ART_DESCR)
|
|
||||||
{
|
|
||||||
const auto * art = ArtifactID(ser).toArtifact(VLC->artifacts());
|
|
||||||
if(art)
|
|
||||||
dst = art->getDescriptionTranslated();
|
|
||||||
else
|
|
||||||
dst = "#!#";
|
|
||||||
}
|
|
||||||
else if (type == ART_EVNTS)
|
|
||||||
{
|
|
||||||
const auto * art = ArtifactID(ser).toArtifact(VLC->artifacts());
|
|
||||||
if(art)
|
|
||||||
dst = art->getEventTranslated();
|
|
||||||
else
|
|
||||||
dst = "#!#";
|
|
||||||
}
|
|
||||||
else if(type == CRE_PL_NAMES)
|
|
||||||
{
|
|
||||||
const auto * cre = CreatureID(ser).toCreature(VLC->creatures());
|
|
||||||
if(cre)
|
|
||||||
dst = cre->getNamePluralTranslated();
|
|
||||||
else
|
|
||||||
dst = "#!#";
|
|
||||||
}
|
|
||||||
else if(type == CRE_SING_NAMES)
|
|
||||||
{
|
|
||||||
const auto * cre = CreatureID(ser).toCreature(VLC->creatures());
|
|
||||||
if(cre)
|
|
||||||
dst = cre->getNameSingularTranslated();
|
|
||||||
else
|
|
||||||
dst = "#!#";
|
|
||||||
}
|
|
||||||
else if(type == MINE_NAMES)
|
|
||||||
{
|
|
||||||
dst = VLC->generaltexth->translate("core.minename", ser);
|
|
||||||
}
|
|
||||||
else if(type == MINE_EVNTS)
|
|
||||||
{
|
|
||||||
dst = VLC->generaltexth->translate("core.mineevnt", ser);
|
|
||||||
}
|
|
||||||
else if(type == SPELL_NAME)
|
|
||||||
{
|
|
||||||
const auto * spell = SpellID(ser).toSpell(VLC->spells());
|
|
||||||
if(spell)
|
|
||||||
dst = spell->getNameTranslated();
|
|
||||||
else
|
|
||||||
dst = "#!#";
|
|
||||||
}
|
|
||||||
else if(type == OBJ_NAMES)
|
|
||||||
{
|
|
||||||
dst = VLC->objtypeh->getObjectName(ser, 0);
|
|
||||||
}
|
|
||||||
else if(type == SEC_SKILL_NAME)
|
|
||||||
{
|
|
||||||
dst = VLC->skillh->getByIndex(ser)->getNameTranslated();
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
switch(type)
|
|
||||||
{
|
|
||||||
case GENERAL_TXT:
|
|
||||||
dst = VLC->generaltexth->translate("core.genrltxt", ser);
|
|
||||||
break;
|
|
||||||
case RES_NAMES:
|
|
||||||
dst = VLC->generaltexth->translate("core.restypes", ser);
|
|
||||||
break;
|
|
||||||
case ARRAY_TXT:
|
|
||||||
dst = VLC->generaltexth->translate("core.arraytxt", ser);
|
|
||||||
break;
|
|
||||||
case CREGENS:
|
|
||||||
dst = VLC->objtypeh->getObjectName(Obj::CREATURE_GENERATOR1, ser);
|
|
||||||
break;
|
|
||||||
case CREGENS4:
|
|
||||||
dst = VLC->objtypeh->getObjectName(Obj::CREATURE_GENERATOR4, ser);
|
|
||||||
break;
|
|
||||||
case ADVOB_TXT:
|
|
||||||
dst = VLC->generaltexth->translate("core.advevent", ser);
|
|
||||||
break;
|
|
||||||
case COLOR:
|
|
||||||
dst = VLC->generaltexth->translate("vcmi.capitalColors", ser);
|
|
||||||
break;
|
|
||||||
case JK_TXT:
|
|
||||||
dst = VLC->generaltexth->translate("core.jktext", ser);
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
logGlobal->error("Failed string substitution because type is %d", type);
|
|
||||||
dst = "#@#";
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
DLL_LINKAGE void MetaString::toString(std::string &dst) const
|
|
||||||
{
|
|
||||||
size_t exSt = 0;
|
|
||||||
size_t loSt = 0;
|
|
||||||
size_t nums = 0;
|
|
||||||
dst.clear();
|
|
||||||
|
|
||||||
for(const auto & elem : message)
|
|
||||||
{//TEXACT_STRING, TLOCAL_STRING, TNUMBER, TREPLACE_ESTRING, TREPLACE_LSTRING, TREPLACE_NUMBER
|
|
||||||
switch(elem)
|
|
||||||
{
|
|
||||||
case TEXACT_STRING:
|
|
||||||
dst += exactStrings[exSt++];
|
|
||||||
break;
|
|
||||||
case TLOCAL_STRING:
|
|
||||||
{
|
|
||||||
std::string hlp;
|
|
||||||
getLocalString(localStrings[loSt++], hlp);
|
|
||||||
dst += hlp;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case TNUMBER:
|
|
||||||
dst += std::to_string(numbers[nums++]);
|
|
||||||
break;
|
|
||||||
case TREPLACE_ESTRING:
|
|
||||||
boost::replace_first(dst, "%s", exactStrings[exSt++]);
|
|
||||||
break;
|
|
||||||
case TREPLACE_LSTRING:
|
|
||||||
{
|
|
||||||
std::string hlp;
|
|
||||||
getLocalString(localStrings[loSt++], hlp);
|
|
||||||
boost::replace_first(dst, "%s", hlp);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case TREPLACE_NUMBER:
|
|
||||||
boost::replace_first(dst, "%d", std::to_string(numbers[nums++]));
|
|
||||||
break;
|
|
||||||
case TREPLACE_PLUSNUMBER:
|
|
||||||
boost::replace_first(dst, "%+d", '+' + std::to_string(numbers[nums++]));
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
logGlobal->error("MetaString processing error! Received message of type %d", int(elem));
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
DLL_LINKAGE std::string MetaString::toString() const
|
|
||||||
{
|
|
||||||
std::string ret;
|
|
||||||
toString(ret);
|
|
||||||
return ret;
|
|
||||||
}
|
|
||||||
|
|
||||||
DLL_LINKAGE std::string MetaString::buildList () const
|
|
||||||
///used to handle loot from creature bank
|
|
||||||
{
|
|
||||||
|
|
||||||
size_t exSt = 0;
|
|
||||||
size_t loSt = 0;
|
|
||||||
size_t nums = 0;
|
|
||||||
std::string lista;
|
|
||||||
for (int i = 0; i < message.size(); ++i)
|
|
||||||
{
|
|
||||||
if (i > 0 && (message[i] == TEXACT_STRING || message[i] == TLOCAL_STRING))
|
|
||||||
{
|
|
||||||
if (exSt == exactStrings.size() - 1)
|
|
||||||
lista += VLC->generaltexth->allTexts[141]; //" and "
|
|
||||||
else
|
|
||||||
lista += ", ";
|
|
||||||
}
|
|
||||||
switch (message[i])
|
|
||||||
{
|
|
||||||
case TEXACT_STRING:
|
|
||||||
lista += exactStrings[exSt++];
|
|
||||||
break;
|
|
||||||
case TLOCAL_STRING:
|
|
||||||
{
|
|
||||||
std::string hlp;
|
|
||||||
getLocalString (localStrings[loSt++], hlp);
|
|
||||||
lista += hlp;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case TNUMBER:
|
|
||||||
lista += std::to_string(numbers[nums++]);
|
|
||||||
break;
|
|
||||||
case TREPLACE_ESTRING:
|
|
||||||
lista.replace (lista.find("%s"), 2, exactStrings[exSt++]);
|
|
||||||
break;
|
|
||||||
case TREPLACE_LSTRING:
|
|
||||||
{
|
|
||||||
std::string hlp;
|
|
||||||
getLocalString (localStrings[loSt++], hlp);
|
|
||||||
lista.replace (lista.find("%s"), 2, hlp);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case TREPLACE_NUMBER:
|
|
||||||
lista.replace (lista.find("%d"), 2, std::to_string(numbers[nums++]));
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
logGlobal->error("MetaString processing error! Received message of type %d",int(message[i]));
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
return lista;
|
|
||||||
}
|
|
||||||
|
|
||||||
void MetaString::addCreReplacement(const CreatureID & id, TQuantity count) //adds sing or plural name;
|
|
||||||
{
|
|
||||||
if (!count)
|
|
||||||
addReplacement (CRE_PL_NAMES, id); //no creatures - just empty name (eg. defeat Angels)
|
|
||||||
else if (count == 1)
|
|
||||||
addReplacement (CRE_SING_NAMES, id);
|
|
||||||
else
|
|
||||||
addReplacement (CRE_PL_NAMES, id);
|
|
||||||
}
|
|
||||||
|
|
||||||
void MetaString::addReplacement(const CStackBasicDescriptor & stack)
|
|
||||||
{
|
|
||||||
assert(stack.type); //valid type
|
|
||||||
addCreReplacement(stack.type->getId(), stack.count);
|
|
||||||
}
|
|
||||||
|
|
||||||
static CGObjectInstance * createObject(const Obj & id, int subid, const int3 & pos, const PlayerColor & owner)
|
static CGObjectInstance * createObject(const Obj & id, int subid, const int3 & pos, const PlayerColor & owner)
|
||||||
{
|
{
|
||||||
CGObjectInstance * nobj;
|
CGObjectInstance * nobj;
|
||||||
|
@ -43,7 +43,7 @@ class CCreature;
|
|||||||
class CMap;
|
class CMap;
|
||||||
struct StartInfo;
|
struct StartInfo;
|
||||||
struct SetObjectProperty;
|
struct SetObjectProperty;
|
||||||
struct MetaString;
|
class MetaString;
|
||||||
struct CPack;
|
struct CPack;
|
||||||
class CSpell;
|
class CSpell;
|
||||||
struct TerrainTile;
|
struct TerrainTile;
|
||||||
|
@ -20,7 +20,7 @@ struct SetMovePoints;
|
|||||||
struct GiveBonus;
|
struct GiveBonus;
|
||||||
struct BlockingDialog;
|
struct BlockingDialog;
|
||||||
struct TeleportDialog;
|
struct TeleportDialog;
|
||||||
struct MetaString;
|
class MetaString;
|
||||||
struct StackLocation;
|
struct StackLocation;
|
||||||
struct ArtifactLocation;
|
struct ArtifactLocation;
|
||||||
class CCreatureSet;
|
class CCreatureSet;
|
||||||
|
@ -49,7 +49,7 @@ struct BattleTriggerEffect;
|
|||||||
struct CObstacleInstance;
|
struct CObstacleInstance;
|
||||||
struct CPackForServer;
|
struct CPackForServer;
|
||||||
class EVictoryLossCheckResult;
|
class EVictoryLossCheckResult;
|
||||||
struct MetaString;
|
class MetaString;
|
||||||
class ObstacleChanges;
|
class ObstacleChanges;
|
||||||
class UnitChanges;
|
class UnitChanges;
|
||||||
|
|
||||||
|
253
lib/MetaString.cpp
Normal file
253
lib/MetaString.cpp
Normal file
@ -0,0 +1,253 @@
|
|||||||
|
/*
|
||||||
|
* CGameState.cpp, 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
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
#include "StdInc.h"
|
||||||
|
#include "MetaString.h"
|
||||||
|
|
||||||
|
#include "CArtHandler.h"
|
||||||
|
#include "CCreatureHandler.h"
|
||||||
|
#include "CCreatureSet.h"
|
||||||
|
#include "CGeneralTextHandler.h"
|
||||||
|
#include "CSkillHandler.h"
|
||||||
|
#include "GameConstants.h"
|
||||||
|
#include "VCMI_Lib.h"
|
||||||
|
#include "mapObjectConstructors/CObjectClassesHandler.h"
|
||||||
|
#include "spells/CSpellHandler.h"
|
||||||
|
|
||||||
|
VCMI_LIB_NAMESPACE_BEGIN
|
||||||
|
|
||||||
|
void MetaString::getLocalString(const std::pair<ui8, ui32> & txt, std::string & dst) const
|
||||||
|
{
|
||||||
|
int type = txt.first;
|
||||||
|
int ser = txt.second;
|
||||||
|
|
||||||
|
if(type == ART_NAMES)
|
||||||
|
{
|
||||||
|
const auto * art = ArtifactID(ser).toArtifact(VLC->artifacts());
|
||||||
|
if(art)
|
||||||
|
dst = art->getNameTranslated();
|
||||||
|
else
|
||||||
|
dst = "#!#";
|
||||||
|
}
|
||||||
|
else if(type == ART_DESCR)
|
||||||
|
{
|
||||||
|
const auto * art = ArtifactID(ser).toArtifact(VLC->artifacts());
|
||||||
|
if(art)
|
||||||
|
dst = art->getDescriptionTranslated();
|
||||||
|
else
|
||||||
|
dst = "#!#";
|
||||||
|
}
|
||||||
|
else if (type == ART_EVNTS)
|
||||||
|
{
|
||||||
|
const auto * art = ArtifactID(ser).toArtifact(VLC->artifacts());
|
||||||
|
if(art)
|
||||||
|
dst = art->getEventTranslated();
|
||||||
|
else
|
||||||
|
dst = "#!#";
|
||||||
|
}
|
||||||
|
else if(type == CRE_PL_NAMES)
|
||||||
|
{
|
||||||
|
const auto * cre = CreatureID(ser).toCreature(VLC->creatures());
|
||||||
|
if(cre)
|
||||||
|
dst = cre->getNamePluralTranslated();
|
||||||
|
else
|
||||||
|
dst = "#!#";
|
||||||
|
}
|
||||||
|
else if(type == CRE_SING_NAMES)
|
||||||
|
{
|
||||||
|
const auto * cre = CreatureID(ser).toCreature(VLC->creatures());
|
||||||
|
if(cre)
|
||||||
|
dst = cre->getNameSingularTranslated();
|
||||||
|
else
|
||||||
|
dst = "#!#";
|
||||||
|
}
|
||||||
|
else if(type == MINE_NAMES)
|
||||||
|
{
|
||||||
|
dst = VLC->generaltexth->translate("core.minename", ser);
|
||||||
|
}
|
||||||
|
else if(type == MINE_EVNTS)
|
||||||
|
{
|
||||||
|
dst = VLC->generaltexth->translate("core.mineevnt", ser);
|
||||||
|
}
|
||||||
|
else if(type == SPELL_NAME)
|
||||||
|
{
|
||||||
|
const auto * spell = SpellID(ser).toSpell(VLC->spells());
|
||||||
|
if(spell)
|
||||||
|
dst = spell->getNameTranslated();
|
||||||
|
else
|
||||||
|
dst = "#!#";
|
||||||
|
}
|
||||||
|
else if(type == OBJ_NAMES)
|
||||||
|
{
|
||||||
|
dst = VLC->objtypeh->getObjectName(ser, 0);
|
||||||
|
}
|
||||||
|
else if(type == SEC_SKILL_NAME)
|
||||||
|
{
|
||||||
|
dst = VLC->skillh->getByIndex(ser)->getNameTranslated();
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
switch(type)
|
||||||
|
{
|
||||||
|
case GENERAL_TXT:
|
||||||
|
dst = VLC->generaltexth->translate("core.genrltxt", ser);
|
||||||
|
break;
|
||||||
|
case RES_NAMES:
|
||||||
|
dst = VLC->generaltexth->translate("core.restypes", ser);
|
||||||
|
break;
|
||||||
|
case ARRAY_TXT:
|
||||||
|
dst = VLC->generaltexth->translate("core.arraytxt", ser);
|
||||||
|
break;
|
||||||
|
case CREGENS:
|
||||||
|
dst = VLC->objtypeh->getObjectName(Obj::CREATURE_GENERATOR1, ser);
|
||||||
|
break;
|
||||||
|
case CREGENS4:
|
||||||
|
dst = VLC->objtypeh->getObjectName(Obj::CREATURE_GENERATOR4, ser);
|
||||||
|
break;
|
||||||
|
case ADVOB_TXT:
|
||||||
|
dst = VLC->generaltexth->translate("core.advevent", ser);
|
||||||
|
break;
|
||||||
|
case COLOR:
|
||||||
|
dst = VLC->generaltexth->translate("vcmi.capitalColors", ser);
|
||||||
|
break;
|
||||||
|
case JK_TXT:
|
||||||
|
dst = VLC->generaltexth->translate("core.jktext", ser);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
logGlobal->error("Failed string substitution because type is %d", type);
|
||||||
|
dst = "#@#";
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
DLL_LINKAGE void MetaString::toString(std::string &dst) const
|
||||||
|
{
|
||||||
|
size_t exSt = 0;
|
||||||
|
size_t loSt = 0;
|
||||||
|
size_t nums = 0;
|
||||||
|
dst.clear();
|
||||||
|
|
||||||
|
for(const auto & elem : message)
|
||||||
|
{//TEXACT_STRING, TLOCAL_STRING, TNUMBER, TREPLACE_ESTRING, TREPLACE_LSTRING, TREPLACE_NUMBER
|
||||||
|
switch(elem)
|
||||||
|
{
|
||||||
|
case TEXACT_STRING:
|
||||||
|
dst += exactStrings[exSt++];
|
||||||
|
break;
|
||||||
|
case TLOCAL_STRING:
|
||||||
|
{
|
||||||
|
std::string hlp;
|
||||||
|
getLocalString(localStrings[loSt++], hlp);
|
||||||
|
dst += hlp;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case TNUMBER:
|
||||||
|
dst += std::to_string(numbers[nums++]);
|
||||||
|
break;
|
||||||
|
case TREPLACE_ESTRING:
|
||||||
|
boost::replace_first(dst, "%s", exactStrings[exSt++]);
|
||||||
|
break;
|
||||||
|
case TREPLACE_LSTRING:
|
||||||
|
{
|
||||||
|
std::string hlp;
|
||||||
|
getLocalString(localStrings[loSt++], hlp);
|
||||||
|
boost::replace_first(dst, "%s", hlp);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case TREPLACE_NUMBER:
|
||||||
|
boost::replace_first(dst, "%d", std::to_string(numbers[nums++]));
|
||||||
|
break;
|
||||||
|
case TREPLACE_PLUSNUMBER:
|
||||||
|
boost::replace_first(dst, "%+d", '+' + std::to_string(numbers[nums++]));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
logGlobal->error("MetaString processing error! Received message of type %d", int(elem));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
DLL_LINKAGE std::string MetaString::toString() const
|
||||||
|
{
|
||||||
|
std::string ret;
|
||||||
|
toString(ret);
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
DLL_LINKAGE std::string MetaString::buildList () const
|
||||||
|
///used to handle loot from creature bank
|
||||||
|
{
|
||||||
|
|
||||||
|
size_t exSt = 0;
|
||||||
|
size_t loSt = 0;
|
||||||
|
size_t nums = 0;
|
||||||
|
std::string lista;
|
||||||
|
for (int i = 0; i < message.size(); ++i)
|
||||||
|
{
|
||||||
|
if (i > 0 && (message[i] == TEXACT_STRING || message[i] == TLOCAL_STRING))
|
||||||
|
{
|
||||||
|
if (exSt == exactStrings.size() - 1)
|
||||||
|
lista += VLC->generaltexth->allTexts[141]; //" and "
|
||||||
|
else
|
||||||
|
lista += ", ";
|
||||||
|
}
|
||||||
|
switch (message[i])
|
||||||
|
{
|
||||||
|
case TEXACT_STRING:
|
||||||
|
lista += exactStrings[exSt++];
|
||||||
|
break;
|
||||||
|
case TLOCAL_STRING:
|
||||||
|
{
|
||||||
|
std::string hlp;
|
||||||
|
getLocalString (localStrings[loSt++], hlp);
|
||||||
|
lista += hlp;
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case TNUMBER:
|
||||||
|
lista += std::to_string(numbers[nums++]);
|
||||||
|
break;
|
||||||
|
case TREPLACE_ESTRING:
|
||||||
|
lista.replace (lista.find("%s"), 2, exactStrings[exSt++]);
|
||||||
|
break;
|
||||||
|
case TREPLACE_LSTRING:
|
||||||
|
{
|
||||||
|
std::string hlp;
|
||||||
|
getLocalString (localStrings[loSt++], hlp);
|
||||||
|
lista.replace (lista.find("%s"), 2, hlp);
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
case TREPLACE_NUMBER:
|
||||||
|
lista.replace (lista.find("%d"), 2, std::to_string(numbers[nums++]));
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
logGlobal->error("MetaString processing error! Received message of type %d",int(message[i]));
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
return lista;
|
||||||
|
}
|
||||||
|
|
||||||
|
void MetaString::addCreReplacement(const CreatureID & id, TQuantity count) //adds sing or plural name;
|
||||||
|
{
|
||||||
|
if (!count)
|
||||||
|
addReplacement (CRE_PL_NAMES, id); //no creatures - just empty name (eg. defeat Angels)
|
||||||
|
else if (count == 1)
|
||||||
|
addReplacement (CRE_SING_NAMES, id);
|
||||||
|
else
|
||||||
|
addReplacement (CRE_PL_NAMES, id);
|
||||||
|
}
|
||||||
|
|
||||||
|
void MetaString::addReplacement(const CStackBasicDescriptor & stack)
|
||||||
|
{
|
||||||
|
assert(stack.type); //valid type
|
||||||
|
addCreReplacement(stack.type->getId(), stack.count);
|
||||||
|
}
|
||||||
|
|
||||||
|
VCMI_LIB_NAMESPACE_END
|
90
lib/MetaString.h
Normal file
90
lib/MetaString.h
Normal file
@ -0,0 +1,90 @@
|
|||||||
|
/*
|
||||||
|
* 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
|
||||||
|
|
||||||
|
class CreatureID;
|
||||||
|
class CStackBasicDescriptor;
|
||||||
|
using TQuantity = si32;
|
||||||
|
|
||||||
|
class DLL_LINKAGE MetaString
|
||||||
|
{
|
||||||
|
private:
|
||||||
|
enum EMessage {TEXACT_STRING, TLOCAL_STRING, TNUMBER, TREPLACE_ESTRING, TREPLACE_LSTRING, TREPLACE_NUMBER, TREPLACE_PLUSNUMBER};
|
||||||
|
public:
|
||||||
|
enum {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};
|
||||||
|
|
||||||
|
std::vector<ui8> message; //vector of EMessage
|
||||||
|
|
||||||
|
std::vector<std::pair<ui8,ui32> > localStrings;
|
||||||
|
std::vector<std::string> exactStrings;
|
||||||
|
std::vector<int64_t> numbers;
|
||||||
|
|
||||||
|
template <typename Handler> void serialize(Handler & h, const int version)
|
||||||
|
{
|
||||||
|
h & exactStrings;
|
||||||
|
h & localStrings;
|
||||||
|
h & message;
|
||||||
|
h & numbers;
|
||||||
|
}
|
||||||
|
void addTxt(ui8 type, ui32 serial)
|
||||||
|
{
|
||||||
|
message.push_back(TLOCAL_STRING);
|
||||||
|
localStrings.emplace_back(type, serial);
|
||||||
|
}
|
||||||
|
void addRawString(std::string value)
|
||||||
|
{
|
||||||
|
message.push_back(TEXACT_STRING);
|
||||||
|
exactStrings.push_back(value);
|
||||||
|
}
|
||||||
|
void appendNumber(int64_t value)
|
||||||
|
{
|
||||||
|
message.push_back(TNUMBER);
|
||||||
|
numbers.push_back(value);
|
||||||
|
}
|
||||||
|
void addReplacement(ui8 type, ui32 serial)
|
||||||
|
{
|
||||||
|
message.push_back(TREPLACE_LSTRING);
|
||||||
|
localStrings.emplace_back(type, serial);
|
||||||
|
}
|
||||||
|
void addReplacement(const std::string &txt)
|
||||||
|
{
|
||||||
|
message.push_back(TREPLACE_ESTRING);
|
||||||
|
exactStrings.push_back(txt);
|
||||||
|
}
|
||||||
|
void addReplacement(int64_t txt)
|
||||||
|
{
|
||||||
|
message.push_back(TREPLACE_NUMBER);
|
||||||
|
numbers.push_back(txt);
|
||||||
|
}
|
||||||
|
void addReplacement2(int64_t txt)
|
||||||
|
{
|
||||||
|
message.push_back(TREPLACE_PLUSNUMBER);
|
||||||
|
numbers.push_back(txt);
|
||||||
|
}
|
||||||
|
void addCreReplacement(const CreatureID & id, TQuantity count); //adds sing or plural name;
|
||||||
|
void addReplacement(const CStackBasicDescriptor &stack); //adds sing or plural name;
|
||||||
|
std::string buildList () const;
|
||||||
|
void clear()
|
||||||
|
{
|
||||||
|
exactStrings.clear();
|
||||||
|
localStrings.clear();
|
||||||
|
message.clear();
|
||||||
|
numbers.clear();
|
||||||
|
}
|
||||||
|
void toString(std::string &dst) const;
|
||||||
|
std::string toString() const;
|
||||||
|
void getLocalString(const std::pair<ui8, ui32> & txt, std::string & dst) const;
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
VCMI_LIB_NAMESPACE_END
|
@ -19,6 +19,7 @@
|
|||||||
#include "CGameStateFwd.h"
|
#include "CGameStateFwd.h"
|
||||||
#include "mapping/CMapDefines.h"
|
#include "mapping/CMapDefines.h"
|
||||||
#include "battle/CObstacleInstance.h"
|
#include "battle/CObstacleInstance.h"
|
||||||
|
#include "MetaString.h"
|
||||||
|
|
||||||
#include "spells/ViewSpellInt.h"
|
#include "spells/ViewSpellInt.h"
|
||||||
|
|
||||||
|
@ -115,91 +115,6 @@ protected:
|
|||||||
virtual void visitBasic(ICPackVisitor & cpackVisitor) override;
|
virtual void visitBasic(ICPackVisitor & cpackVisitor) override;
|
||||||
};
|
};
|
||||||
|
|
||||||
struct DLL_LINKAGE MetaString
|
|
||||||
{
|
|
||||||
private:
|
|
||||||
enum EMessage {TEXACT_STRING, TLOCAL_STRING, TNUMBER, TREPLACE_ESTRING, TREPLACE_LSTRING, TREPLACE_NUMBER, TREPLACE_PLUSNUMBER};
|
|
||||||
public:
|
|
||||||
enum {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};
|
|
||||||
|
|
||||||
std::vector<ui8> message; //vector of EMessage
|
|
||||||
|
|
||||||
std::vector<std::pair<ui8,ui32> > localStrings;
|
|
||||||
std::vector<std::string> exactStrings;
|
|
||||||
std::vector<int64_t> numbers;
|
|
||||||
|
|
||||||
template <typename Handler> void serialize(Handler & h, const int version)
|
|
||||||
{
|
|
||||||
h & exactStrings;
|
|
||||||
h & localStrings;
|
|
||||||
h & message;
|
|
||||||
h & numbers;
|
|
||||||
}
|
|
||||||
void addTxt(ui8 type, ui32 serial)
|
|
||||||
{
|
|
||||||
message.push_back(TLOCAL_STRING);
|
|
||||||
localStrings.emplace_back(type, serial);
|
|
||||||
}
|
|
||||||
MetaString& operator<<(const std::pair<ui8,ui32> &txt)
|
|
||||||
{
|
|
||||||
message.push_back(TLOCAL_STRING);
|
|
||||||
localStrings.push_back(txt);
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
MetaString& operator<<(int64_t txt)
|
|
||||||
{
|
|
||||||
message.push_back(TNUMBER);
|
|
||||||
numbers.push_back(txt);
|
|
||||||
return *this;
|
|
||||||
}
|
|
||||||
|
|
||||||
void addRawString(std::string value)
|
|
||||||
{
|
|
||||||
message.push_back(TEXACT_STRING);
|
|
||||||
exactStrings.push_back(value);
|
|
||||||
}
|
|
||||||
void addNumber(int64_t value)
|
|
||||||
{
|
|
||||||
message.push_back(TNUMBER);
|
|
||||||
numbers.push_back(value);
|
|
||||||
}
|
|
||||||
void addReplacement(ui8 type, ui32 serial)
|
|
||||||
{
|
|
||||||
message.push_back(TREPLACE_LSTRING);
|
|
||||||
localStrings.emplace_back(type, serial);
|
|
||||||
}
|
|
||||||
void addReplacement(const std::string &txt)
|
|
||||||
{
|
|
||||||
message.push_back(TREPLACE_ESTRING);
|
|
||||||
exactStrings.push_back(txt);
|
|
||||||
}
|
|
||||||
void addReplacement(int64_t txt)
|
|
||||||
{
|
|
||||||
message.push_back(TREPLACE_NUMBER);
|
|
||||||
numbers.push_back(txt);
|
|
||||||
}
|
|
||||||
void addReplacement2(int64_t txt)
|
|
||||||
{
|
|
||||||
message.push_back(TREPLACE_PLUSNUMBER);
|
|
||||||
numbers.push_back(txt);
|
|
||||||
}
|
|
||||||
void addCreReplacement(const CreatureID & id, TQuantity count); //adds sing or plural name;
|
|
||||||
void addReplacement(const CStackBasicDescriptor &stack); //adds sing or plural name;
|
|
||||||
std::string buildList () const;
|
|
||||||
void clear()
|
|
||||||
{
|
|
||||||
exactStrings.clear();
|
|
||||||
localStrings.clear();
|
|
||||||
message.clear();
|
|
||||||
numbers.clear();
|
|
||||||
}
|
|
||||||
void toString(std::string &dst) const;
|
|
||||||
std::string toString() const;
|
|
||||||
void getLocalString(const std::pair<ui8, ui32> & txt, std::string & dst) const;
|
|
||||||
|
|
||||||
};
|
|
||||||
|
|
||||||
struct Component
|
struct Component
|
||||||
{
|
{
|
||||||
enum class EComponentType : uint8_t
|
enum class EComponentType : uint8_t
|
||||||
|
@ -13,6 +13,7 @@
|
|||||||
|
|
||||||
#include "../VCMI_Lib.h"
|
#include "../VCMI_Lib.h"
|
||||||
#include "../CGeneralTextHandler.h"
|
#include "../CGeneralTextHandler.h"
|
||||||
|
#include "../MetaString.h"
|
||||||
#include "../NetPacksBase.h"
|
#include "../NetPacksBase.h"
|
||||||
|
|
||||||
#include "../serializer/JsonDeserializer.h"
|
#include "../serializer/JsonDeserializer.h"
|
||||||
|
@ -21,7 +21,7 @@
|
|||||||
|
|
||||||
VCMI_LIB_NAMESPACE_BEGIN
|
VCMI_LIB_NAMESPACE_BEGIN
|
||||||
|
|
||||||
struct MetaString;
|
class MetaString;
|
||||||
class JsonNode;
|
class JsonNode;
|
||||||
class JsonSerializeFormat;
|
class JsonSerializeFormat;
|
||||||
|
|
||||||
|
@ -49,7 +49,7 @@ std::string CGCreature::getHoverText(const CGHeroInstance * hero) const
|
|||||||
if(hero->hasVisions(this, 0))
|
if(hero->hasVisions(this, 0))
|
||||||
{
|
{
|
||||||
MetaString ms;
|
MetaString ms;
|
||||||
ms << stacks.begin()->second->count;
|
ms.appendNumber(stacks.begin()->second->count);
|
||||||
ms.addRawString(" ");
|
ms.addRawString(" ");
|
||||||
ms.addTxt(MetaString::CRE_PL_NAMES,subID);
|
ms.addTxt(MetaString::CRE_PL_NAMES,subID);
|
||||||
|
|
||||||
@ -324,7 +324,7 @@ void CGCreature::joinDecision(const CGHeroInstance *h, int cost, ui32 accept) co
|
|||||||
{
|
{
|
||||||
InfoWindow iw;
|
InfoWindow iw;
|
||||||
iw.player = h->tempOwner;
|
iw.player = h->tempOwner;
|
||||||
iw.text << std::pair<ui8,ui32>(1,29); //You don't have enough gold
|
iw.text.addTxt(1,29); //You don't have enough gold
|
||||||
cb->showInfoDialog(&iw);
|
cb->showInfoDialog(&iw);
|
||||||
|
|
||||||
//act as if player refused
|
//act as if player refused
|
||||||
|
@ -1157,7 +1157,7 @@ void CGBorderGuard::initObj(CRandomGenerator & rand)
|
|||||||
|
|
||||||
void CGBorderGuard::getVisitText (MetaString &text, std::vector<Component> &components, bool isCustom, bool FirstVisit, const CGHeroInstance * h) const
|
void CGBorderGuard::getVisitText (MetaString &text, std::vector<Component> &components, bool isCustom, bool FirstVisit, const CGHeroInstance * h) const
|
||||||
{
|
{
|
||||||
text << std::pair<ui8,ui32>(11,18);
|
text.addTxt(11,18);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CGBorderGuard::getRolloverText (MetaString &text, bool onHover) const
|
void CGBorderGuard::getRolloverText (MetaString &text, bool onHover) const
|
||||||
|
@ -20,6 +20,7 @@ class CRandomGenerator;
|
|||||||
class IGameCallback;
|
class IGameCallback;
|
||||||
class ResourceSet;
|
class ResourceSet;
|
||||||
class int3;
|
class int3;
|
||||||
|
class MetaString;
|
||||||
|
|
||||||
class DLL_LINKAGE IObjectInterface
|
class DLL_LINKAGE IObjectInterface
|
||||||
{
|
{
|
||||||
|
@ -10,6 +10,7 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "CArmedInstance.h"
|
#include "CArmedInstance.h"
|
||||||
|
#include "../MetaString.h"
|
||||||
|
|
||||||
VCMI_LIB_NAMESPACE_BEGIN
|
VCMI_LIB_NAMESPACE_BEGIN
|
||||||
|
|
||||||
|
@ -11,8 +11,9 @@
|
|||||||
#pragma once
|
#pragma once
|
||||||
|
|
||||||
#include "Limiter.h"
|
#include "Limiter.h"
|
||||||
#include "Reward.h"
|
#include "MetaString.h"
|
||||||
#include "NetPacksBase.h"
|
#include "NetPacksBase.h"
|
||||||
|
#include "Reward.h"
|
||||||
|
|
||||||
VCMI_LIB_NAMESPACE_BEGIN
|
VCMI_LIB_NAMESPACE_BEGIN
|
||||||
|
|
||||||
|
@ -13,7 +13,7 @@
|
|||||||
|
|
||||||
#include <vcmi/spells/Spell.h>
|
#include <vcmi/spells/Spell.h>
|
||||||
|
|
||||||
#include "../NetPacksBase.h"
|
#include "../MetaString.h"
|
||||||
#include "../battle/Unit.h"
|
#include "../battle/Unit.h"
|
||||||
#include "../bonuses/Bonus.h"
|
#include "../bonuses/Bonus.h"
|
||||||
|
|
||||||
|
@ -8,7 +8,6 @@
|
|||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
#include "StdInc.h"
|
#include "StdInc.h"
|
||||||
|
|
||||||
#include "Problem.h"
|
#include "Problem.h"
|
||||||
|
|
||||||
VCMI_LIB_NAMESPACE_BEGIN
|
VCMI_LIB_NAMESPACE_BEGIN
|
||||||
|
@ -12,7 +12,7 @@
|
|||||||
|
|
||||||
#include <vcmi/spells/Magic.h>
|
#include <vcmi/spells/Magic.h>
|
||||||
|
|
||||||
#include "../NetPacksBase.h"
|
#include "../MetaString.h"
|
||||||
|
|
||||||
VCMI_LIB_NAMESPACE_BEGIN
|
VCMI_LIB_NAMESPACE_BEGIN
|
||||||
|
|
||||||
|
@ -16,7 +16,7 @@ VCMI_LIB_NAMESPACE_BEGIN
|
|||||||
|
|
||||||
struct Bonus;
|
struct Bonus;
|
||||||
struct SetStackEffect;
|
struct SetStackEffect;
|
||||||
struct MetaString;
|
class MetaString;
|
||||||
|
|
||||||
namespace spells
|
namespace spells
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user