Исходник 2018 game autowall (sup paste ready)

Начинающий
Статус
Оффлайн
Регистрация
5 Авг 2023
Сообщения
61
Реакции[?]
15
Поинты[?]
15K
seen too many people use bad/broken ones or gatekeep this
go on pasters feed on this (i see you retards like apache and cale, fuck off from this community you do nothing but make it worse)

C++:
CS_MASK_SHOOT               = MASK_SOLID | CONTENTS_DEBRIS
C++:
#include "includes.h"

#define MAX( a, b )         ( a > b ? a : b )
#define MIN( a, b )         ( a < b ? a : b )

static ConVar* ff_damage_reduction_bullets;
static ConVar* ff_damage_bullet_penetration;
static ConVar* mp_damage_scale_ct_head;
static ConVar* mp_damage_scale_ct_body;
static ConVar* mp_damage_scale_t_head;
static ConVar* mp_damage_scale_t_body;

inline float DistanceToRay( const vec3_t& pos, const vec3_t& rayStart, const vec3_t& rayEnd, float* along = NULL, vec3_t* pointOnRay = NULL ) {

    vec3_t to = pos - rayStart;
    vec3_t dir = rayEnd - rayStart;
    float length = dir.normalize( );
    float rangeAlong = dir.dot( to );

    if( along )
        *along = rangeAlong;

    float range;

    if( rangeAlong < 0.0f ) {
        range = -( pos - rayStart ).length( );

        if( pointOnRay )
            *pointOnRay = rayStart;
    }
    else if( rangeAlong > length ) {
        range = -( pos - rayEnd ).length( );

        if ( pointOnRay )
            *pointOnRay = rayEnd;
    }
    else {
        vec3_t onRay = rayStart + rangeAlong * dir;
        range = ( pos - onRay ).length( );

        if( pointOnRay )
            *pointOnRay = onRay;
    }

    return range;
}

void UTIL_ClipTraceToPlayers( const vec3_t& vecAbsStart, const vec3_t& vecAbsEnd, unsigned int mask, ITraceFilter *filter, CGameTrace *tr, Player* pVictim = nullptr ) {

    CGameTrace playerTrace;
    Ray ray( vecAbsStart, vecAbsEnd );
    float smallestFraction = tr->m_fraction;
    const float maxRange = 60.0f;

    for ( int i = 1; i <= g_csgo.m_globals->m_max_clients; ++i )
    {
        Player *player = g_csgo.m_entlist->GetClientEntity< Player* >( i );

        if ( !player || !player->alive( ) )
            continue;

        if ( player->dormant( ) )
            continue;

        if( pVictim && pVictim->index( ) != i )
            continue;

        if ( filter && filter->ShouldHitEntity( player, mask ) == false )
            continue;

        float range = DistanceToRay( player->WorldSpaceCenter( ), vecAbsStart, vecAbsEnd );
        if ( range < 0.0f || range > maxRange )
            continue;

        g_csgo.m_engine_trace->ClipRayToEntity( ray, mask | CONTENTS_HITBOX, player, &playerTrace );
        if ( playerTrace.m_fraction < smallestFraction ) {
            *tr = playerTrace;
            smallestFraction = playerTrace.m_fraction;
        }
    }
}

inline void UTIL_TraceLineIgnoreTwoEntities( const vec3_t & vecAbsStart, const vec3_t& vecAbsEnd, unsigned int mask, const Entity *ignore, const Entity *ignore2, int collisionGroup, CGameTrace *ptr )
{
    CTraceFilterSkipTwoEntities traceFilter( ignore, ignore2, collisionGroup );
    g_csgo.m_engine_trace->TraceRay( Ray( vecAbsStart, vecAbsEnd ), mask, &traceFilter, ptr );
}

