Refactored Allow All Weapons In Vehicle to force all vehicles to use … (#1730)
* Refactored Allow All Weapons In Vehicle to force all vehicles to use all GROUPs. * Refactored project to not depend on src/gta files that already exist in the GTA-V-Classes project. * feat(cmake): bump GTAV-Classes
This commit is contained in:
parent
8c097f0915
commit
152642cf1b
scripts
src
backend
core
gta
net_object_mgr.hppnode_list.hppscript_handler.hppscript_id.hppscript_program.hppscript_thread.hpptls_context.hppweapons.hpp
gta_pointers.hppgta_util.hpphooking.cpphooking.hpphooks
misc
protections
toxic
logger
native_hooks
pointers.cppscript_function.cppscript_mgr.cppservices
util
views/network
@ -3,7 +3,7 @@ include(FetchContent)
|
||||
FetchContent_Declare(
|
||||
gtav_classes
|
||||
GIT_REPOSITORY https://github.com/Yimura/GTAV-Classes.git
|
||||
GIT_TAG 95dadd6e7ee7bfa15d66bb2c597d13e97c631727
|
||||
GIT_TAG e56523456c42d918bb19814863827a7e6b77ae89
|
||||
GIT_PROGRESS TRUE
|
||||
CONFIGURE_COMMAND ""
|
||||
BUILD_COMMAND ""
|
||||
|
@ -89,6 +89,7 @@ namespace big
|
||||
while (g_running)
|
||||
{
|
||||
looped::vehicle_auto_drive();
|
||||
looped::vehicle_allow_all_weapons();
|
||||
looped::vehicle_boost_behavior();
|
||||
looped::derail_train();
|
||||
looped::drive_train();
|
||||
|
@ -54,7 +54,7 @@ namespace big
|
||||
|
||||
auto thread = gta_util::find_script_thread(RAGE_JOAAT("am_hunt_the_beast"));
|
||||
auto stack = thread->m_stack;
|
||||
auto net_component = thread->m_net_component;
|
||||
auto net_component = (CGameScriptHandlerNetComponent*)thread->m_net_component;
|
||||
auto idx = scr_locals::am_hunt_the_beast::broadcast_idx;
|
||||
|
||||
if (!stack || !net_component || !player->is_valid())
|
||||
@ -112,13 +112,13 @@ namespace big
|
||||
return;
|
||||
|
||||
auto stack = thread->m_stack;
|
||||
auto net_component = thread->m_net_component;
|
||||
auto net_component = (CGameScriptHandlerNetComponent*)thread->m_net_component;
|
||||
auto idx = scr_locals::am_hunt_the_beast::broadcast_idx;
|
||||
|
||||
if (!stack || !net_component)
|
||||
return;
|
||||
|
||||
thread->m_net_component->block_host_migration(true);
|
||||
((CGameScriptHandlerNetComponent*)thread->m_net_component)->block_host_migration(true);
|
||||
thread->m_context.m_state = rage::eThreadState::unk_3;
|
||||
g.m_hunt_the_beast_thread = thread;
|
||||
|
||||
|
@ -46,7 +46,8 @@ namespace big
|
||||
int num_array_handlers{};
|
||||
int received_array_handlers{};
|
||||
|
||||
while (auto handler = g_pointers->m_gta.m_get_host_array_handler_by_index(freemode->m_net_component, num_array_handlers++))
|
||||
while (
|
||||
auto handler = g_pointers->m_gta.m_get_host_array_handler_by_index((CGameScriptHandlerNetComponent*)freemode->m_net_component, num_array_handlers++))
|
||||
if (handler->m_flags & 1)
|
||||
received_array_handlers++;
|
||||
|
||||
|
@ -42,6 +42,7 @@ namespace big
|
||||
static void system_rainbow();
|
||||
|
||||
static void vehicle_auto_drive();
|
||||
static void vehicle_allow_all_weapons();
|
||||
static void vehicle_boost_behavior();
|
||||
static void vehicle_ls_customs();
|
||||
static void vehicle_rainbow_paint();
|
||||
|
@ -12,7 +12,7 @@ namespace big
|
||||
if (g.session.randomize_ceo_colors && *g_pointers->m_gta.m_is_session_started && !STREAMING::IS_PLAYER_SWITCH_IN_PROGRESS() && SCRIPT::GET_NUMBER_OF_THREADS_RUNNING_THE_SCRIPT_WITH_THIS_HASH(RAGE_JOAAT("maintransition")) == 0)
|
||||
{
|
||||
if (auto freemode = gta_util::find_script_thread(RAGE_JOAAT("freemode"));
|
||||
freemode && freemode->m_net_component && freemode->m_net_component->is_local_player_host())
|
||||
freemode && freemode->m_net_component && ((CGameScriptHandlerNetComponent*)freemode->m_net_component)->is_local_player_host())
|
||||
{
|
||||
for (int i = 0; i < *scr_globals::gsbd.at(818).at(44).as<int*>(); i++)
|
||||
{
|
||||
|
54
src/backend/looped/vehicle/allow_all_weapons.cpp
Normal file
54
src/backend/looped/vehicle/allow_all_weapons.cpp
Normal file
@ -0,0 +1,54 @@
|
||||
#include "backend/looped/looped.hpp"
|
||||
#include "util/vehicle.hpp"
|
||||
|
||||
#include <vehicle/CVehicleModelInfo.hpp>
|
||||
#include <vehicle/CVehicleSeatMetadataMgr.hpp>
|
||||
#include <vehicle/CVehicleDriveByMetadataMgr.hpp>
|
||||
|
||||
#include "gta/weapons.hpp"
|
||||
|
||||
namespace big
|
||||
{
|
||||
void looped::vehicle_allow_all_weapons()
|
||||
{
|
||||
CVehicle* vehicle_ptr = (CVehicle*)g_pointers->m_gta.m_handle_to_ptr(self::veh);
|
||||
|
||||
if (vehicle_ptr == nullptr)
|
||||
return;
|
||||
|
||||
rage::atArray<Hash> one_handed_groups =
|
||||
g_pointers->m_gta.m_driveby_metadata_mgr->m_drive_by_weapon_groups->m_drive_by_default->m_driveby_default_one_handed_weapon_group_names;
|
||||
|
||||
if (g.vehicle.unlimited_weapons == false)
|
||||
{
|
||||
if (one_handed_groups.size() != 1)
|
||||
{
|
||||
rage::atArray<Hash> one_handed_groups;
|
||||
one_handed_groups.append(GROUP_PISTOL);
|
||||
g_pointers->m_gta.m_driveby_metadata_mgr->m_drive_by_weapon_groups->m_drive_by_default->m_driveby_default_one_handed_weapon_group_names = one_handed_groups;
|
||||
}
|
||||
return;
|
||||
}
|
||||
|
||||
CVehicleModelInfo* vehicle_model_info = static_cast<CVehicleModelInfo*>(vehicle_ptr->m_model_info);
|
||||
|
||||
auto num_seats = vehicle_model_info->m_vehicle_layout->m_max_seats;
|
||||
auto seat_info = vehicle_model_info->m_vehicle_layout->m_layout_metadata->m_seat_info;
|
||||
auto defaults = g_pointers->m_gta.m_vehicle_layout_metadata_mgr->m_drive_by_seat_defaults;
|
||||
if (seat_info->m_front_left->m_drive_by_info != defaults->m_driveby_standard_front_left)
|
||||
seat_info->m_front_left->m_drive_by_info = defaults->m_driveby_standard_front_left;
|
||||
if (num_seats > 1 && seat_info->m_front_right->m_drive_by_info != defaults->m_driveby_standard_front_right)
|
||||
seat_info->m_front_right->m_drive_by_info = defaults->m_driveby_standard_front_right;
|
||||
if (num_seats > 2 && seat_info->m_rear_left->m_drive_by_info != defaults->m_driveby_standard_rear_left)
|
||||
seat_info->m_rear_left->m_drive_by_info = defaults->m_driveby_standard_rear_left;
|
||||
if (num_seats > 3 && seat_info->m_rear_right->m_drive_by_info != defaults->m_driveby_standard_rear_right)
|
||||
seat_info->m_rear_right->m_drive_by_info = defaults->m_driveby_standard_rear_right;
|
||||
|
||||
if (g_pointers->m_gta.m_driveby_metadata_mgr->m_drive_by_weapon_groups->m_drive_by_default
|
||||
->m_driveby_default_one_handed_weapon_group_names.size() == 1)
|
||||
{
|
||||
one_handed_groups.append({GROUP_MG, GROUP_RIFLE, GROUP_SHOTGUN, GROUP_HEAVY, GROUP_SNIPER, GROUP_SMG});
|
||||
g_pointers->m_gta.m_driveby_metadata_mgr->m_drive_by_weapon_groups->m_drive_by_default->m_driveby_default_one_handed_weapon_group_names = one_handed_groups;
|
||||
}
|
||||
}
|
||||
}
|
@ -683,13 +683,12 @@ namespace big
|
||||
bool keep_vehicle_clean = false;
|
||||
bool vehinvisibility = false;
|
||||
bool localveh_visibility = false;
|
||||
bool localped_visibility = true;
|
||||
bool keep_on_ground = false;
|
||||
bool no_collision = false;
|
||||
bool unlimited_weapons = false;
|
||||
bool siren_mute = false;
|
||||
|
||||
NLOHMANN_DEFINE_TYPE_INTRUSIVE(vehicle, speedo_meter, fly, rainbow_paint, speed_unit, god_mode, proof_bullet, proof_fire, proof_collision, proof_melee, proof_explosion, proof_steam, proof_water, proof_mask, auto_drive_destination, auto_drive_style, auto_drive_speed, auto_turn_signals, boost_behavior, drive_on_water, horn_boost, instant_brake, block_homing, seatbelt, turn_signals, vehicle_jump, keep_vehicle_repaired, no_water_collision, disable_engine_auto_start, change_engine_state_immediately, keep_engine_running, keep_vehicle_clean, vehinvisibility, localveh_visibility, localped_visibility, keep_on_ground, no_collision, unlimited_weapons, siren_mute)
|
||||
NLOHMANN_DEFINE_TYPE_INTRUSIVE(vehicle, speedo_meter, fly, rainbow_paint, speed_unit, god_mode, proof_bullet, proof_fire, proof_collision, proof_melee, proof_explosion, proof_steam, proof_water, proof_mask, auto_drive_destination, auto_drive_style, auto_drive_speed, auto_turn_signals, boost_behavior, drive_on_water, horn_boost, instant_brake, block_homing, seatbelt, turn_signals, vehicle_jump, keep_vehicle_repaired, no_water_collision, disable_engine_auto_start, change_engine_state_immediately, keep_engine_running, keep_vehicle_clean, vehinvisibility, localveh_visibility, keep_on_ground, no_collision, unlimited_weapons, siren_mute)
|
||||
} vehicle{};
|
||||
|
||||
struct weapons
|
||||
|
@ -1,7 +1,7 @@
|
||||
#pragma once
|
||||
#include "../pointers.hpp"
|
||||
#include "enums.hpp"
|
||||
#include "node_list.hpp"
|
||||
#include "script/dataList.hpp"
|
||||
|
||||
class CNetGamePlayer;
|
||||
|
||||
|
@ -1,24 +0,0 @@
|
||||
#pragma once
|
||||
#include "fwddec.hpp"
|
||||
|
||||
#include <base/datBase.hpp>
|
||||
|
||||
namespace rage
|
||||
{
|
||||
template<typename T, typename Base = datBase>
|
||||
class atDNode : public Base
|
||||
{
|
||||
public:
|
||||
T m_data;
|
||||
void* m_unk;
|
||||
atDNode<T, Base>* m_next;
|
||||
};
|
||||
|
||||
template<typename Node>
|
||||
class atDList
|
||||
{
|
||||
public:
|
||||
Node* m_head;
|
||||
Node* m_tail;
|
||||
};
|
||||
}
|
@ -1,19 +1,16 @@
|
||||
#pragma once
|
||||
#include "fwddec.hpp"
|
||||
#include "node_list.hpp"
|
||||
#include "script_id.hpp"
|
||||
#include "script/dataList.hpp"
|
||||
#include "script/scriptIdBase.hpp"
|
||||
#include "script/scriptResource.hpp"
|
||||
#include "script/scriptHandler.hpp"
|
||||
#include "script/scriptHandlerNetComponent.hpp"
|
||||
|
||||
#include <cstdint>
|
||||
|
||||
#pragma pack(push, 1)
|
||||
namespace rage
|
||||
{
|
||||
class scriptResource
|
||||
{
|
||||
public:
|
||||
virtual ~scriptResource() = default;
|
||||
};
|
||||
|
||||
class scriptResourceEntry
|
||||
{
|
||||
public:
|
||||
@ -23,83 +20,6 @@ namespace rage
|
||||
scriptResourceEntry* m_next;// 0x18
|
||||
};
|
||||
|
||||
class scriptHandlerNetComponent
|
||||
{
|
||||
public:
|
||||
virtual ~scriptHandlerNetComponent() = default;
|
||||
|
||||
public:
|
||||
scriptHandler* m_script_handler;// 0x08
|
||||
};
|
||||
|
||||
class scriptHandler
|
||||
{
|
||||
public:
|
||||
class atDScriptObjectNode : public atDNode<scriptHandlerObject*>
|
||||
{
|
||||
};
|
||||
|
||||
public:
|
||||
virtual ~scriptHandler() = default;// 0 (0x00)
|
||||
|
||||
virtual bool _0x08() = 0;// 1 (0x08)
|
||||
|
||||
virtual void _0x10() = 0;// 2 (0x10)
|
||||
|
||||
virtual void cleanup_objects() = 0;// 3 (0x18)
|
||||
|
||||
virtual scriptId* _0x20() = 0;// 4 (0x20)
|
||||
|
||||
virtual scriptId* get_id() = 0;// 5 (0x28)
|
||||
|
||||
// Returns whether the script handler belongs to a networked script.
|
||||
virtual bool is_networked() = 0;// 6 (0x30)
|
||||
|
||||
// Initializes the network component for the script handler.
|
||||
virtual void init_net_component() = 0;// 7 (0x38)
|
||||
|
||||
// Deletes the script handler's network component, if it exists.
|
||||
virtual void reset_net_component() = 0;// 8 (0x40)
|
||||
|
||||
// Destroys the script handler.
|
||||
virtual bool destroy() = 0;// 9 (0x48)
|
||||
|
||||
// Adds the object to the script handler's list of objects.
|
||||
virtual void add_object(scriptHandlerObject*, bool is_network, bool is_network_and_scriptcheck) = 0;// 10 (0x50)
|
||||
|
||||
// Something related to reservations.
|
||||
virtual void _0x58(void*) = 0;// 11 (0x58)
|
||||
|
||||
virtual void register_resource(scriptResource*, void*) = 0;// 12 (0x60)
|
||||
|
||||
virtual void _0x68() = 0;// 13 (0x68)
|
||||
|
||||
virtual void _0x70() = 0;// 14 (0x70)
|
||||
|
||||
virtual void _0x78() = 0;// 15 (0x78)
|
||||
|
||||
virtual void _0x80() = 0;// 16 (0x80)
|
||||
|
||||
virtual void _0x88() = 0;// 17 (0x88)
|
||||
|
||||
virtual void _0x90() = 0;// 18 (0x90)
|
||||
|
||||
virtual void _0x98() = 0;// 19 (0x98)
|
||||
public:
|
||||
void* m_0x08; // 0x08
|
||||
void* m_0x10; // 0x10
|
||||
scrThread* m_script_thread; // 0x18
|
||||
atDList<atDScriptObjectNode> m_objects; // 0x20
|
||||
scriptResource* m_resource_list_head; // 0x30
|
||||
scriptResource* m_resource_list_tail; // 0x38
|
||||
void* m_0x40; // 0x40
|
||||
scriptHandlerNetComponent* m_net_component;// 0x48
|
||||
std::uint32_t m_0x50; // 0x50
|
||||
std::uint32_t m_0x54; // 0x54
|
||||
std::uint32_t m_0x58; // 0x58
|
||||
std::uint32_t m_0x60; // 0x5C
|
||||
};
|
||||
|
||||
class scriptHandlerMgr
|
||||
{
|
||||
public:
|
||||
|
@ -1,99 +0,0 @@
|
||||
#pragma once
|
||||
#include "fwddec.hpp"
|
||||
#include "joaat.hpp"
|
||||
|
||||
#include <cstdint>
|
||||
|
||||
#pragma pack(push, 1)
|
||||
namespace rage
|
||||
{
|
||||
class scriptIdBase
|
||||
{
|
||||
public:
|
||||
virtual ~scriptIdBase() = default;// 0 (0x00)
|
||||
|
||||
// Assumes the script thread's identity.
|
||||
virtual void assume_thread_identity(scrThread*){};// 1 (0x08)
|
||||
|
||||
// Returns whether the hash of the script id is valid.
|
||||
virtual bool is_valid()
|
||||
{
|
||||
return false;
|
||||
};// 2 (0x10)
|
||||
|
||||
// Gets the hash of the script id.
|
||||
virtual joaat_t* get_hash(joaat_t* out)
|
||||
{
|
||||
return 0;
|
||||
};// 3 (0x18)
|
||||
|
||||
// Gets an unknown value from the script id.
|
||||
virtual std::uint32_t* get_hash2(std::uint32_t* out)
|
||||
{
|
||||
return 0;
|
||||
};// 4 (0x20)
|
||||
|
||||
// Gets the name of the script id.
|
||||
virtual const char* get_name()
|
||||
{
|
||||
return nullptr;
|
||||
};// 5 (0x28)
|
||||
|
||||
// Serializes the script id from the buffer.
|
||||
virtual void deserialize(datBitBuffer* buffer){};// 6 (0x30)
|
||||
|
||||
// Serializes the script id to the buffer.
|
||||
virtual void serialize(datBitBuffer* buffer){};// 7 (0x38)
|
||||
|
||||
// Calculates some information with the position hash & instance id.
|
||||
virtual std::uint32_t _0x40()
|
||||
{
|
||||
return 0;
|
||||
};// 8 (0x40)
|
||||
|
||||
// Calls _0x40 and returns it's value added to another value.
|
||||
virtual std::uint32_t _0x48()
|
||||
{
|
||||
return 0;
|
||||
};// 9 (0x48)
|
||||
|
||||
// Logs some information about the script id.
|
||||
virtual void log_information(netLoggingInterface* logger){};// 10 (0x50)
|
||||
|
||||
// Copies the information of other to this object.
|
||||
virtual void copy_data(scriptIdBase* other)
|
||||
{
|
||||
}// 11 (0x58)
|
||||
|
||||
// Returns whether the other script id is equal.
|
||||
virtual bool operator==(scriptIdBase*)
|
||||
{
|
||||
return false;
|
||||
};// 12 (0x60)
|
||||
|
||||
virtual bool _0x68(void*)
|
||||
{
|
||||
return false;
|
||||
};// 13 (0x68)
|
||||
};
|
||||
|
||||
class scriptId : public scriptIdBase
|
||||
{
|
||||
public:
|
||||
joaat_t m_hash; // 0x08
|
||||
char m_name[0x20];// 0x0C
|
||||
};
|
||||
}
|
||||
|
||||
class CGameScriptId : public rage::scriptId
|
||||
{
|
||||
public:
|
||||
char m_padding[0x04]; // 0x2C
|
||||
std::int32_t m_timestamp; // 0x30
|
||||
std::int32_t m_position_hash;// 0x34
|
||||
std::int32_t m_instance_id; // 0x38
|
||||
std::int32_t m_unk; // 0x3C
|
||||
};
|
||||
|
||||
static_assert(sizeof(CGameScriptId) == 0x40);
|
||||
#pragma pack(pop)
|
@ -2,7 +2,7 @@
|
||||
#include "base.hpp"
|
||||
#include "fwddec.hpp"
|
||||
#include "joaat.hpp"
|
||||
#include "script_id.hpp"
|
||||
#include "script/scriptIdBase.hpp"
|
||||
|
||||
#include <cstdint>
|
||||
|
||||
|
@ -1,70 +1,11 @@
|
||||
#pragma once
|
||||
#include "fwddec.hpp"
|
||||
#include "joaat.hpp"
|
||||
#include "tls_context.hpp"
|
||||
|
||||
#include <cstdint>
|
||||
|
||||
class CGameScriptHandlerNetComponent;
|
||||
|
||||
namespace rage
|
||||
{
|
||||
enum class eThreadState : std::uint32_t
|
||||
{
|
||||
idle,
|
||||
running,
|
||||
killed,
|
||||
unk_3,
|
||||
unk_4,
|
||||
};
|
||||
|
||||
class scrThreadContext
|
||||
{
|
||||
public:
|
||||
std::uint32_t m_thread_id; // 0x00
|
||||
joaat_t m_script_hash; // 0x04
|
||||
eThreadState m_state; // 0x08
|
||||
std::uint32_t m_instruction_pointer;// 0x0C
|
||||
std::uint32_t m_frame_pointer; // 0x10
|
||||
std::uint32_t m_stack_pointer; // 0x14
|
||||
float m_timer_a; // 0x18
|
||||
float m_timer_b; // 0x1C
|
||||
float m_timer_c; // 0x20
|
||||
char m_padding1[0x2C]; // 0x24
|
||||
std::uint32_t m_stack_size; // 0x50
|
||||
char m_padding2[0x54]; // 0x54
|
||||
};
|
||||
static_assert(sizeof(scrThreadContext) == 0xA8);
|
||||
|
||||
class scrThread
|
||||
{
|
||||
public:
|
||||
virtual ~scrThread() = default;// 0 (0x00)
|
||||
virtual void reset(std::uint32_t script_hash, void* args, std::uint32_t arg_count) = 0; // 1 (0x08)
|
||||
virtual eThreadState run() = 0; // 2 (0x10)
|
||||
virtual eThreadState tick(std::uint32_t ops_to_execute) = 0; // 3 (0x18)
|
||||
virtual void kill() = 0; // 4 (0x20)
|
||||
|
||||
inline static scrThread* get()
|
||||
{
|
||||
return rage::tlsContext::get()->m_script_thread;
|
||||
}
|
||||
|
||||
public:
|
||||
scrThreadContext m_context; // 0x08
|
||||
void* m_stack; // 0xB0
|
||||
char m_padding[0x4]; // 0xB8
|
||||
uint32_t m_arg_size; // 0xBC
|
||||
uint32_t m_arg_loc; // 0xC0
|
||||
char m_padding2[0x4]; // 0xC4
|
||||
const char* m_exit_message; // 0xC8
|
||||
std::uint32_t m_name_hash; // 0xCC
|
||||
char m_name[0x40]; // 0xD4
|
||||
scriptHandler* m_handler; // 0x114
|
||||
CGameScriptHandlerNetComponent* m_net_component;// 0x11C
|
||||
};
|
||||
}
|
||||
|
||||
class GtaThread : public rage::scrThread
|
||||
{
|
||||
public:
|
||||
|
@ -1,23 +0,0 @@
|
||||
#pragma once
|
||||
#include "fwddec.hpp"
|
||||
|
||||
#include <intrin.h>
|
||||
|
||||
namespace rage
|
||||
{
|
||||
class tlsContext
|
||||
{
|
||||
public:
|
||||
char m_padding1[0xB8]; // 0x00
|
||||
sysMemAllocator* m_allocator; // 0xB8
|
||||
char m_padding2[0x788]; // 0xD0
|
||||
scrThread* m_script_thread; // 0x848
|
||||
bool m_is_script_thread_active;// 0x850
|
||||
|
||||
static tlsContext* get()
|
||||
{
|
||||
return *reinterpret_cast<tlsContext**>(__readgsqword(0x58));
|
||||
}
|
||||
};
|
||||
static_assert(sizeof(tlsContext) == 0x858);
|
||||
}
|
@ -21,6 +21,7 @@ enum WeaponGroup : Hash
|
||||
GROUP_PISTOL = RAGE_JOAAT("GROUP_PISTOL"),
|
||||
GROUP_RIFLE = RAGE_JOAAT("GROUP_RIFLE"),
|
||||
GROUP_MG = RAGE_JOAAT("GROUP_MG"),
|
||||
GROUP_SMG = RAGE_JOAAT("GROUP_SMG"),
|
||||
GROUP_SHOTGUN = RAGE_JOAAT("GROUP_SHOTGUN"),
|
||||
GROUP_STUNGUN = RAGE_JOAAT("GROUP_STUNGUN"),
|
||||
GROUP_SNIPER = RAGE_JOAAT("GROUP_SNIPER"),
|
||||
|
@ -9,6 +9,8 @@ class ChatData;
|
||||
class ScInfo;
|
||||
class GenericPool;
|
||||
class VehiclePool;
|
||||
class CVehicleSeatMetadataMgr;
|
||||
class CVehicleDriveByMetadataMgr;
|
||||
|
||||
namespace rage
|
||||
{
|
||||
@ -274,6 +276,9 @@ namespace big
|
||||
PVOID m_send_non_physical_player_data;
|
||||
|
||||
void** m_presence_data{};
|
||||
|
||||
CVehicleSeatMetadataMgr* m_vehicle_layout_metadata_mgr{};
|
||||
CVehicleDriveByMetadataMgr* m_driveby_metadata_mgr{};
|
||||
};
|
||||
#pragma pack(pop)
|
||||
static_assert(sizeof(gta_pointers) % 8 == 0, "Pointers are not properly aligned");
|
||||
|
@ -1,6 +1,6 @@
|
||||
#pragma once
|
||||
#include "gta/script_thread.hpp"
|
||||
#include "gta/tls_context.hpp"
|
||||
#include "script/tlsContext.hpp"
|
||||
#include "pointers.hpp"
|
||||
|
||||
#include <network/CNetworkPlayerMgr.hpp>
|
||||
|
@ -108,8 +108,6 @@ namespace big
|
||||
|
||||
detour_hook_helper::add<hooks::write_vehicle_proximity_migration_data_node>("WVPMDN", g_pointers->m_gta.m_write_vehicle_proximity_migration_data_node);
|
||||
|
||||
detour_hook_helper::add<hooks::allow_weapons_in_vehicle>("AWIV", g_pointers->m_gta.m_allow_weapons_in_vehicle);
|
||||
|
||||
detour_hook_helper::add<hooks::netfilter_handle_message>("NHM", g_pointers->m_gta.m_netfilter_handle_message);
|
||||
|
||||
detour_hook_helper::add<hooks::log_error_message_box>("E0MBH", g_pointers->m_gta.m_error_message_box);
|
||||
|
@ -148,7 +148,6 @@ namespace big
|
||||
|
||||
static void write_vehicle_proximity_migration_data_node(rage::netObject* veh, CVehicleProximityMigrationDataNode* node);
|
||||
|
||||
static bool allow_weapons_in_vehicle(int64_t unk, int weaponinfo_group);
|
||||
static int netfilter_handle_message(__int64 filter, char* message, int flags);
|
||||
|
||||
static void log_error_message_box(rage::joaat_t joaated_error_code, char a2);
|
||||
|
@ -1,16 +0,0 @@
|
||||
#include "hooking.hpp"
|
||||
#include "gta/weapons.hpp"
|
||||
|
||||
namespace big
|
||||
{
|
||||
bool hooks::allow_weapons_in_vehicle(int64_t unk, int weaponinfo_group)
|
||||
{
|
||||
if (g.vehicle.unlimited_weapons)
|
||||
{
|
||||
if (weaponinfo_group == GROUP_THROWN) // Because the thrower can be used without bypassing, we let the game decide the return value, since this function has multiple xrefs, it may be necessary to return 0 at some point
|
||||
return g_hooking->get_original<allow_weapons_in_vehicle>()(unk, weaponinfo_group);
|
||||
return true;
|
||||
}
|
||||
return g_hooking->get_original<allow_weapons_in_vehicle>()(unk, weaponinfo_group);
|
||||
}
|
||||
}
|
@ -3,7 +3,7 @@
|
||||
#include "backend/player_command.hpp"
|
||||
#include "core/data/packet_types.hpp"
|
||||
#include "gta/net_game_event.hpp"
|
||||
#include "gta/script_id.hpp"
|
||||
#include "script/scriptIdBase.hpp"
|
||||
#include "gta_util.hpp"
|
||||
#include "hooking.hpp"
|
||||
#include "lua/lua_manager.hpp"
|
||||
|
@ -22,7 +22,7 @@ namespace big
|
||||
{
|
||||
old_beast_index = *script_local(beast->m_stack, scr_locals::am_hunt_the_beast::broadcast_idx).at(1).at(6).as<int*>();
|
||||
if (beast->m_net_component)
|
||||
participant_id = beast->m_net_component->m_local_participant_index;
|
||||
participant_id = ((CGameScriptHandlerNetComponent*)beast->m_net_component)->m_local_participant_index;
|
||||
}
|
||||
|
||||
bool result = g_hooking->get_original<hooks::received_array_update>()(array, sender, buffer, size, cycle);
|
||||
|
@ -1,7 +1,7 @@
|
||||
#include "fiber_pool.hpp"
|
||||
#include "gta/enums.hpp"
|
||||
#include "gta/net_game_event.hpp"
|
||||
#include "gta/script_id.hpp"
|
||||
#include "script/scriptIdBase.hpp"
|
||||
#include "hooking.hpp"
|
||||
#include "util/math.hpp"
|
||||
#include "util/notify.hpp"
|
||||
|
@ -383,7 +383,7 @@ namespace big
|
||||
{
|
||||
if (auto script = gta_util::find_script_thread(RAGE_JOAAT("freemode")))
|
||||
{
|
||||
if (script->m_net_component && script->m_net_component->m_host && script->m_net_component->m_host->m_net_game_player != player)
|
||||
if (script->m_net_component && ((CGameScriptHandlerNetComponent*)script->m_net_component)->m_host && ((CGameScriptHandlerNetComponent*)script->m_net_component)->m_host->m_net_game_player != player)
|
||||
{
|
||||
g.reactions.trigger_business_raid.process(plyr);
|
||||
}
|
||||
@ -396,7 +396,7 @@ namespace big
|
||||
// TODO: Breaks stuff
|
||||
if (auto script = gta_util::find_script_thread(RAGE_JOAAT("freemode")))
|
||||
{
|
||||
if (script->m_net_component && script->m_net_component->m_host && script->m_net_component->m_host->m_net_game_player != player)
|
||||
if (script->m_net_component && ((CGameScriptHandlerNetComponent*)script->m_net_component)->m_host && ((CGameScriptHandlerNetComponent*)script->m_net_component)->m_host->m_net_game_player != player)
|
||||
{
|
||||
g.reactions.start_script.process(plyr);
|
||||
return true;
|
||||
|
@ -58,7 +58,7 @@ namespace big
|
||||
.as<int*>();
|
||||
|
||||
*script_local(g.m_hunt_the_beast_thread->m_stack, scr_locals::am_hunt_the_beast::broadcast_idx).at(1).at(6).as<int*>() =
|
||||
g.m_hunt_the_beast_thread->m_net_component->get_participant_index(target);// participant idx
|
||||
((CGameScriptHandlerNetComponent*)g.m_hunt_the_beast_thread->m_net_component)->get_participant_index(target);// participant idx
|
||||
*script_local(g.m_hunt_the_beast_thread->m_stack, scr_locals::am_hunt_the_beast::broadcast_idx).at(1).at(7).as<Player*>() =
|
||||
target->m_player_id;// beast player idx
|
||||
*script_local(g.m_hunt_the_beast_thread->m_stack, scr_locals::am_hunt_the_beast::broadcast_idx).at(1).at(2).as<int*>() = INT_MAX;// stopwatch time
|
||||
|
@ -150,7 +150,7 @@ namespace big
|
||||
|
||||
void stack_trace::dump_script_info()
|
||||
{
|
||||
m_dump << "Currently executing script: " << rage::scrThread::get()->m_name << '\n';
|
||||
m_dump << "Currently executing script: " << rage::tlsContext::get()->m_script_thread->m_name << '\n';
|
||||
m_dump << "Thread program counter (could be inaccurate): "
|
||||
<< m_exception_info->ContextRecord->Rdi - m_exception_info->ContextRecord->Rsi << '\n';
|
||||
}
|
||||
|
@ -77,7 +77,7 @@ namespace big
|
||||
g_fiber_pool->queue_job([hash] {
|
||||
scripts::force_host(hash);
|
||||
if (auto script = gta_util::find_script_thread(hash); script && script->m_net_component)
|
||||
script->m_net_component->block_host_migration(true);
|
||||
((CGameScriptHandlerNetComponent*)script->m_net_component)->block_host_migration(true);
|
||||
});
|
||||
}
|
||||
|
||||
|
@ -1371,6 +1371,17 @@ namespace big
|
||||
{
|
||||
g_pointers->m_gta.m_get_title_caption_error_message_box = ptr.add(1).rip().as<functions::get_title_caption_error_message_box>();
|
||||
}
|
||||
},
|
||||
// Vehicle Metadata Manager.
|
||||
{
|
||||
"VEHMMGR",
|
||||
"7C B8 48 8B 0D",
|
||||
[](memory::handle ptr)
|
||||
{
|
||||
ptr = ptr.add(5).rip();
|
||||
g_pointers->m_gta.m_driveby_metadata_mgr = ptr.as<CVehicleDriveByMetadataMgr*>();
|
||||
g_pointers->m_gta.m_vehicle_layout_metadata_mgr = ptr.add(0x20).as<CVehicleSeatMetadataMgr*>();
|
||||
}
|
||||
}
|
||||
>(); // don't leave a trailing comma at the end
|
||||
|
||||
|
@ -106,10 +106,10 @@ namespace big
|
||||
populate_ip();
|
||||
|
||||
rage::scrThread* thread = (rage::scrThread*)new uint8_t[sizeof(rage::scrThread)];
|
||||
memcpy(thread, rage::scrThread::get(), sizeof(rage::scrThread));
|
||||
memcpy(thread, rage::tlsContext::get()->m_script_thread, sizeof(rage::scrThread));
|
||||
|
||||
void* stack = new uint64_t[25000];
|
||||
thread->m_stack = stack;
|
||||
thread->m_stack = (rage::scrValue*)stack;
|
||||
thread->m_context.m_stack_size = 25000;
|
||||
thread->m_context.m_stack_pointer = 1;
|
||||
|
||||
|
@ -2,7 +2,7 @@
|
||||
|
||||
#include "common.hpp"
|
||||
#include "gta/script_thread.hpp"
|
||||
#include "gta/tls_context.hpp"
|
||||
#include "script/tlsContext.hpp"
|
||||
#include "gta_util.hpp"
|
||||
#include "invoker.hpp"
|
||||
#include "pointers.hpp"
|
||||
|
@ -2,7 +2,7 @@
|
||||
|
||||
#include "gta/joaat.hpp"
|
||||
#include "gta/sysMemAllocator.hpp"
|
||||
#include "gta/tls_context.hpp"
|
||||
#include "script/tlsContext.hpp"
|
||||
#include "natives.hpp"
|
||||
#include "pointers.hpp"
|
||||
#include "script.hpp"
|
||||
|
@ -167,7 +167,7 @@ namespace big
|
||||
{
|
||||
if (m_thread && m_thread->m_net_component)
|
||||
{
|
||||
for (int i = 0; !m_thread->m_net_component->is_local_player_host(); i++)
|
||||
for (int i = 0; !((CGameScriptHandlerNetComponent*)m_thread->m_net_component)->is_local_player_host(); i++)
|
||||
{
|
||||
if (i > 200)
|
||||
return false;
|
||||
@ -180,7 +180,7 @@ namespace big
|
||||
return false;
|
||||
}
|
||||
|
||||
m_thread->m_net_component->block_host_migration(true);
|
||||
((CGameScriptHandlerNetComponent*)m_thread->m_net_component)->block_host_migration(true);
|
||||
}
|
||||
|
||||
return true;
|
||||
|
@ -62,7 +62,7 @@ namespace big::scripts
|
||||
{
|
||||
if (auto launcher = gta_util::find_script_thread(hash); launcher && launcher->m_net_component)
|
||||
{
|
||||
for (int i = 0; !launcher->m_net_component->is_local_player_host(); i++)
|
||||
for (int i = 0; !((CGameScriptHandlerNetComponent*)launcher->m_net_component)->is_local_player_host(); i++)
|
||||
{
|
||||
if (i > 200)
|
||||
return false;
|
||||
@ -100,7 +100,7 @@ namespace big::scripts
|
||||
|
||||
for (auto& [_, plyr] : g_player_service->players())
|
||||
{
|
||||
if (launcher->m_net_component->is_player_a_participant(plyr->get_net_game_player()))
|
||||
if (((CGameScriptHandlerNetComponent*)launcher->m_net_component)->is_player_a_participant(plyr->get_net_game_player()))
|
||||
{
|
||||
if (*script_local(launcher->m_stack, 233).at(plyr->id(), 3).at(2).as<int*>() == state)
|
||||
{
|
||||
|
@ -24,7 +24,7 @@ namespace big
|
||||
components::button("Win Event", [] {
|
||||
if (auto checkpoints = gta_util::find_script_thread(RAGE_JOAAT("am_cp_collection")))
|
||||
*script_local(checkpoints->m_stack, scr_locals::am_cp_collection::player_broadcast_idx)
|
||||
.at(checkpoints->m_net_component->m_local_participant_index, 5)
|
||||
.at(((CGameScriptHandlerNetComponent*)checkpoints->m_net_component)->m_local_participant_index, 5)
|
||||
.at(4)
|
||||
.as<int*>() = 999'999'999;
|
||||
|
||||
|
@ -290,11 +290,11 @@ namespace big
|
||||
g_fiber_pool->queue_job([] {
|
||||
scripts::force_host(RAGE_JOAAT("freemode"));
|
||||
if (auto script = gta_util::find_script_thread(RAGE_JOAAT("freemode")); script && script->m_net_component)
|
||||
script->m_net_component->block_host_migration(true);
|
||||
((CGameScriptHandlerNetComponent*)script->m_net_component)->block_host_migration(true);
|
||||
|
||||
scripts::force_host(RAGE_JOAAT("fmmc_launcher"));
|
||||
if (auto script = gta_util::find_script_thread(RAGE_JOAAT("fmmc_launcher")); script && script->m_net_component)
|
||||
script->m_net_component->block_host_migration(true);
|
||||
((CGameScriptHandlerNetComponent*)script->m_net_component)->block_host_migration(true);
|
||||
});
|
||||
}
|
||||
if (ImGui::IsItemHovered())
|
||||
|
Reference in New Issue
Block a user