mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-12 02:28:11 +02:00
Modding-related bugfixes:
- hero classes will be loaded correctly - objects without index will have correctly assigned ID's
This commit is contained in:
parent
50dfe05cd1
commit
db221829aa
@ -199,7 +199,7 @@ void CHeroClassHandler::loadObject(std::string scope, std::string name, const Js
|
|||||||
|
|
||||||
VLC->modh->identifiers.requestIdentifier(scope, "object", "hero", [=](si32 index)
|
VLC->modh->identifiers.requestIdentifier(scope, "object", "hero", [=](si32 index)
|
||||||
{
|
{
|
||||||
JsonNode classConf;
|
JsonNode classConf = data["mapObject"];
|
||||||
classConf["heroClass"].String() = name;
|
classConf["heroClass"].String() = name;
|
||||||
classConf.setMeta(scope);
|
classConf.setMeta(scope);
|
||||||
VLC->objtypeh->loadSubObject(name, classConf, index, object->id);
|
VLC->objtypeh->loadSubObject(name, classConf, index, object->id);
|
||||||
|
@ -310,6 +310,7 @@ bool CContentHandler::ContentTypeHandler::preloadModData(std::string modName, st
|
|||||||
if (remoteName == modName)
|
if (remoteName == modName)
|
||||||
logGlobal->warnStream() << "Redundant namespace definition for " << objectName;
|
logGlobal->warnStream() << "Redundant namespace definition for " << objectName;
|
||||||
|
|
||||||
|
logGlobal->traceStream() << "Patching object " << objectName << " (" << remoteName << ") from " << modName;
|
||||||
JsonNode & remoteConf = modData[remoteName].patches[objectName];
|
JsonNode & remoteConf = modData[remoteName].patches[objectName];
|
||||||
|
|
||||||
JsonUtils::merge(remoteConf, entry.second);
|
JsonUtils::merge(remoteConf, entry.second);
|
||||||
|
@ -140,7 +140,7 @@ si32 selectNextID(const JsonNode & fixedID, const Map & map, si32 defaultID)
|
|||||||
|
|
||||||
if (map.empty())
|
if (map.empty())
|
||||||
return defaultID; // no objects loaded, keep gap for H3M objects
|
return defaultID; // no objects loaded, keep gap for H3M objects
|
||||||
if (map.rbegin()->first > defaultID)
|
if (map.rbegin()->first >= defaultID)
|
||||||
return map.rbegin()->first + 1; // some modded objects loaded, return next available
|
return map.rbegin()->first + 1; // some modded objects loaded, return next available
|
||||||
|
|
||||||
return defaultID; // some H3M objects loaded, first modded found
|
return defaultID; // some H3M objects loaded, first modded found
|
||||||
@ -173,8 +173,9 @@ void CObjectClassesHandler::loadObjectEntry(const JsonNode & entry, ObjectContai
|
|||||||
legacyTemplates.erase(range.first, range.second);
|
legacyTemplates.erase(range.first, range.second);
|
||||||
}
|
}
|
||||||
|
|
||||||
obj->objects[id] = handler;
|
|
||||||
logGlobal->debugStream() << "Loaded object " << obj->id << ":" << id;
|
logGlobal->debugStream() << "Loaded object " << obj->id << ":" << id;
|
||||||
|
assert(!obj->objects.count(id)); // DO NOT override
|
||||||
|
obj->objects[id] = handler;
|
||||||
}
|
}
|
||||||
|
|
||||||
CObjectClassesHandler::ObjectContainter * CObjectClassesHandler::loadFromJson(const JsonNode & json)
|
CObjectClassesHandler::ObjectContainter * CObjectClassesHandler::loadFromJson(const JsonNode & json)
|
||||||
|
Loading…
Reference in New Issue
Block a user