X-Git-Url: https://git.netwichtig.de/gitweb/?a=blobdiff_plain;f=src%2Fcommands%2Fcmd_away.cpp;h=96da5cda5874c415852cfed466c5fc02ce3fd065;hb=33ce32eb8bfddfc1cb04668a03c9b795d33eb9c0;hp=33e140beb978a02ba9a8cef246295d0f30f5610f;hpb=d48726ce802019f2e1573ebef7ae9f50a14f0a31;p=user%2Fhenk%2Fcode%2Finspircd.git diff --git a/src/commands/cmd_away.cpp b/src/commands/cmd_away.cpp index 33e140beb..96da5cda5 100644 --- a/src/commands/cmd_away.cpp +++ b/src/commands/cmd_away.cpp @@ -21,11 +21,11 @@ extern "C" DllExport Command* init_command(InspIRCd* Instance) /** Handle /AWAY */ -CmdResult CommandAway::Handle (const char* const* parameters, int pcnt, User *user) +CmdResult CommandAway::Handle (const std::vector& parameters, User *user) { int MOD_RESULT = 0; - if ((pcnt) && (*parameters[0])) + if ((parameters.size()) && (!parameters[0].empty())) { FOREACH_RESULT(I_OnSetAway, OnSetAway(user, parameters[0])); @@ -33,8 +33,9 @@ CmdResult CommandAway::Handle (const char* const* parameters, int pcnt, User *us return CMD_FAILURE; user->awaytime = ServerInstance->Time(); - strlcpy(user->awaymsg,parameters[0],MAXAWAY); - user->WriteNumeric(306, "%s :You have been marked as being away",user->nick); + user->awaymsg.assign(parameters[0], 0, ServerInstance->Config->Limits.MaxAway); + + user->WriteNumeric(RPL_NOWAWAY, "%s :You have been marked as being away",user->nick.c_str()); } else { @@ -43,8 +44,8 @@ CmdResult CommandAway::Handle (const char* const* parameters, int pcnt, User *us if (MOD_RESULT != 0 && !IS_LOCAL(user)) return CMD_FAILURE; - *user->awaymsg = 0; - user->WriteNumeric(305, "%s :You are no longer marked as being away",user->nick); + user->awaymsg.clear(); + user->WriteNumeric(RPL_UNAWAY, "%s :You are no longer marked as being away",user->nick.c_str()); } return CMD_SUCCESS;