diff options
author | Attila Molnar <attilamolnar@hush.com> | 2015-01-17 15:19:08 +0100 |
---|---|---|
committer | Attila Molnar <attilamolnar@hush.com> | 2015-01-17 15:19:08 +0100 |
commit | b7b21b660c164abfb1acd75564082df2f5b1078e (patch) | |
tree | 892a927fef7283203f868633015f1487a0d81fca | |
parent | 25542af56d0edad33104fe3314fdfaf0fcf381fb (diff) | |
parent | cd5edf841bffc810466de2752323cd0730c9db9e (diff) |
Merge pull request #968 from ShutterQuick/insp20+sporder
cmd_list: Give +s precedence to +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()); |