inline void UTIL_TraceLine( const vec3_t& vecAbsStart, const vec3_t& vecAbsEnd, unsigned int mask, const Entity *ignore, int collisionGroup, CGameTrace *ptr )
{
    CTraceFilterSimple traceFilter( ignore, collisionGroup );
    g_csgo.m_engine_trace->TraceRay( Ray( vecAbsStart, vecAbsEnd ), mask, &traceFilter, ptr );
}

inline void UTIL_TraceLine( const vec3_t& vecAbsStart, const vec3_t& vecAbsEnd, unsigned int mask, CTraceFilter *pFilter, CGameTrace *ptr )
{
    g_csgo.m_engine_trace->TraceRay( Ray( vecAbsStart, vecAbsEnd ), mask, pFilter, ptr);
}

static bool TraceToExit( vec3_t start, vec3_t dir, vec3_t &end, CGameTrace &trEnter, CGameTrace &trExit, float flStepSize, float flMaxDistance )
{
    float flDistance = 0;
    vec3_t last = start;
    int nStartContents = 0;

    while ( flDistance <= flMaxDistance )
    {
        flDistance += flStepSize;

        end = start + ( flDistance * dir );

        vec3_t vecTrEnd = end - ( flStepSize * dir );
        int nCurrentContents = g_csgo.m_engine_trace->GetPointContents_WorldOnly( end, CS_MASK_SHOOT | CONTENTS_HITBOX );

        if ( nStartContents == 0 )
            nStartContents = nCurrentContents;

        if ( ( nCurrentContents & CS_MASK_SHOOT ) == 0 || ( ( nCurrentContents & CONTENTS_HITBOX ) && nStartContents != nCurrentContents ) )
        {
            // this gets a bit more complicated and expensive when we have to deal with displacements
            UTIL_TraceLine( end, vecTrEnd, CS_MASK_SHOOT|CONTENTS_HITBOX, NULL, &trExit );

            // we exited the wall into a player's hitbox
            if ( trExit.m_startsolid == true && ( trExit.m_surface.m_flags & SURF_HITBOX ) )
            {
                // do another trace, but skip the player to get the actual exit surface
                UTIL_TraceLine( end, start, CS_MASK_SHOOT, trExit.m_entity, COLLISION_GROUP_NONE, &trExit );
                if ( trExit.hit( ) && trExit.m_startsolid == false )
                {
                    end = trExit.m_endpos;
                    return true;
                }
            }
            else if ( trExit.hit() && trExit.m_startsolid == false )
            {
                bool bStartIsNodraw = !!( trEnter.m_surface.m_flags & SURF_NODRAW );
                bool bExitIsNodraw = !!( trExit.m_surface.m_flags & SURF_NODRAW );
                if ( bExitIsNodraw && game::IsBreakable( trExit.m_entity ) && game::IsBreakable( trEnter.m_entity ) )
                {
                    // we have a case where we have a breakable object, but the mapper put a nodraw on the backside
                    end = trExit.m_endpos;
                    return true;
                }
                else if ( bExitIsNodraw == false || ( bStartIsNodraw && bExitIsNodraw ) ) // exit nodraw is only valid if our entrace is also nodraw
                {
                    vec3_t vecNormal = trExit.m_plane.m_normal;
                    float flDot = dir.dot( vecNormal );
                    if ( flDot <= 1.0f )
                    {
                        // get the real end pos
                        end = end - ( ( flStepSize * trExit.m_fraction ) * dir );
                        return true;
                    }
                }
            }
            else if ( trEnter.m_entity
                && trEnter.m_entity != g_csgo.m_entlist->GetClientEntity( 0 )
                && game::IsBreakable( trEnter.m_entity ) )
            {
                // if we hit a breakable, make the assumption that we broke it if we can't find an exit (hopefully..)
                // fake the end pos
                trExit = trEnter;
                trExit.m_endpos = start + ( 1.0f * dir );
                return true;
            }
        }
    }

    return false;
}

