Fixed mission cars not being properly cleaned up. (#3434)
This commit is contained in:
parent
995b381053
commit
43afdae9e7
@ -1,41 +1,44 @@
|
||||
#include "hooking/hooking.hpp"
|
||||
#include "util/notify.hpp"
|
||||
|
||||
namespace big
|
||||
{
|
||||
void hooks::received_clone_remove(CNetworkObjectMgr* mgr, CNetGamePlayer* src, CNetGamePlayer* dst, int16_t object_id, uint32_t ownership_token)
|
||||
{
|
||||
if (!dst || !dst->m_player_info || !dst->m_player_info->m_ped || !dst->m_player_info->m_ped->m_net_object
|
||||
|| dst->m_player_info->m_ped->m_net_object->m_object_id == object_id) [[unlikely]]
|
||||
{
|
||||
notify::crash_blocked(src, "player ped removal");
|
||||
return;
|
||||
}
|
||||
|
||||
if (g_local_player && g_local_player->m_vehicle && g_local_player->m_vehicle->m_net_object
|
||||
&& object_id == g_local_player->m_vehicle->m_net_object->m_object_id) [[unlikely]]
|
||||
{
|
||||
if (auto plyr = g_player_service->get_by_id(src->m_player_id))
|
||||
{
|
||||
g.reactions.delete_vehicle.process(plyr);
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
if (auto object = g_pointers->m_gta.m_get_net_object(*g_pointers->m_gta.m_network_object_mgr, object_id, true)) [[likely]]
|
||||
{
|
||||
if (object->m_object_type == (int)eNetObjType::NET_OBJ_TYPE_PLAYER && object->m_owner_id != src->m_player_id) [[unlikely]]
|
||||
{
|
||||
std::string target = "<UNKNOWN>";
|
||||
|
||||
if (auto tgt = g_player_service->get_by_id(object->m_owner_id))
|
||||
target = tgt->get_name();
|
||||
|
||||
LOGF(stream::net_sync, WARNING, "Rejecting clone remove from {}, who is trying to delete {}'s player ped", src->get_name(), target);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
g_hooking->get_original<hooks::received_clone_remove>()(mgr, src, dst, object_id, ownership_token);
|
||||
}
|
||||
#include "hooking/hooking.hpp"
|
||||
#include "util/notify.hpp"
|
||||
|
||||
namespace big
|
||||
{
|
||||
void hooks::received_clone_remove(CNetworkObjectMgr* mgr, CNetGamePlayer* src, CNetGamePlayer* dst, int16_t object_id, uint32_t ownership_token)
|
||||
{
|
||||
if (!dst || !dst->m_player_info || !dst->m_player_info->m_ped || !dst->m_player_info->m_ped->m_net_object
|
||||
|| dst->m_player_info->m_ped->m_net_object->m_object_id == object_id) [[unlikely]]
|
||||
{
|
||||
notify::crash_blocked(src, "player ped removal");
|
||||
return;
|
||||
}
|
||||
|
||||
if (g_local_player && g_local_player->m_vehicle && g_local_player->m_vehicle->m_net_object
|
||||
&& object_id == g_local_player->m_vehicle->m_net_object->m_object_id) [[unlikely]]
|
||||
{
|
||||
if (!NETWORK::NETWORK_IS_ACTIVITY_SESSION()) //If we're in Freemode.
|
||||
{
|
||||
if (auto plyr = g_player_service->get_by_id(src->m_player_id))
|
||||
{
|
||||
g.reactions.delete_vehicle.process(plyr);
|
||||
}
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
if (auto object = g_pointers->m_gta.m_get_net_object(*g_pointers->m_gta.m_network_object_mgr, object_id, true)) [[likely]]
|
||||
{
|
||||
if (object->m_object_type == (int)eNetObjType::NET_OBJ_TYPE_PLAYER && object->m_owner_id != src->m_player_id) [[unlikely]]
|
||||
{
|
||||
std::string target = "<UNKNOWN>";
|
||||
|
||||
if (auto tgt = g_player_service->get_by_id(object->m_owner_id))
|
||||
target = tgt->get_name();
|
||||
|
||||
LOGF(stream::net_sync, WARNING, "Rejecting clone remove from {}, who is trying to delete {}'s player ped", src->get_name(), target);
|
||||
return;
|
||||
}
|
||||
}
|
||||
|
||||
g_hooking->get_original<hooks::received_clone_remove>()(mgr, src, dst, object_id, ownership_token);
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user