]> git.netwichtig.de Git - user/henk/code/inspircd.git/blobdiff - src/modules/m_spanningtree/away.cpp
m_spanningtree Rewrite PING logic to use Timers
[user/henk/code/inspircd.git] / src / modules / m_spanningtree / away.cpp
index 7b151dfefb94d3d536582997d053ef46cc4e7f94..f14c8ac987937f735f488c4d12052f4d38cbd8ce 100644 (file)
@@ -27,14 +27,14 @@ CmdResult CommandAway::HandleRemote(RemoteUser* u, std::vector<std::string>& par
 {
        if (params.size())
        {
-               FOREACH_MOD(OnSetAway, (u, params[params.size() - 1]));
+               FOREACH_MOD(OnSetAway, (u, params.back()));
 
                if (params.size() > 1)
                        u->awaytime = ConvToInt(params[0]);
                else
                        u->awaytime = ServerInstance->Time();
 
-               u->awaymsg = params[params.size() - 1];
+               u->awaymsg = params.back();
        }
        else
        {
@@ -43,3 +43,16 @@ CmdResult CommandAway::HandleRemote(RemoteUser* u, std::vector<std::string>& par
        }
        return CMD_SUCCESS;
 }
+
+CommandAway::Builder::Builder(User* user)
+       : CmdBuilder(user, "AWAY")
+{
+       push_int(user->awaytime).push_last(user->awaymsg);
+}
+
+CommandAway::Builder::Builder(User* user, const std::string& msg)
+       : CmdBuilder(user, "AWAY")
+{
+       if (!msg.empty())
+               push_int(ServerInstance->Time()).push_last(msg);
+}