소스 검색

Minor fixes in text

nordsoft 2 년 전
부모
커밋
31d71ddd25
1개의 변경된 파일25개의 추가작업 그리고 2개의 파일을 삭제
  1. 25 2
      lib/mapObjects/CQuest.cpp

+ 25 - 2
lib/mapObjects/CQuest.cpp

@@ -28,6 +28,7 @@
 #include "../mapping/CMap.h"
 #include "../modding/ModScope.h"
 #include "../modding/ModUtility.h"
+#include "../spells/CSpellHandler.h"
 
 VCMI_LIB_NAMESPACE_BEGIN
 
@@ -59,7 +60,7 @@ static std::string visitedTxt(const bool visited)
 
 const std::string & CQuest::missionName(int mission)
 {
-	static const std::array<std::string, 11> names = {
+	static const std::array<std::string, 14> names = {
 		"empty",
 		"heroLevel",
 		"primarySkill",
@@ -169,6 +170,9 @@ void CQuest::addTextReplacements(MetaString & text, std::vector<Component> & com
 	if(heroLevel > 0)
 		text.replaceNumber(heroLevel);
 	
+	if(heroExperience > 0)
+		text.replaceNumber(heroExperience);
+	
 	{ //primary skills
 		MetaString loot;
 		for(int i = 0; i < 4; ++i)
@@ -180,6 +184,17 @@ void CQuest::addTextReplacements(MetaString & text, std::vector<Component> & com
 				loot.replaceRawString(VLC->generaltexth->primarySkillNames[i]);
 			}
 		}
+		
+		for(auto & skill : secondary)
+		{
+			loot.appendTextID(VLC->skillh->getById(skill.first)->getNameTextID());
+		}
+		
+		for(auto & spell : spells)
+		{
+			loot.appendTextID(VLC->spellh->getById(spell)->getNameTextID());
+		}
+		
 		if(!loot.empty())
 			text.replaceRawString(loot.buildList());
 	}
@@ -237,7 +252,13 @@ void CQuest::addTextReplacements(MetaString & text, std::vector<Component> & com
 	}
 	
 	if(!players.empty())
-		text.replaceLocalString(EMetaText::COLOR, players.front());
+	{
+		MetaString loot;
+		for(auto & p : players)
+			loot.appendLocalString(EMetaText::COLOR, p);
+		
+		text.replaceRawString(loot.buildList());
+	}
 }
 
 void CQuest::getVisitText(MetaString &iwText, std::vector<Component> &components, bool firstVisit, const CGHeroInstance * h) const
@@ -280,6 +301,8 @@ void CQuest::defineQuestName()
 	questName = CQuest::missionName(0);
 	if(heroLevel > 0) questName = CQuest::missionName(1);
 	for(auto & s : primary) if(s) questName = CQuest::missionName(2);
+	if(!spells.empty()) questName = CQuest::missionName(2);
+	if(!secondary.empty()) questName = CQuest::missionName(2);
 	if(killTarget >= 0 && !heroName.empty()) questName = CQuest::missionName(3);
 	if(killTarget >= 0 && stackToKill.getType()) questName = CQuest::missionName(4);
 	if(!artifacts.empty()) questName = CQuest::missionName(5);