From 66221de4b6cca64692c84eabfe0b81cabdbd00bc Mon Sep 17 00:00:00 2001 From: Attila Molnar Date: Wed, 14 Jan 2015 12:07:20 +0100 Subject: cmode_k Fix oversight in substr() conversion While at it, introduce a named constant for maximum key length --- include/builtinmodes.h | 1 + src/modes/cmode_k.cpp | 3 ++- 2 files changed, 3 insertions(+), 1 deletion(-) diff --git a/include/builtinmodes.h b/include/builtinmodes.h index 96838ce5e..62ccaf62d 100644 --- a/include/builtinmodes.h +++ b/include/builtinmodes.h @@ -39,6 +39,7 @@ class ModeChannelBan : public ListModeBase */ class ModeChannelKey : public ParamMode { + static const std::string::size_type maxkeylen = 32; public: ModeChannelKey(); ModeAction OnModeChange(User* source, User* dest, Channel* channel, std::string ¶meter, bool adding); diff --git a/src/modes/cmode_k.cpp b/src/modes/cmode_k.cpp index 6738c046e..980b3215a 100644 --- a/src/modes/cmode_k.cpp +++ b/src/modes/cmode_k.cpp @@ -52,7 +52,8 @@ ModeAction ModeChannelKey::OnModeChange(User* source, User*, Channel* channel, s channel->SetMode(this, adding); if (adding) { - parameter.erase(32); + if (parameter.length() > maxkeylen) + parameter.erase(maxkeylen); ext.set(channel, parameter); } else -- cgit v1.2.3