From ba55ac6a72aae178b14b49b121a5f3bd1a738917 Mon Sep 17 00:00:00 2001 From: attilamolnar Date: Sun, 17 Jun 2012 18:37:47 +0200 Subject: m_cap Allow clients to disable specific capabilities by prefixing them with a dash (-) to be compliant with the specification --- src/modules/m_cap.h | 18 ++++++++++++------ 1 file changed, 12 insertions(+), 6 deletions(-) diff --git a/src/modules/m_cap.h b/src/modules/m_cap.h index 9ce7f9501..ce7e7f394 100644 --- a/src/modules/m_cap.h +++ b/src/modules/m_cap.h @@ -57,13 +57,19 @@ class GenericCap CapEvent *data = static_cast(&ev); if (data->type == CapEvent::CAPEVENT_REQ) { - std::vector::iterator it; - if ((it = std::find(data->wanted.begin(), data->wanted.end(), cap)) != data->wanted.end()) + for (std::vector::iterator it = data->wanted.begin(); it != data->wanted.end(); ++it) { - // we can handle this, so ACK it, and remove it from the wanted list - data->ack.push_back(*it); - data->wanted.erase(it); - ext.set(data->user, 1); + if (it->empty()) + continue; + bool enablecap = ((*it)[0] != '-'); + if (((enablecap) && (*it == cap)) || (*it == "-" + cap)) + { + // we can handle this, so ACK it, and remove it from the wanted list + data->ack.push_back(*it); + data->wanted.erase(it); + ext.set(data->user, enablecap ? 1 : 0); + break; + } } } else if (data->type == CapEvent::CAPEVENT_LS) -- cgit v1.2.3