2006-12-16 03:16:21 +01:00
|
|
|
#include "sm_srvcmds.h"
|
|
|
|
|
|
|
|
ConVarAccessor g_ConCmdAccessor;
|
|
|
|
|
|
|
|
void ConVarAccessor::OnSourceModStartup(bool late)
|
|
|
|
{
|
|
|
|
ConCommandBaseMgr::OneTimeInit(&g_ConCmdAccessor);
|
|
|
|
}
|
|
|
|
|
|
|
|
bool ConVarAccessor::RegisterConCommandBase(ConCommandBase *pCommand)
|
|
|
|
{
|
|
|
|
META_REGCVAR(pCommand);
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2006-12-16 03:48:58 +01:00
|
|
|
inline const char *StatusToStr(PluginStatus st)
|
|
|
|
{
|
|
|
|
switch (st)
|
|
|
|
{
|
|
|
|
case Plugin_Running:
|
|
|
|
return "Running";
|
|
|
|
case Plugin_Paused:
|
|
|
|
return "Paused";
|
|
|
|
case Plugin_Error:
|
|
|
|
return "Error";
|
|
|
|
case Plugin_Uncompiled:
|
|
|
|
return "Uncompiled";
|
|
|
|
case Plugin_BadLoad:
|
|
|
|
return "Bad Load";
|
|
|
|
default:
|
2006-12-17 10:59:01 +01:00
|
|
|
assert(false);
|
2006-12-16 03:48:58 +01:00
|
|
|
return "-";
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2006-12-16 03:16:21 +01:00
|
|
|
CON_COMMAND(sm, "SourceMod Menu")
|
|
|
|
{
|
|
|
|
int argnum = engine->Cmd_Argc();
|
|
|
|
|
|
|
|
if (argnum >= 2)
|
|
|
|
{
|
|
|
|
const char *cmd = engine->Cmd_Argv(1);
|
|
|
|
if (!strcmp("plugins", cmd))
|
|
|
|
{
|
|
|
|
if (argnum >= 3)
|
|
|
|
{
|
|
|
|
const char *cmd2 = engine->Cmd_Argv(2);
|
|
|
|
if (!strcmp("list", cmd2))
|
|
|
|
{
|
|
|
|
char buffer[256];
|
|
|
|
unsigned int id = 1;
|
|
|
|
int plnum = g_PluginSys.GetPluginCount();
|
|
|
|
|
|
|
|
if (!plnum)
|
|
|
|
{
|
|
|
|
META_CONPRINT("[SM] No plugins loaded\n");
|
|
|
|
return;
|
|
|
|
} else {
|
|
|
|
META_CONPRINTF("[SM] Displaying %d plugin%s:\n", g_PluginSys.GetPluginCount(), (plnum > 1) ? "s" : "");
|
|
|
|
}
|
|
|
|
|
|
|
|
IPluginIterator *iter = g_PluginSys.GetPluginIterator();
|
|
|
|
for (; iter->MorePlugins(); iter->NextPlugin(), id++)
|
|
|
|
{
|
2006-12-16 03:48:58 +01:00
|
|
|
IPlugin *pl = iter->GetPlugin();
|
|
|
|
assert(pl->GetStatus() != Plugin_Created);
|
2006-12-16 03:16:21 +01:00
|
|
|
int len = 0;
|
2006-12-16 03:48:58 +01:00
|
|
|
const sm_plugininfo_t *info = pl->GetPublicInfo();
|
2006-12-16 03:16:21 +01:00
|
|
|
|
2006-12-16 03:48:58 +01:00
|
|
|
len += snprintf(&buffer[len], sizeof(buffer)-len, " %02d <%s>", id, StatusToStr(pl->GetStatus()));
|
2006-12-17 10:59:01 +01:00
|
|
|
len += snprintf(&buffer[len], sizeof(buffer)-len, " \"%s\"", (info->name) ? info->name : iter->GetPlugin()->GetFilename());
|
|
|
|
if (info->version)
|
2006-12-16 03:16:21 +01:00
|
|
|
{
|
|
|
|
len += snprintf(&buffer[len], sizeof(buffer)-len, " (%s)", info->version);
|
|
|
|
}
|
2006-12-17 10:59:01 +01:00
|
|
|
if (info->author)
|
2006-12-16 03:16:21 +01:00
|
|
|
{
|
|
|
|
snprintf(&buffer[len], sizeof(buffer)-len, " by %s", info->author);
|
|
|
|
}
|
|
|
|
META_CONPRINTF("%s\n", buffer);
|
|
|
|
}
|
|
|
|
|
|
|
|
iter->Release();
|
|
|
|
return;
|
|
|
|
} else if (!strcmp("load", cmd2)) {
|
|
|
|
if (argnum < 4)
|
|
|
|
{
|
|
|
|
META_CONPRINT("Usage: sm plugins load <file>\n");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2006-12-16 03:48:58 +01:00
|
|
|
char error[128];
|
2006-12-16 03:16:21 +01:00
|
|
|
const char *filename = engine->Cmd_Argv(3);
|
|
|
|
IPlugin *pl = g_PluginSys.LoadPlugin(filename, false, PluginType_MapUpdated, error, sizeof(error));
|
|
|
|
|
|
|
|
if (pl)
|
|
|
|
{
|
|
|
|
META_CONPRINTF("Loaded plugin %s successfully.\n", filename);
|
|
|
|
} else {
|
|
|
|
META_CONPRINTF("Plugin %s failed to load: %s.\n", filename, error);
|
|
|
|
}
|
|
|
|
|
|
|
|
return;
|
2006-12-17 10:59:01 +01:00
|
|
|
|
2006-12-16 03:16:21 +01:00
|
|
|
} else if (!strcmp("unload", cmd2)) {
|
|
|
|
if (argnum < 4)
|
|
|
|
{
|
|
|
|
META_CONPRINT("Usage: sm plugins unload <#>\n");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2006-12-17 10:59:01 +01:00
|
|
|
IPlugin *pl = NULL;
|
2006-12-16 03:16:21 +01:00
|
|
|
int id = 1;
|
|
|
|
int num = atoi(engine->Cmd_Argv(3));
|
|
|
|
if (num < 1 || num > (int)g_PluginSys.GetPluginCount())
|
|
|
|
{
|
|
|
|
META_CONPRINT("Plugin index not found.\n");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
IPluginIterator *iter = g_PluginSys.GetPluginIterator();
|
|
|
|
for (; iter->MorePlugins() && id<num; iter->NextPlugin(), id++) {}
|
2006-12-17 10:59:01 +01:00
|
|
|
pl = iter->GetPlugin();
|
2006-12-16 03:16:21 +01:00
|
|
|
|
|
|
|
char name[64];
|
|
|
|
const sm_plugininfo_t *info = pl->GetPublicInfo();
|
2006-12-17 10:59:01 +01:00
|
|
|
strcpy(name, (info->name) ? info->name : pl->GetFilename());
|
2006-12-16 03:16:21 +01:00
|
|
|
|
|
|
|
if (g_PluginSys.UnloadPlugin(pl))
|
|
|
|
{
|
|
|
|
META_CONPRINTF("Plugin %s unloaded successfully.\n", name);
|
|
|
|
} else {
|
|
|
|
META_CONPRINTF("Failed to unload plugin %s.\n", name);
|
|
|
|
}
|
|
|
|
|
|
|
|
iter->Release();
|
|
|
|
return;
|
2006-12-17 10:59:01 +01:00
|
|
|
|
2006-12-16 03:16:21 +01:00
|
|
|
} else if (!strcmp("info", cmd2)) {
|
|
|
|
if (argnum < 4)
|
|
|
|
{
|
|
|
|
META_CONPRINT("Usage: sm plugins info <#>\n");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2006-12-17 10:59:01 +01:00
|
|
|
IPlugin *pl = NULL;
|
2006-12-16 03:16:21 +01:00
|
|
|
int id = 1;
|
|
|
|
int num = atoi(engine->Cmd_Argv(3));
|
|
|
|
if (num < 1 || num > (int)g_PluginSys.GetPluginCount())
|
|
|
|
{
|
|
|
|
META_CONPRINT("Plugin index not found.\n");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
IPluginIterator *iter = g_PluginSys.GetPluginIterator();
|
|
|
|
for (; iter->MorePlugins() && id<num; iter->NextPlugin(), id++) {}
|
2006-12-17 10:59:01 +01:00
|
|
|
pl = iter->GetPlugin();
|
2006-12-16 03:16:21 +01:00
|
|
|
const sm_plugininfo_t *info = pl->GetPublicInfo();
|
|
|
|
|
|
|
|
META_CONPRINTF(" Filename: %s\n", pl->GetFilename());
|
2006-12-17 10:59:01 +01:00
|
|
|
if (info->name)
|
2006-12-16 03:16:21 +01:00
|
|
|
{
|
|
|
|
META_CONPRINTF(" Title: %s\n", info->name);
|
|
|
|
}
|
2006-12-17 10:59:01 +01:00
|
|
|
if (info->author)
|
2006-12-16 03:16:21 +01:00
|
|
|
{
|
|
|
|
META_CONPRINTF(" Author: %s\n", info->author);
|
|
|
|
}
|
2006-12-17 10:59:01 +01:00
|
|
|
if (info->version)
|
2006-12-16 03:16:21 +01:00
|
|
|
{
|
|
|
|
META_CONPRINTF(" Version: %s\n", info->version);
|
|
|
|
}
|
2006-12-17 10:59:01 +01:00
|
|
|
if (info->description)
|
2006-12-16 03:16:21 +01:00
|
|
|
{
|
|
|
|
META_CONPRINTF(" Description: %s\n", info->description);
|
|
|
|
}
|
2006-12-17 10:59:01 +01:00
|
|
|
if (info->url)
|
2006-12-16 03:16:21 +01:00
|
|
|
{
|
|
|
|
META_CONPRINTF(" URL: %s\n", info->url);
|
|
|
|
}
|
|
|
|
//:TODO: write if it's in debug mode, or do it inside LIST ?
|
|
|
|
|
|
|
|
iter->Release();
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//:TODO: print plugins cmd list
|
|
|
|
}
|
|
|
|
}
|
|
|
|
//:TODO: print cmd list or something
|
|
|
|
}
|