diff options
author | Adam <Adam@anope.org> | 2011-01-08 00:25:11 -0500 |
---|---|---|
committer | Adam <Adam@anope.org> | 2011-01-08 00:25:11 -0500 |
commit | 512d23d60f25203ab88605ba131a0704cadd2263 (patch) | |
tree | f7bf42a648677f02f170db1e6692fafad10d81c6 | |
parent | 44038491264a350a8849e1d7e8547bbdec134d74 (diff) |
Made the Flag class able to convert flags to strings and back
-rw-r--r-- | include/account.h | 10 | ||||
-rw-r--r-- | include/channels.h | 4 | ||||
-rw-r--r-- | include/commands.h | 10 | ||||
-rw-r--r-- | include/modes.h | 35 | ||||
-rw-r--r-- | include/regchannel.h | 6 | ||||
-rw-r--r-- | include/servers.h | 2 | ||||
-rw-r--r-- | include/services.h | 36 | ||||
-rw-r--r-- | include/sockets.h | 2 | ||||
-rw-r--r-- | include/users.h | 1 | ||||
-rw-r--r-- | modules/core/db_plain.cpp | 150 | ||||
-rw-r--r-- | modules/extra/db_mysql.cpp | 329 | ||||
-rw-r--r-- | src/bots.cpp | 4 | ||||
-rw-r--r-- | src/channels.cpp | 8 | ||||
-rw-r--r-- | src/command.cpp | 2 | ||||
-rw-r--r-- | src/config.cpp | 2 | ||||
-rw-r--r-- | src/memoserv.cpp | 2 | ||||
-rw-r--r-- | src/modes.cpp | 4 | ||||
-rw-r--r-- | src/nickalias.cpp | 2 | ||||
-rw-r--r-- | src/nickcore.cpp | 2 | ||||
-rw-r--r-- | src/operserv.cpp | 4 | ||||
-rw-r--r-- | src/regchannel.cpp | 4 | ||||
-rw-r--r-- | src/servers.cpp | 5 | ||||
-rw-r--r-- | src/sockets.cpp | 4 | ||||
-rw-r--r-- | src/users.cpp | 2 |
24 files changed, 206 insertions, 424 deletions
diff --git a/include/account.h b/include/account.h index 08652f13c..afef1236d 100644 --- a/include/account.h +++ b/include/account.h @@ -41,6 +41,10 @@ enum NickNameFlag NS_END }; +const Anope::string NickNameFlagStrings[] = { + "NS_BEGIN", "NS_FORBIDDEN", "NS_NO_EXPIRE", "NS_HELD", "NS_COLLIDED", "NS_END", "" +}; + /** Flags set on NickCores */ enum NickCoreFlag @@ -85,6 +89,12 @@ enum NickCoreFlag NI_END }; +const Anope::string NickCoreFlagStrings[] = { + "NI_BEGIN", "NI_KILLPROTECT", "NI_SECURE", "NI_MSG", "NI_MEMO_HARDMAX", "NI_MEMO_SIGNON", "NI_MEMO_RECEIVE", + "NI_PRIVATE", "NI_HIDE_EMAIL", "NI_HIDE_MASK", "NI_HIDE_QUIT", "NI_KILL_QUICK", "NI_KILL_IMMED", + "NI_MEMO_MAIL", "NI_HIDE_STATUS", "NI_SUSPENDED", "NI_AUTOOP", "NI_FORBIDDEN", "" +}; + class CoreExport NickRequest : public Extensible { public: diff --git a/include/channels.h b/include/channels.h index 6991e1a20..8d6cbde5e 100644 --- a/include/channels.h +++ b/include/channels.h @@ -52,7 +52,7 @@ struct UserContainer typedef std::list<UserContainer *> CUserList; -enum ChannelFlags +enum ChannelFlag { /* Channel still exists when emptied */ CH_PERSIST, @@ -62,7 +62,7 @@ enum ChannelFlags CH_LOGCHAN }; -class CoreExport Channel : public Extensible, public Flags<ChannelFlags> +class CoreExport Channel : public Extensible, public Flags<ChannelFlag, 3> { public: typedef std::multimap<ChannelModeName, Anope::string> ModeList; diff --git a/include/commands.h b/include/commands.h index 4abaa43b8..afb7ab51f 100644 --- a/include/commands.h +++ b/include/commands.h @@ -43,6 +43,16 @@ enum CommandFlag CFLAG_DISABLE_FANTASY }; +const Anope::string CommandFlagStrings[] = { + "CFLAG_ALLOW_UNREGISTERED", + "CFLAG_ALLOW_FORBIDDEN", + "CFLAG_ALLOW_SUSPENDED", + "CFLAG_ALLOW_UNREGISTEREDCHANNEL", + "CFLAG_STRIP_CHANNEL", + "CFLAG_DISABLE_FANTASY", + "" +}; + /* The source for a command */ struct CoreExport CommandSource { diff --git a/include/modes.h b/include/modes.h index c6534f353..9cf780b31 100644 --- a/include/modes.h +++ b/include/modes.h @@ -24,6 +24,18 @@ enum UserModeName UMODE_END }; +const Anope::string UserModeNameStrings[] = { + "UMODE_BEGIN", + + "UMODE_SERV_ADMIN", "UMODE_BOT", "UMODE_CO_ADMIN", "UMODE_FILTER", "UMODE_HIDEOPER", "UMODE_NETADMIN", + "UMODE_REGPRIV", "UMODE_PROTECTED", "UMODE_NO_CTCP", "UMODE_WEBTV", "UMODE_WEBIRC", "UMODE_WHOIS", "UMODE_ADMIN", "UMODE_DEAF", + "UMODE_GLOBOPS", "UMODE_HELPOP", "UMODE_INVIS", "UMODE_OPER", "UMODE_PRIV", "UMODE_GOD", "UMODE_REGISTERED", + "UMODE_SNOMASK", "UMODE_VHOST", "UMODE_WALLOPS", "UMODE_CLOAK", "UMODE_SSL", "UMODE_SOFTCALLERID", "UMODE_CALLERID", + "UMODE_COMMONCHANS", "UMODE_HIDDEN", "UMODE_STRIPCOLOR", "UMODE_INVISIBLE_OPER", + + "" +}; + /** All of the valid channel mode names */ enum ChannelModeName @@ -49,6 +61,29 @@ enum ChannelModeName CMODE_END }; +const Anope::string ChannelModeNameStrings[] = { + "CMODE_BEGIN", + + /* Channel modes */ + "CMODE_BLOCKCOLOR", " CMODE_FLOOD", " CMODE_INVITE", " CMODE_KEY", " CMODE_LIMIT", " CMODE_MODERATED", " CMODE_NOEXTERNAL", + "CMODE_PRIVATE", " CMODE_REGISTERED", " CMODE_SECRET", " CMODE_TOPIC", " CMODE_AUDITORIUM", " CMODE_SSL", " CMODE_ADMINONLY", + "CMODE_NOCTCP", " CMODE_FILTER", " CMODE_NOKNOCK", " CMODE_REDIRECT", " CMODE_REGMODERATED", " CMODE_NONICK", " CMODE_OPERONLY", + "CMODE_NOKICK", " CMODE_REGISTEREDONLY", " CMODE_STRIPCOLOR", " CMODE_NONOTICE", " CMODE_NOINVITE", " CMODE_ALLINVITE", + "CMODE_BLOCKCAPS", " CMODE_PERM", " CMODE_NICKFLOOD", " CMODE_JOINFLOOD", " CMODE_DELAYEDJOIN", " CMODE_NOREJOIN", + "CMODE_BANDWIDTH", + + /* b/e/I */ + "CMODE_BAN", " CMODE_EXCEPT", + "CMODE_INVITEOVERRIDE", + + /* v/h/o/a/q */ + "CMODE_VOICE", " CMODE_HALFOP", " CMODE_OP", + "CMODE_PROTECT", " CMODE_OWNER", + + "" +}; + + /** The different types of modes */ enum ModeType diff --git a/include/regchannel.h b/include/regchannel.h index 4be8a50aa..298e35798 100644 --- a/include/regchannel.h +++ b/include/regchannel.h @@ -62,6 +62,12 @@ enum ChannelInfoFlag CI_END }; +const Anope::string ChannelInfoFlagStrings[] = { + "CI_BEGIN", "CI_INHABIT", "CI_KEEPTOPIC", "CI_SECUREOPS", "CI_PRIVATE", "CI_TOPICLOCK", "CI_RESTRICTED", + "CI_PEACE", "CI_SECURE", "CI_FORBIDDEN", "CI_NO_EXPIRE", "CI_MEMO_HARDMAX", "CI_OPNOTICE", "CI_SECUREFOUNDER", + "CI_SIGNKICK", "CI_SIGNKICK_LEVEL", "CI_XOP", "CI_SUSPENDED", "CI_PERSIST", "" +}; + struct ModeLock { bool set; diff --git a/include/servers.h b/include/servers.h index d22ab05ac..c9d85804b 100644 --- a/include/servers.h +++ b/include/servers.h @@ -70,6 +70,8 @@ enum ServerFlag SERVER_JUPED }; +const Anope::string ServerFlagStrings[] = { "SERVER_NONE", "SERVER_SYNCING", "SERVER_JUPED", "" }; + /** Class representing a server */ class CoreExport Server : public Flags<ServerFlag> diff --git a/include/services.h b/include/services.h index 881bbbb76..69ed1a944 100644 --- a/include/services.h +++ b/include/services.h @@ -306,8 +306,11 @@ template<typename T, size_t Size = 32> class Flags { protected: std::bitset<Size> Flag_Values; + const Anope::string *Flag_Strings; public: + Flags(const Anope::string *flag_strings) : Flag_Strings(flag_strings) { } + /** Add a flag to this item * @param Value The flag */ @@ -347,6 +350,23 @@ template<typename T, size_t Size = 32> class Flags { Flag_Values.reset(); } + + std::vector<Anope::string> ToString() + { + std::vector<Anope::string> ret; + for (unsigned i = 0; this->Flag_Strings && !this->Flag_Strings[i].empty(); ++i) + if (this->HasFlag(static_cast<T>(i))) + ret.push_back(this->Flag_Strings[i]); + return ret; + } + + void FromString(const std::vector<Anope::string> &strings) + { + for (unsigned i = 0; this->Flag_Strings && !this->Flag_Strings[i].empty(); ++i) + for (unsigned j = 0; j < strings.size(); ++j) + if (this->Flag_Strings[i] == strings[j]) + this->SetFlag(static_cast<T>(i)); + } }; #include "sockets.h" @@ -470,17 +490,22 @@ enum MemoFlag { /* Memo is unread */ MF_UNREAD, - /* SEnder requests a receipt */ + /* Sender requests a receipt */ MF_RECEIPT, /* Memo is a notification of receipt */ MF_NOTIFYS }; +const Anope::string MemoFlagStrings[] = { + "MF_UNREAD", "MF_RECEIPT", "MF_NOTIFYS", "" +}; + /* Memo info structures. Since both nicknames and channels can have memos, * we encapsulate memo data in a MemoList to make it easier to handle. */ class Memo : public Flags<MemoFlag> { public: + Memo(); time_t time; /* When it was sent */ Anope::string sender; Anope::string text; @@ -592,10 +617,13 @@ enum AutoKickFlag AK_ISNICK }; +const Anope::string AutoKickFlagString[] = { "AK_ISNICK", "" }; + /* AutoKick data. */ class AutoKick : public Flags<AutoKickFlag> { public: + AutoKick() : Flags<AutoKickFlag>(AutoKickFlagString) { } /* Only one of these can be in use */ Anope::string mask; NickCore *nc; @@ -715,6 +743,12 @@ enum BotServFlag BS_END }; +const Anope::string BotServFlagStrings[] = { + "BS_BEGIN", "BS_DONTKICKOPS", "BS_DONTKICKVOICES", "BS_FANTASY", "BS_SYMBIOSIS", "BS_GREET", "BS_NOBOT", + "BS_KICK_BOLDs", "BS_KICK_COLORS", "BS_KICK_REVERSES", "BS_KICK_UNDERLINES", "BS_KICK_BADWORDS", "BS_KICK_CAPS", + "BS_KICK_FLOOD", "BS_KICK_REPEAT", "BS_KICK_ITALICS", "BS_MSG_PRIVMSG", "BS_MSG_NOTICE", "BS_MSG_NOTICEOPS", "" +}; + /* Indices for TTB (Times To Ban) */ enum { diff --git a/include/sockets.h b/include/sockets.h index 4d6938e09..6d48d1481 100644 --- a/include/sockets.h +++ b/include/sockets.h @@ -121,6 +121,8 @@ enum SocketFlag SF_WRITABLE }; +static const Anope::string SocketFlagStrings[] = { "SF_DEAD", "SF_WRITABLE", "" }; + class Socket; class ClientSocket; class ListenSocket; diff --git a/include/users.h b/include/users.h index 8eba0e476..d54fd13be 100644 --- a/include/users.h +++ b/include/users.h @@ -14,6 +14,7 @@ extern CoreExport patricia_tree<User *> UserListByUID; class CoreExport ChannelStatus : public Flags<ChannelModeName, CMODE_END * 2> { public: + ChannelStatus(); Anope::string BuildCharPrefixList() const; Anope::string BuildModePrefixList() const; }; diff --git a/modules/core/db_plain.cpp b/modules/core/db_plain.cpp index dd634dd02..ab95ea094 100644 --- a/modules/core/db_plain.cpp +++ b/modules/core/db_plain.cpp @@ -203,51 +203,12 @@ static void ReadDatabase(Module *m = NULL) db.close(); } -struct ChannelFlagInfo -{ - Anope::string Name; - ChannelInfoFlag Flag; -}; - struct ChannelLevel { Anope::string Name; int Level; }; -struct BotFlagInfo -{ - Anope::string Name; - BotServFlag Flag; -}; - -struct NickCoreFlagInfo -{ - Anope::string Name; - NickCoreFlag Flag; -}; - -ChannelFlagInfo ChannelInfoFlags[] = { - {"KEEPTOPIC", CI_KEEPTOPIC}, - {"SECUREOPS", CI_SECUREOPS}, - {"PRIVATE", CI_PRIVATE}, - {"TOPICLOCK", CI_TOPICLOCK}, - {"RESTRICTED", CI_RESTRICTED}, - {"PEACE", CI_PEACE}, - {"SECURE", CI_SECURE}, - {"FORBIDDEN", CI_FORBIDDEN}, - {"NO_EXPIRE", CI_NO_EXPIRE}, - {"MEMO_HARDMAX", CI_MEMO_HARDMAX}, - {"OPNOTICE", CI_OPNOTICE}, - {"SECUREFOUNDER", CI_SECUREFOUNDER}, - {"SIGNKICK", CI_SIGNKICK}, - {"SIGNKICK_LEVEL", CI_SIGNKICK_LEVEL}, - {"XOP", CI_XOP}, - {"SUSPENDED", CI_SUSPENDED}, - {"PERSIST", CI_PERSIST}, - {"", static_cast<ChannelInfoFlag>(-1)} -}; - ChannelLevel ChannelLevels[] = { {"INVITE", CA_INVITE}, {"AKICK", CA_AKICK}, @@ -289,48 +250,18 @@ ChannelLevel ChannelLevels[] = { {"", -1} }; -BotFlagInfo BotFlags[] = { - {"DONTKICKOPS", BS_DONTKICKOPS}, - {"DONTKICKVOICES", BS_DONTKICKVOICES}, - {"FANTASY", BS_FANTASY}, - {"SYMBIOSIS", BS_SYMBIOSIS}, - {"GREET", BS_GREET}, - {"NOBOT", BS_NOBOT}, - {"KICK_BOLDS", BS_KICK_BOLDS}, - {"KICK_COLORS", BS_KICK_COLORS}, - {"KICK_REVERSES", BS_KICK_REVERSES}, - {"KICK_UNDERLINES", BS_KICK_UNDERLINES}, - {"KICK_BADWORDS", BS_KICK_BADWORDS}, - {"KICK_CAPS", BS_KICK_CAPS}, - {"KICK_FLOOD", BS_KICK_FLOOD}, - {"KICK_REPEAT", BS_KICK_REPEAT}, - {"KICK_ITALICS", BS_KICK_ITALICS}, - {"MSG_PRIVMSG", BS_MSG_PRIVMSG}, - {"MSG_NOTICE", BS_MSG_NOTICE}, - {"MSG_NOTICEOPS", BS_MSG_NOTICEOPS}, - {"", static_cast<BotServFlag>(-1)} -}; +static Anope::string ToString(const std::vector<Anope::string> &strings) +{ + Anope::string ret; -NickCoreFlagInfo NickCoreFlags[] = { - {"KILLPROTECT", NI_KILLPROTECT}, - {"SECURE", NI_SECURE}, - {"MSG", NI_MSG}, - {"MEMO_HARDMAX", NI_MEMO_HARDMAX}, - {"MEMO_SIGNON", NI_MEMO_SIGNON}, - {"MEMO_RECEIVE", NI_MEMO_RECEIVE}, - {"PRIVATE", NI_PRIVATE}, - {"HIDE_EMAIL", NI_HIDE_EMAIL}, - {"HIDE_MASK", NI_HIDE_MASK}, - {"HIDE_QUIT", NI_HIDE_QUIT}, - {"KILL_QUICK", NI_KILL_QUICK}, - {"KILL_IMMED", NI_KILL_IMMED}, - {"MEMO_MAIL", NI_MEMO_MAIL}, - {"HIDE_STATUS", NI_HIDE_STATUS}, - {"SUSPENDED", NI_SUSPENDED}, - {"AUTOOP", NI_AUTOOP}, - {"FORBIDDEN", NI_FORBIDDEN}, - {"", static_cast<NickCoreFlag>(-1)} -}; + for (unsigned i = 0; i < strings.size(); ++i) + ret += " " + strings[i]; + + if (!ret.empty()) + ret.erase(ret.begin()); + + return ret; +} static void LoadNickCore(const std::vector<Anope::string> ¶ms) { @@ -587,12 +518,7 @@ class DBPlain : public Module else if (key.equals_ci("ACCESS")) nc->AddAccess(params[0]); else if (key.equals_ci("FLAGS")) - { - for (unsigned j = 0, end = params.size(); j < end; ++j) - for (int i = 0; NickCoreFlags[i].Flag != -1; ++i) - if (params[j].equals_ci(NickCoreFlags[i].Name)) - nc->SetFlag(NickCoreFlags[i].Flag); - } + nc->FromString(params); else if (key.equals_ci("MI")) { Memo *m = new Memo; @@ -676,12 +602,7 @@ class DBPlain : public Module ci->levels[ChannelLevels[i].Level] = params[j + 1].is_number_only() ? convertTo<int16>(params[j + 1]) : 0; } else if (key.equals_ci("FLAGS")) - { - for (unsigned j = 0, end = params.size(); j < end; ++j) - for (int i = 0; ChannelInfoFlags[i].Flag != -1; ++i) - if (params[j].equals_ci(ChannelInfoFlags[i].Name)) - ci->SetFlag(ChannelInfoFlags[i].Flag); - } + ci->FromString(params); else if (key.equals_ci("DESC")) ci->desc = params[0]; else if (key.equals_ci("TOPIC")) @@ -776,12 +697,7 @@ class DBPlain : public Module if (params[0].equals_ci("NAME")) ci->bi = findbot(params[1]); else if (params[0].equals_ci("FLAGS")) - { - for (unsigned j = 1, end = params.size(); j < end; ++j) - for (int i = 0; BotFlags[i].Flag != -1; ++i) - if (params[j].equals_ci(BotFlags[i].Name)) - ci->botflags.SetFlag(BotFlags[i].Flag); - } + ci->FromString(params); else if (params[0].equals_ci("TTB")) { for (unsigned j = 1, end = params.size(); j < end; j += 2) @@ -880,13 +796,7 @@ class DBPlain : public Module db << "MD ACCESS " << *it << endl; } if (nc->FlagCount()) - { - db << "MD FLAGS"; - for (int j = 0; NickCoreFlags[j].Flag != -1; ++j) - if (nc->HasFlag(NickCoreFlags[j].Flag)) - db << " " << NickCoreFlags[j].Name; - db << endl; - } + db << "MD FLAGS " << ToString(nc->ToString()) << endl; MemoInfo *mi = &nc->memos; for (unsigned k = 0, end = mi->memos.size(); k < end; ++k) { @@ -915,8 +825,8 @@ class DBPlain : public Module db << "MD LAST_REALNAME :" << na->last_realname << endl; if (!na->last_quit.empty()) db << "MD LAST_QUIT :" << na->last_quit << endl; - if (na->HasFlag(NS_FORBIDDEN) || na->HasFlag(NS_NO_EXPIRE)) - db << "MD FLAGS" << (na->HasFlag(NS_FORBIDDEN) ? " FORBIDDEN" : "") << (na->HasFlag(NS_NO_EXPIRE) ? " NOEXPIRE " : "") << endl; + if (na->FlagCount()) + db << "MD FLAGS " << ToString(na->ToString()) << endl; if (na->hostinfo.HasVhost()) db << "MD VHOST " << na->hostinfo.GetCreator() << " " << na->hostinfo.GetTime() << " " << na->hostinfo.GetHost() << " :" << na->hostinfo.GetIdent() << endl; @@ -928,10 +838,8 @@ class DBPlain : public Module BotInfo *bi = *it; db << "BI " << bi->nick << " " << bi->GetIdent() << " " << bi->host << " " << bi->created << " " << bi->chancount << " :" << bi->realname << endl; - if (bi->HasFlag(BI_PRIVATE)) - { - db << "MD FLAGS PRIVATE" << endl; - } + if (bi->FlagCount()) + db << "MD FLAGS " << ToString(bi->ToString()) << endl; } for (registered_channel_map::const_iterator cit = RegisteredChannelList.begin(), cit_end = RegisteredChannelList.end(); cit != cit_end; ++cit) @@ -954,15 +862,9 @@ class DBPlain : public Module db << " " << ChannelLevels[j].Name << " " << ci->levels[ChannelLevels[j].Level]; db << endl; if (ci->FlagCount()) - { - db << "MD FLAGS"; - for (int j = 0; ChannelInfoFlags[j].Flag != -1; ++j) - if (ci->HasFlag(ChannelInfoFlags[j].Flag)) - db << " " << ChannelInfoFlags[j].Name; - db << endl; - if (ci->HasFlag(CI_FORBIDDEN)) - db << "MD FORBID " << ci->forbidby << " :" << ci->forbidreason << endl; - } + db << "MD FLAGS " << ToString(ci->ToString()) << endl; + if (ci->HasFlag(CI_FORBIDDEN)) + db << "MD FORBID " << ci->forbidby << " :" << ci->forbidreason << endl; for (unsigned k = 0, end = ci->GetAccessCount(); k < end; ++k) db << "MD ACCESS " << ci->GetAccess(k)->mask << " " << ci->GetAccess(k)->level << " " << ci->GetAccess(k)->last_seen << " " << ci->GetAccess(k)->creator << endl; for (unsigned k = 0, end = ci->GetAkickCount(); k < end; ++k) @@ -1057,13 +959,7 @@ class DBPlain : public Module if (ci->bi) db << "MD BI NAME " << ci->bi->nick << endl; if (ci->botflags.FlagCount()) - { - db << "MD BI FLAGS"; - for (int j = 0; BotFlags[j].Flag != -1; ++j) - if (ci->botflags.HasFlag(BotFlags[j].Flag)) - db << " " << BotFlags[j].Name; - db << endl; - } + db << "MD BI FLAGS " << ToString(ci->botflags.ToString()) << endl; db << "MD BI TTB BOLDS " << ci->ttb[0] << " COLORS " << ci->ttb[1] << " REVERSES " << ci->ttb[2] << " UNDERLINES " << ci->ttb[3] << " BADWORDS " << ci->ttb[4] << " CAPS " << ci->ttb[5] << " FLOOD " << ci->ttb[6] << " REPEAT " << ci->ttb[7] << " ITALICS " << ci->ttb[8] << endl; if (ci->capsmin) db << "MD BI CAPSMIN " << ci->capsmin << endl; diff --git a/modules/extra/db_mysql.cpp b/modules/extra/db_mysql.cpp index d11d7b914..d5c51fb36 100644 --- a/modules/extra/db_mysql.cpp +++ b/modules/extra/db_mysql.cpp @@ -1,123 +1,18 @@ #include "module.h" #include "sql.h" -struct NickAliasFlagInfo +static Anope::string ToString(const std::vector<Anope::string> &strings) { - Anope::string Name; - NickNameFlag Flag; -}; - -NickAliasFlagInfo NickAliasFlags[] = { - {"FORBIDDEN", NS_FORBIDDEN}, - {"NOEXPIRE", NS_NO_EXPIRE}, - {"", static_cast<NickNameFlag>(-1)} -}; - -struct NickCoreFlagInfo -{ - Anope::string Name; - NickCoreFlag Flag; -}; - -NickCoreFlagInfo NickCoreFlags[] = { - {"KILLPROTECT", NI_KILLPROTECT}, - {"SECURE", NI_SECURE}, - {"MSG", NI_MSG}, - {"MEMO_HARDMAX", NI_MEMO_HARDMAX}, - {"MEMO_SIGNON", NI_MEMO_SIGNON}, - {"MEMO_RECEIVE", NI_MEMO_RECEIVE}, - {"PRIVATE", NI_PRIVATE}, - {"HIDE_EMAIL", NI_HIDE_EMAIL}, - {"HIDE_MASK", NI_HIDE_MASK}, - {"HIDE_QUIT", NI_HIDE_QUIT}, - {"KILL_QUICK", NI_KILL_QUICK}, - {"KILL_IMMED", NI_KILL_IMMED}, - {"MEMO_MAIL", NI_MEMO_MAIL}, - {"HIDE_STATUS", NI_HIDE_STATUS}, - {"SUSPENDED", NI_SUSPENDED}, - {"AUTOOP", NI_AUTOOP}, - {"FORBIDDEN", NI_FORBIDDEN}, - {"", static_cast<NickCoreFlag>(-1)} -}; - -struct BotServFlagInfo -{ - Anope::string Name; - BotFlag Flag; -}; - -BotServFlagInfo BotServFlags[] = { - {"PRIVATE", BI_PRIVATE}, - {"", static_cast<BotFlag>(-1)} -}; - -struct BotFlagInfo -{ - Anope::string Name; - BotServFlag Flag; -}; - -BotFlagInfo BotFlags[] = { - {"DONTKICKOPS", BS_DONTKICKOPS}, - {"DONTKICKVOICES", BS_DONTKICKVOICES}, - {"FANTASY", BS_FANTASY}, - {"SYMBIOSIS", BS_SYMBIOSIS}, - {"GREET", BS_GREET}, - {"NOBOT", BS_NOBOT}, - {"KICK_BOLDS", BS_KICK_BOLDS}, - {"KICK_COLORS", BS_KICK_COLORS}, - {"KICK_REVERSES", BS_KICK_REVERSES}, - {"KICK_UNDERLINES", BS_KICK_UNDERLINES}, - {"KICK_BADWORDS", BS_KICK_BADWORDS}, - {"KICK_CAPS", BS_KICK_CAPS}, - {"KICK_FLOOD", BS_KICK_FLOOD}, - {"KICK_REPEAT", BS_KICK_REPEAT}, - {"KICK_ITALICS", BS_KICK_ITALICS}, - {"MSG_PRIVMSG", BS_MSG_PRIVMSG}, - {"MSG_NOTICE", BS_MSG_NOTICE}, - {"MSG_NOTICEOPS", BS_MSG_NOTICEOPS}, - {"", static_cast<BotServFlag>(-1)} -}; - -struct ChannelFlagInfo -{ - Anope::string Name; - ChannelInfoFlag Flag; -}; - -ChannelFlagInfo ChannelFlags[] = { - {"KEEPTOPIC", CI_KEEPTOPIC}, - {"SECUREOPS", CI_SECUREOPS}, - {"PRIVATE", CI_PRIVATE}, - {"TOPICLOCK", CI_TOPICLOCK}, - {"RESTRICTED", CI_RESTRICTED}, - {"PEACE", CI_PEACE}, - {"SECURE", CI_SECURE}, - {"FORBIDDEN", CI_FORBIDDEN}, - {"NO_EXPIRE", CI_NO_EXPIRE}, - {"MEMO_HARDMAX", CI_MEMO_HARDMAX}, - {"OPNOTICE", CI_OPNOTICE}, - {"SECUREFOUNDER", CI_SECUREFOUNDER}, - {"SIGNKICK", CI_SIGNKICK}, - {"SIGNKICK_LEVEL", CI_SIGNKICK_LEVEL}, - {"XOP", CI_XOP}, - {"SUSPENDED", CI_SUSPENDED}, - {"PERSIST", CI_PERSIST}, - {"", static_cast<ChannelInfoFlag>(-1)} -}; - -struct MemoFlagInfo -{ - Anope::string Name; - MemoFlag Flag; -}; + Anope::string ret; -MemoFlagInfo MemoFlags[] = { - {"UNREAD", MF_UNREAD}, - {"RECEIPT", MF_RECEIPT}, - {"NOTIFYS", MF_NOTIFYS}, - {"", static_cast<MemoFlag>(-1)} -}; + for (unsigned i = 0; i < strings.size(); ++i) + ret += " " + strings[i]; + + if (!ret.empty()) + ret.erase(ret.begin()); + + return ret; +} static std::vector<Anope::string> MakeVector(const Anope::string &buf) { @@ -142,62 +37,6 @@ static std::vector<Anope::string> MakeVector(const Anope::string &buf) return params; } -static Anope::string BuildFlagsList(ChannelInfo *ci) -{ - Anope::string ret; - - for (int i = 0; ChannelFlags[i].Flag != -1; ++i) - if (ci->HasFlag(ChannelFlags[i].Flag)) - ret += " " + ChannelFlags[i].Name; - - if (!ret.empty()) - ret.erase(ret.begin()); - - return ret; -} - -static Anope::string BuildFlagsList(NickAlias *na) -{ - Anope::string ret; - - for (int i = 0; NickAliasFlags[i].Flag != -1; ++i) - if (na->HasFlag(NickAliasFlags[i].Flag)) - ret += " " + NickAliasFlags[i].Name; - - if (!ret.empty()) - ret.erase(ret.begin()); - - return ret; -} - -static Anope::string BuildFlagsList(NickCore *nc) -{ - Anope::string ret; - - for (int i = 0; NickCoreFlags[i].Flag != -1; ++i) - if (nc->HasFlag(NickCoreFlags[i].Flag)) - ret += " " + NickCoreFlags[i].Name; - - if (!ret.empty()) - ret.erase(ret.begin()); - - return ret; -} - -static Anope::string BuildFlagsList(Memo *m) -{ - Anope::string ret; - - for (int i = 0; MemoFlags[i].Flag != -1; ++i) - if (m->HasFlag(MemoFlags[i].Flag)) - ret += " " + MemoFlags[i].Name; - - if (!ret.empty()) - ret.erase(ret.begin()); - - return ret; -} - static Anope::string MakeMLock(ChannelInfo *ci, bool status) { Anope::string ret; @@ -268,34 +107,6 @@ static Anope::string GetMLockParams(ChannelInfo *ci, bool onoff) return ret; } -static Anope::string GetBotFlags(Flags<BotServFlag>& Flags) -{ - Anope::string buf; - - for (int i = 0; BotFlags[i].Flag != -1; ++i) - if (Flags.HasFlag(BotFlags[i].Flag)) - buf += " " + BotFlags[i].Name; - - if (!buf.empty()) - buf.erase(buf.begin()); - - return buf; -} - -static Anope::string GetBotServFlags(BotInfo *bi) -{ - Anope::string buf; - - for (int i = 0; BotServFlags[i].Flag != -1; ++i) - if (bi->HasFlag(BotServFlags[i].Flag)) - buf += " " + BotServFlags[i].Name; - - if (!buf.empty()) - buf.erase(buf.begin());; - - return buf; -} - static NickAlias *CurNick = NULL; static NickCore *CurCore = NULL; static ChannelInfo *CurChannel = NULL; @@ -446,17 +257,10 @@ class DBMySQL : public Module spacesepstream sep(r.Get(i, "flags")); Anope::string buf; + std::vector<Anope::string> flags; while (sep.GetToken(buf)) - { - for (int j = 0; NickCoreFlags[j].Flag != -1; ++j) - { - if (NickCoreFlags[j].Name == buf) - { - nc->SetFlag(NickCoreFlags[j].Flag); - break; - } - } - } + flags.push_back(buf); + nc->FromString(flags); nc->language = r.Get(i, "language"); nc->channelcount = r.Get(i, "channelcount").is_number_only() ? convertTo<int>(r.Get(i, "channelcount")) : 0; @@ -510,17 +314,11 @@ class DBMySQL : public Module spacesepstream sep(r.Get(i, "flags")); Anope::string buf; + std::vector<Anope::string> flags; while (sep.GetToken(buf)) - { - for (int j = 0; NickAliasFlags[j].Flag != -1; ++j) - { - if (NickAliasFlags[j].Name == buf) - { - na->SetFlag(NickAliasFlags[j].Flag); - break; - } - } - } + flags.push_back(buf); + + na->FromString(flags); } r = SQL->RunQuery("SELECT * FROM `anope_ns_alias_metadata`"); @@ -563,17 +361,11 @@ class DBMySQL : public Module spacesepstream sep(r.Get(i, "flags")); Anope::string buf; + std::vector<Anope::string> flags; while (sep.GetToken(buf)) - { - for (int j = 0; BotServFlags[j].Flag != -1; ++j) - { - if (buf == BotServFlags[j].Name) - { - bi->SetFlag(BotServFlags[j].Flag); - break; - } - } - } + flags.push_back(buf); + + bi->FromString(flags); } r = SQL->RunQuery("SELECT * FROM `anope_bs_info_metadata`"); @@ -629,17 +421,11 @@ class DBMySQL : public Module { spacesepstream sep(r.Get(i, "botflags")); Anope::string buf; + std::vector<Anope::string> flags; while (sep.GetToken(buf)) - { - for (int j = 0; BotFlags[j].Flag != -1; ++j) - { - if (buf == BotFlags[j].Name) - { - ci->botflags.SetFlag(BotFlags[j].Flag); - break; - } - } - } + flags.push_back(buf); + + ci->botflags.FromString(flags); } if (!r.Get(i, "mlock_on").empty()) @@ -691,18 +477,11 @@ class DBMySQL : public Module { spacesepstream sep(r.Get(i, "flags")); Anope::string buf; - + std::vector<Anope::string> flags; while (sep.GetToken(buf)) - { - for (int j = 0; ChannelFlags[j].Flag != -1; ++j) - { - if (buf == ChannelFlags[j].Name) - { - ci->SetFlag(ChannelFlags[j].Flag); - break; - } - } - } + flags.push_back(buf); + + ci->FromString(flags); } } } @@ -847,17 +626,11 @@ class DBMySQL : public Module { spacesepstream sep(r.Get(i, "flags")); Anope::string buf; + std::vector<Anope::string> flags; while (sep.GetToken(buf)) - { - for (unsigned j = 0; MemoFlags[j].Flag != -1; ++j) - { - if (MemoFlags[j].Name == buf) - { - m->SetFlag(MemoFlags[j].Flag); - break; - } - } - } + flags.push_back(buf); + + m->FromString(flags); } } } @@ -978,7 +751,7 @@ class DBMySQL : public Module FOREACH_MOD(I_OnDatabaseWriteMetadata, OnDatabaseWriteMetadata(WriteBotMetadata, CurBot)); /* This is for the core bots, bots added by users are already handled by an event */ - this->RunQuery("INSERT INTO `anope_bs_core` (nick, user, host, rname, flags, created, chancount) VALUES('" + this->Escape(CurBot->nick) + "', '" + this->Escape(CurBot->GetIdent()) + "', '" + this->Escape(CurBot->host) + "', '" + this->Escape(CurBot->realname) + "', '" + GetBotServFlags(CurBot) + "', " + stringify(CurBot->created) + ", " + stringify(CurBot->chancount) + ") ON DUPLICATE KEY UPDATE nick=VALUES(nick), user=VALUES(user), host=VALUES(host), rname=VALUES(rname), flags=VALUES(flags), created=VALUES(created), chancount=VALUES(chancount)"); + this->RunQuery("INSERT INTO `anope_bs_core` (nick, user, host, rname, flags, created, chancount) VALUES('" + this->Escape(CurBot->nick) + "', '" + this->Escape(CurBot->GetIdent()) + "', '" + this->Escape(CurBot->host) + "', '" + this->Escape(CurBot->realname) + "', '" + ToString(CurBot->ToString()) + "', " + stringify(CurBot->created) + ", " + stringify(CurBot->chancount) + ") ON DUPLICATE KEY UPDATE nick=VALUES(nick), user=VALUES(user), host=VALUES(host), rname=VALUES(rname), flags=VALUES(flags), created=VALUES(created), chancount=VALUES(chancount)"); } this->RunQuery("TRUNCATE TABLE `anope_extra`"); @@ -1019,7 +792,7 @@ class DBMySQL : public Module } else if (cmd.equals_ci("KILL") || cmd.equals_ci("SECURE") || cmd.equals_ci("PRIVATE") || cmd.equals_ci("MSG") || cmd.equals_ci("HIDE") || cmd.equals_ci("AUTOOP")) { - this->RunQuery("UPDATE `anope_ns_core` SET `flags` = '" + BuildFlagsList(nc) + "' WHERE `display` = '" + this->Escape(nc->display) + "'"); + this->RunQuery("UPDATE `anope_ns_core` SET `flags` = '" + ToString(CurBot->ToString()) + "' WHERE `display` = '" + this->Escape(nc->display) + "'"); } } } @@ -1056,7 +829,7 @@ class DBMySQL : public Module } else if (params[1].equals_ci("KEEPTOPIC") || params[1].equals_ci("TOPICLOCK") || params[1].equals_ci("PRIVATE") || params[1].equals_ci("SECUREOPS") || params[1].equals_ci("SECUREFOUNDER") || params[1].equals_ci("RESTRICTED") || params[1].equals_ci("SECURE") || params[1].equals_ci("SIGNKICK") || params[1].equals_ci("OPNOTICE") || params[1].equals_ci("XOP") || params[1].equals_ci("PEACE") || params[1].equals_ci("PERSIST") || params[1].equals_ci("NOEXPIRE")) { - this->RunQuery("UPDATE `anope_cs_info` SET `flags` = '" + BuildFlagsList(ci) + "' WHERE `name` = '" + this->Escape(ci->name) + "'"); + this->RunQuery("UPDATE `anope_cs_info` SET `flags` = '" + ToString(ci->ToString()) + "' WHERE `name` = '" + this->Escape(ci->name) + "'"); } } } @@ -1076,7 +849,7 @@ class DBMySQL : public Module { this->RunQuery("INSERT INTO `anope_cs_ttb` (channel, ttb_id, value) VALUES('" + this->Escape(ci->name) + "', " + stringify(i) + ", " + stringify(ci->ttb[i]) + ") ON DUPLICATE KEY UPDATE channel=VALUES(channel), ttb_id=VALUES(ttb_id), value=VALUES(value)"); } - this->RunQuery("UPDATE `anope_cs_info` SET `botflags` = '" + GetBotFlags(ci->botflags) + "' WHERE `name` = '" + this->Escape(ci->name) + "'"); + this->RunQuery("UPDATE `anope_cs_info` SET `botflags` = '" + ToString(ci->botflags.ToString()) + "' WHERE `name` = '" + this->Escape(ci->name) + "'"); if (params[1].equals_ci("CAPS")) { @@ -1102,13 +875,13 @@ class DBMySQL : public Module bi = findbot(params[0]); if (bi && params[1].equals_ci("PRIVATE") && u->Account()->HasPriv("botserv/set/private")) { - this->RunQuery("UPDATE `anope_bs_core` SET `flags` = '" + GetBotServFlags(bi) + "' WHERE `nick` = '" + this->Escape(bi->nick) + "'"); + this->RunQuery("UPDATE `anope_bs_core` SET `flags` = '" + ToString(bi->ToString()) + "' WHERE `nick` = '" + this->Escape(bi->nick) + "'"); } else if (!ci) return; else if (params[1].equals_ci("DONTKICKOPS") || params[1].equals_ci("DONTKICKVOICES") || params[1].equals_ci("FANTASY") || params[1].equals_ci("GREET") || params[1].equals_ci("SYMBIOSIS") || params[1].equals_ci("NOBOT")) { - this->RunQuery("UPDATE `anope_cs_info` SET `botflags` = '" + GetBotFlags(ci->botflags) + "' WHERE `name` = '" + this->Escape(ci->name) + "'"); + this->RunQuery("UPDATE `anope_cs_info` SET `botflags` = '" + ToString(ci->botflags.ToString()) + "' WHERE `name` = '" + this->Escape(ci->name) + "'"); } } } @@ -1166,7 +939,7 @@ class DBMySQL : public Module void OnNickForbidden(NickAlias *na) { - this->RunQuery("UPDATE `anope_ns_alias` SET `flags` = '" + BuildFlagsList(na) + "' WHERE `nick` = '" + this->Escape(na->nick) + "'"); + this->RunQuery("UPDATE `anope_ns_alias` SET `flags` = '" + ToString(na->ToString()) + "' WHERE `nick` = '" + this->Escape(na->nick) + "'"); } void OnNickGroup(User *u, NickAlias *) @@ -1189,7 +962,7 @@ class DBMySQL : public Module this->RunQuery("INSERT INTO `anope_ns_alias` (nick, last_quit, last_realname, last_usermask, time_registered, last_seen, flags, display) VALUES('" + this->Escape(na->nick) + "', '" + this->Escape(na->last_quit) + "', '" + this->Escape(na->last_realname) + "', '" + this->Escape(na->last_usermask) + "', " + stringify(na->time_registered) + ", " + stringify(na->last_seen) + - ", '" + BuildFlagsList(na) + "', '" + this->Escape(na->nc->display) + "') " + "ON DUPLICATE KEY UPDATE last_quit=VALUES(last_quit), " + ", '" + ToString(na->ToString()) + "', '" + this->Escape(na->nc->display) + "') " + "ON DUPLICATE KEY UPDATE last_quit=VALUES(last_quit), " "last_realname=VALUES(last_realname), last_usermask=VALUES(last_usermask), time_registered=VALUES(time_registered), last_seen=VALUES(last_seen), " "flags=VALUES(flags), display=VALUES(display)"); } @@ -1199,7 +972,7 @@ class DBMySQL : public Module this->RunQuery("INSERT INTO `anope_ns_core` (display, pass, email, greet, flags, language, channelcount, memomax) VALUES('" + this->Escape(nc->display) + "', '" + this->Escape(nc->pass) + "', '" + this->Escape(nc->email) + "', '" + this->Escape(nc->greet) + "', '" + - BuildFlagsList(nc) + "', " + stringify(nc->language) + ", " + stringify(nc->channelcount) + ", " + + ToString(nc->ToString()) + "', " + stringify(nc->language) + ", " + stringify(nc->channelcount) + ", " + stringify(nc->memos.memomax) + ") " + "ON DUPLICATE KEY UPDATE pass=VALUES(pass), email=VALUES(email), greet=VALUES(greet), flags=VALUES(flags), language=VALUES(language), " + "channelcount=VALUES(channelcount), memomax=VALUES(memomax)"); @@ -1218,7 +991,7 @@ class DBMySQL : public Module void OnNickSuspend(NickAlias *na) { - this->RunQuery("UPDATE `anope_ns_core` SET `flags` = '" + BuildFlagsList(na->nc) + "' WHERE `display` = '" + this->Escape(na->nc->display) + "'"); + this->RunQuery("UPDATE `anope_ns_core` SET `flags` = '" + ToString(na->nc->ToString()) + "' WHERE `display` = '" + this->Escape(na->nc->display) + "'"); } void OnAccessAdd(ChannelInfo *ci, User *u, ChanAccess *access) @@ -1253,7 +1026,7 @@ class DBMySQL : public Module void OnChanForbidden(ChannelInfo *ci) { this->RunQuery("INSERT INTO `anope_cs_info` (name, time_registered, last_used, flags, forbidby, forbidreason) VALUES ('" + - this->Escape(ci->name) + "', " + stringify(ci->time_registered) + ", " + stringify(ci->last_used) + ", '" + BuildFlagsList(ci) + "', '" + this->Escape(ci->forbidby) + "', '" + this->Escape(ci->name) + "', " + stringify(ci->time_registered) + ", " + stringify(ci->last_used) + ", '" + ToString(ci->ToString()) + "', '" + this->Escape(ci->forbidby) + "', '" + this->Escape(ci->forbidreason) + "')"); } @@ -1264,22 +1037,22 @@ class DBMySQL : public Module void OnChanRegistered(ChannelInfo *ci) { - Anope::string flags = BuildFlagsList(ci), mlockon = GetMLockOn(ci), mlockoff = GetMLockOff(ci), mlockparams = GetMLockParams(ci, true), mlockparams_off = GetMLockParams(ci, false); + Anope::string mlockon = GetMLockOn(ci), mlockoff = GetMLockOff(ci), mlockparams = GetMLockParams(ci, true), mlockparams_off = GetMLockParams(ci, false); this->RunQuery("INSERT INTO `anope_cs_info` (name, founder, successor, descr, time_registered, last_used, last_topic, last_topic_setter, last_topic_time, flags, forbidby, forbidreason, bantype, mlock_on, mlock_off, mlock_params, mlock_params_off, memomax, botnick, botflags, capsmin, capspercent, floodlines, floodsecs, repeattimes) VALUES('" + this->Escape(ci->name) + "', '" + this->Escape(ci->founder ? ci->founder->display : "") + "', '" + this->Escape(ci->successor ? ci->successor->display : "") + "', '" + this->Escape(ci->desc) + "', " + stringify(ci->time_registered) + ", " + stringify(ci->last_used) + ", '" + this->Escape(ci->last_topic) + "', '" + - this->Escape(ci->last_topic_setter) + "', " + stringify(ci->last_topic_time) + ", '" + flags + "', '" + + this->Escape(ci->last_topic_setter) + "', " + stringify(ci->last_topic_time) + ", '" + ToString(ci->ToString()) + "', '" + this->Escape(ci->forbidby) + "', '" + this->Escape(ci->forbidreason) + "', " + stringify(ci->bantype) + ", '" + mlockon + "', '" + mlockoff + "', '" + mlockparams + "', '" + mlockparams_off + "', " + - stringify(ci->memos.memomax) + ", '" + this->Escape(ci->bi ? ci->bi->nick : "") + "', '" + GetBotFlags(ci->botflags) + + stringify(ci->memos.memomax) + ", '" + this->Escape(ci->bi ? ci->bi->nick : "") + "', '" + ToString(ci->botflags.ToString()) + "', " + stringify(ci->capsmin) + ", " + stringify(ci->capspercent) + ", " + stringify(ci->floodlines) + ", " + stringify(ci->floodsecs) + ", " + stringify(ci->repeattimes) + ") " + "ON DUPLICATE KEY UPDATE founder=VALUES(founder), successor=VALUES(successor), descr=VALUES(descr), time_registered=VALUES(time_registered), last_used=VALUES(last_used), last_topic=VALUES(last_topic), last_topic_setter=VALUES(last_topic_setter), last_topic_time=VALUES(last_topic_time), flags=VALUES(flags), forbidby=VALUES(forbidby), forbidreason=VALUES(forbidreason), bantype=VALUES(bantype), mlock_on=VALUES(mlock_on), mlock_off=VALUES(mlock_off), mlock_params=VALUES(mlock_params), memomax=VALUES(memomax), botnick=VALUES(botnick), botflags=VALUES(botflags), capsmin=VALUES(capsmin), capspercent=VALUES(capspercent), floodlines=VALUES(floodlines), floodsecs=VALUES(floodsecs), repeattimes=VALUES(repeattimes)"); } void OnChanSuspend(ChannelInfo *ci) { - this->RunQuery("UPDATE `anope_cs_info` SET `flags` = '" + BuildFlagsList(ci) + "' WHERE `name` = '" + this->Escape(ci->name) + "'"); + this->RunQuery("UPDATE `anope_cs_info` SET `flags` = '" + ToString(ci->ToString()) + "' WHERE `name` = '" + this->Escape(ci->name) + "'"); this->RunQuery("UPDATE `anope_cs_info` SET `forbidby` = '" + this->Escape(ci->forbidby) + " WHERE `name` = '" + this->Escape(ci->name) + "'"); this->RunQuery("UPDATE `anope_cs_info` SET `forbidreason` = '" + this->Escape(ci->forbidreason) + " WHERE `name` = '" + this->Escape(ci->name) + "'"); } @@ -1301,7 +1074,7 @@ class DBMySQL : public Module { this->RunQuery("INSERT INTO `anope_bs_core` (nick, user, host, rname, flags, created, chancount) VALUES('" + this->Escape(bi->nick) + "', '" + this->Escape(bi->GetIdent()) + "', '" + this->Escape(bi->host) + "', '" + - this->Escape(bi->realname) + "', '" + GetBotServFlags(bi) + "', " + stringify(bi->created) + ", " + stringify(bi->chancount) + ") " + + this->Escape(bi->realname) + "', '" + ToString(bi->ToString()) + "', " + stringify(bi->created) + ", " + stringify(bi->chancount) + ") " + "ON DUPLICATE KEY UPDATE nick=VALUES(nick), user=VALUES(user), host=VALUES(host), rname=VALUES(rname), flags=VALUES(flags), created=VALUES(created), chancount=VALUES(chancount)"); } @@ -1372,14 +1145,14 @@ class DBMySQL : public Module void OnMemoSend(User *, NickCore *nc, Memo *m) { this->RunQuery("INSERT INTO `anope_ms_info` (receiver, flags, time, sender, text, serv) VALUES('" + - this->Escape(nc->display) + "', '" + BuildFlagsList(m) + "', " + stringify(m->time) + ", '" + + this->Escape(nc->display) + "', '" + ToString(m->ToString()) + "', " + stringify(m->time) + ", '" + this->Escape(m->sender) + "', '" + this->Escape(m->text) + "', 'NICK')"); } void OnMemoSend(User *, ChannelInfo *ci, Memo *m) { this->RunQuery("INSERT INTO `anope_ms_info` (receiver, flags, time, sender, text, serv) VALUES('" + - this->Escape(ci->name) + "', '" + BuildFlagsList(m) + "', " + stringify(m->time) + ", '" + + this->Escape(ci->name) + "', '" + ToString(m->ToString()) + "', " + stringify(m->time) + ", '" + this->Escape(m->sender) + "', '" + this->Escape(m->text) + "', 'CHAN')"); } diff --git a/src/bots.cpp b/src/bots.cpp index 90edc63be..e5b29fbf7 100644 --- a/src/bots.cpp +++ b/src/bots.cpp @@ -20,7 +20,9 @@ BotInfo *MemoServ = NULL; BotInfo *NickServ = NULL; BotInfo *OperServ = NULL; -BotInfo::BotInfo(const Anope::string &nnick, const Anope::string &nuser, const Anope::string &nhost, const Anope::string &nreal) : User(nnick, nuser, nhost, ts6_uid_retrieve()) +static const Anope::string BotFlagString[] = { "1", "BI_CORE", "BI_PRIVATE", "" }; + +BotInfo::BotInfo(const Anope::string &nnick, const Anope::string &nuser, const Anope::string &nhost, const Anope::string &nreal) : User(nnick, nuser, nhost, ts6_uid_retrieve()), Flags<BotFlag, BI_END>(BotFlagString) { this->realname = nreal; this->server = Me; diff --git a/src/channels.cpp b/src/channels.cpp index 2a1bcbf1c..a4c920227 100644 --- a/src/channels.cpp +++ b/src/channels.cpp @@ -14,11 +14,13 @@ channel_map ChannelList; +static const Anope::string ChannelFlagString[] = { "CH_PERSIST", "CH_SYNCING", "CH_LOGCHAN", "" }; + /** Default constructor * @param name The channel name * @param ts The time the channel was created */ -Channel::Channel(const Anope::string &nname, time_t ts) +Channel::Channel(const Anope::string &nname, time_t ts) : Flags<ChannelFlag, 3>(ChannelFlagString) { if (nname.empty()) throw CoreException("A channel without a name ?"); @@ -1227,10 +1229,12 @@ void MassChannelModes(BotInfo *bi, const Anope::string &modes) } } +static const Anope::string EntryFlagString[] = { "ENTRYTYPE_NONE", "ENTRYTYPE_CIDR", "ENTRYTYPE_NICK_WILD", "ENTRYTYPE_NICK", "ENTRYTYPE_USER_WILD", "ENTRYTYPE_USER", "ENTRYTYPE_HOST_WILD", "ENTRYTYPE_HOST", "" }; + /** Constructor * @param _host A full nick!ident@host/cidr mask */ -Entry::Entry(const Anope::string &_host) +Entry::Entry(const Anope::string &_host) : Flags<EntryType>(EntryFlagString) { this->SetFlag(ENTRYTYPE_NONE); this->cidr_len = 0; diff --git a/src/command.cpp b/src/command.cpp index bbbaf0cb6..17de467e9 100644 --- a/src/command.cpp +++ b/src/command.cpp @@ -66,7 +66,7 @@ void CommandSource::Reply(const char *message, ...) } } -Command::Command(const Anope::string &sname, size_t min_params, size_t max_params, const Anope::string &spermission) : MaxParams(max_params), MinParams(min_params), name(sname), permission(spermission) +Command::Command(const Anope::string &sname, size_t min_params, size_t max_params, const Anope::string &spermission) : Flags<CommandFlag>(CommandFlagStrings), MaxParams(max_params), MinParams(min_params), name(sname), permission(spermission) { this->module = NULL; this->service = NULL; diff --git a/src/config.cpp b/src/config.cpp index 47f0f82ce..330594c13 100644 --- a/src/config.cpp +++ b/src/config.cpp @@ -40,7 +40,7 @@ static Anope::string NSDefaults; /*************************************************************************/ -ServerConfig::ServerConfig() : errstr(""), config_data() +ServerConfig::ServerConfig() : errstr(""), config_data(), NSDefFlags(NickCoreFlagStrings), CSDefFlags(ChannelInfoFlagStrings), BSDefFlags(BotServFlagStrings) { this->Read(); diff --git a/src/memoserv.cpp b/src/memoserv.cpp index 40bc47f22..a13eeab55 100644 --- a/src/memoserv.cpp +++ b/src/memoserv.cpp @@ -14,6 +14,8 @@ static bool SendMemoMail(NickCore *nc, MemoInfo *mi, Memo *m); +Memo::Memo() : Flags<MemoFlag>(MemoFlagStrings) { } + /** * MemoServ initialization. * @return void diff --git a/src/modes.cpp b/src/modes.cpp index ce5543f93..4f09e0545 100644 --- a/src/modes.cpp +++ b/src/modes.cpp @@ -101,6 +101,10 @@ void SetDefaultMLock(ServerConfig *config) } } +ChannelStatus::ChannelStatus() : Flags<ChannelModeName, CMODE_END * 2>(ChannelModeNameStrings) +{ +} + Anope::string ChannelStatus::BuildCharPrefixList() const { Anope::string ret; diff --git a/src/nickalias.cpp b/src/nickalias.cpp index 4f404b023..b49a02121 100644 --- a/src/nickalias.cpp +++ b/src/nickalias.cpp @@ -24,7 +24,7 @@ NickRequest::~NickRequest() * @param nick The nick * @param nickcore The nickcofe for this nick */ -NickAlias::NickAlias(const Anope::string &nickname, NickCore *nickcore) +NickAlias::NickAlias(const Anope::string &nickname, NickCore *nickcore) : Flags<NickNameFlag, NS_END>(NickNameFlagStrings) { if (nickname.empty()) throw CoreException("Empty nick passed to NickAlias constructor"); diff --git a/src/nickcore.cpp b/src/nickcore.cpp index b094c8962..85c703dbf 100644 --- a/src/nickcore.cpp +++ b/src/nickcore.cpp @@ -4,7 +4,7 @@ /** Default constructor * @param display The display nick */ -NickCore::NickCore(const Anope::string &coredisplay) +NickCore::NickCore(const Anope::string &coredisplay) : Flags<NickCoreFlag, NI_END>(NickCoreFlagStrings) { if (coredisplay.empty()) throw CoreException("Empty display passed to NickCore constructor"); diff --git a/src/operserv.cpp b/src/operserv.cpp index b31a4385d..3e1f6b7bd 100644 --- a/src/operserv.cpp +++ b/src/operserv.cpp @@ -17,9 +17,9 @@ std::vector<NewsItem *> News; std::vector<std::bitset<32> > DefCon; bool DefConModesSet = false; /* Defcon modes mlocked on */ -Flags<ChannelModeName, CMODE_END * 2> DefConModesOn; +Flags<ChannelModeName, CMODE_END * 2> DefConModesOn(ChannelModeNameStrings); /* Defcon modes mlocked off */ -Flags<ChannelModeName, CMODE_END * 2> DefConModesOff; +Flags<ChannelModeName, CMODE_END * 2> DefConModesOff(ChannelModeNameStrings); /* Map of Modesa and Params for DefCon */ std::map<ChannelModeName, Anope::string> DefConModesOnParams; diff --git a/src/regchannel.cpp b/src/regchannel.cpp index b240b8554..0d0f5dc54 100644 --- a/src/regchannel.cpp +++ b/src/regchannel.cpp @@ -18,7 +18,7 @@ static ChanAccess dummy_access; /** Default constructor * @param chname The channel name */ -ChannelInfo::ChannelInfo(const Anope::string &chname) +ChannelInfo::ChannelInfo(const Anope::string &chname) : Flags<ChannelInfoFlag, CI_END>(ChannelInfoFlagStrings), botflags(BotServFlagStrings) { if (chname.empty()) throw CoreException("Empty channel passed to ChannelInfo constructor"); @@ -65,7 +65,7 @@ ChannelInfo::ChannelInfo(const Anope::string &chname) /** Copy constructor * @param ci The ChannelInfo to copy settings to */ -ChannelInfo::ChannelInfo(ChannelInfo *ci) +ChannelInfo::ChannelInfo(ChannelInfo *ci) : Flags<ChannelInfoFlag, CI_END>(ChannelInfoFlagStrings), botflags(BotServFlagStrings) { *this = *ci; diff --git a/src/servers.cpp b/src/servers.cpp index 0f9930403..47a5e5389 100644 --- a/src/servers.cpp +++ b/src/servers.cpp @@ -45,7 +45,8 @@ CapabInfo Capab_Info[] = { {"", CAPAB_END} }; -Flags<CapabType, CAPAB_END> Capab; +static const Anope::string CapabFlags = ""; +Flags<CapabType, CAPAB_END> Capab(&CapabFlags); /** Constructor * @param uplink The uplink this server is from, is only NULL when creating Me @@ -55,7 +56,7 @@ Flags<CapabType, CAPAB_END> Capab; * @param sid Server sid/numeric * @param flag An optional server flag */ -Server::Server(Server *uplink, const Anope::string &name, unsigned hops, const Anope::string &description, const Anope::string &sid, ServerFlag flag) : Name(name), Hops(hops), Description(description), SID(sid), UplinkServer(uplink) +Server::Server(Server *uplink, const Anope::string &name, unsigned hops, const Anope::string &description, const Anope::string &sid, ServerFlag flag) : Flags<ServerFlag>(ServerFlagStrings), Name(name), Hops(hops), Description(description), SID(sid), UplinkServer(uplink) { this->SetFlag(SERVER_SYNCING); this->SetFlag(flag); diff --git a/src/sockets.cpp b/src/sockets.cpp index d15d292cb..941169c17 100644 --- a/src/sockets.cpp +++ b/src/sockets.cpp @@ -337,7 +337,7 @@ void SocketIO::Connect(ConnectionSocket *s, const Anope::string &target, int por /** Empty constructor, used for things such as the pipe socket */ -Socket::Socket() +Socket::Socket() : Flags<SocketFlag, 2>(SocketFlagStrings) { this->Type = SOCKTYPE_BASE; this->IO = &normalSocketIO; @@ -348,7 +348,7 @@ Socket::Socket() * @param ipv6 IPv6? * @param type The socket type, defaults to SOCK_STREAM */ -Socket::Socket(int sock, bool ipv6, int type) +Socket::Socket(int sock, bool ipv6, int type) : Flags<SocketFlag, 2>(SocketFlagStrings) { this->Type = SOCKTYPE_BASE; this->IO = &normalSocketIO; diff --git a/src/users.cpp b/src/users.cpp index 58da0f7b2..5e406ced2 100644 --- a/src/users.cpp +++ b/src/users.cpp @@ -22,7 +22,7 @@ time_t maxusertime; /*************************************************************************/ /*************************************************************************/ -User::User(const Anope::string &snick, const Anope::string &sident, const Anope::string &shost, const Anope::string &suid) +User::User(const Anope::string &snick, const Anope::string &sident, const Anope::string &shost, const Anope::string &suid) : modes(UserModeNameStrings) { if (snick.empty() || sident.empty() || shost.empty()) throw CoreException("Bad args passed to User::User"); |