mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-12 02:28:11 +02:00
Workaround for serializer allowing sending CStackInstance* pointing to commander. (and only CStackInstance*)
This commit is contained in:
parent
d34cf90bf7
commit
401d6816d1
@ -1030,7 +1030,15 @@ bool CArtifactInstance::canBePutAt(const CArtifactSet *artSet, int slot, bool as
|
||||
return true;
|
||||
}
|
||||
|
||||
if(!vstd::contains(artType->possibleSlots[artSet->bearerType()], slot))
|
||||
auto possibleSlots = artType->possibleSlots.find(artSet->bearerType());
|
||||
if(possibleSlots == artType->possibleSlots.end())
|
||||
{
|
||||
tlog3 << "Warning: arrtifact " << artType->Name() << " doesn't have defined allowed slots for bearer of type "
|
||||
<< artSet->bearerType() << std::endl;
|
||||
return false;
|
||||
}
|
||||
|
||||
if(!vstd::contains(possibleSlots->second, slot))
|
||||
return false;
|
||||
|
||||
return artSet->isPositionFree(slot, assumeDestRemoved);
|
||||
|
@ -24,6 +24,8 @@
|
||||
#include "CObjectHandler.h" //fo CArmedInstance
|
||||
|
||||
const ui32 version = 732;
|
||||
const TSlot COMMANDER_SLOT_PLACEHOLDER = -2;
|
||||
|
||||
class CConnection;
|
||||
class CGObjectInstance;
|
||||
class CStackInstance;
|
||||
@ -378,7 +380,14 @@ struct SaveIfStackInstance<Ser, CStackInstance *>
|
||||
static bool invoke(Ser &s, const CStackInstance* const &data)
|
||||
{
|
||||
assert(data->armyObj);
|
||||
TSlot slot = data->armyObj->findStack(data);
|
||||
TSlot slot = -1;
|
||||
|
||||
if(data->getNodeType() == Bonus::COMMANDER)
|
||||
slot = COMMANDER_SLOT_PLACEHOLDER;
|
||||
else
|
||||
slot = data->armyObj->findStack(data);
|
||||
|
||||
assert(slot != -1);
|
||||
s << data->armyObj << slot;
|
||||
return true;
|
||||
}
|
||||
@ -391,6 +400,7 @@ struct LoadIfStackInstance
|
||||
return false;
|
||||
}
|
||||
};
|
||||
|
||||
template<typename Ser>
|
||||
struct LoadIfStackInstance<Ser, CStackInstance *>
|
||||
{
|
||||
@ -399,8 +409,18 @@ struct LoadIfStackInstance<Ser, CStackInstance *>
|
||||
CArmedInstance *armedObj;
|
||||
TSlot slot;
|
||||
s >> armedObj >> slot;
|
||||
if(slot != COMMANDER_SLOT_PLACEHOLDER)
|
||||
{
|
||||
assert(armedObj->hasStackAtSlot(slot));
|
||||
data = armedObj->stacks[slot];
|
||||
}
|
||||
else
|
||||
{
|
||||
auto hero = dynamic_cast<CGHeroInstance *>(armedObj);
|
||||
assert(hero);
|
||||
assert(hero->commander);
|
||||
data = hero->commander;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
};
|
||||
|
Loading…
Reference in New Issue
Block a user