1
0

Merge pull request #2451 from cuberite/mobchartoint

Changed mob age from char to int
This commit is contained in:
worktycho 2015-11-17 10:35:03 +00:00
commit 3955742e2f
4 changed files with 92 additions and 41 deletions

View File

@ -117,8 +117,8 @@ public:
// tolua_begin // tolua_begin
bool IsBaby (void) const { return m_Age < 0; } bool IsBaby (void) const { return m_Age < 0; }
char GetAge (void) const { return m_Age; } int GetAge (void) const { return m_Age; }
void SetAge(char a_Age) { m_Age = a_Age; } void SetAge(int a_Age) { m_Age = a_Age; }
// tolua_end // tolua_end
@ -279,7 +279,7 @@ protected:
bool m_BurnsInDaylight; bool m_BurnsInDaylight;
double m_RelativeWalkSpeed; double m_RelativeWalkSpeed;
char m_Age; int m_Age;
/** Adds a random number of a_Item between a_Min and a_Max to itemdrops a_Drops */ /** Adds a random number of a_Item between a_Min and a_Max to itemdrops a_Drops */
void AddRandomDropItem(cItems & a_Drops, unsigned int a_Min, unsigned int a_Max, short a_Item, short a_ItemHealth = 0); void AddRandomDropItem(cItems & a_Drops, unsigned int a_Min, unsigned int a_Max, short a_Item, short a_ItemHealth = 0);

View File

