Revert "Project modernization (#630)"
This code was not tested and breaks in Release builds, reverting to restore
functionality of the nightly. All in-game menus do not work and generating
a world crashes.
This reverts commit a9be52c41a.
This commit is contained in:
@@ -24,36 +24,36 @@ MushroomCow::MushroomCow(Level *level) : Cow(level)
|
||||
bool MushroomCow::mobInteract(shared_ptr<Player> player)
|
||||
{
|
||||
shared_ptr<ItemInstance> item = player->inventory->getSelected();
|
||||
if (item != nullptr && item->id == Item::bowl_Id && getAge() >= 0)
|
||||
if (item != NULL && item->id == Item::bowl_Id && getAge() >= 0)
|
||||
{
|
||||
if (item->count == 1)
|
||||
{
|
||||
player->inventory->setItem(player->inventory->selected, std::make_shared<ItemInstance>(Item::mushroomStew));
|
||||
player->inventory->setItem(player->inventory->selected, shared_ptr<ItemInstance>( new ItemInstance(Item::mushroomStew) ) );
|
||||
return true;
|
||||
}
|
||||
|
||||
if (player->inventory->add(std::make_shared<ItemInstance>(Item::mushroomStew)) && !player->abilities.instabuild)
|
||||
if (player->inventory->add(shared_ptr<ItemInstance>(new ItemInstance(Item::mushroomStew))) && !player->abilities.instabuild)
|
||||
{
|
||||
player->inventory->removeItem(player->inventory->selected, 1);
|
||||
return true;
|
||||
}
|
||||
}
|
||||
// 4J: Do not allow shearing if we can't create more cows
|
||||
if (item != nullptr && item->id == Item::shears_Id && getAge() >= 0 && level->canCreateMore(eTYPE_COW, Level::eSpawnType_Breed))
|
||||
if (item != NULL && item->id == Item::shears_Id && getAge() >= 0 && level->canCreateMore(eTYPE_COW, Level::eSpawnType_Breed))
|
||||
{
|
||||
remove();
|
||||
level->addParticle(eParticleType_largeexplode, x, y + bbHeight / 2, z, 0, 0, 0);
|
||||
if(!level->isClientSide)
|
||||
{
|
||||
remove();
|
||||
shared_ptr<Cow> cow = std::make_shared<Cow>(level);
|
||||
shared_ptr<Cow> cow = shared_ptr<Cow>( new Cow(level) );
|
||||
cow->moveTo(x, y, z, yRot, xRot);
|
||||
cow->setHealth(getHealth());
|
||||
cow->yBodyRot = yBodyRot;
|
||||
level->addEntity(cow);
|
||||
for (int i = 0; i < 5; i++)
|
||||
{
|
||||
level->addEntity(std::make_shared<ItemEntity>(level, x, y + bbHeight, z, shared_ptr<ItemInstance>(new ItemInstance(Tile::mushroom_red))));
|
||||
level->addEntity( shared_ptr<ItemEntity>( new ItemEntity(level, x, y + bbHeight, z, shared_ptr<ItemInstance>( new ItemInstance(Tile::mushroom_red))) ));
|
||||
}
|
||||
return true;
|
||||
}
|
||||
@@ -76,7 +76,7 @@ shared_ptr<AgableMob> MushroomCow::getBreedOffspring(shared_ptr<AgableMob> targe
|
||||
// 4J - added limit to number of animals that can be bred
|
||||
if( level->canCreateMore( GetType(), Level::eSpawnType_Breed) )
|
||||
{
|
||||
return std::make_shared<MushroomCow>(level);
|
||||
return shared_ptr<MushroomCow>( new MushroomCow(level) );
|
||||
}
|
||||
else
|
||||
{
|
||||
|
||||
Reference in New Issue
Block a user