mirror of
https://github.com/s1lentq/ReGameDLL_CS.git
synced 2025-01-28 06:28:04 +03:00
32df585edc
Refactoring & cleanup code
104 lines
2.9 KiB
C++
104 lines
2.9 KiB
C++
/*
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify it
|
|
* under the terms of the GNU General Public License as published by the
|
|
* Free Software Foundation; either version 2 of the License, or (at
|
|
* your option) any later version.
|
|
*
|
|
* This program is distributed in the hope that it will be useful, but
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
* General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software Foundation,
|
|
* Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
|
*
|
|
* In addition, as a special exception, the author gives permission to
|
|
* link the code of this program with the Half-Life Game Engine ("HL
|
|
* Engine") and Modified Game Libraries ("MODs") developed by Valve,
|
|
* L.L.C ("Valve"). You must obey the GNU General Public License in all
|
|
* respects for all of the code used other than the HL Engine and MODs
|
|
* from Valve. If you modify this file, you may extend this exception
|
|
* to your version of the file, but you are not obligated to do so. If
|
|
* you do not wish to do so, delete this exception statement from your
|
|
* version.
|
|
*
|
|
*/
|
|
|
|
#include "precompiled.h"
|
|
#include "hookchains_impl.h"
|
|
|
|
AbstractHookChainRegistry::AbstractHookChainRegistry()
|
|
{
|
|
Q_memset(m_Hooks, 0, sizeof(m_Hooks));
|
|
Q_memset(m_Priorities, 0, sizeof(m_Priorities));
|
|
|
|
m_NumHooks = 0;
|
|
}
|
|
|
|
bool AbstractHookChainRegistry::findHook(void* hookFunc) const
|
|
{
|
|
for (auto i = 0; i < m_NumHooks; i++) {
|
|
if (m_Hooks[i] == hookFunc)
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
void AbstractHookChainRegistry::addHook(void* hookFunc, int priority)
|
|
{
|
|
if (!hookFunc) {
|
|
Sys_Error("%s: Parameter hookFunc can't be a nullptr", __func__);
|
|
}
|
|
|
|
if (findHook(hookFunc)) {
|
|
Sys_Error("%s: The same handler can't be used twice on the hookchain.", __func__);
|
|
}
|
|
|
|
for (auto i = 0; i < MAX_HOOKS_IN_CHAIN; i++)
|
|
{
|
|
if (m_Hooks[i] && priority <= m_Priorities[i])
|
|
continue;
|
|
|
|
auto swapHookFunc = m_Hooks[i];
|
|
auto swapPriority = m_Priorities[i];
|
|
|
|
m_Hooks[i] = hookFunc;
|
|
m_Priorities[i] = priority;
|
|
|
|
hookFunc = swapHookFunc;
|
|
priority = swapPriority;
|
|
}
|
|
|
|
if (m_NumHooks >= MAX_HOOKS_IN_CHAIN) {
|
|
Sys_Error("%s: MAX_HOOKS_IN_CHAIN limit hit", __func__);
|
|
}
|
|
|
|
m_NumHooks++;
|
|
}
|
|
|
|
void AbstractHookChainRegistry::removeHook(void* hookFunc) {
|
|
|
|
// erase hook
|
|
for (auto i = 0; i < m_NumHooks; i++)
|
|
{
|
|
if (hookFunc == m_Hooks[i])
|
|
{
|
|
--m_NumHooks;
|
|
if (m_NumHooks != i)
|
|
{
|
|
Q_memmove(&m_Hooks[i], &m_Hooks[i + 1], (m_NumHooks - i) * sizeof(m_Hooks[0]));
|
|
Q_memmove(&m_Priorities[i], &m_Priorities[i + 1], (m_NumHooks - i) * sizeof(m_Priorities[0]));
|
|
m_Hooks[m_NumHooks] = nullptr;
|
|
}
|
|
else
|
|
{
|
|
m_Hooks[i] = nullptr;
|
|
}
|
|
|
|
return;
|
|
}
|
|
}
|
|
}
|