]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_setname.cpp
Fix mistakenly using Clang instead of GCC on older FreeBSD versions.
[user/henk/code/inspircd.git] / src / modules / m_setname.cpp
index 0d6b1d9f3f55237e506e5c6715545e196935ce3f..d0610853bc4ce7e1308d01616473136b25c8eb98 100644 (file)
@@ -30,18 +30,13 @@ class CommandSetname : public Command
  public:
        CommandSetname(Module* Creator) : Command(Creator,"SETNAME", 1, 1)
        {
+               allow_empty_last_param = false;
                syntax = "<new-gecos>";
                TRANSLATE2(TR_TEXT, TR_END);
        }
 
        CmdResult Handle (const std::vector<std::string>& parameters, User *user)
        {
-               if (parameters.size() == 0)
-               {
-                       user->WriteServ("NOTICE %s :*** SETNAME: GECOS must be specified", user->nick.c_str());
-                       return CMD_FAILURE;
-               }
-
                if (parameters[0].size() > ServerInstance->Config->Limits.MaxGecos)
                {
                        user->WriteServ("NOTICE %s :*** SETNAME: GECOS too long", user->nick.c_str());
@@ -50,8 +45,7 @@ class CommandSetname : public Command
 
                if (user->ChangeName(parameters[0].c_str()))
                {
-                       ServerInstance->SNO->WriteGlobalSno('a', "%s used SETNAME to change their GECOS to %s", user->nick.c_str(), parameters[0].c_str());
-                       return CMD_SUCCESS;
+                       ServerInstance->SNO->WriteGlobalSno('a', "%s used SETNAME to change their GECOS to '%s'", user->nick.c_str(), parameters[0].c_str());
                }
 
                return CMD_SUCCESS;
@@ -66,7 +60,11 @@ class ModuleSetName : public Module
        ModuleSetName()
                : cmd(this)
        {
-               ServerInstance->AddCommand(&cmd);
+       }
+
+       void init()
+       {
+               ServerInstance->Modules->AddService(cmd);
        }
 
        virtual ~ModuleSetName()