X-Git-Url: https://jfr.im/git/irc/rqf/shadowircd.git/blobdiff_plain/212380e3f42f585dc1ea927402252eb943f91f7b..8097430a810ac1535fe5304f74991b16ff58b064:/modules/m_capab.c diff --git a/modules/m_capab.c b/modules/m_capab.c index e915f40..227a997 100644 --- a/modules/m_capab.c +++ b/modules/m_capab.c @@ -1,6 +1,6 @@ /* * ircd-ratbox: A slightly useful ircd. - * m_away.c: Negotiates capabilities with a remote server. + * m_capab.c: Negotiates capabilities with a remote server. * * Copyright (C) 1990 Jarkko Oikarinen and University of Oulu, Co Center * Copyright (C) 1996-2002 Hybrid Development Team @@ -26,7 +26,7 @@ #include "stdinc.h" #include "client.h" -#include "irc_string.h" +#include "match.h" #include "s_serv.h" #include "s_conf.h" #include "msg.h" @@ -50,7 +50,6 @@ DECLARE_MODULE_AV1(capab, NULL, NULL, capab_clist, NULL, NULL, "$Revision: 1295 /* * mr_capab - CAPAB message handler - * parv[0] = sender prefix * parv[1] = space-separated list of capabilities * */ @@ -78,13 +77,13 @@ mr_capab(struct Client *client_p, struct Client *source_p, int parc, const char else client_p->localClient->caps |= CAP_CAP; - MyFree(client_p->localClient->fullcaps); - DupString(client_p->localClient->fullcaps, parv[1]); + rb_free(client_p->localClient->fullcaps); + client_p->localClient->fullcaps = rb_strdup(parv[1]); for (i = 1; i < parc; i++) { char *t = LOCAL_COPY(parv[i]); - for (s = strtoken(&p, t, " "); s; s = strtoken(&p, NULL, " ")) + for (s = rb_strtok_r(t, " ", &p); s; s = rb_strtok_r(NULL, " ", &p)) { for (cap = captab; cap->name; cap++) { @@ -114,11 +113,14 @@ me_gcap(struct Client *client_p, struct Client *source_p, /* already had GCAPAB?! */ if(!EmptyString(source_p->serv->fullcaps)) - return 0; + { + source_p->serv->caps = 0; + rb_free(source_p->serv->fullcaps); + } - DupString(source_p->serv->fullcaps, parv[1]); + source_p->serv->fullcaps = rb_strdup(parv[1]); - for (s = strtoken(&p, t, " "); s; s = strtoken(&p, NULL, " ")) + for (s = rb_strtok_r(t, " ", &p); s; s = rb_strtok_r(NULL, " ", &p)) { for (cap = captab; cap->name; cap++) {