@ -3361,9 +3361,8 @@ void cProtocol180::WriteMobMetadata(cPacketizer & a_Pkt, const cMonster & a_Mob)
a_Pkt.WriteBEInt32(Appearance); a_Pkt.WriteBEInt32(Appearance);
a_Pkt.WriteBEUInt8(0x56); // Int at index 22 a_Pkt.WriteBEUInt8(0x56); // Int at index 22
a_Pkt.WriteBEInt32(Horse.GetHorseArmour()); a_Pkt.WriteBEInt32(Horse.GetHorseArmour());
a_Pkt.WriteBEUInt8(0x0c); a_Pkt.WriteBEUInt8(0x0c);
a_Pkt.WriteBEInt8(Horse.GetAge()); a_Pkt.WriteBEInt8(Horse.IsBaby() ? -1 : 0);
break; break;
} // case mtHorse } // case mtHorse
@ -3379,7 +3378,7 @@ void cProtocol180::WriteMobMetadata(cPacketizer & a_Pkt, const cMonster & a_Mob)
{ {
auto & Ocelot = reinterpret_cast<const cOcelot &>(a_Mob); auto & Ocelot = reinterpret_cast<const cOcelot &>(a_Mob);
a_Pkt.WriteBEUInt8(0x0c); a_Pkt.WriteBEUInt8(0x0c);
a_Pkt.WriteBEInt8(Ocelot.GetAge()); a_Pkt.WriteBEInt8(Ocelot.IsBaby() ? -1 : 0);
break; break;
} // case mtOcelot } // case mtOcelot
@ -3387,7 +3386,7 @@ void cProtocol180::WriteMobMetadata(cPacketizer & a_Pkt, const cMonster & a_Mob)
{ {
auto & Pig = reinterpret_cast<const cPig &>(a_Mob); auto & Pig = reinterpret_cast<const cPig &>(a_Mob);
a_Pkt.WriteBEUInt8(0x0c); a_Pkt.WriteBEUInt8(0x0c);
a_Pkt.WriteBEInt8(Pig.GetAge()); a_Pkt.WriteBEInt8(Pig.IsBaby() ? -1 : 0);
a_Pkt.WriteBEUInt8(0x10); a_Pkt.WriteBEUInt8(0x10);
a_Pkt.WriteBEUInt8(Pig.IsSaddled() ? 1 : 0); a_Pkt.WriteBEUInt8(Pig.IsSaddled() ? 1 : 0);
break; break;
@ -3397,7 +3396,7 @@ void cProtocol180::WriteMobMetadata(cPacketizer & a_Pkt, const cMonster & a_Mob)
{ {
auto & Sheep = reinterpret_cast<const cSheep &>(a_Mob); auto & Sheep = reinterpret_cast<const cSheep &>(a_Mob);
a_Pkt.WriteBEUInt8(0x0c); a_Pkt.WriteBEUInt8(0x0c);
a_Pkt.WriteBEInt8(Sheep.GetAge()); a_Pkt.WriteBEInt8(Sheep.IsBaby() ? -1 : 0);
a_Pkt.WriteBEUInt8(0x10); a_Pkt.WriteBEUInt8(0x10);
Byte SheepMetadata = 0; Byte SheepMetadata = 0;
@ -3415,9 +3414,8 @@ void cProtocol180::WriteMobMetadata(cPacketizer & a_Pkt, const cMonster & a_Mob)
auto & Rabbit = reinterpret_cast<const cRabbit &>(a_Mob); auto & Rabbit = reinterpret_cast<const cRabbit &>(a_Mob);
a_Pkt.WriteBEUInt8(0x12); a_Pkt.WriteBEUInt8(0x12);
a_Pkt.WriteBEUInt8(Rabbit.GetRabbitTypeAsNumber()); a_Pkt.WriteBEUInt8(Rabbit.GetRabbitTypeAsNumber());
a_Pkt.WriteBEUInt8(0x0c); a_Pkt.WriteBEUInt8(0x0c);
a_Pkt.WriteBEInt8(Rabbit.GetAge()); a_Pkt.WriteBEInt8(Rabbit.IsBaby() ? -1 : 0);
break; break;
} // case mtRabbit } // case mtRabbit
@ -3443,7 +3441,7 @@ void cProtocol180::WriteMobMetadata(cPacketizer & a_Pkt, const cMonster & a_Mob)
a_Pkt.WriteBEUInt8(0x50); a_Pkt.WriteBEUInt8(0x50);
a_Pkt.WriteBEInt32(Villager.GetVilType()); a_Pkt.WriteBEInt32(Villager.GetVilType());
a_Pkt.WriteBEUInt8(0x0c); a_Pkt.WriteBEUInt8(0x0c);
a_Pkt.WriteBEInt8(Villager.GetAge()); a_Pkt.WriteBEInt8(Villager.IsBaby() ? -1 : 0);
break; break;
} // case mtVillager } // case mtVillager
@ -3490,9 +3488,8 @@ void cProtocol180::WriteMobMetadata(cPacketizer & a_Pkt, const cMonster & a_Mob)
a_Pkt.WriteBEUInt8(Wolf.IsBegging() ? 1 : 0); a_Pkt.WriteBEUInt8(Wolf.IsBegging() ? 1 : 0);
a_Pkt.WriteBEUInt8(0x14); a_Pkt.WriteBEUInt8(0x14);
a_Pkt.WriteBEUInt8(static_cast<UInt8>(Wolf.GetCollarColor())); a_Pkt.WriteBEUInt8(static_cast<UInt8>(Wolf.GetCollarColor()));
a_Pkt.WriteBEUInt8(0x0c); a_Pkt.WriteBEUInt8(0x0c);
a_Pkt.WriteBEInt8(Wolf.GetAge()); a_Pkt.WriteBEInt8(Wolf.IsBaby() ? -1 : 0);
break; break;
} // case mtWolf } // case mtWolf

View File

@ -572,7 +572,7 @@ void cNBTChunkSerializer::AddMonsterEntity(cMonster * a_Monster)
m_Writer.AddInt ("Style", Horse->GetHorseStyle()); m_Writer.AddInt ("Style", Horse->GetHorseStyle());
m_Writer.AddInt ("ArmorType", Horse->GetHorseArmour()); m_Writer.AddInt ("ArmorType", Horse->GetHorseArmour());
m_Writer.AddByte("Saddle", Horse->IsSaddled()? 1 : 0); m_Writer.AddByte("Saddle", Horse->IsSaddled()? 1 : 0);
m_Writer.AddByte("Age", static_cast<Byte>(Horse->GetAge())); m_Writer.AddInt ("Age", Horse->GetAge());
break; break;
} }
case mtMagmaCube: case mtMagmaCube:
@ -585,7 +585,7 @@ void cNBTChunkSerializer::AddMonsterEntity(cMonster * a_Monster)
const cSheep *Sheep = reinterpret_cast<const cSheep *>(a_Monster); const cSheep *Sheep = reinterpret_cast<const cSheep *>(a_Monster);
m_Writer.AddByte("Sheared", Sheep->IsSheared()? 1 : 0); m_Writer.AddByte("Sheared", Sheep->IsSheared()? 1 : 0);
m_Writer.AddByte("Color", static_cast<Byte>(Sheep->GetFurColor())); m_Writer.AddByte("Color", static_cast<Byte>(Sheep->GetFurColor()));
m_Writer.AddByte("Age", static_cast<Byte>(Sheep->GetAge())); m_Writer.AddInt ("Age", Sheep->GetAge());
break; break;
} }
case mtSlime: case mtSlime:
@ -602,7 +602,7 @@ void cNBTChunkSerializer::AddMonsterEntity(cMonster * a_Monster)
{ {
const cVillager *Villager = reinterpret_cast<const cVillager *>(a_Monster); const cVillager *Villager = reinterpret_cast<const cVillager *>(a_Monster);
m_Writer.AddInt("Profession", Villager->GetVilType()); m_Writer.AddInt("Profession", Villager->GetVilType());
m_Writer.AddByte("Age", static_cast<Byte>(Villager->GetAge())); m_Writer.AddInt("Age", Villager->GetAge());
break; break;
} }
case mtWither: case mtWither:
@ -624,7 +624,7 @@ void cNBTChunkSerializer::AddMonsterEntity(cMonster * a_Monster)
m_Writer.AddByte("Sitting", Wolf->IsSitting() ? 1 : 0); m_Writer.AddByte("Sitting", Wolf->IsSitting() ? 1 : 0);
m_Writer.AddByte("Angry", Wolf->IsAngry() ? 1 : 0); m_Writer.AddByte("Angry", Wolf->IsAngry() ? 1 : 0);
m_Writer.AddByte("CollarColor", static_cast<Byte>(Wolf->GetCollarColor())); m_Writer.AddByte("CollarColor", static_cast<Byte>(Wolf->GetCollarColor()));
m_Writer.AddByte("Age", static_cast<Byte>(Wolf->GetAge())); m_Writer.AddInt ("Age", Wolf->GetAge());
break; break;
} }
case mtZombie: case mtZombie:
@ -632,30 +632,30 @@ void cNBTChunkSerializer::AddMonsterEntity(cMonster * a_Monster)
const cZombie *Zombie = reinterpret_cast<const cZombie *>(a_Monster); const cZombie *Zombie = reinterpret_cast<const cZombie *>(a_Monster);
m_Writer.AddByte("IsVillager", Zombie->IsVillagerZombie() ? 1 : 0); m_Writer.AddByte("IsVillager", Zombie->IsVillagerZombie() ? 1 : 0);
m_Writer.AddByte("IsConverting", Zombie->IsConverting() ? 1 : 0); m_Writer.AddByte("IsConverting", Zombie->IsConverting() ? 1 : 0);
m_Writer.AddByte("Age", static_cast<Byte>(Zombie->GetAge())); m_Writer.AddInt ("Age", Zombie->GetAge());
break; break;
} }
case mtZombiePigman: case mtZombiePigman:
{ {
m_Writer.AddByte("Age", static_cast<Byte>(reinterpret_cast<const cZombiePigman *>(a_Monster)->GetAge())); m_Writer.AddInt("Age", reinterpret_cast<const cZombiePigman *>(a_Monster)->GetAge());
break; break;
} }
case mtOcelot: case mtOcelot:
{ {
m_Writer.AddByte("Age", static_cast<Byte>(reinterpret_cast<const cOcelot *>(a_Monster)->GetAge())); m_Writer.AddInt("Age", reinterpret_cast<const cOcelot *>(a_Monster)->GetAge());
break; break;
} }
case mtPig: case mtPig:
{ {
m_Writer.AddByte("Age", static_cast<Byte>(reinterpret_cast<const cPig *>(a_Monster)->GetAge())); m_Writer.AddInt("Age", reinterpret_cast<const cPig *>(a_Monster)->GetAge());
break; break;
} }
case mtRabbit: case mtRabbit:
{ {
const cRabbit *Rabbit = reinterpret_cast<const cRabbit *>(a_Monster); const cRabbit *Rabbit = reinterpret_cast<const cRabbit *>(a_Monster);
m_Writer.AddInt("RabbitType", Rabbit->GetRabbitTypeAsNumber()); m_Writer.AddInt("RabbitType", Rabbit->GetRabbitTypeAsNumber());
m_Writer.AddInt("MoreCarrotTicks", Rabbit->GetMoreCarrotTicks()); m_Writer.AddInt("MoreCarrotTicks", Rabbit->GetMoreCarrotTicks());
m_Writer.AddByte("Age", static_cast<Byte>(Rabbit->GetAge())); m_Writer.AddInt("Age", Rabbit->GetAge());
break; break;
} }
case mtInvalidType: case mtInvalidType:

