Minecarts get saved into Anvil.
git-svn-id: http://mc-server.googlecode.com/svn/trunk@1263 0a769ca7-a7f5-676a-18bf-c427514a06d6
This commit is contained in:
parent
7593707713
commit
e694893edf
@ -115,7 +115,7 @@ cMinecartWithChest::cMinecartWithChest(double a_X, double a_Y, double a_Z) :
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
void cMinecartWithChest::SetItem(int a_Idx, const cItem & a_Item)
|
void cMinecartWithChest::SetSlot(int a_Idx, const cItem & a_Item)
|
||||||
{
|
{
|
||||||
ASSERT((a_Idx >= 0) && (a_Idx < ARRAYCOUNT(m_Items)));
|
ASSERT((a_Idx >= 0) && (a_Idx < ARRAYCOUNT(m_Items)));
|
||||||
|
|
||||||
|
@ -80,10 +80,10 @@ public:
|
|||||||
|
|
||||||
cMinecartWithChest(double a_X, double a_Y, double a_Z);
|
cMinecartWithChest(double a_X, double a_Y, double a_Z);
|
||||||
|
|
||||||
const cItem & GetItem(int a_Idx) const { return m_Items[a_Idx]; }
|
const cItem & GetSlot(int a_Idx) const { return m_Items[a_Idx]; }
|
||||||
cItem & GetItem(int a_Idx) { return m_Items[a_Idx]; }
|
cItem & GetSlot(int a_Idx) { return m_Items[a_Idx]; }
|
||||||
|
|
||||||
void SetItem(int a_Idx, const cItem & a_Item);
|
void SetSlot(int a_Idx, const cItem & a_Item);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
|
@ -231,9 +231,9 @@ void cNBTChunkSerializer::AddMinecartEntity(cMinecart * a_Minecart)
|
|||||||
const char * EntityClass = NULL;
|
const char * EntityClass = NULL;
|
||||||
switch (a_Minecart->GetPayload())
|
switch (a_Minecart->GetPayload())
|
||||||
{
|
{
|
||||||
case cMinecart::mpNone: EntityClass = "MinecarRideable"; break;
|
case cMinecart::mpNone: EntityClass = "MinecartRideable"; break;
|
||||||
case cMinecart::mpChest: EntityClass = "MinecartChest"; break;
|
case cMinecart::mpChest: EntityClass = "MinecartChest"; break;
|
||||||
case cMinecart::mpFurnace: EntityClass = "MinecartFurnace"; break;
|
case cMinecart::mpFurnace: EntityClass = "MinecartFurnace"; break;
|
||||||
default:
|
default:
|
||||||
{
|
{
|
||||||
ASSERT(!"Unhandled minecart payload type");
|
ASSERT(!"Unhandled minecart payload type");
|
||||||
@ -293,7 +293,7 @@ void cNBTChunkSerializer::AddMinecartChestContents(cMinecartWithChest * a_Mineca
|
|||||||
m_Writer.BeginList("Items", TAG_Compound);
|
m_Writer.BeginList("Items", TAG_Compound);
|
||||||
for (int i = 0; i < cMinecartWithChest::NumSlots; i++)
|
for (int i = 0; i < cMinecartWithChest::NumSlots; i++)
|
||||||
{
|
{
|
||||||
const cItem & Item = a_Minecart->GetItem(i);
|
const cItem & Item = a_Minecart->GetSlot(i);
|
||||||
if (Item.IsEmpty())
|
if (Item.IsEmpty())
|
||||||
{
|
{
|
||||||
continue;
|
continue;
|
||||||
|
@ -861,7 +861,12 @@ void cWSSAnvil::LoadFallingBlockFromNBT(cEntityList & a_Entities, const cParsedN
|
|||||||
|
|
||||||
void cWSSAnvil::LoadMinecartRFromNBT(cEntityList & a_Entities, const cParsedNBT & a_NBT, int a_TagIdx)
|
void cWSSAnvil::LoadMinecartRFromNBT(cEntityList & a_Entities, const cParsedNBT & a_NBT, int a_TagIdx)
|
||||||
{
|
{
|
||||||
// TODO
|
std::auto_ptr<cEmptyMinecart> Minecart(new cEmptyMinecart(0, 0, 0));
|
||||||
|
if (!LoadEntityBaseFromNBT(*Minecart.get(), a_NBT, a_TagIdx))
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
a_Entities.push_back(Minecart.release());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -870,7 +875,30 @@ void cWSSAnvil::LoadMinecartRFromNBT(cEntityList & a_Entities, const cParsedNBT
|
|||||||
|
|
||||||
void cWSSAnvil::LoadMinecartCFromNBT(cEntityList & a_Entities, const cParsedNBT & a_NBT, int a_TagIdx)
|
void cWSSAnvil::LoadMinecartCFromNBT(cEntityList & a_Entities, const cParsedNBT & a_NBT, int a_TagIdx)
|
||||||
{
|
{
|
||||||
// TODO
|
int Items = a_NBT.FindChildByName(a_TagIdx, "Items");
|
||||||
|
if ((Items < 0) || (a_NBT.GetType(Items) != TAG_List))
|
||||||
|
{
|
||||||
|
return; // Make it an empty chest - the chunk loader will provide an empty cChestEntity for this
|
||||||
|
}
|
||||||
|
std::auto_ptr<cMinecartWithChest> Minecart(new cMinecartWithChest(0, 0, 0));
|
||||||
|
if (!LoadEntityBaseFromNBT(*Minecart.get(), a_NBT, a_TagIdx))
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
for (int Child = a_NBT.GetFirstChild(Items); Child != -1; Child = a_NBT.GetNextSibling(Child))
|
||||||
|
{
|
||||||
|
int Slot = a_NBT.FindChildByName(Child, "Slot");
|
||||||
|
if ((Slot < 0) || (a_NBT.GetType(Slot) != TAG_Byte))
|
||||||
|
{
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
cItem Item;
|
||||||
|
if (LoadItemFromNBT(Item, a_NBT, Child))
|
||||||
|
{
|
||||||
|
Minecart->SetSlot(a_NBT.GetByte(Slot), Item);
|
||||||
|
}
|
||||||
|
} // for itr - ItemDefs[]
|
||||||
|
a_Entities.push_back(Minecart.release());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@ -879,7 +907,15 @@ void cWSSAnvil::LoadMinecartCFromNBT(cEntityList & a_Entities, const cParsedNBT
|
|||||||
|
|
||||||
void cWSSAnvil::LoadMinecartFFromNBT(cEntityList & a_Entities, const cParsedNBT & a_NBT, int a_TagIdx)
|
void cWSSAnvil::LoadMinecartFFromNBT(cEntityList & a_Entities, const cParsedNBT & a_NBT, int a_TagIdx)
|
||||||
{
|
{
|
||||||
// TODO
|
std::auto_ptr<cMinecartWithFurnace> Minecart(new cMinecartWithFurnace(0, 0, 0));
|
||||||
|
if (!LoadEntityBaseFromNBT(*Minecart.get(), a_NBT, a_TagIdx))
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
// TODO: Load the Push and Fuel tags
|
||||||
|
|
||||||
|
a_Entities.push_back(Minecart.release());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user