summaryrefslogtreecommitdiff
path: root/cheat/gmod/in_prediction.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'cheat/gmod/in_prediction.cpp')
-rw-r--r--cheat/gmod/in_prediction.cpp32
1 files changed, 32 insertions, 0 deletions
diff --git a/cheat/gmod/in_prediction.cpp b/cheat/gmod/in_prediction.cpp
new file mode 100644
index 0000000..cb5a7bf
--- /dev/null
+++ b/cheat/gmod/in_prediction.cpp
@@ -0,0 +1,32 @@
+#include "mem.hpp"
+#include "hooks.hpp"
+#include "context.hpp"
+
+#undef max
+
+bool __fastcall hooks::in_prediction( void* ecx_, void* edx_ ) {
+ static auto in_prediction_o = g_csgo.m_prediction->get_old_function< decltype( &hooks::in_prediction ) >( 14 );
+ static auto ret_address = pattern::first_code_match( g_csgo.m_chl.dll( ),
+ xors( "84 C0 75 08 57 8B CE E8 ? ? ? ? 8B 06" ) );
+
+ if( g_ctx.m_local && ret_address && g_settings.rage.enabled && g_settings.rage.resolver ) {
+ stack_t stack( get_baseptr( ) );
+ int local_team = g_ctx.m_local->m_iTeamNum( );
+
+ if( stack.return_address( ) == ret_address ) {
+ for( size_t i{ }; i < 65; ++i ) {
+ auto ent = g_csgo.m_entlist( )->GetClientEntity< >( i );
+
+ if( !ent || !ent->is_valid( ) || ent == g_ctx.m_local )
+ continue;
+
+ if( ent->m_iTeamNum( ) != local_team || g_settings.rage.friendlies ) {
+ ent->m_flLastBoneSetupTime( ) = std::numeric_limits< float >::quiet_NaN( );
+ ent->m_iMostRecentModelBoneCounter( ) -= 1;
+ }
+ }
+ }
+ }
+
+ return in_prediction_o( ecx_, 0 );
+} \ No newline at end of file