mirror of
https://github.com/osmarks/ngircd.git
synced 2024-12-12 09:50:29 +00:00
Convert more code to use Channel_HasMode
This commit is contained in:
parent
c74115f25c
commit
74514b8c23
@ -657,7 +657,7 @@ IRC_LIST( CLIENT *Client, REQUEST *Req )
|
||||
GLOBAL bool
|
||||
IRC_CHANINFO( CLIENT *Client, REQUEST *Req )
|
||||
{
|
||||
char modes_add[COMMAND_LEN], l[16], *ptr;
|
||||
char modes_add[COMMAND_LEN], l[16];
|
||||
CLIENT *from;
|
||||
CHANNEL *chan;
|
||||
int arg_topic;
|
||||
@ -688,9 +688,8 @@ IRC_CHANINFO( CLIENT *Client, REQUEST *Req )
|
||||
return CONNECTED;
|
||||
|
||||
if (Req->argv[1][0] == '+') {
|
||||
ptr = Channel_Modes(chan);
|
||||
if (!*ptr) {
|
||||
/* OK, this channel doesn't have modes jet,
|
||||
if (!Channel_Modes(chan)) {
|
||||
/* OK, this channel doesn't have modes yet,
|
||||
* set the received ones: */
|
||||
Channel_SetModes(chan, &Req->argv[1][1]);
|
||||
|
||||
@ -706,22 +705,16 @@ IRC_CHANINFO( CLIENT *Client, REQUEST *Req )
|
||||
}
|
||||
|
||||
strcpy(modes_add, "");
|
||||
ptr = Channel_Modes(chan);
|
||||
while (*ptr) {
|
||||
if (*ptr == 'l') {
|
||||
if (Channel_HasMode(chan, 'l')) {
|
||||
snprintf(l, sizeof(l), " %lu",
|
||||
Channel_MaxUsers(chan));
|
||||
strlcat(modes_add, l,
|
||||
sizeof(modes_add));
|
||||
strlcat(modes_add, l, sizeof(modes_add));
|
||||
}
|
||||
if (*ptr == 'k') {
|
||||
strlcat(modes_add, " ",
|
||||
sizeof(modes_add));
|
||||
if (Channel_HasMode(chan, 'k')) {
|
||||
strlcat(modes_add, " ", sizeof(modes_add));
|
||||
strlcat(modes_add, Channel_Key(chan),
|
||||
sizeof(modes_add));
|
||||
}
|
||||
ptr++;
|
||||
}
|
||||
|
||||
/* Inform members of this channel */
|
||||
IRC_WriteStrChannelPrefix(Client, chan, from, false,
|
||||
@ -734,8 +727,7 @@ IRC_CHANINFO( CLIENT *Client, REQUEST *Req )
|
||||
|
||||
if (arg_topic > 0) {
|
||||
/* We got a topic */
|
||||
ptr = Channel_Topic( chan );
|
||||
if (!*ptr && Req->argv[arg_topic][0]) {
|
||||
if (!Channel_Topic( chan ) && Req->argv[arg_topic][0]) {
|
||||
/* OK, there is no topic jet */
|
||||
Channel_SetTopic(chan, Client, Req->argv[arg_topic]);
|
||||
IRC_WriteStrChannelPrefix(Client, chan, from, false,
|
||||
|
Loading…
Reference in New Issue
Block a user