#include "client.h"
#include "common.h"
#include "hash.h"
-#include "irc_string.h"
+#include "match.h"
#include "ircd.h"
#include "numeric.h"
#include "send.h"
#include "modules.h"
#include "s_conf.h"
#include "packet.h"
+#include "inline/stringops.h"
static int m_part(struct Client *, struct Client *, int, const char **);
reason[0] = '\0';
if(parc > 2)
- strlcpy(reason, parv[2], sizeof(reason));
+ rb_strlcpy(reason, parv[2], sizeof(reason));
- name = strtoken(&p, s, ",");
+ name = rb_strtok_r(s, ",", &p);
/* Finish the flood grace period... */
if(MyClient(source_p) && !IsFloodDone(source_p))
flood_endgrace(source_p);
- strip_colour(reason);
-
while(name)
{
part_one_client(client_p, source_p, name, reason);
- name = strtoken(&p, NULL, ",");
+ name = rb_strtok_r(NULL, ",", &p);
}
return 0;
}
{
struct Channel *chptr;
struct membership *msptr;
+ char reason2[BUFSIZE];
if((chptr = find_channel(name)) == NULL)
{
if(reason[0] && (is_chanop(msptr) || !MyConnect(source_p) ||
((can_send(chptr, source_p, msptr) > 0 &&
(source_p->localClient->firsttime +
- ConfigFileEntry.anti_spam_exit_message_time) < CurrentTime))))
+ ConfigFileEntry.anti_spam_exit_message_time) < rb_current_time()))))
{
+ if(chptr->mode.mode & MODE_NOCOLOR)
+ {
+ rb_strlcpy(reason2, reason, BUFSIZE);
+ strip_colour(reason2);
+ reason = reason2;
+ }
sendto_server(client_p, chptr, CAP_TS6, NOCAPS,
":%s PART %s :%s", use_id(source_p), chptr->chname, reason);
- sendto_server(client_p, chptr, NOCAPS, CAP_TS6,
- ":%s PART %s :%s", source_p->name, chptr->chname, reason);
sendto_channel_local(ALL_MEMBERS, chptr, ":%s!%s@%s PART %s :%s",
source_p->name, source_p->username,
source_p->host, chptr->chname, reason);
{
sendto_server(client_p, chptr, CAP_TS6, NOCAPS,
":%s PART %s", use_id(source_p), chptr->chname);
- sendto_server(client_p, chptr, NOCAPS, CAP_TS6,
- ":%s PART %s", source_p->name, chptr->chname);
sendto_channel_local(ALL_MEMBERS, chptr, ":%s!%s@%s PART %s",
source_p->name, source_p->username,
source_p->host, chptr->chname);