bool Player::IsArmored( int nHitGroup )
{
    bool bApplyArmor = false;

    if ( m_ArmorValue( ) > 0 )
    {
        switch ( nHitGroup )
        {
        case HITGROUP_GENERIC:
        case HITGROUP_CHEST:
        case HITGROUP_STOMACH:
        case HITGROUP_LEFTARM:
        case HITGROUP_RIGHTARM:
            bApplyArmor = true;
            break;
        case HITGROUP_HEAD:
            if ( m_bHasHelmet( ) )
            {
                bApplyArmor = true;
            }
            break;
        default:
            break;
        }
    }

    return bApplyArmor;
}

float Player::ScaleDamage( float flWpnArmorRatio, int group, float fDamage ) {
    float flArmorBonus = 0.5f;
    float fDamageToHealth = fDamage;
    float fDamageToArmor = 0;
    float fHeavyArmorBonus = 1.0f;
    float flArmorRatio = 0.5f;
    flArmorRatio *= flWpnArmorRatio;

    if( !mp_damage_scale_ct_body )
        mp_damage_scale_ct_body = g_csgo.m_cvar->FindVar( HASH( "mp_damage_scale_ct_body" ) );

    if( !mp_damage_scale_ct_head )
        mp_damage_scale_ct_head = g_csgo.m_cvar->FindVar( HASH( "mp_damage_scale_ct_head" ) );

    if( !mp_damage_scale_t_body )
        mp_damage_scale_t_body = g_csgo.m_cvar->FindVar( HASH( "mp_damage_scale_t_body" ) );

    if( !mp_damage_scale_t_head )
        mp_damage_scale_t_head = g_csgo.m_cvar->FindVar( HASH( "mp_damage_scale_t_head" ) );

    float flBodyDamageScale = ( m_iTeamNum( ) == TEAM_COUNTERTERRORISTS ) ? mp_damage_scale_ct_body->GetFloat( ) : mp_damage_scale_t_body->GetFloat( );
    float flHeadDamageScale = ( m_iTeamNum( ) == TEAM_COUNTERTERRORISTS ) ? mp_damage_scale_ct_head->GetFloat( ) : mp_damage_scale_t_head->GetFloat( );

    if ( m_bHasHeavyArmor( ) ) {
        flArmorRatio *= 0.5f;
        flArmorBonus = 0.33f;
        fHeavyArmorBonus = 0.33f;

        // heavy armor reduces headshot damage by have of what it is, so it does x2 instead of x4
        flHeadDamageScale = flHeadDamageScale * 0.5f;
    }

    switch( group ) {
    case HITGROUP_GENERIC:
        break;

    case HITGROUP_HEAD:
        fDamage *= 4.f;
        fDamage *= flHeadDamageScale;
        break;

    case HITGROUP_CHEST:
        fDamage *= 1.f;
        fDamage *= flBodyDamageScale;
        break;

    case HITGROUP_STOMACH:
        fDamage *= 1.25f;
        fDamage *= flBodyDamageScale;
        break;

    case HITGROUP_LEFTARM:
    case HITGROUP_RIGHTARM:
        fDamage *= 1.0f;
        fDamage *= flBodyDamageScale;
        break;

    case HITGROUP_LEFTLEG:
    case HITGROUP_RIGHTLEG:
        fDamage *= 0.75f;
        fDamage *= flBodyDamageScale;
        break;

    default:
        break;
    }

    // deal with Armour
    if( m_ArmorValue( ) > 0.f && IsArmored( group ) ) {
        fDamageToHealth = fDamage * flArmorRatio;
        fDamageToArmor = ( fDamage - fDamageToHealth ) * ( flArmorBonus * fHeavyArmorBonus );

        int armorValue = m_ArmorValue( );

        // Does this use more armor than we have?
        if( fDamageToArmor > armorValue )
            fDamageToHealth = fDamage - armorValue / flArmorBonus;

        return fDamageToHealth;
    }

    return fDamage;
}

