diff options
author | Adam <Adam@anope.org> | 2010-07-15 22:55:02 -0400 |
---|---|---|
committer | Adam <Adam@anope.org> | 2010-07-15 22:55:02 -0400 |
commit | a22f8d3b2de88b9bb6f80f0c2780846ae23ab389 (patch) | |
tree | a2fdf570868896a787df8a1169951b0028e68d6b /modules/core/cs_help.cpp | |
parent | 43b1e43afb85639485e36d24da351dc0f121be6e (diff) |
Moved some files and diretories around, made cmake skip files it knows it can't compile because of missing dependices.
Diffstat (limited to 'modules/core/cs_help.cpp')
-rw-r--r-- | modules/core/cs_help.cpp | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/modules/core/cs_help.cpp b/modules/core/cs_help.cpp new file mode 100644 index 000000000..536a6e423 --- /dev/null +++ b/modules/core/cs_help.cpp @@ -0,0 +1,73 @@ +/* ChanServ core functions + * + * (C) 2003-2010 Anope Team + * Contact us at team@anope.org + * + * Please read COPYING and README for further details. + * + * Based on the original code of Epona by Lara. + * Based on the original code of Services by Andy Church. + */ + +/*************************************************************************/ + +#include "module.h" + +class CommandCSHelp : public Command +{ + public: + CommandCSHelp() : Command("HELP", 1, 1) + { + this->SetFlag(CFLAG_ALLOW_UNREGISTERED); + this->SetFlag(CFLAG_STRIP_CHANNEL); + } + + CommandReturn Execute(User *u, const std::vector<ci::string> ¶ms) + { + ci::string cmd = params[0]; + + if (cmd == "LEVELS DESC") + { + int i; + notice_help(Config.s_ChanServ, u, CHAN_HELP_LEVELS_DESC); + if (!levelinfo_maxwidth) + for (i = 0; levelinfo[i].what >= 0; ++i) + { + int len = strlen(levelinfo[i].name); + if (len > levelinfo_maxwidth) + levelinfo_maxwidth = len; + } + for (i = 0; levelinfo[i].what >= 0; ++i) + notice_help(Config.s_ChanServ, u, CHAN_HELP_LEVELS_DESC_FORMAT, levelinfo_maxwidth, levelinfo[i].name, getstring(u, levelinfo[i].desc)); + } + else + mod_help_cmd(ChanServ, u, cmd.c_str()); + + return MOD_CONT; + } + + void OnSyntaxError(User *u, const ci::string &subcommand) + { + notice_help(Config.s_ChanServ, u, CHAN_HELP); + for (CommandMap::const_iterator it = ChanServ->Commands.begin(); it != ChanServ->Commands.end(); ++it) + if (!Config.HidePrivilegedCommands || it->second->permission.empty() || (u->Account() && u->Account()->HasCommand(it->second->permission))) + it->second->OnServHelp(u); + if (Config.CSExpire >= 86400) + notice_help(Config.s_ChanServ, u, CHAN_HELP_EXPIRES, Config.CSExpire / 86400); + if (u->Account() && u->Account()->IsServicesOper()) + notice_help(Config.s_ChanServ, u, CHAN_SERVADMIN_HELP); + } +}; + +class CSHelp : public Module +{ + public: + CSHelp(const std::string &modname, const std::string &creator) : Module(modname, creator) + { + this->SetAuthor("Anope"); + this->SetType(CORE); + this->AddCommand(ChanServ, new CommandCSHelp()); + } +}; + +MODULE_INIT(CSHelp) |