Не работает плагин ассистов

Статус
В этой теме нельзя размещать новые ответы.
Сообщения
61
Реакции
-5
Ошибка
[ReAPI] RegisterHookChain: function (SV_WriteFullClientUpdate) is not available, ReHLDS required.
[AMXX] Displaying debug trace (plugin "next21_kill_assist.amxx", version "1.3c")
[AMXX] Run time error 10: native error (native "RegisterHookChain")
[AMXX] [0] next21_kill_assist.sma::plugin_init (line 64)
ОС
Windows
Amx Mod X
AMX Mod X 1.10.0.5445
Билд
Protocol version 48
Exe version 1.1.2.7/Stdio (cstrike)
ReHLDS version: 3.10.0.759-dev
ReGamedll
ReGameDLL version: 5.21.0.576-dev
Версия Metamod
Metamod-r v1.3.0.131, API (5:13)
Список метамодулей
[ 1] SafeNameAndChat  RUN   -    safenameandchat.dll     v1.2 Beta 3      ini  ANY   ANY
[ 2] AMX Mod X RUN - amxmodx_mm.dll v1.10.0.5445 ini Start ANY
[ 3] Reunion RUN - reunion_mm.dll v0.1.92d ini Start Never
[ 4] Rechecker RUN - rechecker_mm.dll v2.7 ini Chlvl ANY
[ 5] ReAuthCheck RUN - reauthcheck_mm.dll v0.1.6 ini Start Never
[ 6] Revoice RUN - revoice_mm.dll v0.1.0.36 ini Start Never
[ 7] WHBlocker RUN - whblocker_mm.dll v1.5.697 ini Chlvl ANY
[ 8] ReSemiclip RUN - resemiclip_mm.dll v2.3.9 ini Chlvl ANY
[ 9] ReAPI RUN - reapi_amxx.dll v5.22.0.254-dev pl2 ANY Never
[10] ReAimDetector RUN - reaimdetector_amxx.dll v0.2.2 pl2 ANY Never
[11] hackdetector RUN - hackdetector_amxx.dll v0.15.328.lite pl2 ANY ANY
[12] CStrike RUN - cstrike_amxx.dll v1.10.0.5445 pl2 ANY ANY
[13] FakeMeta RUN - fakemeta_amxx.dll v1.10.0.5445 pl2 ANY ANY
[14] Fun RUN - fun_amxx.dll v1.10.0.5445 pl2 ANY ANY
[15] Engine RUN - engine_amxx.dll v1.10.0.5445 pl2 ANY ANY
[16] Ham Sandwich RUN - hamsandwich_amxx.dll v1.10.0.5445 pl2 ANY ANY
Список плагинов
[  1] 0   Admin Base              1.10.0.544  AMXX Dev Team                                      admin.amxx   running  
[ 2] 1 Admin Commands 1.10.0.544 AMXX Dev Team admincmd.am running
[ 3] 2 Slots Reservation 1.10.0.544 AMXX Dev Team adminslots. running
[ 4] 3 Commands Menu 1.10.0.544 AMXX Dev Team cmdmenu.amx running
[ 5] 4 Players Menu 1.10.0.544 AMXX Dev Team plmenu.amxx running
[ 6] 5 Maps Menu 1.10.0.544 AMXX Dev Team mapsmenu.am running
[ 7] 6 Admin Chat 1.10.0.544 AMXX Dev Team adminchat.a running
[ 8] 7 Admin Votes 1.10.0.544 AMXX Dev Team adminvote.a running
[ 9] 8 Pause Plugins 1.10.0.544 AMXX Dev Team pausecfg.am running
[ 10] 9 Stats Configuration 1.10.0.544 AMXX Dev Team statscfg.am running
[ 11] 10 Restrict Weapons 1.10.0.544 AMXX Dev Team restmenu.am running
[ 12] 11 ReAPI Test 1.0 s1lent reapi_test. running
[ 13] 12 ReAimDetector API 0.2.2 ReHLDS Team reaimdetect running
[ 14] 13 HackDetector 0.15.lite Lev @ AGHL.RU De hackdetecto running
[ 15] 14 [Customizable] AmxModM 0.0.5 Albertio amxmodmenu. running
[ 16] 15 GameName Changer 1.0.0 Nordic Warrior gamenamecha running
[ 17] 16 Reset Score 1.0 Silenttt resetscore. running
[ 18] 17 FocusOnVotemap 1.2.1 Boec[SpecOPs] focus_on_vo running
[ 19] 18 Team Select 1.6.0 F@nt0M teamselect. running
[ 20] 19 Chat Manager 1.1.2-16 Mistrick chatmanager running
[ 21] 20 Chat Manager: Addon 0.0.4-70 Mistrick chatmanager running
[ 22] 21 Potti 1.40 p3tsin potti.amxx running
[ 23] 22 Меню потти Only Locky pottimenu.a running
[ 24] 23 mute 1.0 Aziz mute.amxx running
[ 25] 24 Parachute 1.0 maeStro parachute.a running
[ 26] 25 Menu 1.0 WaT_1 menu.amxx running
[ 27] 26 Say me and Say hp 1.4 neygomon killerhp.am running
[ 28] 27 Simple Damager 2.1.0 fl0wer simple_dama running
[ 29] 28 Advanced Kill Assists 1.3c Xelson next21_kill debug
[ 30] 29 Map Manager: Core 3.1.5 Mistrick map_manager running
[ 31] 30 Map Manager: Scheduler 0.1.10 Mistrick map_manager running
[ 32] 31 Map Manager: Rtv 0.1.1 Mistrick map_manager running
[ 33] 32 Map Manager: Effects 0.1.1 Mistrick map_manager running
[ 34] 33 Map Manager: Informer 0.0.5 Mistrick map_manager running
[ 35] 34 Map Manager: Sounds 0.0.2 Mistrick map_manager running
35 plugins, 35 running
Автор плагина
Xelson
Версия плагина
1.3c
Исходный код
#include <amxmodx>
#include <reapi>
#tryinclude <aes_v>