bool penetration::run( PenetrationInput_t* in, PenetrationOutput_t* out ) {
    int              iPenCount{ 4 };
    vec3_t          vecStart, dir, end, pen_end;
    ang_t          angAimDir;
    CGameTrace      trace, exit_trace;
    Weapon          *weapon;
    WeaponInfo    *weapon_info;

    // if we are tracing from our local player perspective.
    if( in->m_from->m_bIsLocalPlayer( ) ) {
        weapon      = g_cl.m_weapon;
        weapon_info = g_cl.m_weapon_info;
        vecStart    = g_cl.m_shoot_pos;
    }

    // not local player.
    else {
        weapon = in->m_from->GetActiveWeapon( );
        if( !weapon )
            return false;

        // get weapon info.
        weapon_info = weapon->GetWpnData( );
        if( !weapon_info )
            return false;

        // set trace start.
        vecStart = in->m_from->GetShootPosition( );
    }

    // calculate aim dir.
    math::VectorAngles( in->m_pos - g_cl.m_shoot_pos, angAimDir );

    // weapon damage.
    int iDamage            = weapon_info->m_damage;

    // get damage and hitgroup for our shot.
    const int iHitgroup = in->m_from->FireBullet( vecStart,
        angAimDir,
        weapon_info->m_armor_ratio,
        weapon_info->m_range,
        weapon_info->m_penetration,
        iPenCount,
        iDamage,
        weapon_info->m_range_modifier,
        in->m_target );

    // we need to get a damage trace
    if( in->m_target ) {
        if( iHitgroup > HITGROUP_GENERIC ) {

            out->m_damage   = iDamage;
            out->m_hitgroup = iHitgroup;
            out->m_pen        = iPenCount;

            if( iDamage > in->m_target->m_iHealth( ) )
                return true;

            if( iPenCount != 4 )
                return ( iDamage >= in->m_damage_pen );

            return ( iDamage >= in->m_damage );
        }

        out->m_damage = -1.f;
        out->m_hitgroup = -1;
        out->m_pen = iPenCount;
        return false;
    }

    out->m_damage = iDamage;
    out->m_hitgroup = iHitgroup ;
    out->m_pen = iPenCount;
    return ( iDamage > 0.f );
}

