diff options
author | Daniel Vassdal <shutter@canternet.org> | 2015-01-17 14:46:28 +0100 |
---|---|---|
committer | Daniel Vassdal <shutter@canternet.org> | 2015-01-17 14:46:28 +0100 |
commit | cd5edf841bffc810466de2752323cd0730c9db9e (patch) | |
tree | 91ed039c45ab8ab0b3dd7a9c89b834b9edc5fed5 | |
parent | 225322b46f888fb034c87aea45fdde3f941c6450 (diff) |
cmd_list: Give +s precedence to +p
When +ps is set, handle it as +s (most restrictive) instead of +p
-rw-r--r-- | src/commands/cmd_list.cpp | 15 |
1 files changed, 8 insertions, 7 deletions
diff --git a/src/commands/cmd_list.cpp b/src/commands/cmd_list.cpp index 2f417bc04..2c420d1dd 100644 --- a/src/commands/cmd_list.cpp +++ b/src/commands/cmd_list.cpp @@ -82,14 +82,15 @@ CmdResult CommandList::Handle (const std::vector<std::string>& parameters, User // if the channel is not private/secret, OR the user is on the channel anyway bool n = (i->second->HasUser(user) || user->HasPrivPermission("channels/auspex")); - if (!n && i->second->IsModeSet('p')) + // If we're not in the channel and +s is set on it, we want to ignore it + if (n || !i->second->IsModeSet('s')) { - /* Channel is +p and user is outside/not privileged */ - user->WriteNumeric(322, "%s * %ld :",user->nick.c_str(), users); - } - else - { - if (n || !i->second->IsModeSet('s')) + if (!n && i->second->IsModeSet('p')) + { + /* Channel is +p and user is outside/not privileged */ + user->WriteNumeric(322, "%s * %ld :",user->nick.c_str(), users); + } + else { /* User is in the channel/privileged, channel is not +s */ user->WriteNumeric(322, "%s %s %ld :[+%s] %s",user->nick.c_str(),i->second->name.c_str(),users,i->second->ChanModes(n),i->second->topic.c_str()); |