#define CONFIG_FILE "adv_kill_assist.cfg"

#define NAMES_LENGTH 28
#define is_user_valid(%0) (0 < %0 && %0 < g_iMaxPlayers)

#if AMXX_VERSION_NUM < 183
#define client_disconnected client_disconnect
#endif

#if REAPI_VERSION < 52121
#error This plugin supports ReAPI >=5.2.0.121
#endif

//#define DEBUG

enum
{
ALGORITHM_CSSTATSX,
ALGORITHM_ADVANCED
}

enum _:CVARS_DATA
{
CVAR_FRAG,
CVAR_MONEY,
CVAR_EXP,
CVAR_DAMAGE,
CVAR_ALGORITHM,
CVAR_MESSAGE
}

enum _:PLAYER_DATA
{
DAMAGE_ON[33],
Float:DAMAGE_ON_TIME[33],
NAME[32]
}
new g_ePlayerData[33][PLAYER_DATA], g_pCvars[CVARS_DATA], g_iMaxPlayers, g_iMsgScoreInfo
new HookChain:g_pSV_WriteFullClientUpdate, HookChain:g_pCBasePlayer_Killed_Post, g_szDeathString[32], g_iAssistKiller
new g_pCvarAssistHp

public plugin_natives()
{
set_native_filter("plugin_native_filter")
}

public plugin_native_filter(szNative[], iIndex, bool:bTrap)
{
return PLUGIN_HANDLED
}

public plugin_init()
{
register_plugin("Advanced Kill Assists", "1.3c", "Xelson")

RegisterHookChain(RG_CBasePlayer_Spawn, "CBasePlayer_Spawn_Post", true)
RegisterHookChain(RG_CBasePlayer_Killed, "CBasePlayer_Killed_Pre", false)
RegisterHookChain(RG_CBasePlayer_TakeDamage, "CBasePlayer_TakeDamage_Pre", false)
DisableHookChain((g_pCBasePlayer_Killed_Post = RegisterHookChain(RG_CBasePlayer_Killed, "CBasePlayer_Killed_Post", true)))
DisableHookChain((g_pSV_WriteFullClientUpdate = RegisterHookChain(RH_SV_WriteFullClientUpdate, "SV_WriteFullClientUpdate", false)))
register_message(get_user_msgid("DeathMsg"), "Message_DeathMsg")

#if defined DEBUG
register_clcmd("assist", "ClCmd_Assist")
#endif

g_pCvarAssistHp = get_cvar_pointer("csstats_sql_assisthp")
g_iMsgScoreInfo = get_user_msgid("ScoreInfo")
g_iMaxPlayers = get_maxplayers() + 1
}

