From 8ec9a73a91ad1c7009fd3055fbad7c980b5e1732 Mon Sep 17 00:00:00 2001 From: Peter Powell Date: Sun, 16 Dec 2018 01:26:04 +0000 Subject: Fix ParamModeBase::OnUnset() not being virtual. Closes #1536. --- include/parammode.h | 5 ++--- src/modules/m_delaymsg.cpp | 2 +- src/modules/m_repeat.cpp | 2 +- 3 files changed, 4 insertions(+), 5 deletions(-) diff --git a/include/parammode.h b/include/parammode.h index b00082bd6..c79d11b6b 100644 --- a/include/parammode.h +++ b/include/parammode.h @@ -31,7 +31,7 @@ class CoreExport ParamModeBase : public ModeHandler ModeAction OnModeChange(User* source, User* dest, Channel* channel, std::string& param, bool adding) CXX11_OVERRIDE; // Does nothing by default - void OnUnset(User* source, Channel* chan) { } + virtual void OnUnset(User* source, Channel* chan) { } virtual ModeAction OnSet(User* source, Channel* chan, std::string& param) = 0; virtual void GetParameter(Channel* chan, std::string& out) = 0; }; @@ -62,8 +62,7 @@ class ParamMode : public ParamModeBase void OnUnsetInternal(User* source, Channel* chan) CXX11_OVERRIDE { - T* mh = static_cast(this); - mh->OnUnset(source, chan); + this->OnUnset(source, chan); ext.unset(chan); } diff --git a/src/modules/m_delaymsg.cpp b/src/modules/m_delaymsg.cpp index 9015e7bf9..f13ea48ea 100644 --- a/src/modules/m_delaymsg.cpp +++ b/src/modules/m_delaymsg.cpp @@ -36,7 +36,7 @@ class DelayMsgMode : public ParamMode } ModeAction OnSet(User* source, Channel* chan, std::string& parameter) CXX11_OVERRIDE; - void OnUnset(User* source, Channel* chan); + void OnUnset(User* source, Channel* chan) CXX11_OVERRIDE; void SerializeParam(Channel* chan, intptr_t n, std::string& out) { diff --git a/src/modules/m_repeat.cpp b/src/modules/m_repeat.cpp index af69f6be1..bd4206166 100644 --- a/src/modules/m_repeat.cpp +++ b/src/modules/m_repeat.cpp @@ -127,7 +127,7 @@ class RepeatMode : public ParamMode > { } - void OnUnset(User* source, Channel* chan) + void OnUnset(User* source, Channel* chan) CXX11_OVERRIDE { // Unset the per-membership extension when the mode is removed const Channel::MemberMap& users = chan->GetUsers(); -- cgit v1.2.3