mirror of
https://github.com/alliedmodders/metamod-source.git
synced 2025-12-07 02:18:30 +00:00
--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
132 lines
3.4 KiB
C++
132 lines
3.4 KiB
C++
/* ======== SourceMM ========
|
|
* Copyright (C) 2004-2008 Metamod:Source Development Team
|
|
* No warranties of any kind
|
|
*
|
|
* License: zlib/libpng
|
|
*
|
|
* Author(s): David "BAILOPAN" Anderson
|
|
* ============================
|
|
*/
|
|
|
|
#ifndef _INCLUDE_SOURCEMM_H
|
|
#define _INCLUDE_SOURCEMM_H
|
|
|
|
/**
|
|
* @brief SourceMM main functionality for GameDLL interception
|
|
* @file sourcemm.h
|
|
*/
|
|
|
|
#include <string>
|
|
#include <interface.h>
|
|
#include <eiface.h>
|
|
#include <sourcehook/sourcehook_impl.h>
|
|
#include <sourcehook/sourcehook.h>
|
|
#include "ISmmAPI.h"
|
|
#include "CPlugin.h"
|
|
#include "oslink.h"
|
|
#include "util.h"
|
|
#include "svn_version.h"
|
|
|
|
/**
|
|
* Versioning
|
|
* increase api_major when API breaks
|
|
* increase api_minor when new functions are added (non-breaking)
|
|
*/
|
|
#define SOURCEMM_VERSION SVN_FILE_VERSION_STRING
|
|
#define SOURCEMM_DATE __DATE__
|
|
#define SM_VERS_API_MAJOR 1 //increase this on a breaking change
|
|
#define SM_VERS_API_MINOR 5 //increase this on a non-breaking API change
|
|
|
|
//We need a good CServerGameDLL version to work properly. We support these inclusively.
|
|
#define MIN_GAMEDLL_VERSION 3
|
|
#define MAX_GAMEDLL_VERSION 8
|
|
|
|
/**
|
|
* @brief Entry point for HL2 Engine
|
|
*/
|
|
SMM_API void *CreateInterface(const char *name, int *code);
|
|
|
|
/** @brief Wrapper to catch GameDLL calls */
|
|
void *EngineFactory(const char *name, int *code);
|
|
|
|
/** @brief Wrapper to catch GameDLL calls */
|
|
void *PhysicsFactory(const char *name, int *code);
|
|
|
|
/** @brief Wrapper to catch GameDLL calls */
|
|
void *FileSystemFactory(const char *name, int *code);
|
|
|
|
/** @brief Loads all plugins found in a file */
|
|
int LoadPluginsFromFile(const char *file);
|
|
|
|
/** @brief Logs a message to the standard log file */
|
|
void LogMessage(const char *msg, ...);
|
|
|
|
/** @brief Stores information about the GameDLL */
|
|
struct GameDllInfo
|
|
{
|
|
bool loaded;
|
|
HINSTANCE lib;
|
|
CreateInterfaceFn factory;
|
|
IServerGameDLL *pGameDLL;
|
|
IServerGameClients *pGameClients;
|
|
};
|
|
|
|
/** @brief Stores information about the HL2 Engine pointers */
|
|
struct EngineInfo
|
|
{
|
|
EngineInfo() : loaded(false), original(false),
|
|
engineFactory(NULL), physicsFactory(NULL), fileSystemFactory(NULL),
|
|
pGlobals(NULL), icvar(NULL), engine(NULL)
|
|
{ };
|
|
bool loaded;
|
|
bool original;
|
|
CreateInterfaceFn engineFactory;
|
|
CreateInterfaceFn physicsFactory;
|
|
CreateInterfaceFn fileSystemFactory;
|
|
CGlobalVars *pGlobals;
|
|
ICvar *icvar;
|
|
IVEngineServer *engine;
|
|
};
|
|
|
|
bool AlternatelyLoadMetamod(CreateInterfaceFn ifaceFactory, CreateInterfaceFn serverFactory);
|
|
|
|
/** @brief Global variable for GameDLL info */
|
|
extern GameDllInfo g_GameDll;
|
|
|
|
/** @brief Global variable for Engine info */
|
|
extern EngineInfo g_Engine;
|
|
|
|
/** @brief Global singleton for SourceHook */
|
|
extern SourceHook::CSourceHookImpl g_SourceHook;
|
|
|
|
/** @brief Mod path (important!)*/
|
|
extern SourceHook::String g_ModPath;
|
|
|
|
/** @brief Path to server binary */
|
|
extern SourceHook::String g_BinPath;
|
|
|
|
/** @brief Path to SourceMM binary */
|
|
extern SourceHook::String g_SmmPath;
|
|
|
|
/** @brief Global variable for SourceHook macros */
|
|
extern SourceHook::ISourceHook *g_SHPtr;
|
|
|
|
/** @brief We have our own internal plugin id... */
|
|
extern PluginId g_PLID;
|
|
|
|
/** @brief ServerGameDLL version that is currently loaded */
|
|
extern int g_GameDllVersion;
|
|
|
|
extern bool bGameInit;
|
|
extern bool g_bLevelChanged;
|
|
|
|
void UnloadMetamod(bool shutting_down);
|
|
|
|
/** @brief Global CallClass for IServerGameDLL */
|
|
extern SourceHook::CallClass<IServerGameDLL> *g_GameDllPatch;
|
|
|
|
/** @brief Global CallClass for ICvar */
|
|
extern SourceHook::CallClass<ICvar> *g_CvarPatch;
|
|
|
|
#endif //_INCLUDE_SOURCEMM_H
|