Server Crash due grab plugin

Статус
В этой теме нельзя размещать новые ответы.
Сообщения
18
Реакции
0
Помог
1 раз(а)
Ошибка
server crash
ОС
Linux
Amx Mod X
AMX Mod X 1.9.0.5294 (http://www.amxmodx.org)
Authors:
David "BAILOPAN" Anderson, Pavol "PM OnoTo" Marko
Felix "SniperBeamer" Geyer, Jonny "Got His Gun" Bergstrom
Lukasz "SidLuke" Wlasinski, Christian "Basic-Master" Hammacher
Borja "faluco" Ferrer, Scott "DS" Ehlert
Compiled: Dec 3 2021 15:54:56
Built from: https://github.com/alliedmodders/amxmodx/commit/363871a
Build ID: 5294:363871a
Core mode: JIT+ASM32
Билд
Protocol version 48
Exe version 1.1.2.7/Stdio (cstrike)
ReHLDS version: 3.13.0.801-dev
Build date: 17:25:27 Jan 13 2024 (3563)
Build from: https://github.com/dreamstalker/rehlds/commit/1d6c682
ReGamedll
ReGameDLL version: 5.22.0.593-dev
Build date: 03:10:30 Jul 11 2023
Build from: https://github.com/s1lentq/ReGameDLL_CS/commit/e1d1c11
Версия Metamod
Metamod-r v1.3.0.149, API (5:13)
Metamod-r build: 18:21:12 Jan 15 2024
Metamod-r from: https://github.com/theAsmodai/metamod-r/commit/603a257
Список метамодулей
Currently loaded plugins:
description stat pend file vers src load unload
[ 1] Reunion RUN - reunion_mm_i386.so-92c v0.1.92d ini Start Never
[ 2] AMX Mod X RUN - amxmodx_mm_i386.so v1.9.0.5294 ini Start ANY
[ 3] Print Center Fix RUN - printcenterfix_mm_i386.so v2.0.1 ini ANY ANY
[ 4] ReAuthCheck RUN - reauthcheck_mm_i386.so v0.1.6 ini Start Never
[ 5] Revoice RUN - revoice_plus_mm.so v1.0.3 ini ANY Never
[ 6] ReAPI RUN - reapi_amxx_i386.so v5.22.0.254-dev pl2 ANY Never
[ 7] FakeMeta RUN - fakemeta_amxx_i386.so v1.9.0.5294 pl2 ANY ANY
[ 8] Ham Sandwich RUN - hamsandwich_amxx_i386.so v1.9.0.5294 pl2 ANY ANY
[ 9] MySQL RUN - mysql_amxx_i386.so v1.9.0.5294 pl2 ANY ANY
[10] CStrike RUN - cstrike_amxx_i386.so v1.9.0.5294 pl2 ANY ANY
[11] Engine RUN - engine_amxx_i386.so v1.9.0.5294 pl2 ANY ANY
[12] GeoIP RUN - geoip_amxx_i386.so v1.9.0.5294 pl2 ANY ANY
[13] Fun RUN - fun_amxx_i386.so v1.9.0.5294 pl2 ANY ANY
[14] CSX RUN - csx_amxx_i386.so v1.9.0.5294 pl2 ANY ANY
14 plugins, 14 running
Список плагинов
Currently loaded plugins:
name version author file status
[ 1] UcanBAN + UzaBAN 1.4 Persians Special techline_idchan debug
[ 2] Ultimate Bans 1.9 Souvik UltimateBans.am running
[ 3] Aliases checker 1.0.3 kanagava alias_detector. running
[ 4] Gag System 1.1 TheRedShoko @ AM gag_system.amxx running
[ 5] Multi FastDL 1.2 JoRoPiTo multifast.amxx running
[ 6] Fix fast download to r 0.0.3 PomanoB \ Bos93 FIxFastDL.amxx running
[ 7] Admin Base 1.9.0.5294 AMXX Dev Team admin.amxx running
[ 8] Admin Commands 1.9.0.5294 AMXX Dev Team admincmd.amxx running
[ 9] Admin Help 1.9.0.5294 AMXX Dev Team adminhelp.amxx running
[ 10] Slots Reservation 1.9.0.5294 AMXX Dev Team adminslots.amxx running
[ 11] Multi-Lingual System 1.9.0.5294 AMXX Dev Team multilingual.am running
[ 12] Menus Front-End 1.9.0.5271 AMXX Dev Team menufront.amxx running
[ 13] Commands Menu 1.9.0.5294 AMXX Dev Team cmdmenu.amxx running
[ 14] Players Menu 1.9.0.5271 AMXX Dev Team plmenu.amxx running
[ 15] Maps Menu 1.9.0.5294 AMXX Dev Team mapsmenu.amxx running
[ 16] Plugin Menu 1.9.0.5294 AMXX Dev Team pluginmenu.amxx running
[ 17] Admin Chat 2.0 Hell Phoenix/EJL adminchat.amxx running
[ 18] Anti Flood 1.9.0.5294 AMXX Dev Team antiflood.amxx running
[ 19] Scrolling Message 1.9.0.5294 AMXX Dev Team scrollmsg.amxx running
[ 20] Info. Messages 1.9.0.5294 AMXX Dev Team imessage.amxx running
[ 21] Admin Votes 1.8.2 AMXX Dev Team adminvote.amxx running
[ 22] NextMap 1.9.0.5271 AMXX Dev Team nextmap.amxx running
[ 23] TimeLeft 1.9.0.5271 AMXX Dev Team timeleft.amxx running
[ 24] Pause Plugins 1.9.0.5294 AMXX Dev Team pausecfg.amxx running
[ 25] Stats Configuration 1.9.0.5294 AMXX Dev Team statscfg.amxx running
[ 26] NadeModes 11.2 Nomexous & OT nademodes.amxx running
[ 27] Auto Demo Record 1.0 Eghos. amx_demorecorde running
[ 28] KGB Bots 2.1 OvidiuS & Desika kgbbots.amxx running
[ 29] Menu per shum servera 1.0 c0d3 lista-serverave running
[ 30] Map Spawns Editor 1.0.16 iG_os Map_Spawns_Edit running
[ 31] Don't say IPs 0.1 JGHG no_ip_spam.amxx running
[ 32] No Radio Flood 1.1 Starsailor no_radio_flood. running
[ 33] Advanced Spam Nick Cha 1.0 Fullserver tgs_spam_nick.a running
[ 34] New-Era_UnlimitedAmmo 1.0.1 New-Era Scriptin unlimited_ammoc running
[ 35] WalkGuard 1.3.2 mogel walkguard.amxx running
[ 36] Precache X 1.0 Dias Leon & DeXT PrecacheX.amxx running
[ 37] Chat Logger 2.1a Jim chat_logger.amx running
[ 38] GO SPEC 1.0 Unknown admin_spec.amxx running
[ 39] AutoJoin 2.0b SideWinder TGS_autoJoin.am running
[ 40] KH_HEALTH 1.0 Kulogram ze_show_damage. running
[ 41] Show IP 1.0 $uicid3 amx_showip.amxx running
[ 42] Anti water speed 1.0 emirakpinar anti_fast_swim. running
[ 43] No Block 1.0 Unknown block_entity.am running
[ 44] Block Sprays 1.0 29th ID block_spray.amx running
[ 45] Break & Button Info 1.0 Unknown ButtonInfo.amxx running
[ 46] Matematik Quiz 1.0 EliVvo. Quiz.amxx running
[ 47] Slay Team 1.0 hleV slay_team.amxx running
[ 48] FPS CHECKER 1.1 EliVvo. fps_checker.amx running
[ 49] Camera View Menu v1.0 AUTHOR ze_cam.amxx running
[ 50] Target Info 1.0 Raheem ze_showinfo.amx running
[ 51] Show keys 1.0.0 OpenHNS showkeys.amxx running
[ 52] Sys Tick 1.1 ->UrOS<- systick.amxx paused
[ 53] [SCM] Entity Editor 1.3.1 schmurgel1983 scm_entity_edit running
[ 54] [CS] Team Semiclip 3.3.1 schmurgel1983 cs_team_semicli running
[ 55] [ZE] Core/Engine 1.6 ZE Dev Team ze_core.amxx running
[ 56] [AMXX] External Settin 0.1 WiLS amx_settings_ap running
[ 57] [CS] Weapon Models API 1.1 WiLS cs_weap_models_ running
[ 58] [ZE] Blocked Messages 1.6 ZE Dev Team ze_block_events running
[ 59] [ZE] Nightvision/Light 1.6 ZE Dev Team ze_nightvision_ running
[ 60] [ZE] Frags Awards/Deat 1.6 ZE Dev Team ze_effects_frag running
[ 61] [ZE] Weather Effects 1.6 ZE Dev Team ze_effects_weat running
[ 62] [ZE] Escape Coins Syst 1.6 ZE Dev Team ze_coins_system running
[ 63] [ZE] Items Manager 1.6 ZE Dev Team ze_items_manage running
[ 64] [ZE] Items Manager: Es 1.6 ZE Dev Team ze_items_escape running
[ 65] [ZE] Items Manager: Li 1.6 ZE Dev Team ze_items_limit. running
[ 66] [ZE] Fire Nade 1.6 ZE Dev Team ze_fire.amxx running
[ 67] [ZE] Frost Nade 1.6 ZE Dev Team ze_frost.amxx running
[ 68] [ZE] Models & Sounds 1.6 ZE Dev Team ze_resources.am running
[ 69] [ZE] Sound Countdown 1.6 ZE Dev Team ze_countdown.am running
[ 70] [ZE] Zombie Sounds 1.6 ZE Dev Team ze_zombie_sound running
[ 71] [ZE] Items Manager: VI 1.6 ZE Dev Team ze_items_vip.am running
[ 72] [ZE] Multi-Jump 1.1 Raheem ze_multijump.am running
[ 73] [ZE] Tank-Gun Control 1.1 Raheem ze_block_tank_g running
[ 74] Custom Flashlight 0.5.4 ConnorMcLeod ze_CustomFlashL running
[ 75] Autoresponder/Advertis 0.5 MaximusBrood ad_manager.amxx running
[ 76] Weapon Model + Sound R 1.3 GHW_Chronic GHW_Weapon_Repl running
[ 77] [ZE] Escapes Count 1.1 ZE-DEV-TEAM + sP ze_achievements running
[ 78] Admin Prefixes 4.0 m0skVi4a ;] ze_admin_chat.a running
[ 79] Auto Config 1.0 TGS ze_auto_config. running
[ 80] [ZE] LEVEL SYSTEM 1.8 ZE Dev Team ze_level_system running
[ 81] [ZE] Zombie Escape VIP 1.3 ZE Dev Team ze_vip_system.a running
[ 82] [ZE] First Round Resta 1.0 EliVvo. ze_first_round_ running
[ 83] [ZE] Manual Unstuck 1.0 Raheem ze_manual_unstu running
[ 84] [ZE] Bad Spawn Fix 1.0 Raheem ze_spawn_auto_u running
[ 85] [ZE] Map-Damage Contro 1.0 Raheem ze_damage_contr running
[ 86] [ZE] Special Models 1.6 ZE Dev Team ze_models.amxx running
[ 87] Custom Radio Commands 0.6 KaLoSZyFeR ze_custom_radio running
[ 88] [ZE] Main Menu 1.6 ZE Dev Team ze_main_menu.am running
[ 89] administration Menu 1.1 EliVvo. admin_main_menu running
[ 90] Settings Menu 1.1 EliVvo. settings_menu.a running
[ 91] Glow Menu v1.2 Unknown ze_glow_menu.am running
[ 92] [ZE] Addon: Knife Menu 1.2 Jack GamePlay ze_knife_menu.a running
[ 93] [ZE] Hats Menu 1.0 EliVvo. ze_hats_menu.am running
[ 94] [ZE] Addons: Admin szM 1.0 Jack GamePlay ze_make_zm_hm.a running
[ 95] Custom zModel Menu 1.0 Mark ze_models_menu_ running
[ 96] akcaliberkk 1.0 Revive Menu ze_revmenu.amxx running
[ 97] [JBE] Addons: Trail 1.2 OverGame & Hellm ze_trail.amxx running
[ 98] ZE VIP Menu 1.1 EliVvo. ze_vip_main_men running
[ 99] Sound Menu 1.0 Raheem sound_menu.amxx running
[100] [ZE] Levels Weapons Me 1.1 Raheem ze_weapon_menu. running
[101] Golden M3 1.1 Wisam187 ze_golden_m3.am running
[102] Golden MP5 1.1 Wisam187 : JaCk ze_golden_mp5.a running
[103] Golden M4A1 1.1 JaCk ze_golden_m4a1. running
[104] Golden AK-47 1.1 Wisam187 : JaCk ze_golden_ak47. running
[105] [ZE] Weapon: BALROG3 1.0 PbI)I(Uu ze_barlog3.amxx running
[106] [CSO] M4A1 Dark Knight 1.0 Dias Pendragon ze_m4a1_darkkni running
[107] [CSO] AK47 Paladin 1.0 Dias Pendragon AK47_Paladin.am running
[108] [ZE] Rail Cannon 1.0 m4m3ts ze_railcannon.a running
[109] [ZE] Star Chaser AR 1.0 Bim Bim Cay + Le ze_starchasear. running
[110] Weapon: Plasma Gun 1.0 S3xTy ze_plasma_gun.a running
[111] Tiamat MK4 1.0 extazY / Arabas ze_tiamat.amxx running
[112] VIP Features 1.3 EliVvo. ze_vip_features running
[113] [ZE] Items: Fire Nade 1.6 ZE Dev Team ze_extra_fire_n running
[114] [ZE] Items: Fire Nade 1.6 ZE Dev Team ze_extra_frost_ running
[115] [ZE] Items: SF Tornado 1.0 Batcon/t3rkecore ze_extra_tornad running
[116] [CSO] Coilgun 1.0 Dias + ZE DEV TE ze_coilgun.amxx running
[117] unknown unknown unknown ze_extra_scar_b running
[118] [ZE] UT3 Link Gun 1.0 xUnicorn ut3_linkgun.amx running
[119] [ZP] Extra Item: Jump 1.0 Opo4uMapy ze_extra_bombju running
[120] [ZE] Extra Item: Blind 1.1 Catastrophe+ZE D ze_blind_bomb.a running
120 plugins, 119 running
my server is getting crash every time i enable grab plugin can someone fix it
ps : there is not error's at sys_logs
JavaScript:
-------------------------------------------- -
CRASH: Sun Feb 18 04:39:49 CET 2024
Start Line: ./hlds_linux -game cstrike +ip 51.195.97.176 -port 27017 +maxplayers 32 +map ze_area51_lg +mapchangecfgfile server.cfg +fps_max 333 +sys_ticrate 333 +heapsize 512000 -zone 2048 -num_edicts 2048 -nobreak pad -master -edicts 2048
End of crash report
----------------------------------------------
----------------------------------------------
CRASH: Sun Feb 18 12:51:44 CET 2024
Start Line: ./hlds_linux -game cstrike +ip 51.195.97.176 -port 27017 +maxplayers 32 +map ze_area51_lg +mapchangecfgfile server.cfg +fps_max 333 +sys_ticrate 333 +heapsize 512000 -zone 2048 -num_edicts 2048 -nobreak pad -master -edicts 2048
End of crash report
----------------------------------------------
----------------------------------------------
CRASH: Sun Feb 18 19:40:59 CET 2024
Start Line: ./hlds_linux -game cstrike +ip 51.195.97.176 -port 27017 +maxplayers 32 +map ze_area51_lg +mapchangecfgfile server.cfg +fps_max 333 +sys_ticrate 333 +heapsize 512000 -zone 2048 -num_edicts 2048 -nobreak pad -master -edicts 2048
End of crash report
----------------------------------------------
grab plugin
JavaScript:
#include <amxmodx>
#include <amxmisc>
#include <fakemeta>
#include <fun>
#include <hamsandwich>

#pragma tabsize 0

#define PLUGIN "MG Grab"
#define VERSION "1.0"
#define AUTHOR "Nickron"

#define ADMIN ADMIN_LEVEL_F
#define RESON_KICK "Kick [MG Grab] 4utau PravuLa"
#define GRAB_MENU

#define TSK_CHKE 50

#define SF_FADEOUT 0

new client_data[33][4]
#define GRABBED 0
#define GRABBER 1
#define GRAB_LEN 2
#define FLAGS 3

#define CDF_IN_PUSH (1<<0)
#define CDF_IN_PULL (1<<1)
#define CDF_NO_CHOKE (1<<2)

enum
{
    r = 0.0,
    g = 255.0,
    b = 255.0,

    a = 200.0
};

new const Menu[][] =
{
    "",
    "MENU_1",
    "MENU_2",
    "MENU_3",
    "MENU_4",
    "MENU_5",
    "MENU_6"
};

new p_enabled, p_players_only
new p_throw_force, p_min_dist, p_speed, p_grab_force
new p_choke_time, p_choke_dmg, p_auto_choke
new p_glow
new speed_off[33]
new g_short
new model_gibs
new MAXPLAYERS
new SVC_SCREENSHAKE, SVC_SCREENFADE, WTF_DAMAGE

public plugin_init( )
{
    register_plugin(PLUGIN, VERSION, AUTHOR)
    register_event("CurWeapon", "CurrentWeapon", "be", "1=1")
    RegisterHam(Ham_Spawn, "player", "SpawnPlayer")

    p_enabled = register_cvar( "gp_enabled", "1" )
    p_players_only = register_cvar( "gp_players_only", "0" )
   
    p_min_dist = register_cvar("gp_min_dist", "90")
    p_throw_force = register_cvar( "gp_throw_force", "1500" )
    p_grab_force = register_cvar( "gp_grab_force", "8" )
    p_speed = register_cvar( "gp_speed", "5" )
   
    p_choke_time = register_cvar( "gp_choke_time", "1.5" )
    p_choke_dmg = register_cvar( "gp_choke_dmg", "5" )
    p_auto_choke = register_cvar( "gp_auto_choke", "1" )
   
    p_glow = register_cvar( "gp_glow", "1" )
   
    register_clcmd( "amx_grab", "force_grab", ADMIN, "Grab client & teleport to you." )
    register_clcmd( "+grab", "grab", ADMIN, "bind a key to +grab" )
    register_clcmd( "-grab", "unset_grabbed" )
   
    register_clcmd( "+push", "push", ADMIN, "bind a key to +push" )
    register_clcmd( "-push", "push" )
    register_clcmd( "+pull", "pull", ADMIN, "bind a key to +pull" )
    register_clcmd( "-pull", "pull" )
    register_clcmd( "push", "push2" )
    register_clcmd( "pull", "pull2" )
   
    register_clcmd( "drop" , "throw" )
   
    register_event( "DeathMsg", "DeathMsg", "a" )
   
    register_forward( FM_PlayerPreThink, "fm_player_prethink" )
   
    register_dictionary( "grab_plus.txt" )
   
    MAXPLAYERS = get_maxplayers()
   
    SVC_SCREENFADE = get_user_msgid( "ScreenFade" )
    SVC_SCREENSHAKE = get_user_msgid( "ScreenShake" )
    WTF_DAMAGE = get_user_msgid( "Damage" )

    register_dictionary("mg_grab.txt");
}

public plugin_precache( )
{
    precache_sound("player/PL_PAIN2.WAV")
    precache_sound("MG_grab/grab_victim_xa.wav")
    precache_sound("MG_grab/grab_id_mine.wav")
    precache_sound("MG_grab/grab_weapon.wav")
    precache_sound("MG_grab/grab_bury.wav")
    g_short = precache_model("sprites/MG_grab/energy_grab.spr");
    model_gibs = precache_model("models/rockgibs.mdl")
}

public fm_player_prethink( id )
{
    new target
    //Search for a target
    if ( client_data[id][GRABBED] == -1 )
    {
        new Float:orig[3], Float:ret[3]
        get_view_pos( id, orig )
        ret = vel_by_aim( id, 9999 )
       
        ret[0] += orig[0]
        ret[1] += orig[1]
        ret[2] += orig[2]
       
        target = traceline( orig, ret, id, ret )
       
        if( 0 < target <= MAXPLAYERS )
        {
            if( is_grabbed( target, id ) ) return FMRES_IGNORED
            set_grabbed( id, target )
        }
        else if( !get_pcvar_num( p_players_only ) )
        {
            new movetype
            if( target && pev_valid( target ) )
            {
                movetype = pev( target, pev_movetype )
                if( !( movetype == MOVETYPE_WALK || movetype == MOVETYPE_STEP || movetype == MOVETYPE_TOSS ) )
                    return FMRES_IGNORED
            }
            else
            {
                target = 0
                new ent = engfunc( EngFunc_FindEntityInSphere, -1, ret, 12.0 )
                while( !target && ent > 0 )
                {
                    movetype = pev( ent, pev_movetype )
                    if( ( movetype == MOVETYPE_WALK || movetype == MOVETYPE_STEP || movetype == MOVETYPE_TOSS )
                            && ent != id )
                        target = ent
                    ent = engfunc( EngFunc_FindEntityInSphere, ent, ret, 12.0 )
                }
            }
            if( target )
            {
                if( is_grabbed( target, id ) ) return FMRES_IGNORED
                set_grabbed( id, target )
            }
        }
    }
   
    target = client_data[id][GRABBED]
    //If they've grabbed something
    if( target > 0 )
    {
        if( !pev_valid( target ) || ( pev( target, pev_health ) < 1 && pev( target, pev_max_health ) ) )
        {
            unset_grabbed( id )
            return FMRES_IGNORED
        }
       
        //Use key choke
        if( pev( id, pev_button ) & IN_USE )
            do_choke(id)
       
        //Push and pull
        new cdf = client_data[id][FLAGS]
        if ( cdf & CDF_IN_PULL )
            do_pull(id)
        else if ( cdf & CDF_IN_PUSH )
            do_push(id)
       
        if( target > MAXPLAYERS ) grab_think( id )
    }
   
    //If they're grabbed
    target = client_data[id][GRABBER]
    if( target > 0 ) grab_think( target )
   
    return FMRES_IGNORED
}

public grab_think( id ) //id of the grabber
{
    new target = client_data[id][GRABBED]
   
    //Keep grabbed clients from sticking to ladders
    if( pev( target, pev_movetype ) == MOVETYPE_FLY && !( pev( target, pev_button ) & IN_JUMP ) ) client_cmd( target, "+jump;wait;-jump" )
   
    //Move targeted client
    new Float:tmpvec[3], Float:tmpvec2[3], Float:torig[3], Float:tvel[3]
   
    get_view_pos( id, tmpvec )
   
    tmpvec2 = vel_by_aim( id, client_data[id][GRAB_LEN] )
   
    torig = get_target_origin_f( target )
   
    new force = get_pcvar_num( p_grab_force )
   
    tvel[0] = ( ( tmpvec[0] + tmpvec2[0] ) - torig[0] ) * force
    tvel[1] = ( ( tmpvec[1] + tmpvec2[1] ) - torig[1] ) * force
    tvel[2] = ( ( tmpvec[2] + tmpvec2[2] ) - torig[2] ) * force
   
    set_pev( target, pev_velocity, tvel )
}

stock Float:get_target_origin_f( id )
{
    new Float:origin[3]
    pev( id, pev_origin, orig )
   
    //If grabbed is not a player, move origin to center
    if( id > MAXPLAYERS )
    {
        new Float:mins[3], Float:maxs[3]
        pev( id, pev_mins, mins )
        pev( id, pev_maxs, maxs )
       
        if( !mins[2] ) orig[2] += maxs[2] / 2
    }
   
    return origin
}

public grab( id, level, cid )
{
    if( !cmd_access( id, level, cid, 1 ) || !get_pcvar_num( p_enabled ) ) return PLUGIN_HANDLED
   
    if ( !client_data[id][GRABBED] ) client_data[id][GRABBED] = -1
   
    return PLUGIN_HANDLED
}

public SpawnPlayer(id)
    speed_off[id] = false

public CurrentWeapon(id)
{
    if(speed_off[id])
        set_pev(id, pev_maxspeed, 00000.0)
}

public grab_menu(id)
{
    new name[32]
    new target = client_data[id][GRABBED]
    if(target && is_user_alive(target))
    {
        get_user_name(target, name, charsmax(name))
    }
    new Item[512], Str[10], menu;

    formatex(Item, charsmax(Item), "%L", id, "MENU_NAME", name);
    menu = menu_create(Item, "menu_handler")

    for(new i = 1; i <= charsmax(Menu); i++)
    {
        num_to_str(i, Str, charsmax(Str));

        formatex(Item, charsmax(Item), "%L", id, Menu[i]);
        menu_additem(menu, Item, Str, 0);
    }
    formatex(Item, charsmax(Item), "%L", id, "MENU_EXIT");
    menu_setprop(menu, MPROP_EXITNAME, Item);

    menu_display(id, menu, 0);

    return PLUGIN_HANDLED;
}
   
public menu_handler(id, menu, item)
{
    if(item == MENU_EXIT)
    {
        menu_destroy(menu)
        return PLUGIN_HANDLED
    }
       
    new data[6], iName[64], access, callback
    menu_item_getinfo(menu, item, access, data, 5, iName, 63, callback)
       
    new key = str_to_num(data)
    new target = client_data[id][GRABBED]
       
    switch(key)
    {
        case 1:
        {
            if(target && is_user_alive(target))
            {
                grab_eff_zd(id, target)
                server_cmd("kick #%d ^"%s^"", get_user_userid(target), RESON_KICK)
            }
        }
        case 2:
        {
            if(target && is_user_alive(target))
            {
                user_kill(target)
            }
        }
        case 3:
        {
            if(target && is_user_alive(target))
            {
                fm_strip_user_weapons(target)
                fm_give_item(target, "weapon_knife")              
            }
        }
        case 4:
        {
            if(target && is_user_alive(target))
            {
                Bury(id, target)
            }
        }
        case 5:
        {
            if(target && is_user_alive(target))
            {
                Bury_off(id, target)
            }
        }
        case 6:
        {
            if(target && is_user_alive(target))
            {
                pull(id)
            }
        }
        case 7:
        {
            if(target && is_user_alive(target))
            {
                set_pev(target, pev_punchangle, { 400.0, 999.0, 400.0 })
            }
        }
    }
    return PLUGIN_HANDLED
}

public throw(id)
{
    new target = client_data[id][GRABBED]
    if( target > 0 )
    {
        set_pev( target, pev_velocity, vel_by_aim( id, get_pcvar_num(p_throw_force) ) )
        unset_grabbed( id )
        return PLUGIN_HANDLED
    }

    return PLUGIN_CONTINUE
}

public unset_grabbed( id )
{
    new target = client_data[id][GRABBED]
    if( target > 0 && pev_valid( target ) )
    {
        set_pev( target, pev_renderfx, kRenderFxNone )
        set_pev( target, pev_rendercolor, {255.0, 255.0, 255.0} )
        set_pev( target, pev_rendermode, kRenderNormal )
        set_pev( target, pev_renderamt, 16.0 )
       
        if( 0 < target <= MAXPLAYERS )
            client_data[target][GRABBER] = 0
    }
    show_menu(id, 0, "^n", 1)
    client_data[id][GRABBED] = 0
}

//Grabs onto someone
public set_grabbed( id, target )
{
    if( get_pcvar_num( p_glow ) )
    {
        set_pev( target, pev_renderfx, kRenderFxGlowShell )
        set_pev( target, pev_rendercolor, {r, g, b})
        set_pev( target, pev_rendermode, kRenderTransColor )
        set_pev( target, pev_renderamt, a )
    }
   
    if( 0 < target <= MAXPLAYERS )
        client_data[target][GRABBER] = id
    client_data[id][FLAGS] = 0
    client_data[id][GRABBED] = target
    new name[33], name2[33]
    get_user_name(id, name, 32)
    get_user_name(target, name2, 32)
    if(get_user_team(target)==1 || get_user_team(target)==2)
    {      
        client_cmd(target, "spk MG_grab/grab_victim_xa.wav")
        client_cmd(id, "spk MG_grab/grab_id_mine.wav")
        ChatColor(target, "%L", target, "CHAT_1", name)
        ChatColor(id, "%L", id, "CHAT_2", name2)
        grab_eff(target)
        #if defined GRAB_MENU
        grab_menu(id)
        #endif
    }
    else
    {
        ChatColor(id, "%L", id, "CHAT_3")
        client_cmd(0, "spk MG_grab/grab_weapon.wav")
    }
    new Float:torig[3], Float:orig[3]
    pev( target, pev_origin, torig )
    pev( id, pev_origin, orig )
    client_data[id][GRAB_LEN] = floatround( get_distance_f( torig, orig ) )
    if( client_data[id][GRAB_LEN] < get_pcvar_num( p_min_dist ) ) client_data[id][GRAB_LEN] = get_pcvar_num( p_min_dist )
}

public Bury(id, target)
{
        ChatColor(id, "%L", id, "CHAT_4")
    client_cmd(id, "spk MG_grab/grab_bury.wav")
    grab_eff_zd(id, target)
    if(is_user_alive(target))
        {
            new origin[3]
            get_user_origin(target, origin)
            origin[2] -= 30
            set_user_origin(target, origin)
        }
}

public Bury_off(id, target)
{
        ChatColor(id, "%L", id, "CHAT_5")
   
    if(is_user_alive(target))
        {
            new origin[3]
            get_user_origin(target, origin)
            origin[2] += 30
            set_user_origin(target, origin)
        }
}  

public grab_eff(target)
{
    new origin[3]
 
    get_user_origin(target,origin)
 
    message_begin(MSG_ALL,SVC_TEMPENTITY,{0,0,0},target)
    write_byte(TE_SPRITETRAIL) //Capture sprite
    write_coord(origin[0])
    write_coord(origin[1])
    write_coord(origin[2]+20)
    write_coord(origin[0])
    write_coord(origin[1])
    write_coord(origin[2]+80)
    write_short(g_short)
    write_byte(20)
    write_byte(20)
    write_byte(4)
    write_byte(20)
    write_byte(10)
    message_end()
}

public grab_eff_zd(id, target)
{
    new origin[3]
    get_user_origin(id, origin, 3)

    message_begin(MSG_BROADCAST,SVC_TEMPENTITY);
    write_byte(TE_BREAKMODEL); //TE_
    write_coord(origin[0]); // X
    write_coord(origin[1]); //Y
    write_coord(origin[2] + 24); // Z
    write_coord(16); // size X
    write_coord(16); // size Y
    write_coord(16); // size Z
    write_coord(random_num(-50,50)); //velocity X
    write_coord(random_num(-50,50)); // velocity Y
    write_coord(25); // velocity Z
    write_byte(10); // random velocity
    write_short(model_gibs); // sprite
    write_byte(9); // count
    write_byte(20); // life
    write_byte(0x08); // flags
    message_end();  
}
   
public push(id)
{
    client_data[id][FLAGS] ^= CDF_IN_PUSH
    return PLUGIN_HANDLED
}

public pull(id)
{
    ChatColor(id, "%L", id, "CHAT_6")
    client_data[id][FLAGS] ^= CDF_IN_PULL
    return PLUGIN_HANDLED
}

public push2(id)
{
    if( client_data[id][GRABBED] > 0 )
    {
        do_push(id)
        return PLUGIN_HANDLED
    }
    return PLUGIN_CONTINUE
}

public pull2(id)
{
    if( client_data[id][GRABBED] > 0 )
    {
        do_pull(id)
        return PLUGIN_HANDLED
    }
    return PLUGIN_CONTINUE
}

public do_push(id)
    if( client_data[id][GRAB_LEN] < 9999 )
        client_data[id][GRAB_LEN] += get_pcvar_num( p_speed )

public do_pull( id )
{
    new mindist = get_pcvar_num( p_min_dist )
    new len = client_data[id][GRAB_LEN]
   
    if( len > mindist )
    {
        len -= get_pcvar_num( p_speed )
        if( len < mindist ) len = mindist
        client_data[id][GRAB_LEN] = len
    }
    else if( get_pcvar_num( p_auto_choke ) )
        do_choke(id)
}

public do_choke( id )
{
    new target = client_data[id][GRABBED]
    if( client_data[id][FLAGS] & CDF_NO_CHOKE || id == target || target > MAXPLAYERS) return
   
    new dmg = get_pcvar_num( p_choke_dmg )
    new vec[3]
    FVecIVec( get_target_origin_f( target), vec )
   
    message_begin( MSG_ONE, SVC_SCREENSHAKE, _, target )
    write_short( 999999 ) //amount
    write_short( 9999 ) //duration
    write_short( 999 ) //frequency
    message_end( )
   
    message_begin( MSG_ONE, SVC_SCREENFADE, _, target )
    write_short( 9999 ) //duration
    write_short( 100 ) //hold
    write_short( SF_FADE_MODULATE ) //flags
    write_byte( 200 ) //r
    write_byte( 0 ) //g
    write_byte( 0 ) //b
    write_byte( 200 ) //a
    message_end( )
   
    message_begin( MSG_ONE, WTF_DAMAGE, _, target )
    write_byte( 0 ) //damage armor
    write_byte(dmg) //damage health
    write_long( DMG_CRUSH ) //damage type
    write_coord( vec[0] ) //origin[x]
    write_coord( vec[1] ) //origin[y]
    write_coord( vec[2] ) //origin[z]
    message_end( )
       
    message_begin( MSG_BROADCAST, SVC_TEMPENTITY )
    write_byte(TE_BLOODSTREAM)
    write_coord( vec[0] ) //pos.x
    write_coord( vec[1] ) //pos.y
    write_coord( vec[2] + 15 ) //pos.z
    write_coord( random_num( 0, 255 ) ) //vec.x
    write_coord( random_num( 0, 255 ) ) //vec.y
    write_coord( random_num( 0, 255 ) ) //vec.z
    write_byte( 70 ) //col index
    write_byte( random_num( 50, 250 ) ) //speed
    message_end( )
   
    new health = pev( target, pev_health ) - dmg
    set_pev( target, pev_health, float( health ) )
    if( health < 1 ) dllfunc( DLLFunc_ClientKill, target )
   
    emit_sound( target, CHAN_BODY, "player/PL_PAIN2.WAV", VOL_NORM, ATTN_NORM, 0, PITCH_NORM )
   
    client_data[id][FLAGS] ^= CDF_NO_CHOKE
    set_task( get_pcvar_float( p_choke_time ), "clear_no_choke", TSK_CHKE + id )
}

public clear_no_choke( tskid )
{
    new id = tskid - TSK_CHKE
    client_data[id][FLAGS] ^= CDF_NO_CHOKE
}

//Grabs the client and teleports them to the admin
public force_grab(id, level, cid)
{
    if( !cmd_access( id, level, cid, 1 ) || !get_pcvar_num( p_enabled ) ) return PLUGIN_HANDLED

    new arg[33]
    read_argv( 1, arg, 32 )

    new targetid = cmd_target( id, arg, 1 )
   
    if( is_grabbed( targetid, id ) ) return PLUGIN_HANDLED
    if( !is_user_alive( targetid ) )
    {
        return PLUGIN_HANDLED
    }
   
    //Safe to tp target to aim spot?
    new Float:tmpvec[3], Float:orig[3], Float:torig[3], Float:trace_ret[3]
    new bool:safe = false, i
   
    get_view_pos( id, orig )
    tmpvec = vel_by_aim( id, get_pcvar_num( p_min_dist ) )
   
    for( new j = 1; j < 11 && !safe; j++ )
    {
        torig[0] = orig[0] + tmpvec[i] * j
        torig[1] = orig[1] + tmpvec[i] * j
        torig[2] = orig[2] + tmpvec[i] * j
       
        traceline( tmpvec, torig, id, trace_ret )
       
        if( get_distance_f( trace_ret, torig ) ) break
       
        engfunc( EngFunc_TraceHull, torig, torig, 0, HULL_HUMAN, 0, 0 )
        if ( !get_tr2( 0, TR_StartSolid ) && !get_tr2( 0, TR_AllSolid ) && get_tr2( 0, TR_InOpen ) )
            safe = true
    }
   
    //Still not safe? Then find another safe spot somewhere around the grabber
    pev( id, pev_origin, orig )
    new try[3]
    orig[2] += 2
    while( try[2] < 3 && !safe )
    {
        for( i = 0; i < 3; i++ )
            switch( try[i] )
            {
                case 0 : torig[i] = orig[i] + ( i == 2 ? 80 : 40 )
                case 1 : torig[i] = orig[i]
                case 2 : torig[i] = orig[i] - ( i == 2 ? 80 : 40 )
            }
       
        traceline( tmpvec, torig, id, trace_ret )
       
        engfunc( EngFunc_TraceHull, torig, torig, 0, HULL_HUMAN, 0, 0 )
        if ( !get_tr2( 0, TR_StartSolid ) && !get_tr2( 0, TR_AllSolid ) && get_tr2( 0, TR_InOpen )
                && !get_distance_f( trace_ret, torig ) ) safe = true
       
        try[0]++
        if( try[0] == 3 )
        {
            try[0] = 0
            try[1]++
            if( try[1] == 3 )
            {
                try[1] = 0
                try[2]++
            }
        }
    }
   
    if(safe)
    {
        set_pev( targetid, pev_origin, torig )
        set_grabbed( id, targetid )
    }

    return PLUGIN_HANDLED
}

public is_grabbed( target, grabber )
{
    for( new i = 1; i <= MAXPLAYERS; i++ )
        if( client_data[i][GRABBED] == target )
        {
            unset_grabbed( grabber )
            return true
        }
    return false
}

public DeathMsg( )
    kill_grab( read_data( 2 ) )

public client_disconnected( id )
{
    kill_grab(id)
    speed_off[id] = false
    return PLUGIN_CONTINUE
}

public kill_grab(id)
{
    //If given client has grabbed, or has a grabber, unset it
    if( client_data[id][GRABBED] )
        unset_grabbed( id )
    else if( client_data[id][GRABBER] )
        unset_grabbed( client_data[id][GRABBER] )
}

stock traceline( const Float:vStart[3], const Float:vEnd[3], const pIgnore, Float:vHitPos[3] )
{
    engfunc( EngFunc_TraceLine, vStart, vEnd, 0, pIgnore, 0 )
    get_tr2( 0, TR_vecEndPos, vHitPos )
    return get_tr2( 0, TR_pHit )
}

stock get_view_pos( const id, Float:vViewPos[3] )
{
    new Float:vOfs[3]
    pev( id, pev_origin, vViewPos )
    pev( id, pev_view_ofs, vOfs )      
   
    vViewPos[0] += vOfs[0]
    vViewPos[1] += vOfs[1]
    vViewPos[2] += vOfs[2]
}

stock Float:vel_by_aim( id, speed = 1 )
{
    new Float:v1[3], Float:vBlah[3]
    pev( id, pev_v_angle, v1 )
    engfunc( EngFunc_AngleVectors, v1, v1, vBlah, vBlah )
   
    v1[0] *= speed
    v1[1] *= speed
    v1[2] *= speed
   
    return v1
}
stock fm_give_item(index, const item[])
{
    if (!equal(item, "weapon_", 7) && !equal(item, "ammo_", 5) && !equal(item, "item_", 5) && !equal(item, "tf_weapon_", 10))
        return 0

    new ent = engfunc(EngFunc_CreateNamedEntity, engfunc(EngFunc_AllocString, item))
    if (!pev_valid(ent))
        return 0

    new Float:origin[3];
    pev(index, pev_origin, origin)
    set_pev(ent, pev_origin, origin)
    set_pev(ent, pev_spawnflags, pev(ent, pev_spawnflags) | SF_NORESPAWN)
    dllfunc(DLLFunc_Spawn, ent)

    new save = pev(ent, pev_solid)
    dllfunc(DLLFunc_Touch, ent, index)
    if (pev(ent, pev_solid) != save)
        return ent

    engfunc(EngFunc_RemoveEntity, ent)

    return -1
}

stock fm_strip_user_weapons(id)
{
        static ent
        ent = engfunc(EngFunc_CreateNamedEntity, engfunc(EngFunc_AllocString, "player_weaponstrip"))
        if (!pev_valid(ent)) return;
     
        dllfunc(DLLFunc_Spawn, ent)
        dllfunc(DLLFunc_Use, ent, id)
        engfunc(EngFunc_RemoveEntity, ent)
}

stock ChatColor(const id, const input[], any:...)
{
    new count = 1, players[32]
    static msg[191]
    vformat(msg, 190, input, 3)
   
    replace_all(msg, 190, "!g", "^4")
    replace_all(msg, 190, "!y", "^1")
    replace_all(msg, 190, "!team", "^3")
   
    if (id) players[0] = id; else get_players(players, count, "ch")
    {
        for (new i = 0; i < count; i++)
        {
            if (is_user_connected(players[i]))
            {
                message_begin(MSG_ONE_UNRELIABLE, get_user_msgid("SayText"), _, players[i]);
                write_byte(players[i]);
                write_string(msg);
                message_end();
            }
        }
    }
}
 
В этой теме было размещено решение! Перейти к решению.
Последнее редактирование:
Сообщения
18
Реакции
0
Помог
1 раз(а)
Алексеич, yeah server is not showing any info about crash :/ it's only show
this
JavaScript:
-------------------------------------------- -
CRASH: Sun Feb 18 04:39:49 CET 2024
Start Line: ./hlds_linux -game cstrike +ip 51.195.97.176 -port 27017 +maxplayers 32 +map ze_area51_lg +mapchangecfgfile server.cfg +fps_max 333 +sys_ticrate 333 +heapsize 512000 -zone 2048 -num_edicts 2048 -nobreak pad -master -edicts 2048
End of crash report
----------------------------------------------
----------------------------------------------
CRASH: Sun Feb 18 12:51:44 CET 2024
Start Line: ./hlds_linux -game cstrike +ip 51.195.97.176 -port 27017 +maxplayers 32 +map ze_area51_lg +mapchangecfgfile server.cfg +fps_max 333 +sys_ticrate 333 +heapsize 512000 -zone 2048 -num_edicts 2048 -nobreak pad -master -edicts 2048
End of crash report
----------------------------------------------
----------------------------------------------
CRASH: Sun Feb 18 19:40:59 CET 2024
Start Line: ./hlds_linux -game cstrike +ip 51.195.97.176 -port 27017 +maxplayers 32 +map ze_area51_lg +mapchangecfgfile server.cfg +fps_max 333 +sys_ticrate 333 +heapsize 512000 -zone 2048 -num_edicts 2048 -nobreak pad -master -edicts 2048
End of crash report
----------------------------------------------
 
Сообщения
3,593
Реакции
1,577
Помог
141 раз(а)
 
Сообщения
220
Реакции
23
Помог
6 раз(а)
Введите эту команду в консоли сервера перед включением плагина. Расскажите нам, какая информация возвращается: rescount
FIxFastDL
ConnorMcLeod написал(а):
Из-за последних обновлений этот плагин больше не полезен, не одобрен и заблокирован.
 
Сообщения
18
Реакции
0
Помог
1 раз(а)
Enter this command in the server console before enabling the plugin. Tell us what information is returned: rescount
before enable

Type: Total Limit

model: 334 510
sound: 345 511
generic: 40 4096
event: 29 255
decal: 225 511
------------------------

After enable
rescount

Type: Total Limit

model: 350 510
sound: 347 511
generic: 35 4096
event: 30 255
decal: 225 511
------------------------
 
Сообщения
14
Реакции
2
Помог
1 раз(а)
Если есть возможность посмотреть ХЛТВ что делают с грабом что вызывает краш либо еще лучше получить демо от игрока.
 
Сообщения
3,593
Реакции
1,577
Помог
141 раз(а)
xpombi4, гадать долго можно, нужен хотя бы краш-лог
 
Сообщения
14
Реакции
2
Помог
1 раз(а)
Nordic Warrior, ну это да, по своим методикам просто, порой проще понять происхождение когда понимаешь что делалось, какой отрывок кода задействован был
 
Сообщения
220
Реакции
23
Помог
6 раз(а)
kuniiiz, предоставляет данные из этих файлов, если они существуют:
  • qconsole.log
  • cstrike/sys_error.log
  • cstrike/addons/amxmodx/logs/error_2024xxx.log
 
Сообщения
18
Реакции
0
Помог
1 раз(а)
I Fixed it, you can lock this thread, thx for your help guys
 
Статус
В этой теме нельзя размещать новые ответы.

Пользователи, просматривающие эту тему

Сверху Снизу