int Player::FireBullet(
    vec3_t vecSrc,    // shooting postion
    const ang_t &shootAngles,  //shooting angle
    float flArmorRatio, // ratio for armor
    float flDistance, // max distance
    float flPenetration, // the power of the penetration
    int& nPenetrationCount,
    int& iDamage, // base damage
    float flRangeModifier, // damage range modifier
    Player* pVictim ) {

    // Check for player hitboxes extending outside their collision bounds
    const float rayExtension = 40.0f;
    float fCurrentDamage = iDamage;   // damage of the bullet at it's current trajectory
    float flCurrentDistance = 0.0;  //distance that the bullet has traveled so far
  
    vec3_t vecDirShooting, vecRight, vecUp;
    math::AngleVectors( shootAngles, &vecDirShooting, &vecRight, &vecUp );

    // MIKETODO: put all the ammo parameters into a script file and allow for CS-specific params.
    float flPenetrationPower = flPenetration;         // thickness of a wall that this bullet can penetrate
    float flPenetrationDistance = 3000.f;    // distance at which the bullet is capable of penetrating a wall
    float flDamageModifier = 0.5f;        // default modification of bullets power after they go through a wall.
    float flPenetrationModifier = 1.0f;

    vec3_t vecDir = vecDirShooting;
    vecDir.normalize( );

    int iHitgroup = -1;
    Player* lastPlayerHit = NULL;    // this includes players, bots, and hostages

    while( fCurrentDamage > 0.f ) {
        vec3_t vecEnd = vecSrc + vecDir * ( flDistance - flCurrentDistance );
        CGameTrace tr; // main enter bullet trace

        UTIL_TraceLineIgnoreTwoEntities( vecSrc, vecEnd, CS_MASK_SHOOT|CONTENTS_HITBOX, this, lastPlayerHit, COLLISION_GROUP_NONE, &tr );
        {
            CTraceFilterSkipTwoEntities filter( this, lastPlayerHit, COLLISION_GROUP_NONE );
            UTIL_ClipTraceToPlayers( vecSrc, vecEnd + vecDir * rayExtension, CS_MASK_SHOOT|CONTENTS_HITBOX, &filter, &tr, pVictim );
        }

        if ( tr.m_fraction == 1.0f )
            break; // we didn't hit anything, stop tracing shoot

        /************* MATERIAL DETECTION ***********/
        surfacedata_t *pSurfaceData = g_csgo.m_phys_props->GetSurfaceData( tr.m_surface.m_surface_props );
        int iEnterMaterial = pSurfaceData->m_game.m_material;

        flPenetrationModifier = pSurfaceData->m_game.m_penetration_modifier;
        flDamageModifier = pSurfaceData->m_game.m_damage_modifier;

        bool hitGrate = ( tr.m_contents & CONTENTS_GRATE ) != 0;

        //calculate the damage based on the distance the bullet travelled.
        flCurrentDistance += tr.m_fraction * ( flDistance - flCurrentDistance );
        fCurrentDamage *= pow( flRangeModifier, ( flCurrentDistance / 500.f ) );

        // check if we hit player
        if( tr.m_hitgroup > HITGROUP_GENERIC
            && tr.m_hitgroup < HITGROUP_GEAR
            && tr.m_entity
            && tr.m_entity->index( ) > 0
            && tr.m_entity->index( ) <= 64 ) {
            // NOTE: inaccurate if there's players inside of each other
            if( !pVictim || tr.m_entity->index( ) == pVictim->index( ) ) {
                if( ( ( Player* )tr.m_entity )->enemy( this ) ) {
                    lastPlayerHit = ( Player* )tr.m_entity;
                    iHitgroup      = tr.m_hitgroup;
                    break;
                }
            }
        }

        // check if we reach penetration distance, no more penetrations after that
        // or if our modifyer is super low, just stop the bullet
        if ( ( flCurrentDistance > flPenetrationDistance && flPenetration > 0.f ) ||
            flPenetrationModifier < 0.1f ) {
            // Setting nPenetrationCount to zero prevents the bullet from penetrating object at max distance
            // and will no longer trace beyond the exit point, however "numPenetrationsInitiallyAllowedForThisBullet"
            // is saved off to allow correct determination whether the hit on the object at max distance had
            // *previously* penetrated anything or not. In case of a direct hit over 3000 units the saved off
            // value would be max penetrations value and will determine a direct hit and not a penetration hit.
            // However it is important that all tracing further stops past this point (as the code does at
            // the time of writing) because otherwise next trace will think that 4 penetrations have already
            // occurred.
            nPenetrationCount = 0;
        }

        // [dkorus] note: values are changed inside of HandleBulletPenetration
        bool bulletStopped = HandleBulletPenetration( flPenetration, iEnterMaterial, hitGrate, tr, vecDir, pSurfaceData, flPenetrationModifier,
            flDamageModifier, flPenetrationPower, nPenetrationCount, vecSrc, flDistance,
            flCurrentDistance, fCurrentDamage );

        // [dkorus] bulletStopped is true if the bullet can no longer continue penetrating materials
        if ( bulletStopped )
            break;
    }

    // hit a player.
    if( lastPlayerHit != NULL ) {
  
        // report damage and hitgroup.
        iDamage = lastPlayerHit->ScaleDamage( flArmorRatio, iHitgroup, fCurrentDamage );
        return iHitgroup;
    }

    // we hit nothing or our bullet got stopped.
    return -1;
}

