From dd1c7257b760f4c97c84e66d4ebb4f32fff8a499 Mon Sep 17 00:00:00 2001 From: Andrei Karas Date: Mon, 23 Feb 2015 00:20:47 +0300 Subject: eathena: fix crash if pet went outside of visible area. --- src/being/playerinfo.cpp | 15 +++++++++------ 1 file changed, 9 insertions(+), 6 deletions(-) (limited to 'src/being/playerinfo.cpp') diff --git a/src/being/playerinfo.cpp b/src/being/playerinfo.cpp index 23a55f6fe..6b3bb2703 100644 --- a/src/being/playerinfo.cpp +++ b/src/being/playerinfo.cpp @@ -64,7 +64,7 @@ Equipment *mEquipment = nullptr; MercenaryInfo *mMercenary = nullptr; HomunculusInfo *mHomunculus = nullptr; PetInfo *mPet = nullptr; -Being *mPetBeing = nullptr; +int mPetBeingId = 0; GuildPositionFlags::Type mGuildPositionFlags = GuildPositionFlags::None; bool mTrading = false; @@ -395,7 +395,7 @@ void deinit() { clearInventory(); delete2(mMercenary); - mPetBeing = nullptr; + mPetBeingId = 0; } void loadData() @@ -408,7 +408,7 @@ void loadData() void clear() { mData.mSkills.clear(); - mPetBeing = nullptr; + mPetBeingId = 0; } bool isTalking() @@ -508,7 +508,10 @@ void setPet(PetInfo *const info) void setPetBeing(Being *const being) { - mPetBeing = being; + if (being) + mPetBeingId = being->getId(); + else + mPetBeingId = 0; if (!being || !mPet) return; being->setName(mPet->name); @@ -521,9 +524,9 @@ PetInfo *getPet() return mPet; } -Being *getPetBeing() +int getPetBeingId() { - return mPetBeing; + return mPetBeingId; } void setHomunculus(HomunculusInfo *const info) -- cgit v1.2.3-60-g2f50