Преглед изворни кода

Fix crash on bonus parsing failure (outdated mods?)

Ivan Savenko пре 2 година
родитељ
комит
dd17896082
1 измењених фајлова са 7 додато и 1 уклоњено
  1. 7 1
      lib/JsonNode.cpp

+ 7 - 1
lib/JsonNode.cpp

@@ -829,7 +829,13 @@ std::shared_ptr<Bonus> JsonUtils::parseBonus(const JsonNode &ability)
 	auto b = std::make_shared<Bonus>();
 	if (!parseBonus(ability, b.get()))
 	{
-		return nullptr;
+		// caller code can not handle this case and presumes that returned bonus is always valid
+		logGlobal->error("Failed to parse bonus! Json config was %S ", ability.toJson());
+
+		b->type = BonusType::NONE;
+		assert(0); // or throw? Game *should* work with dummy bonus
+
+		return b;
 	}
 	return b;
 }