Browse Source

More simplification of CBattleInterface::spellCast
* was started in previous branch

AlexVinS 10 years ago
parent
commit
8171924eb4
1 changed files with 12 additions and 28 deletions
  1. 12 28
      client/battle/CBattleInterface.cpp

+ 12 - 28
client/battle/CBattleInterface.cpp

@@ -1351,45 +1351,35 @@ void CBattleInterface::spellCast( const BattleSpellCast * sc )
 		}
 		}
 		else
 		else
 		{
 		{
-			auto getPluralText = [attackedStack](const int baseTextID) -> std::string
+			auto getPluralText = [attackedStack, attackedName](const int baseTextID) -> std::string
 			{
 			{
-				return CGI->generaltexth->allTexts[(attackedStack->count > 1 ? baseTextID+1 : baseTextID)];
+				std::string res = CGI->generaltexth->allTexts[(attackedStack->count > 1 ? baseTextID+1 : baseTextID)];
+				boost::algorithm::replace_first(res, "%s", attackedName);
+				return res;
 			};
 			};
-			
-			bool plural = false; //add singular / plural form of creature text if this is true
-			int textID = 0;
+
+			customSpell = true; //in most following cases text is custom
 			switch(sc->id)
 			switch(sc->id)
 			{
 			{
 				case SpellID::STONE_GAZE:
 				case SpellID::STONE_GAZE:
-					customSpell = true;
-					plural = true;
-					textID = 558;
+					text = getPluralText(558);
 					break;
 					break;
 				case SpellID::POISON:
 				case SpellID::POISON:
-					customSpell = true;
-					plural = true;
-					textID = 561;
+					text = getPluralText(561);
 					break;
 					break;
 				case SpellID::BIND:
 				case SpellID::BIND:
-					customSpell = true;
 					text = CGI->generaltexth->allTexts[560];
 					text = CGI->generaltexth->allTexts[560];
 					boost::algorithm::replace_first(text, "%s", attackedNamePl);
 					boost::algorithm::replace_first(text, "%s", attackedNamePl);
 					break;//Roots and vines bind the %s to the ground!
 					break;//Roots and vines bind the %s to the ground!
 				case SpellID::DISEASE:
 				case SpellID::DISEASE:
-					customSpell = true;
-					plural = true;
-					textID = 553;
+					text = getPluralText(553);
 					break;
 					break;
 				case SpellID::PARALYZE:
 				case SpellID::PARALYZE:
-					customSpell = true;
-					plural = true;
-					textID = 563;
+					text = getPluralText(563);
 					break;
 					break;
 				case SpellID::AGE:
 				case SpellID::AGE:
 				{
 				{
-					customSpell = true;
 					text = getPluralText(551);
 					text = getPluralText(551);
-					boost::algorithm::replace_first(text, "%s", attackedName);
 					//The %s shrivel with age, and lose %d hit points."
 					//The %s shrivel with age, and lose %d hit points."
 					TBonusListPtr bl = attackedStack->getBonuses(Selector::type(Bonus::STACK_HEALTH));
 					TBonusListPtr bl = attackedStack->getBonuses(Selector::type(Bonus::STACK_HEALTH));
 					bl->remove_if(Selector::source(Bonus::SPELL_EFFECT, SpellID::AGE));
 					bl->remove_if(Selector::source(Bonus::SPELL_EFFECT, SpellID::AGE));
@@ -1403,16 +1393,13 @@ void CBattleInterface::spellCast( const BattleSpellCast * sc )
 					text = CGI->generaltexth->allTexts[343].substr(1, CGI->generaltexth->allTexts[343].size() - 1); //Does %d points of damage.
 					text = CGI->generaltexth->allTexts[343].substr(1, CGI->generaltexth->allTexts[343].size() - 1); //Does %d points of damage.
 					boost::algorithm::replace_first(text, "%d", boost::lexical_cast<std::string>(sc->dmgToDisplay)); //no more text afterwards
 					boost::algorithm::replace_first(text, "%d", boost::lexical_cast<std::string>(sc->dmgToDisplay)); //no more text afterwards
 					console->addText(text);
 					console->addText(text);
-					customSpell = true;
 					text = ""; //yeah, it's a terrible mess
 					text = ""; //yeah, it's a terrible mess
 					break;
 					break;
 				case SpellID::DISPEL_HELPFUL_SPELLS:
 				case SpellID::DISPEL_HELPFUL_SPELLS:
 					text = CGI->generaltexth->allTexts[555];
 					text = CGI->generaltexth->allTexts[555];
 					boost::algorithm::replace_first(text, "%s", attackedNamePl);
 					boost::algorithm::replace_first(text, "%s", attackedNamePl);
-					customSpell = true;
 					break;
 					break;
 				case SpellID::DEATH_STARE:
 				case SpellID::DEATH_STARE:
-					customSpell = true;
 					if (sc->dmgToDisplay)
 					if (sc->dmgToDisplay)
 					{
 					{
 						if (sc->dmgToDisplay > 1)
 						if (sc->dmgToDisplay > 1)
@@ -1434,13 +1421,10 @@ void CBattleInterface::spellCast( const BattleSpellCast * sc )
 				default:
 				default:
 					text = CGI->generaltexth->allTexts[565]; //The %s casts %s
 					text = CGI->generaltexth->allTexts[565]; //The %s casts %s
 					boost::algorithm::replace_first(text, "%s", casterName); //casting stack
 					boost::algorithm::replace_first(text, "%s", casterName); //casting stack
+					customSpell = false;
+					break;
 
 
 			}
 			}
-			if (plural)
-			{
-				text = getPluralText(textID);
-				boost::algorithm::replace_first(text, "%s", attackedName);
-			}
 		}
 		}
 		if (!customSpell && !sc->dmgToDisplay)
 		if (!customSpell && !sc->dmgToDisplay)
 			boost::algorithm::replace_first(text, "%s", spellName); //simple spell name
 			boost::algorithm::replace_first(text, "%s", spellName); //simple spell name