From 4a2b9ebcf38d6c0a2860b966421b3af125438488 Mon Sep 17 00:00:00 2001 From: Adam Date: Tue, 25 May 2010 00:57:25 -0500 Subject: Renamed all of source files from .c to .cpp --- src/core/cs_help.cpp | 78 ++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 78 insertions(+) create mode 100644 src/core/cs_help.cpp (limited to 'src/core/cs_help.cpp') diff --git a/src/core/cs_help.cpp b/src/core/cs_help.cpp new file mode 100644 index 000000000..941634483 --- /dev/null +++ b/src/core/cs_help.cpp @@ -0,0 +1,78 @@ +/* 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 ¶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); + FOREACH_MOD(I_OnChanServHelp, OnChanServHelp(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->SetVersion(VERSION_STRING); + this->SetType(CORE); + this->AddCommand(ChanServ, new CommandCSHelp()); + } +}; + +MODULE_INIT(CSHelp) -- cgit From 6cd88494662c5c4af2da891926dcc82367596cb9 Mon Sep 17 00:00:00 2001 From: Adam Date: Sun, 30 May 2010 17:21:44 -0400 Subject: Moved the *Serv help functions to Command, will come in use later with subcommands --- src/core/cs_help.cpp | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) (limited to 'src/core/cs_help.cpp') diff --git a/src/core/cs_help.cpp b/src/core/cs_help.cpp index 941634483..3fe704349 100644 --- a/src/core/cs_help.cpp +++ b/src/core/cs_help.cpp @@ -54,7 +54,8 @@ class CommandCSHelp : public Command void OnSyntaxError(User *u, const ci::string &subcommand) { notice_help(Config.s_ChanServ, u, CHAN_HELP); - FOREACH_MOD(I_OnChanServHelp, OnChanServHelp(u)); + for (CommandMap::const_iterator it = ChanServ->Commands.begin(); it != ChanServ->Commands.end(); ++it) + 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()) -- cgit