瀏覽代碼

Merge pull request #4747 from IvanSavenko/mod_compat_fix

Fixes for loading 1.5 mods in vcmi 1.6
Ivan Savenko 1 年之前
父節點
當前提交
92db0259c3
共有 2 個文件被更改,包括 9 次插入4 次删除
  1. 2 2
      lib/entities/faction/CTownHandler.cpp
  2. 7 2
      lib/mapObjectConstructors/CObjectClassesHandler.cpp

+ 2 - 2
lib/entities/faction/CTownHandler.cpp

@@ -883,8 +883,8 @@ void CTownHandler::beforeValidate(JsonNode & object)
 		if (building.second.Struct().count("onVisitBonuses"))
 		{
 			building.second["configuration"]["visitMode"] = JsonNode("bonus");
-			building.second["configuration"]["visitMode"]["rewards"][0]["message"] = building.second["description"];
-			building.second["configuration"]["visitMode"]["rewards"][0]["bonuses"] = building.second["onVisitBonuses"];
+			building.second["configuration"]["rewards"][0]["message"] = building.second["description"];
+			building.second["configuration"]["rewards"][0]["bonuses"] = building.second["onVisitBonuses"];
 		}
 	}
 }

+ 7 - 2
lib/mapObjectConstructors/CObjectClassesHandler.cpp

@@ -207,8 +207,13 @@ TObjectTypeHandler CObjectClassesHandler::loadSubObjectFromJson(const std::strin
 
 	// Compatibility with 1.5 mods for 1.6. To be removed in 1.7
 	// Detect banks that use old format and load them using old bank hander
-	if (baseObject->id == Obj::CREATURE_BANK && entry.Struct().count("levels") && !entry.Struct().count("rewards"))
-		handler = "bank";
+	if (baseObject->id == Obj::CREATURE_BANK)
+	{
+		if (entry.Struct().count("levels") && !entry.Struct().count("rewards"))
+			handler = "bank";
+		else
+			handler = "configurable";
+	}
 
 	auto createdObject = handlerConstructors.at(handler)();