mirror of
https://github.com/alliedmodders/amxmodx.git
synced 2025-01-13 15:28:04 +03:00
AutoExecConfig: Add AutoExecConfig native
This commit is contained in:
parent
f22185d646
commit
9a1dc5d179
@ -14,6 +14,7 @@
|
|||||||
#include "natives.h"
|
#include "natives.h"
|
||||||
#include "debugger.h"
|
#include "debugger.h"
|
||||||
#include "libraries.h"
|
#include "libraries.h"
|
||||||
|
#include <amxmodx_version.h>
|
||||||
|
|
||||||
extern const char *no_function;
|
extern const char *no_function;
|
||||||
|
|
||||||
@ -443,6 +444,45 @@ void CPluginMngr::CPlugin::unpausePlugin()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void CPluginMngr::CPlugin::AddConfig(bool create, const char *name, const char *folder)
|
||||||
|
{
|
||||||
|
// Do a check for duplicates to prevent double-execution
|
||||||
|
for (size_t i = 0; i < m_configs.length(); ++i)
|
||||||
|
{
|
||||||
|
auto config = m_configs[i];
|
||||||
|
|
||||||
|
if (config->autocfg.compare(name) == 0 && config->folder.compare(folder) == 0 && config->create == create)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
AutoConfig *c = new AutoConfig;
|
||||||
|
|
||||||
|
c->autocfg = name;
|
||||||
|
c->folder = folder;
|
||||||
|
c->create = create;
|
||||||
|
|
||||||
|
m_configs.append(c);
|
||||||
|
}
|
||||||
|
|
||||||
|
size_t CPluginMngr::CPlugin::GetConfigCount()
|
||||||
|
{
|
||||||
|
return m_configs.length();
|
||||||
|
}
|
||||||
|
|
||||||
|
AutoConfig *CPluginMngr::CPlugin::GetConfig(size_t i)
|
||||||
|
{
|
||||||
|
if (i >= GetConfigCount())
|
||||||
|
{
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
return m_configs[i];
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
char *CPluginMngr::ReadIntoOrFromCache(const char *file, size_t &bufsize)
|
char *CPluginMngr::ReadIntoOrFromCache(const char *file, size_t &bufsize)
|
||||||
{
|
{
|
||||||
List<plcache_entry *>::iterator iter;
|
List<plcache_entry *>::iterator iter;
|
||||||
@ -714,3 +754,5 @@ void CPluginMngr::CALMFromFile(const char *file)
|
|||||||
|
|
||||||
fclose(fp);
|
fclose(fp);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -14,6 +14,7 @@
|
|||||||
#include "amx.h"
|
#include "amx.h"
|
||||||
#include "amxxfile.h"
|
#include "amxxfile.h"
|
||||||
#include <am-string.h>
|
#include <am-string.h>
|
||||||
|
#include <am-vector.h>
|
||||||
|
|
||||||
// *****************************************************
|
// *****************************************************
|
||||||
// class CPluginMngr
|
// class CPluginMngr
|
||||||
@ -29,6 +30,13 @@ enum
|
|||||||
ps_running, //Plugin is running
|
ps_running, //Plugin is running
|
||||||
};
|
};
|
||||||
|
|
||||||
|
struct AutoConfig
|
||||||
|
{
|
||||||
|
ke::AString autocfg;
|
||||||
|
ke::AString folder;
|
||||||
|
bool create;
|
||||||
|
};
|
||||||
|
|
||||||
class CPluginMngr
|
class CPluginMngr
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@ -63,6 +71,7 @@ public:
|
|||||||
bool m_Debug;
|
bool m_Debug;
|
||||||
cell* m_pNullStringOfs;
|
cell* m_pNullStringOfs;
|
||||||
cell* m_pNullVectorOfs;
|
cell* m_pNullVectorOfs;
|
||||||
|
ke::Vector<AutoConfig*> m_configs;
|
||||||
public:
|
public:
|
||||||
inline const char* getName() { return name.chars();}
|
inline const char* getName() { return name.chars();}
|
||||||
inline const char* getVersion() { return version.chars();}
|
inline const char* getVersion() { return version.chars();}
|
||||||
@ -94,6 +103,10 @@ public:
|
|||||||
inline bool isDebug() const { return m_Debug; }
|
inline bool isDebug() const { return m_Debug; }
|
||||||
inline cell* getNullStringOfs() const { return m_pNullStringOfs; }
|
inline cell* getNullStringOfs() const { return m_pNullStringOfs; }
|
||||||
inline cell* getNullVectorOfs() const { return m_pNullVectorOfs; }
|
inline cell* getNullVectorOfs() const { return m_pNullVectorOfs; }
|
||||||
|
public:
|
||||||
|
void AddConfig(bool create, const char *name, const char *folder);
|
||||||
|
size_t GetConfigCount();
|
||||||
|
AutoConfig *GetConfig(size_t index);
|
||||||
};
|
};
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
@ -4484,6 +4484,38 @@ static cell AMX_NATIVE_CALL has_map_ent_class(AMX *amx, cell *params)
|
|||||||
return len && !FNullEnt(FIND_ENTITY_BY_STRING(NULL, "classname", name));
|
return len && !FNullEnt(FIND_ENTITY_BY_STRING(NULL, "classname", name));
|
||||||
};
|
};
|
||||||
|
|
||||||
|
static cell AMX_NATIVE_CALL AutoExecConfig(AMX *amx, cell *params)
|
||||||
|
{
|
||||||
|
int length;
|
||||||
|
bool autocreate = params[1] != 0;
|
||||||
|
const char *name = get_amxstring(amx, params[2], 0, length);
|
||||||
|
const char *folder = get_amxstring(amx, params[3], 1, length);
|
||||||
|
|
||||||
|
auto plugin = g_plugins.findPluginFast(amx);
|
||||||
|
|
||||||
|
if (*name == '\0')
|
||||||
|
{
|
||||||
|
char pluginName[PLATFORM_MAX_PATH];
|
||||||
|
strncopy(pluginName, plugin->getName(), sizeof(pluginName));
|
||||||
|
|
||||||
|
char *ptr;
|
||||||
|
|
||||||
|
if ((ptr = strstr(pluginName, ".amxx")))
|
||||||
|
{
|
||||||
|
*ptr = '\0';
|
||||||
|
}
|
||||||
|
|
||||||
|
static char newName[PLATFORM_MAX_PATH];
|
||||||
|
UTIL_Format(newName, sizeof(newName), "plugin.%s", pluginName);
|
||||||
|
|
||||||
|
name = newName;
|
||||||
|
}
|
||||||
|
|
||||||
|
plugin->AddConfig(autocreate, name, folder);
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
static cell AMX_NATIVE_CALL is_rukia_a_hag(AMX *amx, cell *params)
|
static cell AMX_NATIVE_CALL is_rukia_a_hag(AMX *amx, cell *params)
|
||||||
{
|
{
|
||||||
return 1;
|
return 1;
|
||||||
@ -4677,6 +4709,7 @@ AMX_NATIVE_INFO amxmodx_Natives[] =
|
|||||||
{"SetGlobalTransTarget", SetGlobalTransTarget},
|
{"SetGlobalTransTarget", SetGlobalTransTarget},
|
||||||
{"PrepareArray", PrepareArray},
|
{"PrepareArray", PrepareArray},
|
||||||
{"ShowSyncHudMsg", ShowSyncHudMsg},
|
{"ShowSyncHudMsg", ShowSyncHudMsg},
|
||||||
|
{"AutoExecConfig", AutoExecConfig},
|
||||||
{"is_rukia_a_hag", is_rukia_a_hag},
|
{"is_rukia_a_hag", is_rukia_a_hag},
|
||||||
{NULL, NULL}
|
{NULL, NULL}
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user