public plugin_cfg()
{
g_pCvars[CVAR_FRAG] = register_cvar("aka_frag", "1")
g_pCvars[CVAR_MONEY] = register_cvar("aka_money", "100")
g_pCvars[CVAR_EXP] = register_cvar("aka_exp", "0")
g_pCvars[CVAR_DAMAGE] = register_cvar("aka_damage", "30.0")
g_pCvars[CVAR_ALGORITHM] = register_cvar("aka_algorithm", "1")
g_pCvars[CVAR_MESSAGE] = register_cvar("aka_message", "!g[AKA]!y Вы получили !g[award]$!y за помощь !t[killer]!y в убийстве !t[victim]!y!")

new szConfigFile[256]
get_localinfo("amxx_configsdir", szConfigFile, charsmax(szConfigFile))
formatex(szConfigFile, charsmax(szConfigFile), "%s/%s", szConfigFile, CONFIG_FILE)
server_cmd("exec ^"%s^"", szConfigFile)
}

public client_infochanged(id)
{
get_user_info(id, "name", g_ePlayerData[id][NAME], charsmax(g_ePlayerData[][NAME]))
}

public client_disconnected(id)
{
arrayset(g_ePlayerData[id][DAMAGE_ON], 0, sizeof g_ePlayerData[][DAMAGE_ON])
for(new i = 1; i < g_iMaxPlayers; i++) g_ePlayerData[i][DAMAGE_ON][id] = 0
}

public CBasePlayer_Spawn_Post(id)
{
arrayset(g_ePlayerData[id][DAMAGE_ON], 0, sizeof g_ePlayerData[][DAMAGE_ON])
for(new i = 1; i < g_iMaxPlayers; i++) g_ePlayerData[i][DAMAGE_ON][id] = 0
}

public CBasePlayer_TakeDamage_Pre(iVictim, iWeapon, iAttacker, Float:fDamage)
{
if(is_user_valid(iAttacker) && iVictim != iAttacker && rg_is_player_can_takedamage(iVictim, iAttacker))
{
if(get_pcvar_num(g_pCvars[CVAR_ALGORITHM]) == ALGORITHM_ADVANCED)
{
new Float:fHealth; get_entvar(iVictim, var_health, fHealth)
if(fDamage > fHealth) fDamage = fHealth
}
g_ePlayerData[iAttacker][DAMAGE_ON][iVictim] += floatround(fDamage)
g_ePlayerData[iAttacker][DAMAGE_ON_TIME][iVictim] = get_gametime()
}
}

