mirror of
https://github.com/alliedmodders/amxmodx.git
synced 2025-01-26 05:38:04 +03:00
Merge pull request #228 from Arkshine/fix/crash-ham
Fix crash under linux in Hamsandwich module (bug 6323)
This commit is contained in:
commit
4d97a24dd8
@ -16,6 +16,8 @@
|
||||
#ifndef FORWARD_H
|
||||
#define FORWARD_H
|
||||
|
||||
#include <am-refcounting.h>
|
||||
|
||||
enum fwdstate
|
||||
{
|
||||
FSTATE_INVALID = 0,
|
||||
@ -25,7 +27,7 @@ enum fwdstate
|
||||
FSTATE_DESTROY
|
||||
};
|
||||
|
||||
class Forward
|
||||
class Forward :public ke::Refcounted<Forward>
|
||||
{
|
||||
public:
|
||||
int id; // id of the forward
|
||||
|
@ -89,12 +89,12 @@ public:
|
||||
|
||||
for (size_t i = 0; i < pre.length(); ++i)
|
||||
{
|
||||
delete pre.at(i);
|
||||
pre.at(i)->Release();
|
||||
}
|
||||
|
||||
for (size_t i = 0; i < post.length(); ++i)
|
||||
{
|
||||
delete post.at(i);
|
||||
post.at(i)->Release();
|
||||
}
|
||||
|
||||
pre.clear();
|
||||
|
@ -583,6 +583,7 @@ static cell AMX_NATIVE_CALL RegisterHam(AMX *amx, cell *params)
|
||||
}
|
||||
|
||||
Forward *pfwd = new Forward(fwd);
|
||||
pfwd->AddRef();
|
||||
|
||||
// We've passed all tests...
|
||||
if (strcmp(classname, "player") == 0 && enableSpecialBot)
|
||||
@ -676,6 +677,9 @@ static cell AMX_NATIVE_CALL RegisterHamFromEntity(AMX *amx, cell *params)
|
||||
|
||||
// We've passed all tests...
|
||||
|
||||
Forward *pfwd = new Forward(fwd);
|
||||
pfwd->AddRef();
|
||||
|
||||
int **ivtable=(int **)vtable;
|
||||
|
||||
void *vfunction=(void *)ivtable[hooklist[func].vtid];
|
||||
@ -687,7 +691,6 @@ static cell AMX_NATIVE_CALL RegisterHamFromEntity(AMX *amx, cell *params)
|
||||
if (hooks[func].at(i)->tramp == vfunction)
|
||||
{
|
||||
// Yes, this function is hooked
|
||||
Forward *pfwd=new Forward(fwd);
|
||||
if (post)
|
||||
{
|
||||
hooks[func].at(i)->post.append(pfwd);
|
||||
@ -710,7 +713,6 @@ static cell AMX_NATIVE_CALL RegisterHamFromEntity(AMX *amx, cell *params)
|
||||
Hook *hook = new Hook(vtable, hooklist[func].vtid, hooklist[func].targetfunc, hooklist[func].isvoid, hooklist[func].needsretbuf, hooklist[func].paramcount, classname);
|
||||
hooks[func].append(hook);
|
||||
|
||||
Forward *pfwd=new Forward(fwd);
|
||||
if (post)
|
||||
{
|
||||
hook->post.append(pfwd);
|
||||
|
@ -84,6 +84,8 @@ void CHamSpecialBotHandler::RegisterHamSpecialBot(AMX *amx, int &func, const cha
|
||||
|
||||
void CHamSpecialBotHandler::RegisterChecked(AMX *amx, int &func, const char *function, int &post, Forward *pfwd)
|
||||
{
|
||||
pfwd->AddRef();
|
||||
|
||||
void **vtable = m_specialbot_vtable;
|
||||
int **ivtable=(int **)vtable;
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user