// [dkorus] helper for FireBullet
//            changes iPenetration to updated value
//            returns TRUE if we should stop processing more hits after this one
//            returns FALSE if we can continue processing
bool Player::HandleBulletPenetration( float &flPenetration,
                                         int &iEnterMaterial,
                                         bool &hitGrate,
                                         CGameTrace &tr,
                                         vec3_t &vecDir,
                                         surfacedata_t *pSurfaceData,
                                         float flPenetrationModifier,
                                         float flDamageModifier,
                                         float flPenetrationPower,
                                         int &nPenetrationCount,
                                         vec3_t &vecSrc,
                                         float flDistance,
                                         float flCurrentDistance,
                                         float &fCurrentDamage )
{


    // NOTE: not thread-safe
#ifndef THREADING
    if( !ff_damage_reduction_bullets )
        ff_damage_reduction_bullets = g_csgo.m_cvar->FindVar( HASH( "ff_damage_reduction_bullets" ) );

    if( !ff_damage_bullet_penetration )
        ff_damage_bullet_penetration = g_csgo.m_cvar->FindVar( HASH( "ff_damage_bullet_penetration" ) );
#endif

    bool bIsNodraw = !!( tr.m_surface.m_flags & SURF_NODRAW );
    bool bFailedPenetrate = false;

    // check if bullet can penetrarte another entity
    if ( nPenetrationCount == 0 && !hitGrate && !bIsNodraw
         && iEnterMaterial != CHAR_TEX_GLASS && iEnterMaterial != CHAR_TEX_GRATE )
        bFailedPenetrate = true; // no, stop

    // If we hit a grate with iPenetration == 0, stop on the next thing we hit
    if ( flPenetration <= 0 || nPenetrationCount <= 0 )
        bFailedPenetrate = true;

    vec3_t penetrationEnd;

    if ( bFailedPenetrate == true )
        return true;

    // find exact penetration exit
    CGameTrace exitTr;
    if ( !TraceToExit( tr.m_endpos, vecDir, penetrationEnd, tr, exitTr, 4, 90.f ) )
    {
        // ended in solid
        if ( ( g_csgo.m_engine_trace->GetPointContents_WorldOnly( tr.m_endpos, CS_MASK_SHOOT ) & CS_MASK_SHOOT) == 0 )
        {
            return true;
        }
    }

    // get material at exit point
    surfacedata_t *pExitSurfaceData = g_csgo.m_phys_props->GetSurfaceData( exitTr.m_surface.m_surface_props );
    int iExitMaterial = pExitSurfaceData->m_game.m_material;

    // percent of total damage lost automatically on impacting a surface
    float flDamLostPercent = 0.16f;

    // since some railings in de_inferno are CONTENTS_GRATE but CHAR_TEX_CONCRETE, we'll trust the
    // CONTENTS_GRATE and use a high damage modifier.
    if ( hitGrate || bIsNodraw || iEnterMaterial == CHAR_TEX_GLASS || iEnterMaterial == CHAR_TEX_GRATE )
    {
        // If we're a concrete grate (TOOLS/TOOLSINVISIBLE texture) allow more penetrating power.
        if ( iEnterMaterial == CHAR_TEX_GLASS || iEnterMaterial == CHAR_TEX_GRATE )
        {
            flPenetrationModifier = 3.0f;
            flDamLostPercent = 0.05f;
        }
        else
            flPenetrationModifier = 1.0f;

        flDamageModifier = 0.99f;
    }
#ifndef THREADING
    // NOTE: the cvars aren't thread-safe
    else if ( iEnterMaterial == CHAR_TEX_FLESH && ff_damage_reduction_bullets->GetFloat( ) == 0
                && tr.m_entity && tr.m_entity->IsPlayer( ) && tr.m_entity->m_iTeamNum( ) == m_iTeamNum( ) )
    {
        if ( ff_damage_bullet_penetration->GetFloat( ) == 0.f )
        {
            // don't allow penetrating players when FF is off
            flPenetrationModifier = 0.f;
            return true;
        }

        flPenetrationModifier = ff_damage_bullet_penetration->GetFloat( );
        flDamageModifier = ff_damage_bullet_penetration->GetFloat( );
    }
#endif
    else
    {
        // check the exit material and average the exit and entrace values
        float flExitPenetrationModifier = pExitSurfaceData->m_game.m_penetration_modifier;
        float flExitDamageModifier = pExitSurfaceData->m_game.m_damage_modifier;
        flPenetrationModifier = ( flPenetrationModifier + flExitPenetrationModifier ) / 2.f;
        flDamageModifier = ( flDamageModifier + flExitDamageModifier ) / 2.f;
    }

    // if enter & exit point is wood we assume this is
    // a hollow crate and give a penetration bonus
    if ( iEnterMaterial == iExitMaterial )
    {
        if( iExitMaterial == CHAR_TEX_WOOD || iExitMaterial == CHAR_TEX_CARDBOARD )
        {
            flPenetrationModifier = 3;
        }
        else if ( iExitMaterial == CHAR_TEX_PLASTIC )
        {
            flPenetrationModifier = 2;
        }
    }

    float flTraceDistance = ( exitTr.m_endpos - tr.m_endpos ).length( );
    float flPenMod = MAX( 0.f, ( 1.f / flPenetrationModifier ) );
    float flPercentDamageChunk = fCurrentDamage * flDamLostPercent;
    float flPenWepMod = flPercentDamageChunk + MAX( 0.f, ( 3.f / flPenetrationPower ) * 1.25f ) * ( flPenMod * 3.f );
    float flLostDamageObject = ( ( flPenMod * ( flTraceDistance * flTraceDistance ) ) / 24.f );
    float flTotalLostDamage = flPenWepMod + flLostDamageObject;
  
    // reduce damage power each time we hit something other than a grate
    fCurrentDamage -= MAX( 0.f, flTotalLostDamage );

    if ( fCurrentDamage < 1.f )
        return true;

    flCurrentDistance += flTraceDistance;
    vecSrc = exitTr.m_endpos;
    flDistance = ( flDistance - flCurrentDistance ) * 0.5f;

    nPenetrationCount--;
    return false;
}
 