public CBasePlayer_Killed_Pre(iVictim, iKiller)
{
new iAssistant, iMaxDamage
new Float:fDamageForAssist = get_pcvar_float(g_pCvars[CVAR_DAMAGE])

switch(get_pcvar_num(g_pCvars[CVAR_ALGORITHM]))
{
case ALGORITHM_ADVANCED:
{
new iTotalDamage
for(new id = 1; id < g_iMaxPlayers; id++)
{
if(is_user_connected(id))
{
if(id != iKiller && g_ePlayerData[id][DAMAGE_ON][iVictim] > 0)
{
if(g_ePlayerData[id][DAMAGE_ON][iVictim] > iMaxDamage)
{
iAssistant = id
iMaxDamage = g_ePlayerData[id][DAMAGE_ON][iVictim]
}
else if(g_ePlayerData[id][DAMAGE_ON][iVictim] == iMaxDamage)
iAssistant = g_ePlayerData[id][DAMAGE_ON_TIME][iVictim] > g_ePlayerData[iAssistant][DAMAGE_ON_TIME][iVictim] ? id : iAssistant
}
iTotalDamage += g_ePlayerData[id][DAMAGE_ON][iVictim]
}
}
if((float(iMaxDamage) / float(iTotalDamage)) * 100.0 < fDamageForAssist) iAssistant = 0
}
case ALGORITHM_CSSTATSX:
{
new iNeedDamage = g_pCvarAssistHp ? get_pcvar_num(g_pCvarAssistHp) : floatround(fDamageForAssist)
for(new id = 1; id < g_iMaxPlayers; id++)
{
if(is_user_connected(id) && id != iKiller && g_ePlayerData[id][DAMAGE_ON][iVictim] > iMaxDamage)
{
if(g_ePlayerData[id][DAMAGE_ON][iVictim] > iNeedDamage)
{
iAssistant = id
iMaxDamage = g_ePlayerData[id][DAMAGE_ON][iVictim]
}
else if(g_ePlayerData[id][DAMAGE_ON][iVictim] == iNeedDamage)
iAssistant = g_ePlayerData[id][DAMAGE_ON_TIME][iVictim] > g_ePlayerData[iAssistant][DAMAGE_ON_TIME][iVictim] ? id : iAssistant
}
}
}
}

if(!iAssistant || iKiller == iVictim) return HC_CONTINUE

new szName[2][32], iLen[2], iExcess
copy(szName[1], charsmax(szName[]), g_ePlayerData[iAssistant][NAME])
iLen[1] = strlen(szName[1])

EnableHookChain(g_pSV_WriteFullClientUpdate)

static const szWorldName[] = "world"
new bool:bIsAssistantConnected = bool:is_user_connected(iAssistant)

if(!is_user_valid(iKiller))
{
if(bIsAssistantConnected)
{
iExcess = iLen[1] - NAMES_LENGTH - (sizeof szWorldName)
if(iExcess > 0) strclip(szName[1], iExcess)
formatex(g_szDeathString, charsmax(g_szDeathString), "%s + %s", szWorldName, szName[1])

g_iAssistKiller = iAssistant
rh_update_user_info(iAssistant)
}
}
else if(is_user_connected(iKiller))
{
g_ePlayerData[iKiller][DAMAGE_ON][iVictim] = 0

copy(szName[0], charsmax(szName[]), g_ePlayerData[iKiller][NAME])
iLen[0] = strlen(szName[0])

new iLenSum = (iLen[0] + iLen[1])
iExcess = iLenSum - NAMES_LENGTH

if(iExcess > 0)
{
new iLongest = iLen[0] > iLen[1] ? 0 : 1
new iShortest = iLongest == 1 ? 0 : 1

if(float(iExcess) / float(iLen[iLongest]) > 0.60)
{
new iNewLongest = floatround(float(iLen[iLongest]) / float(iLenSum) * float(iExcess))
strclip(szName[iLongest], iNewLongest)
strclip(szName[iShortest], iExcess - iNewLongest)
}
else strclip(szName[iLongest], iExcess)
}
formatex(g_szDeathString, charsmax(g_szDeathString), "%s + %s", szName[0], szName[1])

g_iAssistKiller = iKiller
rh_update_user_info(g_iAssistKiller)
}
if(bIsAssistantConnected)
{
g_ePlayerData[iAssistant][DAMAGE_ON][iVictim] = 0

new iAddMoney = get_pcvar_num(g_pCvars[CVAR_MONEY])
new iAddExp = get_pcvar_num(g_pCvars[CVAR_EXP])

if(iAddMoney > 0 || iAddExp > 0)
{
if(iAddMoney > 0) rg_add_account(iAssistant, iAddMoney)
#if defined aes_add_player_exp_f
if(iAddExp > 0) aes_add_player_exp_f(iAssistant, float(iAddExp))
#endif

new szMessage[192], szMoney[16], szExp[16], szKillerName[32]
get_pcvar_string(g_pCvars[CVAR_MESSAGE], szMessage, charsmax(szMessage))
if(szMessage[0])
{
num_to_str(iAddMoney, szMoney, charsmax(szMoney))
num_to_str(iAddExp, szExp, charsmax(szExp))
if(is_user_valid(iKiller)) copy(szKillerName, charsmax(szKillerName), g_ePlayerData[iKiller][NAME])

replace_all(szMessage, charsmax(szMessage), "[award]", szMoney)
replace_all(szMessage, charsmax(szMessage), "[exp]", szExp)
replace_all(szMessage, charsmax(szMessage), "[killer]", szKillerName)
replace_all(szMessage, charsmax(szMessage), "[victim]", g_ePlayerData[iVictim][NAME])

UTIL_SayText(iAssistant, szMessage)
}
}

if(get_pcvar_num(g_pCvars[CVAR_FRAG]))
{
new Float:fNewFrags; get_entvar(iAssistant, var_frags, fNewFrags)
fNewFrags++
set_entvar(iAssistant, var_frags, fNewFrags)

message_begin(MSG_ALL, g_iMsgScoreInfo)
write_byte(iAssistant)
write_short(floatround(fNewFrags))
write_short(get_member(iAssistant, m_iDeaths))
write_short(0)
write_short(get_member(iAssistant, m_iTeam))
message_end()
}
}

DisableHookChain(g_pSV_WriteFullClientUpdate)
if(g_iAssistKiller) EnableHookChain(g_pCBasePlayer_Killed_Post)

return HC_CONTINUE
}

