1
0
mirror of https://github.com/anope/anope.git synced 2026-06-29 02:46:37 +02:00

Allow other modules to be able to view and modify cs and ns set_misc data

This commit is contained in:
Adam
2014-02-07 13:02:20 -05:00
parent f43c99c5cc
commit 5327becf41
3 changed files with 75 additions and 54 deletions
+17
View File
@@ -0,0 +1,17 @@
/*
* (C) 2003-2014 Anope Team
* Contact us at team@anope.org
*
* Please read COPYING and README for further details.
*/
struct MiscData
{
Anope::string object;
Anope::string name;
Anope::string data;
MiscData() { }
virtual ~MiscData() { }
};
+29 -26
View File
@@ -9,6 +9,7 @@
*/
#include "module.h"
#include "modules/set_misc.h"
static Module *me;
@@ -16,25 +17,33 @@ static std::map<Anope::string, Anope::string> descriptions;
struct CSMiscData;
static Anope::map<ExtensibleItem<CSMiscData> *> items;
static ExtensibleItem<CSMiscData> *GetItem(const Anope::string &name);
struct CSMiscData : Serializable
static ExtensibleItem<CSMiscData> *GetItem(const Anope::string &name) anope_override
{
Serialize::Reference<ChannelInfo> ci;
Anope::string name;
Anope::string data;
ExtensibleItem<CSMiscData>* &it = items[name];
if (!it)
try
{
it = new ExtensibleItem<CSMiscData>(me, name);
}
catch (const ModuleException &) { }
return it;
}
CSMiscData(Extensible *obj) : Serializable("CSMiscData"), ci(anope_dynamic_static_cast<ChannelInfo *>(obj))
{
}
struct CSMiscData : MiscData, Serializable
{
CSMiscData(Extensible *obj) : Serializable("CSMiscData") { }
CSMiscData(ChannelInfo *c, const Anope::string &n, const Anope::string &d) : Serializable("CSMiscData"), ci(c), name(n), data(d)
CSMiscData(ChannelInfo *c, const Anope::string &n, const Anope::string &d) : Serializable("CSMiscData")
{
object = c->name;
name = n;
data = d;
}
void Serialize(Serialize::Data &sdata) const anope_override
{
sdata["ci"] << this->ci->name;
sdata["ci"] << this->object;
sdata["name"] << this->name;
sdata["data"] << this->data;
}
@@ -55,7 +64,7 @@ struct CSMiscData : Serializable
if (obj)
{
d = anope_dynamic_static_cast<CSMiscData *>(obj);
d->ci = ci;
d->object = ci->name;
data["name"] >> d->name;
data["data"] >> d->data;
}
@@ -70,18 +79,6 @@ struct CSMiscData : Serializable
}
};
static ExtensibleItem<CSMiscData> *GetItem(const Anope::string &name)
{
ExtensibleItem<CSMiscData>* &it = items[name];
if (!it)
try
{
it = new ExtensibleItem<CSMiscData>(me, name);
}
catch (const ModuleException &) { }
return it;
}
static Anope::string GetAttribute(const Anope::string &command)
{
size_t sp = command.rfind(' ');
@@ -165,16 +162,22 @@ class CommandCSSetMisc : public Command
class CSSetMisc : public Module
{
Serialize::Type csmiscdata_type;
CommandCSSetMisc commandcssetmisc;
Serialize::Type csmiscdata_type;
public:
CSSetMisc(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator, VENDOR),
csmiscdata_type("CSMiscData", CSMiscData::Unserialize), commandcssetmisc(this)
commandcssetmisc(this), csmiscdata_type("CSMiscData", CSMiscData::Unserialize)
{
me = this;
}
~CSSetMisc()
{
for (Anope::map<ExtensibleItem<CSMiscData> *>::iterator it = items.begin(); it != items.end(); ++it)
delete it->second;
}
void OnReload(Configuration::Conf *conf) anope_override
{
descriptions.clear();
@@ -201,7 +204,7 @@ class CSSetMisc : public Module
for (Anope::map<ExtensibleItem<CSMiscData> *>::iterator it = items.begin(); it != items.end(); ++it)
{
ExtensibleItem<CSMiscData> *e = it->second;
CSMiscData *data = e->Get(ci);
MiscData *data = e->Get(ci);
if (data != NULL)
info[e->name.substr(12).replace_all_cs("_", " ")] = data->data;
+29 -28
View File
@@ -10,6 +10,7 @@
*/
#include "module.h"
#include "modules/set_misc.h"
static Module *me;
@@ -17,25 +18,33 @@ static std::map<Anope::string, Anope::string> descriptions;
struct NSMiscData;
static Anope::map<ExtensibleItem<NSMiscData> *> items;
static ExtensibleItem<NSMiscData> *GetItem(const Anope::string &name);
struct NSMiscData : Serializable
static ExtensibleItem<NSMiscData> *GetItem(const Anope::string &name)
{
Serialize::Reference<NickCore> nc;
Anope::string name;
Anope::string data;
ExtensibleItem<NSMiscData>* &it = items[name];
if (!it)
try
{
it = new ExtensibleItem<NSMiscData>(me, name);
}
catch (const ModuleException &) { }
return it;
}
NSMiscData(Extensible *obj) : Serializable("NSMiscData"), nc(anope_dynamic_static_cast<NickCore *>(obj))
{
}
struct NSMiscData : MiscData, Serializable
{
NSMiscData(Extensible *) : Serializable("NSMiscData") { }
NSMiscData(NickCore *ncore, const Anope::string &n, const Anope::string &d) : Serializable("NSMiscData"), nc(ncore), name(n), data(d)
NSMiscData(NickCore *ncore, const Anope::string &n, const Anope::string &d) : Serializable("NSMiscData")
{
object = ncore->display;
name = n;
data = d;
}
void Serialize(Serialize::Data &sdata) const anope_override
{
sdata["nc"] << this->nc->display;
sdata["nc"] << this->object;
sdata["name"] << this->name;
sdata["data"] << this->data;
}
@@ -52,11 +61,11 @@ struct NSMiscData : Serializable
if (nc == NULL)
return NULL;
NSMiscData *d;
NSMiscData *d = NULL;
if (obj)
{
d = anope_dynamic_static_cast<NSMiscData *>(obj);
d->nc = nc;
d->object = nc->display;
data["name"] >> d->name;
data["data"] >> d->data;
}
@@ -65,26 +74,12 @@ struct NSMiscData : Serializable
ExtensibleItem<NSMiscData> *item = GetItem(sname);
if (item)
d = item->Set(nc, NSMiscData(nc, sname, sdata));
else
d = NULL;
}
return d;
}
};
static ExtensibleItem<NSMiscData> *GetItem(const Anope::string &name)
{
ExtensibleItem<NSMiscData>* &it = items[name];
if (!it)
try
{
it = new ExtensibleItem<NSMiscData>(me, name);
}
catch (const ModuleException &) { }
return it;
}
static Anope::string GetAttribute(const Anope::string &command)
{
size_t sp = command.rfind(' ');
@@ -182,17 +177,23 @@ class CommandNSSASetMisc : public CommandNSSetMisc
class NSSetMisc : public Module
{
Serialize::Type nsmiscdata_type;
CommandNSSetMisc commandnssetmisc;
CommandNSSASetMisc commandnssasetmisc;
Serialize::Type nsmiscdata_type;
public:
NSSetMisc(const Anope::string &modname, const Anope::string &creator) : Module(modname, creator, VENDOR),
nsmiscdata_type("NSMiscData", NSMiscData::Unserialize), commandnssetmisc(this), commandnssasetmisc(this)
commandnssetmisc(this), commandnssasetmisc(this), nsmiscdata_type("NSMiscData", NSMiscData::Unserialize)
{
me = this;
}
~NSSetMisc()
{
for (Anope::map<ExtensibleItem<NSMiscData> *>::iterator it = items.begin(); it != items.end(); ++it)
delete it->second;
}
void OnReload(Configuration::Conf *conf) anope_override
{
descriptions.clear();