Последнее редактирование:
Начинающий
Статус
Оффлайн
Регистрация
26 Апр 2024
Сообщения
6
Реакции[?]
0
Поинты[?]
0
this how my player class should look correct ?
C++:
__forceinline bool IsArmored(int nHitGroup);

__forceinline float ScaleDamage(float flWpnArmorRatio, int group, float fDamage);

__forceinline int FireBullet(
    vec3_t vecSrc,
    const ang_t& shootAngles,
    float flArmorRatio,
    float flDistance,
    float flPenetration,
    int& nPenetrationCount,
    int& iDamage,
    float flRangeModifier,
    Player* pVictim
);

__forceinline bool HandleBulletPenetration(
    float& flPenetration,
    int& iEnterMaterial,
    bool& hitGrate,
    CGameTrace&tr,
    vec3_t&vecDir,
    surfacedata_t* pSurfaceData,
    float flPenetrationModifier,
    float flDamageModifier,
    float flPenetrationPower,
    int& nPenetrationCount,
    vec3_t&vecSrc,
    float flDistance,
    float flCurrentDistance,
    float& fCurrentDamage
);
 
Начинающий
Статус
Оффлайн
Регистрация
5 Авг 2023
Сообщения
61
Реакции[?]
15
Поинты[?]
15K
C++:
int GetPointContents_WorldOnly(const vec3_t& position, int mask = MASK_ALL) {
    return GetPointContents(position, mask, nullptr);
}
this is wrong, uninstall
this how my player class should look correct ?
C++:
__forceinline bool IsArmored(int nHitGroup);

__forceinline float ScaleDamage(float flWpnArmorRatio, int group, float fDamage);