View File

@ -2344,8 +2344,14 @@ void cWSSAnvil::LoadHorseFromNBT(cEntityList & a_Entities, const cParsedNBT & a_
int AgeableIdx = a_NBT.FindChildByName(a_TagIdx, "Age"); int AgeableIdx = a_NBT.FindChildByName(a_TagIdx, "Age");
if (AgeableIdx > 0) if (AgeableIdx > 0)
{ {
Byte Age = a_NBT.GetByte(AgeableIdx); int Age;
Monster->SetAge(static_cast<char>(Age)); switch (a_NBT.GetType(AgeableIdx))
{
case TAG_Byte: Age = static_cast<int>(a_NBT.GetByte(AgeableIdx)); break;
case TAG_Int: Age = a_NBT.GetInt (AgeableIdx); break;
default: Age = 0; break;
}
Monster->SetAge(Age);
} }
a_Entities.push_back(Monster.release()); a_Entities.push_back(Monster.release());
@ -2440,8 +2446,14 @@ void cWSSAnvil::LoadOcelotFromNBT(cEntityList & a_Entities, const cParsedNBT & a
int AgeableIdx = a_NBT.FindChildByName(a_TagIdx, "Age"); int AgeableIdx = a_NBT.FindChildByName(a_TagIdx, "Age");
if (AgeableIdx > 0) if (AgeableIdx > 0)
{ {
Byte Age = a_NBT.GetByte(AgeableIdx); int Age;
Monster->SetAge(static_cast<char>(Age)); switch (a_NBT.GetType(AgeableIdx))
{
case TAG_Byte: Age = static_cast<int>(a_NBT.GetByte(AgeableIdx)); break;
case TAG_Int: Age = a_NBT.GetInt (AgeableIdx); break;
default: Age = 0; break;
}
Monster->SetAge(Age);
} }
a_Entities.push_back(Monster.release()); a_Entities.push_back(Monster.release());
@ -2467,8 +2479,14 @@ void cWSSAnvil::LoadPigFromNBT(cEntityList & a_Entities, const cParsedNBT & a_NB
int AgeableIdx = a_NBT.FindChildByName(a_TagIdx, "Age"); int AgeableIdx = a_NBT.FindChildByName(a_TagIdx, "Age");
if (AgeableIdx > 0) if (AgeableIdx > 0)
{ {
Byte Age = a_NBT.GetByte(AgeableIdx); int Age;
Monster->SetAge(static_cast<char>(Age)); switch (a_NBT.GetType(AgeableIdx))
{
case TAG_Byte: Age = static_cast<int>(a_NBT.GetByte(AgeableIdx)); break;
case TAG_Int: Age = a_NBT.GetInt (AgeableIdx); break;
default: Age = 0; break;
}
Monster->SetAge(Age);
} }
a_Entities.push_back(Monster.release()); a_Entities.push_back(Monster.release());
@ -2505,8 +2523,14 @@ void cWSSAnvil::LoadRabbitFromNBT(cEntityList & a_Entities, const cParsedNBT & a
int AgeableIdx = a_NBT.FindChildByName(a_TagIdx, "Age"); int AgeableIdx = a_NBT.FindChildByName(a_TagIdx, "Age");
if (AgeableIdx > 0) if (AgeableIdx > 0)
{ {
Byte Age = a_NBT.GetByte(AgeableIdx); int Age;
Monster->SetAge(static_cast<char>(Age)); switch (a_NBT.GetType(AgeableIdx))
{
case TAG_Byte: Age = static_cast<int>(a_NBT.GetByte(AgeableIdx)); break;
case TAG_Int: Age = a_NBT.GetInt (AgeableIdx); break;
default: Age = 0; break;
}
Monster->SetAge(Age);
} }
a_Entities.push_back(Monster.release()); a_Entities.push_back(Monster.release());
@ -2545,8 +2569,14 @@ void cWSSAnvil::LoadSheepFromNBT(cEntityList & a_Entities, const cParsedNBT & a_
int AgeableIdx = a_NBT.FindChildByName(a_TagIdx, "Age"); int AgeableIdx = a_NBT.FindChildByName(a_TagIdx, "Age");
if (AgeableIdx > 0) if (AgeableIdx > 0)
{ {
Byte Age = a_NBT.GetByte(AgeableIdx); int Age;
Monster->SetAge(static_cast<char>(Age)); switch (a_NBT.GetType(AgeableIdx))
{
case TAG_Byte: Age = static_cast<int>(a_NBT.GetByte(AgeableIdx)); break;
case TAG_Int: Age = a_NBT.GetInt (AgeableIdx); break;
default: Age = 0; break;
}
Monster->SetAge(Age);
} }
a_Entities.push_back(Monster.release()); a_Entities.push_back(Monster.release());
@ -2717,8 +2747,14 @@ void cWSSAnvil::LoadVillagerFromNBT(cEntityList & a_Entities, const cParsedNBT &
int AgeableIdx = a_NBT.FindChildByName(a_TagIdx, "Age"); int AgeableIdx = a_NBT.FindChildByName(a_TagIdx, "Age");
if (AgeableIdx > 0) if (AgeableIdx > 0)
{ {
Byte Age = a_NBT.GetByte(AgeableIdx); int Age;
Monster->SetAge(static_cast<char>(Age)); switch (a_NBT.GetType(AgeableIdx))
{
case TAG_Byte: Age = static_cast<int>(a_NBT.GetByte(AgeableIdx)); break;
case TAG_Int: Age = a_NBT.GetInt (AgeableIdx); break;
default: Age = 0; break;
}
Monster->SetAge(Age);
} }
@ -2825,8 +2861,14 @@ void cWSSAnvil::LoadWolfFromNBT(cEntityList & a_Entities, const cParsedNBT & a_N
int AgeableIdx = a_NBT.FindChildByName(a_TagIdx, "Age"); int AgeableIdx = a_NBT.FindChildByName(a_TagIdx, "Age");
if (AgeableIdx > 0) if (AgeableIdx > 0)
{ {
Byte Age = a_NBT.GetByte(AgeableIdx); int Age;
Monster->SetAge(static_cast<char>(Age)); switch (a_NBT.GetType(AgeableIdx))
{
case TAG_Byte: Age = static_cast<int>(a_NBT.GetByte(AgeableIdx)); break;
case TAG_Int: Age = a_NBT.GetInt (AgeableIdx); break;
default: Age = 0; break;
}
Monster->SetAge(Age);
} }
a_Entities.push_back(Monster.release()); a_Entities.push_back(Monster.release());
@ -2860,8 +2902,14 @@ void cWSSAnvil::LoadZombieFromNBT(cEntityList & a_Entities, const cParsedNBT & a
int AgeableIdx = a_NBT.FindChildByName(a_TagIdx, "Age"); int AgeableIdx = a_NBT.FindChildByName(a_TagIdx, "Age");
if (AgeableIdx > 0) if (AgeableIdx > 0)
{ {
Byte Age = a_NBT.GetByte(AgeableIdx); int Age;
Monster->SetAge(static_cast<char>(Age)); switch (a_NBT.GetType(AgeableIdx))
{
case TAG_Byte: Age = static_cast<int>(a_NBT.GetByte(AgeableIdx)); break;
case TAG_Int: Age = a_NBT.GetInt (AgeableIdx); break;
default: Age = 0; break;
}
Monster->SetAge(Age);
} }
a_Entities.push_back(Monster.release()); a_Entities.push_back(Monster.release());
@ -2887,8 +2935,14 @@ void cWSSAnvil::LoadPigZombieFromNBT(cEntityList & a_Entities, const cParsedNBT
int AgeableIdx = a_NBT.FindChildByName(a_TagIdx, "Age"); int AgeableIdx = a_NBT.FindChildByName(a_TagIdx, "Age");
if (AgeableIdx > 0) if (AgeableIdx > 0)
{ {
Byte Age = a_NBT.GetByte(AgeableIdx); int Age;
Monster->SetAge(static_cast<char>(Age)); switch (a_NBT.GetType(AgeableIdx))
{
case TAG_Byte: Age = static_cast<int>(a_NBT.GetByte(AgeableIdx)); break;
case TAG_Int: Age = a_NBT.GetInt (AgeableIdx); break;
default: Age = 0; break;
}
Monster->SetAge(Age);
} }
a_Entities.push_back(Monster.release()); a_Entities.push_back(Monster.release());