mirror of
https://github.com/alliedmodders/metamod-source.git
synced 2025-01-20 09:52:24 +01:00
1d9949e1a0
--HG-- rename : core-1.4/CPlugin.cpp => core-legacy/CPlugin.cpp rename : core-1.4/CPlugin.h => core-legacy/CPlugin.h rename : core-1.4/CSmmAPI.cpp => core-legacy/CSmmAPI.cpp rename : core-1.4/CSmmAPI.h => core-legacy/CSmmAPI.h rename : core-1.4/IPluginManager.h => core-legacy/IPluginManager.h rename : core-1.4/ISmmAPI.h => core-legacy/ISmmAPI.h rename : core-1.4/ISmmPlugin.h => core-legacy/ISmmPlugin.h rename : core-1.4/Makefile => core-legacy/Makefile rename : core-1.4/concommands.cpp => core-legacy/concommands.cpp rename : core-1.4/concommands.h => core-legacy/concommands.h rename : core-1.4/convar_smm.h => core-legacy/convar_smm.h rename : core-1.4/msvc7/sourcemm.sln => core-legacy/msvc7/sourcemm.sln rename : core-1.4/msvc7/sourcemm.vcproj => core-legacy/msvc7/sourcemm.vcproj rename : core-1.4/msvc8/sourcemm.sln => core-legacy/msvc8/sourcemm.sln rename : core-1.4/msvc8/sourcemm.vcproj => core-legacy/msvc8/sourcemm.vcproj rename : core-1.4/msvc9/sourcemm.sln => core-legacy/msvc9/sourcemm.sln rename : core-1.4/msvc9/sourcemm.vcproj => core-legacy/msvc9/sourcemm.vcproj rename : core-1.4/oslink.cpp => core-legacy/oslink.cpp rename : core-1.4/oslink.h => core-legacy/oslink.h rename : core-1.4/sourcehook.cpp => core-legacy/sourcehook.cpp rename : core-1.4/sourcehook/FastDelegate.h => core-legacy/sourcehook/FastDelegate.h rename : core-1.4/sourcehook/generate/FastDelegate.h => core-legacy/sourcehook/generate/FastDelegate.h rename : core-1.4/sourcehook/generate/FastDelegate.hxx => core-legacy/sourcehook/generate/FastDelegate.hxx rename : core-1.4/sourcehook/generate/generate => core-legacy/sourcehook/generate/generate rename : core-1.4/sourcehook/generate/generate.bat => core-legacy/sourcehook/generate/generate.bat rename : core-1.4/sourcehook/generate/sh_memfuncinfo.h => core-legacy/sourcehook/generate/sh_memfuncinfo.h rename : core-1.4/sourcehook/generate/sh_memfuncinfo.hxx => core-legacy/sourcehook/generate/sh_memfuncinfo.hxx rename : core-1.4/sourcehook/generate/shworker.bin => core-legacy/sourcehook/generate/shworker.bin rename : core-1.4/sourcehook/generate/shworker.exe => core-legacy/sourcehook/generate/shworker.exe rename : core-1.4/sourcehook/generate/shworker/Makefile => core-legacy/sourcehook/generate/shworker/Makefile rename : core-1.4/sourcehook/generate/shworker/fd_hopter.cpp => core-legacy/sourcehook/generate/shworker/fd_hopter.cpp rename : core-1.4/sourcehook/generate/shworker/msvc7/shworker.vcproj => core-legacy/sourcehook/generate/shworker/msvc7/shworker.vcproj rename : core-1.4/sourcehook/generate/shworker/msvc8/shworker.vcproj => core-legacy/sourcehook/generate/shworker/msvc8/shworker.vcproj rename : core-1.4/sourcehook/generate/shworker/shworker.cpp => core-legacy/sourcehook/generate/shworker/shworker.cpp rename : core-1.4/sourcehook/generate/sourcehook.h => core-legacy/sourcehook/generate/sourcehook.h rename : core-1.4/sourcehook/generate/sourcehook.hxx => core-legacy/sourcehook/generate/sourcehook.hxx rename : core-1.4/sourcehook/sh_list.h => core-legacy/sourcehook/sh_list.h rename : core-1.4/sourcehook/sh_memfuncinfo.h => core-legacy/sourcehook/sh_memfuncinfo.h rename : core-1.4/sourcehook/sh_memory.h => core-legacy/sourcehook/sh_memory.h rename : core-1.4/sourcehook/sh_stack.h => core-legacy/sourcehook/sh_stack.h rename : core-1.4/sourcehook/sh_string.h => core-legacy/sourcehook/sh_string.h rename : core-1.4/sourcehook/sh_tinyhash.h => core-legacy/sourcehook/sh_tinyhash.h rename : core-1.4/sourcehook/sh_vector.h => core-legacy/sourcehook/sh_vector.h rename : core-1.4/sourcehook/sourcehook.cpp => core-legacy/sourcehook/sourcehook.cpp rename : core-1.4/sourcehook/sourcehook.h => core-legacy/sourcehook/sourcehook.h rename : core-1.4/sourcehook/sourcehook_impl.h => core-legacy/sourcehook/sourcehook_impl.h rename : core-1.4/sourcehook/test/Makefile => core-legacy/sourcehook/test/Makefile rename : core-1.4/sourcehook/test/main.cpp => core-legacy/sourcehook/test/main.cpp rename : core-1.4/sourcehook/test/msvc7/test.vcproj => core-legacy/sourcehook/test/msvc7/test.vcproj rename : core-1.4/sourcehook/test/msvc8/test.vcproj => core-legacy/sourcehook/test/msvc8/test.vcproj rename : core-1.4/sourcehook/test/sourcehook_test.h => core-legacy/sourcehook/test/sourcehook_test.h rename : core-1.4/sourcehook/test/test1.cpp => core-legacy/sourcehook/test/test1.cpp rename : core-1.4/sourcehook/test/test2.cpp => core-legacy/sourcehook/test/test2.cpp rename : core-1.4/sourcehook/test/test3.cpp => core-legacy/sourcehook/test/test3.cpp rename : core-1.4/sourcehook/test/test4.cpp => core-legacy/sourcehook/test/test4.cpp rename : core-1.4/sourcehook/test/testbail.cpp => core-legacy/sourcehook/test/testbail.cpp rename : core-1.4/sourcehook/test/testbail.h => core-legacy/sourcehook/test/testbail.h rename : core-1.4/sourcehook/test/testbail2.cpp => core-legacy/sourcehook/test/testbail2.cpp rename : core-1.4/sourcehook/test/testevents.h => core-legacy/sourcehook/test/testevents.h rename : core-1.4/sourcehook/test/testlist.cpp => core-legacy/sourcehook/test/testlist.cpp rename : core-1.4/sourcehook/test/testmanual.cpp => core-legacy/sourcehook/test/testmanual.cpp rename : core-1.4/sourcehook/test/testmulti.cpp => core-legacy/sourcehook/test/testmulti.cpp rename : core-1.4/sourcehook/test/testrecall.cpp => core-legacy/sourcehook/test/testrecall.cpp rename : core-1.4/sourcehook/test/testreentr.cpp => core-legacy/sourcehook/test/testreentr.cpp rename : core-1.4/sourcehook/test/testref.cpp => core-legacy/sourcehook/test/testref.cpp rename : core-1.4/sourcehook/test/testrefret.cpp => core-legacy/sourcehook/test/testrefret.cpp rename : core-1.4/sourcemm.cpp => core-legacy/sourcemm.cpp rename : core-1.4/sourcemm.h => core-legacy/sourcemm.h rename : core-1.4/svn_version.h => core-legacy/svn_version.h rename : core-1.4/svn_version.tpl => core-legacy/svn_version.tpl rename : core-1.4/util.cpp => core-legacy/util.cpp rename : core-1.4/util.h => core-legacy/util.h rename : core-1.4/version.rc => core-legacy/version.rc rename : core-1.4/vsp_listener.cpp => core-legacy/vsp_listener.cpp rename : core-1.4/vsp_listener.h => core-legacy/vsp_listener.h
209 lines
7.1 KiB
C++
209 lines
7.1 KiB
C++
#include "testevents.h"
|
|
#include "sourcehook_test.h"
|
|
|
|
// Tests support for functions which return references
|
|
|
|
namespace
|
|
{
|
|
StateList g_States;
|
|
SourceHook::ISourceHook *g_SHPtr;
|
|
SourceHook::Plugin g_PLID;
|
|
|
|
MAKE_STATE_1(State_Func1_Pre1, int*); // p1: the ref Func1_Pre1 is going to return
|
|
MAKE_STATE_3(State_Func1_Pre2, META_RES, int*, int*); // p1: current status
|
|
// p2: override ret
|
|
// p3: what this handler is going to supercede with
|
|
MAKE_STATE_1(State_Func1, int*); // p1: the ref Func1 is going to return
|
|
MAKE_STATE_2(State_Func1_Post1, int*, int*); // p1: orig_ret; p2: override_ret
|
|
MAKE_STATE_1(State_Func1_Post2, int*); // p1: what it's going to return
|
|
MAKE_STATE_1(State_Func1_Ret, int*); // p1: the ref it returned
|
|
|
|
|
|
MAKE_STATE_2(State_Func2_Pre1, int, const int*); // p1: func's p1; p2: what it's going to ret
|
|
MAKE_STATE_2(State_Func2, int, const int*); // p1: func's p1; p2: what it's going to ret
|
|
MAKE_STATE_3(State_Func2_Post1, int, const int*, const int*); // p1: func's p1; p2: orig ret; p3: override ret
|
|
MAKE_STATE_1(State_Func2_Ret, const int*); // p1: ret
|
|
|
|
int g_Var;
|
|
|
|
class Test
|
|
{
|
|
public:
|
|
int m_Var1;
|
|
int m_Var2;
|
|
|
|
Test() : m_Var1(87)
|
|
{
|
|
}
|
|
|
|
virtual int& Func1()
|
|
{
|
|
ADD_STATE(State_Func1(&m_Var1));
|
|
return m_Var1;
|
|
}
|
|
virtual const int& Func2(int p1)
|
|
{
|
|
ADD_STATE(State_Func2(p1, &m_Var2));
|
|
m_Var2 = p1;
|
|
return m_Var2;
|
|
}
|
|
};
|
|
|
|
class CHook
|
|
{
|
|
public:
|
|
int m_Var;
|
|
virtual int& Func1_Pre1()
|
|
{
|
|
ADD_STATE(State_Func1_Pre1(&m_Var));
|
|
RETURN_META_VALUE(MRES_OVERRIDE, m_Var);
|
|
}
|
|
virtual int &Func1_Pre2()
|
|
{
|
|
int &overrideret = META_RESULT_OVERRIDE_RET(int&);
|
|
overrideret = 1337;
|
|
ADD_STATE(State_Func1_Pre2(META_RESULT_STATUS, &overrideret, &g_Var));
|
|
RETURN_META_VALUE(MRES_SUPERCEDE, g_Var);
|
|
}
|
|
virtual int& Func1_Post1()
|
|
{
|
|
ADD_STATE(State_Func1_Post1(&META_RESULT_ORIG_RET(int&), &META_RESULT_OVERRIDE_RET(int&)));
|
|
RETURN_META_NOREF(MRES_IGNORED, int&);
|
|
}
|
|
virtual int& Func1_Post2()
|
|
{
|
|
ADD_STATE(State_Func1_Post2(&m_Var));
|
|
RETURN_META_VALUE(MRES_OVERRIDE, m_Var);
|
|
}
|
|
|
|
virtual const int& Func2_Pre1(int p1)
|
|
{
|
|
ADD_STATE(State_Func2_Pre1(p1, &m_Var));
|
|
RETURN_META_VALUE_NEWPARAMS(MRES_OVERRIDE, m_Var, static_cast<const int& (Test::*)(int)>(&Test::Func2), (1337));
|
|
}
|
|
|
|
virtual const int& Func2_Post1(int p1)
|
|
{
|
|
ADD_STATE(State_Func2_Post1(p1, &META_RESULT_ORIG_RET(int&), &META_RESULT_OVERRIDE_RET(int&)));
|
|
RETURN_META_NOREF(MRES_IGNORED, const int&);
|
|
}
|
|
};
|
|
|
|
SH_DECL_HOOK0(Test, Func1, SH_NOATTRIB, 0, int&);
|
|
SH_DECL_HOOK1(Test, Func2, SH_NOATTRIB, 0, const int&, int);
|
|
}
|
|
|
|
bool TestRefRet(std::string &error)
|
|
{
|
|
GET_SHPTR(g_SHPtr);
|
|
g_PLID = 1;
|
|
|
|
Test test;
|
|
Test *pTest = &test;
|
|
CHook hook;
|
|
|
|
int &ret1 = pTest->Func1();
|
|
ADD_STATE(State_Func1_Ret(&ret1));
|
|
|
|
CHECK_STATES((&g_States,
|
|
new State_Func1(&test.m_Var1),
|
|
new State_Func1_Ret(&test.m_Var1),
|
|
NULL), "Part 1");
|
|
|
|
// Now add Func1_Pre1, which supercedes and returns hook.m_Var
|
|
SH_ADD_HOOK_MEMFUNC(Test, Func1, &test, &hook, &CHook::Func1_Pre1, false);
|
|
|
|
int &ret2 = pTest->Func1();
|
|
ADD_STATE(State_Func1_Ret(&ret2));
|
|
|
|
CHECK_STATES((&g_States,
|
|
new State_Func1_Pre1(&hook.m_Var), // Pre1 says that it's going to override with hook.m_Var
|
|
new State_Func1(&test.m_Var1), // Function says that it's going to return test.m_Var1
|
|
new State_Func1_Ret(&hook.m_Var), // hook.m_Var is returned
|
|
NULL), "Part 2");
|
|
|
|
// Now add Func1_Post1, which only reports orig ret and override ret
|
|
SH_ADD_HOOK_MEMFUNC(Test, Func1, &test, &hook, &CHook::Func1_Post1, true);
|
|
|
|
int &ret3 = pTest->Func1();
|
|
ADD_STATE(State_Func1_Ret(&ret3));
|
|
|
|
CHECK_STATES((&g_States,
|
|
new State_Func1_Pre1(&hook.m_Var), // Pre1 says that it's going to override with hook.m_Var
|
|
new State_Func1(&test.m_Var1), // Function says that it's going to return test.m_Var1
|
|
new State_Func1_Post1(&test.m_Var1, &hook.m_Var), // origret(=p1) is what it wanted to
|
|
// return, overrideret(=p2) is pre1's var
|
|
new State_Func1_Ret(&hook.m_Var), // hook.m_Var is returned
|
|
NULL), "Part 3");
|
|
|
|
// Now add Func1_Pre2, which supercedes and returns g_Var (it also sets the override ret from pre1 to 1337)
|
|
// and add Func1_Post2, which overrides and returns hook.m_Var again.
|
|
|
|
SH_ADD_HOOK_MEMFUNC(Test, Func1, &test, &hook, &CHook::Func1_Pre2, false);
|
|
SH_ADD_HOOK_MEMFUNC(Test, Func1, &test, &hook, &CHook::Func1_Post2, true);
|
|
|
|
int &ret4 = pTest->Func1();
|
|
ADD_STATE(State_Func1_Ret(&ret4));
|
|
|
|
CHECK_STATES((&g_States,
|
|
new State_Func1_Pre1(&hook.m_Var), // Pre1 says that it's going to override with hook.m_Var
|
|
new State_Func1_Pre2(MRES_OVERRIDE, // current status
|
|
&hook.m_Var, // override ret (which it set to 1337)
|
|
&g_Var), // what it's going to ret, AND supercede with
|
|
|
|
new State_Func1_Post1(&g_Var, &g_Var), // origret(=p1) is what pre2 superceded with,
|
|
// so overrideret(=p2) has to be the same
|
|
new State_Func1_Post2(&hook.m_Var), // post2 is going to override with hook.m_Var again
|
|
new State_Func1_Ret(&hook.m_Var), // ==>>> hook.m_Var is returned
|
|
NULL), "Part 4");
|
|
|
|
CHECK_COND(hook.m_Var == 1337, "Part 4.1");
|
|
|
|
// Through a callclass
|
|
SourceHook::CallClass<Test> *cc1 = SH_GET_CALLCLASS(&test);
|
|
int &ret5 = SH_CALL(cc1, &Test::Func1)();
|
|
ADD_STATE(State_Func1_Ret(&ret5));
|
|
|
|
CHECK_STATES((&g_States,
|
|
new State_Func1(&test.m_Var1),
|
|
new State_Func1_Ret(&test.m_Var1),
|
|
NULL), "Part 5");
|
|
|
|
SH_RELEASE_CALLCLASS(cc1);
|
|
|
|
////////////////////////////////////////////////////////////////////////////////////////
|
|
// Func2 tests
|
|
const int &ret21 = pTest->Func2(500);
|
|
ADD_STATE(State_Func2_Ret(&ret21));
|
|
|
|
CHECK_STATES((&g_States,
|
|
new State_Func2(500, &test.m_Var2),
|
|
new State_Func2_Ret(&test.m_Var2),
|
|
NULL), "Part 6");
|
|
|
|
SH_ADD_HOOK_MEMFUNC(Test, Func2, &test, &hook, &CHook::Func2_Pre1, false);
|
|
SH_ADD_HOOK_MEMFUNC(Test, Func2, &test, &hook, &CHook::Func2_Post1, true);
|
|
|
|
const int &ret22 = pTest->Func2(500);
|
|
ADD_STATE(State_Func2_Ret(&ret22));
|
|
|
|
CHECK_STATES((&g_States,
|
|
new State_Func2_Pre1(500, &hook.m_Var), // p1 was 500; it's going to override with hook.m_Var; and also change p1 to 1337
|
|
new State_Func2(1337, &test.m_Var2), // p1 was 1337; it's going to ret test.m_Var2
|
|
new State_Func2_Post1(1337, // p1 was 1337
|
|
&test.m_Var2, // orig ret was test.m_Var2
|
|
&hook.m_Var), // override ret was hook.m_Var
|
|
new State_Func2_Ret(&hook.m_Var), // really returned hook.m_Var
|
|
NULL), "Part 7");
|
|
|
|
SH_REMOVE_HOOK_MEMFUNC(Test, Func2, &test, &hook, &CHook::Func2_Post1, true);
|
|
SH_REMOVE_HOOK_MEMFUNC(Test, Func2, &test, &hook, &CHook::Func2_Pre1, false);
|
|
SH_REMOVE_HOOK_MEMFUNC(Test, Func1, &test, &hook, &CHook::Func1_Pre1, false);
|
|
SH_REMOVE_HOOK_MEMFUNC(Test, Func1, &test, &hook, &CHook::Func1_Post1, true);
|
|
SH_REMOVE_HOOK_MEMFUNC(Test, Func1, &test, &hook, &CHook::Func1_Pre2, false);
|
|
SH_REMOVE_HOOK_MEMFUNC(Test, Func1, &test, &hook, &CHook::Func1_Post2, true);
|
|
|
|
return true;
|
|
}
|
|
|