public SV_WriteFullClientUpdate(id, pBuffer)
{
if(id == g_iAssistKiller)
set_key_value(pBuffer, "name", g_szDeathString)
}

public Message_DeathMsg()
{
new iWorld = get_msg_arg_int(1)
if(iWorld == 0 && g_iAssistKiller)
set_msg_arg_int(1, ARG_BYTE, g_iAssistKiller)
}

public CBasePlayer_Killed_Post(iVictim, iKiller)
{
DisableHookChain(g_pCBasePlayer_Killed_Post)

new iAssistKiller = g_iAssistKiller; g_iAssistKiller = 0
rh_update_user_info(iAssistKiller)
}

strclip(szString[], iClip, szEnding[] = "..")
{
new iLen = strlen(szString) - 1 - strlen(szEnding) - iClip
format(szString[iLen], iLen, szEnding)
}

UTIL_SayText(id, const szMessage[], any:...)
{
new szBuffer[190];
static iMsgSayText
if(!iMsgSayText) iMsgSayText = get_user_msgid("SayText")
if(numargs() > 2) vformat(szBuffer, charsmax(szBuffer), szMessage, 3);
else copy(szBuffer, charsmax(szBuffer), szMessage);
while(replace(szBuffer, charsmax(szBuffer), "!y", "^1")) {}
while(replace(szBuffer, charsmax(szBuffer), "!t", "^3")) {}
while(replace(szBuffer, charsmax(szBuffer), "!g", "^4")) {}
switch(id)
{
case 0:
{
for(new i = 1; i < g_iMaxPlayers; i++)
{
if(!is_user_connected(i)) continue
message_begin(MSG_ONE_UNRELIABLE, iMsgSayText, .player = i)
write_byte(i);
write_string(szBuffer);
message_end();
}
}
default:
{
message_begin(MSG_ONE_UNRELIABLE, iMsgSayText, .player = id)
write_byte(id);
write_string(szBuffer);
message_end();
}
}
return 0
}

#if defined DEBUG
#include <hamsandwich>
public ClCmd_Assist()
{
new id[4], szArg[64]
for(new i; i < 4; i++)
{
read_argv(i + 1, szArg, charsmax(szArg))
id[i] = str_to_num(szArg)
}
g_ePlayerData[id[1]][DAMAGE_ON][id[2]] = id[3] ? id[3] : 100
ExecuteHamB(Ham_Killed, id[2], id[0], 0)
ExecuteHamB(Ham_CS_RoundRespawn, id[2])
}
#endif
Пишет эту ошибку в консоли с включенным дебагом. Перед тем как писать решение, обратите внимание, если вы до сих не увидили, что у меня не Linux, а Windows.
 
В этой теме было размещено решение! Перейти к решению.
Сообщения
1,344
Реакции
529
Помог
91 раз(а)
требует обновить ReHLDS
 
Статус
В этой теме нельзя размещать новые ответы.

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

Сейчас на форуме нет ни одного пользователя.
Сверху Снизу