2007-01-25 23:36:38 +01:00
|
|
|
/**
|
|
|
|
* ===============================================================
|
|
|
|
* SourceMod (C)2004-2007 AlliedModders LLC. All rights reserved.
|
|
|
|
* ===============================================================
|
|
|
|
*
|
|
|
|
* This file is not open source and may not be copied without explicit
|
|
|
|
* written permission of AlliedModders LLC. This file may not be redistributed
|
|
|
|
* in whole or significant part.
|
|
|
|
* For information, see LICENSE.txt or http://www.sourcemod.net/license.php
|
|
|
|
*
|
|
|
|
* Version: $Id$
|
|
|
|
*/
|
|
|
|
|
2006-11-08 08:32:44 +01:00
|
|
|
#include <stdio.h>
|
|
|
|
#include "sourcemod.h"
|
|
|
|
#include "sourcemm_api.h"
|
|
|
|
#include "systems/LibrarySys.h"
|
|
|
|
#include "vm/sp_vm_engine.h"
|
|
|
|
#include <sh_string.h>
|
2006-11-11 06:49:52 +01:00
|
|
|
#include "PluginSys.h"
|
2007-01-01 20:50:16 +01:00
|
|
|
#include "ShareSys.h"
|
2007-03-10 22:26:04 +01:00
|
|
|
#include "Logger.h"
|
2007-01-19 00:28:14 +01:00
|
|
|
#include "ExtensionSys.h"
|
2007-01-25 03:10:43 +01:00
|
|
|
#include "AdminCache.h"
|
2007-01-25 07:19:17 +01:00
|
|
|
#include "sm_stringutil.h"
|
2007-03-10 22:18:07 +01:00
|
|
|
#include "PlayerManager.h"
|
|
|
|
#include "Translator.h"
|
2007-02-26 05:36:15 +01:00
|
|
|
#include "ForwardSys.h"
|
2007-03-11 04:04:39 +01:00
|
|
|
#include "TimerSys.h"
|
2006-11-08 08:32:44 +01:00
|
|
|
|
2006-12-13 12:16:20 +01:00
|
|
|
SH_DECL_HOOK6(IServerGameDLL, LevelInit, SH_NOATTRIB, false, bool, const char *, const char *, const char *, const char *, bool, bool);
|
2007-01-20 03:12:53 +01:00
|
|
|
SH_DECL_HOOK0_void(IServerGameDLL, LevelShutdown, SH_NOATTRIB, false);
|
2007-02-07 09:44:48 +01:00
|
|
|
SH_DECL_HOOK1_void(IServerGameDLL, GameFrame, SH_NOATTRIB, false, bool);
|
2006-12-13 12:16:20 +01:00
|
|
|
|
2006-11-08 08:32:44 +01:00
|
|
|
SourcePawnEngine g_SourcePawn;
|
|
|
|
SourceModBase g_SourceMod;
|
|
|
|
|
|
|
|
ILibrary *g_pJIT = NULL;
|
|
|
|
SourceHook::String g_BaseDir;
|
|
|
|
ISourcePawnEngine *g_pSourcePawn = &g_SourcePawn;
|
|
|
|
IVirtualMachine *g_pVM;
|
2007-01-01 20:50:16 +01:00
|
|
|
IdentityToken_t *g_pCoreIdent = NULL;
|
2007-02-07 09:44:48 +01:00
|
|
|
float g_LastTime = 0.0f;
|
|
|
|
float g_LastAuthCheck = 0.0f;
|
2007-02-26 05:36:15 +01:00
|
|
|
IForward *g_pOnGameFrame = NULL;
|
2006-11-08 08:32:44 +01:00
|
|
|
|
|
|
|
typedef int (*GIVEENGINEPOINTER)(ISourcePawnEngine *);
|
|
|
|
typedef unsigned int (*GETEXPORTCOUNT)();
|
|
|
|
typedef IVirtualMachine *(*GETEXPORT)(unsigned int);
|
|
|
|
typedef void (*NOTIFYSHUTDOWN)();
|
|
|
|
|
|
|
|
void ShutdownJIT()
|
|
|
|
{
|
|
|
|
NOTIFYSHUTDOWN notify = (NOTIFYSHUTDOWN)g_pJIT->GetSymbolAddress("NotifyShutdown");
|
|
|
|
if (notify)
|
|
|
|
{
|
|
|
|
notify();
|
|
|
|
}
|
|
|
|
|
|
|
|
g_pJIT->CloseLibrary();
|
|
|
|
}
|
|
|
|
|
2006-12-13 12:16:20 +01:00
|
|
|
SourceModBase::SourceModBase()
|
|
|
|
{
|
|
|
|
m_IsMapLoading = false;
|
2007-01-20 03:12:53 +01:00
|
|
|
m_ExecPluginReload = false;
|
2006-12-13 12:16:20 +01:00
|
|
|
}
|
|
|
|
|
2006-11-08 08:32:44 +01:00
|
|
|
bool SourceModBase::InitializeSourceMod(char *error, size_t err_max, bool late)
|
|
|
|
{
|
|
|
|
g_BaseDir.assign(g_SMAPI->GetBaseDir());
|
2006-12-13 12:16:20 +01:00
|
|
|
g_LibSys.PathFormat(m_SMBaseDir, sizeof(m_SMBaseDir), "%s/addons/sourcemod", g_BaseDir.c_str());
|
2007-01-25 05:37:23 +01:00
|
|
|
g_LibSys.PathFormat(m_SMRelDir, sizeof(m_SMRelDir), "addons/sourcemod");
|
2006-11-08 08:32:44 +01:00
|
|
|
|
|
|
|
/* Attempt to load the JIT! */
|
|
|
|
char file[PLATFORM_MAX_PATH];
|
|
|
|
char myerror[255];
|
2006-12-13 12:16:20 +01:00
|
|
|
g_SMAPI->PathFormat(file, sizeof(file), "%s/bin/sourcepawn.jit.x86.%s",
|
2007-01-19 03:14:50 +01:00
|
|
|
GetSourceModPath(),
|
2006-11-08 08:32:44 +01:00
|
|
|
PLATFORM_LIB_EXT
|
|
|
|
);
|
|
|
|
|
|
|
|
g_pJIT = g_LibSys.OpenLibrary(file, myerror, sizeof(myerror));
|
|
|
|
if (!g_pJIT)
|
|
|
|
{
|
|
|
|
if (error && err_max)
|
|
|
|
{
|
|
|
|
snprintf(error, err_max, "%s (failed to load bin/sourcepawn.jit.x86.%s)",
|
|
|
|
myerror,
|
|
|
|
PLATFORM_LIB_EXT);
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
int err;
|
|
|
|
GIVEENGINEPOINTER jit_init = (GIVEENGINEPOINTER)g_pJIT->GetSymbolAddress("GiveEnginePointer");
|
|
|
|
if (!jit_init)
|
|
|
|
{
|
|
|
|
ShutdownJIT();
|
|
|
|
if (error && err_max)
|
|
|
|
{
|
|
|
|
snprintf(error, err_max, "Failed to find GiveEnginePointer in JIT!");
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ((err=jit_init(g_pSourcePawn)) != 0)
|
|
|
|
{
|
|
|
|
ShutdownJIT();
|
|
|
|
if (error && err_max)
|
|
|
|
{
|
|
|
|
snprintf(error, err_max, "GiveEnginePointer returned %d in the JIT", err);
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
GETEXPORTCOUNT jit_getnum = (GETEXPORTCOUNT)g_pJIT->GetSymbolAddress("GetExportCount");
|
|
|
|
GETEXPORT jit_get = (GETEXPORT)g_pJIT->GetSymbolAddress("GetExport");
|
|
|
|
if (!jit_get)
|
|
|
|
{
|
|
|
|
ShutdownJIT();
|
|
|
|
if (error && err_max)
|
|
|
|
{
|
|
|
|
snprintf(error, err_max, "JIT is missing a necessary export!");
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
unsigned int num = jit_getnum();
|
|
|
|
if (!num || ((g_pVM=jit_get(0)) == NULL))
|
|
|
|
{
|
|
|
|
ShutdownJIT();
|
|
|
|
if (error && err_max)
|
|
|
|
{
|
|
|
|
snprintf(error, err_max, "JIT did not export any virtual machines!");
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2006-11-11 06:49:52 +01:00
|
|
|
unsigned int api = g_pVM->GetAPIVersion();
|
|
|
|
if (api != SOURCEPAWN_VM_API_VERSION)
|
|
|
|
{
|
|
|
|
ShutdownJIT();
|
|
|
|
if (error && err_max)
|
|
|
|
{
|
|
|
|
snprintf(error, err_max, "JIT is not a compatible version");
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2006-12-13 12:16:20 +01:00
|
|
|
StartSourceMod(late);
|
2006-11-11 06:49:52 +01:00
|
|
|
|
2006-11-08 08:32:44 +01:00
|
|
|
return true;
|
|
|
|
}
|
2006-12-13 12:16:20 +01:00
|
|
|
|
|
|
|
void SourceModBase::StartSourceMod(bool late)
|
|
|
|
{
|
|
|
|
/* First initialize the global hooks we need */
|
|
|
|
SH_ADD_HOOK_MEMFUNC(IServerGameDLL, LevelInit, gamedll, this, &SourceModBase::LevelInit, false);
|
2007-01-20 03:12:53 +01:00
|
|
|
SH_ADD_HOOK_MEMFUNC(IServerGameDLL, LevelShutdown, gamedll, this, &SourceModBase::LevelShutdown, false);
|
2007-02-07 09:44:48 +01:00
|
|
|
SH_ADD_HOOK_MEMFUNC(IServerGameDLL, GameFrame, gamedll, this, &SourceModBase::GameFrame, false);
|
2006-12-13 12:16:20 +01:00
|
|
|
|
2007-02-15 21:35:17 +01:00
|
|
|
enginePatch = SH_GET_CALLCLASS(engine);
|
2007-02-26 06:26:54 +01:00
|
|
|
gamedllPatch = SH_GET_CALLCLASS(gamedll);
|
2007-02-15 21:35:17 +01:00
|
|
|
|
2006-12-15 14:58:22 +01:00
|
|
|
/* Notify! */
|
|
|
|
SMGlobalClass *pBase = SMGlobalClass::head;
|
|
|
|
while (pBase)
|
|
|
|
{
|
2007-01-19 00:28:14 +01:00
|
|
|
pBase->OnSourceModStartup(false);
|
2006-12-15 14:58:22 +01:00
|
|
|
pBase = pBase->m_pGlobalClassNext;
|
|
|
|
}
|
|
|
|
|
2007-01-01 20:50:16 +01:00
|
|
|
/* Make the global core identity */
|
|
|
|
g_pCoreIdent = g_ShareSys.CreateCoreIdentity();
|
|
|
|
|
2006-12-15 14:58:22 +01:00
|
|
|
/* Notify! */
|
|
|
|
pBase = SMGlobalClass::head;
|
|
|
|
while (pBase)
|
|
|
|
{
|
|
|
|
pBase->OnSourceModAllInitialized();
|
|
|
|
pBase = pBase->m_pGlobalClassNext;
|
|
|
|
}
|
2007-01-19 03:14:50 +01:00
|
|
|
|
|
|
|
/* Add us now... */
|
|
|
|
g_ShareSys.AddInterface(NULL, this);
|
2006-12-13 12:16:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
bool SourceModBase::LevelInit(char const *pMapName, char const *pMapEntities, char const *pOldLevel, char const *pLandmarkName, bool loadGame, bool background)
|
|
|
|
{
|
|
|
|
m_IsMapLoading = true;
|
2007-01-20 03:12:53 +01:00
|
|
|
m_ExecPluginReload = true;
|
2007-02-07 09:44:48 +01:00
|
|
|
g_LastTime = 0.0f;
|
|
|
|
g_LastAuthCheck = 0.0f;
|
2006-12-13 12:16:20 +01:00
|
|
|
|
2007-01-11 02:11:24 +01:00
|
|
|
g_Logger.MapChange(pMapName);
|
2007-03-10 14:16:19 +01:00
|
|
|
g_Timers.MapChange();
|
2007-01-11 02:11:24 +01:00
|
|
|
|
2007-02-17 20:03:18 +01:00
|
|
|
/* Refresh language stuff */
|
|
|
|
char path[PLATFORM_MAX_PATH];
|
|
|
|
BuildPath(Path_SM, path, sizeof(path), "configs/languages.cfg");
|
|
|
|
g_Translator.RebuildLanguageDatabase(path);
|
|
|
|
|
2006-12-13 12:16:20 +01:00
|
|
|
DoGlobalPluginLoads();
|
|
|
|
|
|
|
|
m_IsMapLoading = false;
|
|
|
|
|
2007-02-06 06:13:24 +01:00
|
|
|
g_Admins.DumpAdminCache(AdminCache_Overrides, true);
|
|
|
|
g_Admins.DumpAdminCache(AdminCache_Groups, true);
|
2007-01-25 03:10:43 +01:00
|
|
|
|
2007-02-26 05:36:15 +01:00
|
|
|
if (!g_pOnGameFrame)
|
|
|
|
{
|
|
|
|
g_pOnGameFrame = g_Forwards.CreateForward("OnGameFrame", ET_Ignore, 0, NULL);
|
|
|
|
}
|
|
|
|
|
2006-12-13 12:16:20 +01:00
|
|
|
RETURN_META_VALUE(MRES_IGNORED, true);
|
|
|
|
}
|
|
|
|
|
2007-02-07 09:44:48 +01:00
|
|
|
void SourceModBase::GameFrame(bool simulating)
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Note: This is all hardcoded rather than delegated to save
|
|
|
|
* precious CPU cycles.
|
|
|
|
*/
|
|
|
|
float curtime = gpGlobals->curtime;
|
2007-03-10 14:16:19 +01:00
|
|
|
if (curtime - g_LastTime >= 0.1f)
|
2007-02-07 09:44:48 +01:00
|
|
|
{
|
|
|
|
if (m_CheckingAuth
|
|
|
|
&& (gpGlobals->curtime - g_LastAuthCheck > 0.7f))
|
|
|
|
{
|
|
|
|
g_LastAuthCheck = gpGlobals->curtime;
|
|
|
|
g_Players.RunAuthChecks();
|
|
|
|
}
|
2007-03-10 14:16:19 +01:00
|
|
|
|
|
|
|
g_Timers.RunFrame();
|
2007-02-07 09:44:48 +01:00
|
|
|
g_LastTime = curtime;
|
|
|
|
}
|
2007-03-10 14:16:19 +01:00
|
|
|
|
2007-02-26 05:36:15 +01:00
|
|
|
if (g_pOnGameFrame && g_pOnGameFrame->GetFunctionCount())
|
|
|
|
{
|
|
|
|
g_pOnGameFrame->Execute(NULL);
|
|
|
|
}
|
2007-02-07 09:44:48 +01:00
|
|
|
}
|
|
|
|
|
2007-01-20 03:12:53 +01:00
|
|
|
void SourceModBase::LevelShutdown()
|
|
|
|
{
|
|
|
|
if (m_ExecPluginReload)
|
|
|
|
{
|
|
|
|
g_PluginSys.ReloadOrUnloadPlugins();
|
|
|
|
m_ExecPluginReload = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-02-13 17:11:04 +01:00
|
|
|
bool SourceModBase::IsMapLoading() const
|
2007-01-19 00:28:14 +01:00
|
|
|
{
|
|
|
|
return m_IsMapLoading;
|
|
|
|
}
|
|
|
|
|
2006-12-13 12:16:20 +01:00
|
|
|
void SourceModBase::DoGlobalPluginLoads()
|
|
|
|
{
|
|
|
|
char config_path[PLATFORM_MAX_PATH];
|
|
|
|
char plugins_path[PLATFORM_MAX_PATH];
|
|
|
|
|
2007-01-19 03:14:50 +01:00
|
|
|
BuildPath(Path_SM, config_path,
|
2006-12-13 12:16:20 +01:00
|
|
|
sizeof(config_path),
|
2007-01-19 03:14:50 +01:00
|
|
|
"configs/plugin_settings.cfg");
|
|
|
|
BuildPath(Path_SM, plugins_path,
|
2006-12-13 12:16:20 +01:00
|
|
|
sizeof(plugins_path),
|
2007-01-19 03:14:50 +01:00
|
|
|
"plugins");
|
2006-12-13 12:16:20 +01:00
|
|
|
|
2007-01-27 05:50:33 +01:00
|
|
|
/* Load any auto extensions */
|
|
|
|
g_Extensions.TryAutoload();
|
|
|
|
|
2007-01-19 00:28:14 +01:00
|
|
|
/* Run the first pass */
|
2006-12-15 14:38:04 +01:00
|
|
|
g_PluginSys.LoadAll_FirstPass(config_path, plugins_path);
|
2006-12-15 14:53:58 +01:00
|
|
|
|
2007-01-19 00:28:14 +01:00
|
|
|
/* Mark any extensions as loaded */
|
|
|
|
g_Extensions.MarkAllLoaded();
|
|
|
|
|
2006-12-15 14:53:58 +01:00
|
|
|
/* No modules yet, it's safe to call this from here */
|
|
|
|
g_PluginSys.LoadAll_SecondPass();
|
2007-01-19 00:28:14 +01:00
|
|
|
|
|
|
|
/* Re-mark any extensions as loaded */
|
|
|
|
g_Extensions.MarkAllLoaded();
|
2006-12-15 14:38:04 +01:00
|
|
|
}
|
|
|
|
|
2007-01-19 03:14:50 +01:00
|
|
|
size_t SourceModBase::BuildPath(PathType type, char *buffer, size_t maxlength, char *format, ...)
|
|
|
|
{
|
|
|
|
char _buffer[PLATFORM_MAX_PATH+1];
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
va_start(ap, format);
|
|
|
|
vsnprintf(_buffer, PLATFORM_MAX_PATH, format, ap);
|
|
|
|
va_end(ap);
|
|
|
|
|
|
|
|
const char *base = NULL;
|
|
|
|
if (type == Path_Game)
|
|
|
|
{
|
|
|
|
base = GetModPath();
|
|
|
|
} else if (type == Path_SM) {
|
|
|
|
base = GetSourceModPath();
|
2007-01-25 05:37:23 +01:00
|
|
|
} else if (type == Path_SM_Rel) {
|
|
|
|
base = m_SMRelDir;
|
2007-01-19 03:14:50 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (base)
|
|
|
|
{
|
|
|
|
return g_LibSys.PathFormat(buffer, maxlength, "%s/%s", base, _buffer);
|
|
|
|
} else {
|
|
|
|
return g_LibSys.PathFormat(buffer, maxlength, "%s", _buffer);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-01-13 05:28:13 +01:00
|
|
|
void SourceModBase::CloseSourceMod()
|
|
|
|
{
|
2007-02-26 05:36:15 +01:00
|
|
|
if (g_pOnGameFrame)
|
|
|
|
{
|
|
|
|
g_Forwards.ReleaseForward(g_pOnGameFrame);
|
|
|
|
}
|
|
|
|
|
2007-01-13 05:28:13 +01:00
|
|
|
/* Notify! */
|
|
|
|
SMGlobalClass *pBase = SMGlobalClass::head;
|
|
|
|
while (pBase)
|
|
|
|
{
|
|
|
|
pBase->OnSourceModShutdown();
|
|
|
|
pBase = pBase->m_pGlobalClassNext;
|
|
|
|
}
|
|
|
|
|
2007-02-13 17:11:04 +01:00
|
|
|
/* Delete all data packs */
|
|
|
|
CStack<CDataPack *>::iterator iter;
|
|
|
|
CDataPack *pd;
|
|
|
|
for (iter=m_freepacks.begin(); iter!=m_freepacks.end(); iter++)
|
|
|
|
{
|
|
|
|
pd = (*iter);
|
|
|
|
delete pd;
|
|
|
|
}
|
|
|
|
m_freepacks.popall();
|
|
|
|
|
2007-01-13 05:28:13 +01:00
|
|
|
/* Notify! */
|
|
|
|
pBase = SMGlobalClass::head;
|
|
|
|
while (pBase)
|
|
|
|
{
|
|
|
|
pBase->OnSourceModAllShutdown();
|
|
|
|
pBase = pBase->m_pGlobalClassNext;
|
|
|
|
}
|
|
|
|
|
2007-02-15 21:35:17 +01:00
|
|
|
if (enginePatch)
|
|
|
|
{
|
|
|
|
SH_RELEASE_CALLCLASS(enginePatch);
|
|
|
|
enginePatch = NULL;
|
|
|
|
}
|
|
|
|
|
2007-02-26 06:26:54 +01:00
|
|
|
if (gamedllPatch)
|
|
|
|
{
|
|
|
|
SH_RELEASE_CALLCLASS(gamedllPatch);
|
|
|
|
gamedllPatch = NULL;
|
|
|
|
}
|
|
|
|
|
2007-01-20 03:12:53 +01:00
|
|
|
SH_REMOVE_HOOK_MEMFUNC(IServerGameDLL, LevelInit, gamedll, this, &SourceModBase::LevelInit, false);
|
|
|
|
SH_REMOVE_HOOK_MEMFUNC(IServerGameDLL, LevelShutdown, gamedll, this, &SourceModBase::LevelShutdown, false);
|
2007-02-07 09:44:48 +01:00
|
|
|
SH_REMOVE_HOOK_MEMFUNC(IServerGameDLL, GameFrame, gamedll, this, &SourceModBase::GameFrame, false);
|
2007-01-20 03:12:53 +01:00
|
|
|
|
2007-01-13 05:28:13 +01:00
|
|
|
/* Rest In Peace */
|
|
|
|
ShutdownJIT();
|
|
|
|
}
|
|
|
|
|
2007-01-19 03:14:50 +01:00
|
|
|
void SourceModBase::LogMessage(IExtension *pExt, const char *format, ...)
|
|
|
|
{
|
|
|
|
IExtensionInterface *pAPI = pExt->GetAPI();
|
|
|
|
const char *tag = pAPI->GetExtensionTag();
|
|
|
|
char buffer[2048];
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
va_start(ap, format);
|
|
|
|
vsnprintf(buffer, sizeof(buffer), format, ap);
|
|
|
|
va_end(ap);
|
|
|
|
|
|
|
|
if (tag)
|
|
|
|
{
|
|
|
|
g_Logger.LogMessage("[%s] %s", tag, buffer);
|
|
|
|
} else {
|
|
|
|
g_Logger.LogMessage("%s", buffer);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void SourceModBase::LogError(IExtension *pExt, const char *format, ...)
|
|
|
|
{
|
|
|
|
IExtensionInterface *pAPI = pExt->GetAPI();
|
|
|
|
const char *tag = pAPI->GetExtensionTag();
|
|
|
|
char buffer[2048];
|
|
|
|
va_list ap;
|
|
|
|
|
|
|
|
va_start(ap, format);
|
|
|
|
vsnprintf(buffer, sizeof(buffer), format, ap);
|
|
|
|
va_end(ap);
|
|
|
|
|
|
|
|
if (tag)
|
|
|
|
{
|
|
|
|
g_Logger.LogError("[%s] %s", tag, buffer);
|
|
|
|
} else {
|
|
|
|
g_Logger.LogError("%s", buffer);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2007-01-25 07:19:17 +01:00
|
|
|
size_t SourceModBase::FormatString(char *buffer, size_t maxlength, IPluginContext *pContext, const cell_t *params, unsigned int param)
|
|
|
|
{
|
|
|
|
char *fmt;
|
|
|
|
|
|
|
|
pContext->LocalToString(params[param], &fmt);
|
|
|
|
|
|
|
|
int lparam = ++param;
|
|
|
|
|
|
|
|
return atcprintf(buffer, maxlength, fmt, pContext, params, &lparam);
|
|
|
|
}
|
|
|
|
|
2007-02-13 17:11:04 +01:00
|
|
|
const char *SourceModBase::GetSourceModPath() const
|
2006-12-13 12:16:20 +01:00
|
|
|
{
|
|
|
|
return m_SMBaseDir;
|
|
|
|
}
|
2006-12-15 14:38:04 +01:00
|
|
|
|
2007-02-13 17:11:04 +01:00
|
|
|
const char *SourceModBase::GetModPath() const
|
2007-01-01 22:18:56 +01:00
|
|
|
{
|
|
|
|
return g_BaseDir.c_str();
|
|
|
|
}
|
|
|
|
|
2007-01-30 19:04:53 +01:00
|
|
|
void SourceModBase::SetGlobalTarget(unsigned int index)
|
|
|
|
{
|
|
|
|
m_target = index;
|
|
|
|
}
|
|
|
|
|
2007-02-07 09:44:48 +01:00
|
|
|
void SourceModBase::SetAuthChecking(bool set)
|
|
|
|
{
|
|
|
|
m_CheckingAuth = set;
|
|
|
|
}
|
|
|
|
|
2007-01-30 19:04:53 +01:00
|
|
|
unsigned int SourceModBase::GetGlobalTarget() const
|
|
|
|
{
|
|
|
|
return m_target;
|
|
|
|
}
|
|
|
|
|
2007-02-13 17:11:04 +01:00
|
|
|
IDataPack *SourceModBase::CreateDataPack()
|
|
|
|
{
|
|
|
|
CDataPack *pack;
|
|
|
|
if (m_freepacks.empty())
|
|
|
|
{
|
|
|
|
pack = new CDataPack;
|
|
|
|
} else {
|
|
|
|
pack = m_freepacks.front();
|
|
|
|
m_freepacks.pop();
|
|
|
|
pack->Initialize();
|
|
|
|
}
|
|
|
|
return pack;
|
|
|
|
}
|
|
|
|
|
|
|
|
void SourceModBase::FreeDataPack(IDataPack *pack)
|
|
|
|
{
|
|
|
|
m_freepacks.push(static_cast<CDataPack *>(pack));
|
|
|
|
}
|
|
|
|
|
|
|
|
Handle_t SourceModBase::GetDataPackHandleType(bool readonly)
|
|
|
|
{
|
|
|
|
//:TODO:
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2006-12-15 14:38:04 +01:00
|
|
|
SMGlobalClass *SMGlobalClass::head = NULL;
|
|
|
|
|
|
|
|
SMGlobalClass::SMGlobalClass()
|
|
|
|
{
|
|
|
|
m_pGlobalClassNext = SMGlobalClass::head;
|
|
|
|
SMGlobalClass::head = this;
|
|
|
|
}
|