]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_spanningtree/addline.cpp
Remove MaxMapHeight, replace with dynamically sized buffers
[user/henk/code/inspircd.git] / src / modules / m_spanningtree / addline.cpp
index b9bca310952933d8672b7dd0ed574df58f957a0e..69544aebbc107753655edf45606313f76a8e901e 100644 (file)
@@ -2,7 +2,7 @@
  *       | Inspire Internet Relay Chat Daemon |
  *       +------------------------------------+
  *
- *  InspIRCd: (C) 2002-2008 InspIRCd Development Team
+ *  InspIRCd: (C) 2002-2009 InspIRCd Development Team
  * See: http://www.inspircd.org/wiki/index.php/Credits
  *
  * This program is free but copyrighted software; see
@@ -24,14 +24,14 @@ bool TreeSocket::AddLine(const std::string &prefix, std::deque<std::string> &par
 {
        if (params.size() < 6)
        {
-               this->Instance->SNO->WriteToSnoMask('x',"%s sent me a malformed ADDLINE of type %s.",prefix.c_str(),params[0].c_str());
+               this->ServerInstance->SNO->WriteToSnoMask('x',"%s sent me a malformed ADDLINE of type %s.",prefix.c_str(),params[0].c_str());
                return true;
        }
 
-       XLineFactory* xlf = Instance->XLines->GetFactory(params[0]);
+       XLineFactory* xlf = ServerInstance->XLines->GetFactory(params[0]);
 
        std::string setter = "<unknown>";
-       User* usr = Instance->FindNick(prefix);
+       User* usr = ServerInstance->FindNick(prefix);
        if (usr)
                setter = usr->nick;
        else
@@ -43,33 +43,42 @@ bool TreeSocket::AddLine(const std::string &prefix, std::deque<std::string> &par
 
        if (!xlf)
        {
-               this->Instance->SNO->WriteToSnoMask('x',"%s sent me an unknown ADDLINE type (%s).",setter.c_str(),params[0].c_str());
+               this->ServerInstance->SNO->WriteToSnoMask('x',"%s sent me an unknown ADDLINE type (%s).",setter.c_str(),params[0].c_str());
                return true;
        }
 
-       XLine* xl = xlf->Generate(Instance->Time(), atoi(params[4].c_str()), params[2].c_str(), params[5].c_str(), params[1].c_str());
+       XLine* xl = NULL;
+       try
+       {
+               xl = xlf->Generate(ServerInstance->Time(), atoi(params[4].c_str()), params[2].c_str(), params[5].c_str(), params[1].c_str());
+       }
+       catch (ModuleException &e)
+       {
+               this->ServerInstance->SNO->WriteToSnoMask('x',"Unable to ADDLINE type %s from %s: %s", params[0].c_str(), setter.c_str(), e.GetReason());
+               return true;
+       }
        xl->SetCreateTime(atoi(params[3].c_str()));
-       if (Instance->XLines->AddLine(xl,NULL))
+       if (ServerInstance->XLines->AddLine(xl, NULL))
        {
                if (xl->duration)
                {
-                       this->Instance->SNO->WriteToSnoMask('x',"%s added %s%s on %s to expire on %s (%s).",setter.c_str(),params[0].c_str(),params[0].length() == 1 ? "LINE" : "",
-                                       params[1].c_str(),Instance->TimeString(xl->expiry).c_str(),params[5].c_str());
+                       this->ServerInstance->SNO->WriteToSnoMask('x',"%s added %s%s on %s to expire on %s (%s).",setter.c_str(),params[0].c_str(),params[0].length() == 1 ? "LINE" : "",
+                                       params[1].c_str(),ServerInstance->TimeString(xl->expiry).c_str(),params[5].c_str());
                }
                else
                {
-                       this->Instance->SNO->WriteToSnoMask('x',"%s added permanent %s%s on %s (%s).",setter.c_str(),params[0].c_str(),params[0].length() == 1 ? "LINE" : "",
+                       this->ServerInstance->SNO->WriteToSnoMask('x',"%s added permanent %s%s on %s (%s).",setter.c_str(),params[0].c_str(),params[0].length() == 1 ? "LINE" : "",
                                        params[1].c_str(),params[5].c_str());
                }
                params[5] = ":" + params[5];
 
-               User* u = Instance->FindNick(prefix);
+               User* u = ServerInstance->FindNick(prefix);
                Utils->DoOneToAllButSender(prefix, "ADDLINE", params, u ? u->server : prefix);
                TreeServer *remoteserver = Utils->FindServer(u ? u->server : prefix);
 
                if (!remoteserver->bursting)
                {
-                       Instance->XLines->ApplyLines();
+                       ServerInstance->XLines->ApplyLines();
                }
        }
        else