Browse Source

Random selection for secondary skills

nordsoft 2 years ago
parent
commit
dce5a924b0
1 changed files with 32 additions and 2 deletions
  1. 32 2
      lib/mapObjects/JsonRandom.cpp

+ 32 - 2
lib/mapObjects/JsonRandom.cpp

@@ -20,6 +20,7 @@
 #include "../CCreatureHandler.h"
 #include "../CCreatureSet.h"
 #include "../spells/CSpellHandler.h"
+#include "../CSkillHandler.h"
 
 VCMI_LIB_NAMESPACE_BEGIN
 
@@ -136,11 +137,40 @@ namespace JsonRandom
 	std::map<SecondarySkill, si32> loadSecondary(const JsonNode & value, CRandomGenerator & rng)
 	{
 		std::map<SecondarySkill, si32> ret;
+		std::vector<SecondarySkill> except;
+		
 		for(const auto & pair : value.Struct())
 		{
-			SecondarySkill id(VLC->modh->identifiers.getIdentifier(pair.second.meta, "skill", pair.first).get());
-			ret[id] = loadValue(pair.second, rng);
+			std::string skillName = pair.first;
+			
+			if(skillName == "random")
+			{
+				if(pair.second.isNumber())
+					skillName = RandomGeneratorUtil::nextItem(VLC->skillh->objects, rng)->get()->getNameTextID();
+				else
+				{
+					auto skill = *RandomGeneratorUtil::nextItem(loadSecondary(pair.second, rng), rng);
+					ret[skill.first] = skill.second;
+				}
+			}
+			else if(skillName == "except")
+			{
+				for(auto & i : pair.second.Vector())
+				{
+					SecondarySkill id(VLC->modh->identifiers.getIdentifier(pair.second.meta, "skill", i.String()).get());
+					except.push_back(id);
+				}
+			}
+			else
+			{
+				SecondarySkill id(VLC->modh->identifiers.getIdentifier(pair.second.meta, "skill", pair.first).get());
+				ret[id] = loadValue(pair.second, rng);
+			}
 		}
+		
+		for(auto & i : except)
+			ret.erase(i);
+		
 		return ret;
 	}