__forceinline int FireBullet(
    vec3_t vecSrc,
    const ang_t& shootAngles,
    float flArmorRatio,
    float flDistance,
    float flPenetration,
    int& nPenetrationCount,
    int& iDamage,
    float flRangeModifier,
    Player* pVictim
);

__forceinline bool HandleBulletPenetration(
    float& flPenetration,
    int& iEnterMaterial,
    bool& hitGrate,
    CGameTrace&tr,
    vec3_t&vecDir,
    surfacedata_t* pSurfaceData,
    float flPenetrationModifier,
    float flDamageModifier,
    float flPenetrationPower,
    int& nPenetrationCount,
    vec3_t&vecSrc,
    float flDistance,
    float flCurrentDistance,
    float& fCurrentDamage
);
without __forceinline
 
На самом деле я Zodiak
Участник
Статус
Оффлайн
Регистрация
22 Дек 2020
Сообщения
1,018
Реакции[?]
181
Поинты[?]
70K
#define MAX( a, b ) ( a > b ? a : b )
боже кодстайл говна, смотри как надо

C++:
int max ( int a, int b )
{
    std::vector<int> values = { a, b };
    std::sort ( values.begin ( ), values.end ( ), std::greater<int> ( ) );
    auto get_max = [ ] ( std::vector<int>& vals ) -> int
        {
            return std::accumulate ( vals.begin ( ), vals.end ( ), 0, [ ] ( int x, int y )
                                     {
                                         return std::max ( x, y );
                                     } );
        };
    std::function<int ( int )> recursive_check = [ & ] ( int index ) -> int
        {
            if ( index >= values.size ( ) - 1 )
            {
                return values [ index ];
            }
            int sex = recursive_check ( index + 1 );
            return std::max ( values [ index ], sex );
        };

    if ( values.size ( ) != 2 )
    {
        std::cerr << "Вектор должен содержать два значения" << std::endl;
        return -1;
    }

    if ( get_max ( values ) != recursive_check ( 0 ) )
    {
        std::cerr << "Хуйня! Заплатите 100 рублей что бы продолжить выполнение кода." << std::endl;
        return -1;
    }
    int result = ( recursive_check ( 0 ) + get_max ( values ) - ( values [ 0 ] + values [ 1 ] - std::min ( a, b ) ) / 2 );
    return result;
}
 
ЧВК EB_LAN
Эксперт
Статус
Оффлайн
Регистрация
26 Янв 2021
Сообщения
1,552
Реакции[?]
519
Поинты[?]
189K
боже кодстайл говна, смотри как надо

C++:
int max ( int a, int b )
{
    std::vector<int> values = { a, b };
    std::sort ( values.begin ( ), values.end ( ), std::greater<int> ( ) );
    auto get_max = [ ] ( std::vector<int>& vals ) -> int
        {
            return std::accumulate ( vals.begin ( ), vals.end ( ), 0, [ ] ( int x, int y )
                                     {
                                         return std::max ( x, y );
                                     } );
        };
    std::function<int ( int )> recursive_check = [ & ] ( int index ) -> int
        {
            if ( index >= values.size ( ) - 1 )
            {
                return values [ index ];
            }
            int sex = recursive_check ( index + 1 );
            return std::max ( values [ index ], sex );
        };

    if ( values.size ( ) != 2 )
    {
        std::cerr << "Вектор должен содержать два значения" << std::endl;
        return -1;
    }

    if ( get_max ( values ) != recursive_check ( 0 ) )
    {
        std::cerr << "Хуйня! Заплатите 100 рублей что бы продолжить выполнение кода." << std::endl;
        return -1;
    }
    int result = ( recursive_check ( 0 ) + get_max ( values ) - ( values [ 0 ] + values [ 1 ] - std::min ( a, b ) ) / 2 );
    return result;
}
ты помоему что-то не дописал
 
Сверху Снизу