X-Git-Url: https://jfr.im/git/irc/rqf/shadowircd.git/blobdiff_plain/d9af2dddd3d2361238a2a4f4480396e27953c583..4b4fc78cfba459be6bd20cbaafff3f0606ae4116:/src/supported.c diff --git a/src/supported.c b/src/supported.c index e0f617e..4ed2616 100644 --- a/src/supported.c +++ b/src/supported.c @@ -111,6 +111,32 @@ add_isupport(const char *name, const char *(*func)(const void *), const void *pa rb_dlinkAddTail(item, &item->node, &isupportlist); } +const void * +change_isupport(const char *name, const char *(*func)(const void *), const void *param) +{ + rb_dlink_node *ptr; + struct isupportitem *item; + const void *oldvalue; + + RB_DLINK_FOREACH(ptr, isupportlist.head) + { + item = ptr->data; + + if (!strcmp(item->name, name)) + { + oldvalue = item->param; + + // item->name = name; + item->func = func; + item->param = param; + + break; + } + } + + return oldvalue; +} + void delete_isupport(const char *name) { @@ -218,12 +244,33 @@ isupport_chanmodes(const void *ptr) return result; } +static const char * +isupport_chantypes(const void *ptr) +{ + return ConfigChannel.use_local_channels ? "&#" : "#"; +} + static const char * isupport_chanlimit(const void *ptr) { static char result[30]; - rb_snprintf(result, sizeof result, "&#:%i", ConfigChannel.max_chans_per_user); + rb_snprintf(result, sizeof result, "%s:%i", + ConfigChannel.use_local_channels ? "&#" : "#", + ConfigChannel.max_chans_per_user); + return result; +} + +static const char* +isupport_prefix(const void *ptr) +{ + static char result[11]; + + rb_snprintf(result, sizeof result, "(%so%sv)%s@%s+", + ConfigChannel.use_admin ? "a" : "", + ConfigChannel.use_halfop ? "h" : "", + ConfigChannel.use_admin ? "!" : "", + ConfigChannel.use_halfop ? "%" : ""); return result; } @@ -271,12 +318,12 @@ init_isupport(void) static int channellen = LOC_CHANNELLEN; static int topiclen = TOPICLEN; - add_isupport("CHANTYPES", isupport_string, "&#"); + add_isupport("CHANTYPES", isupport_chantypes, NULL); add_isupport("EXCEPTS", isupport_boolean, &ConfigChannel.use_except); add_isupport("INVEX", isupport_boolean, &ConfigChannel.use_invex); add_isupport("CHANMODES", isupport_chanmodes, NULL); add_isupport("CHANLIMIT", isupport_chanlimit, NULL); - add_isupport("PREFIX", isupport_string, "(ov)@+"); + add_isupport("PREFIX", isupport_prefix, NULL); add_isupport("MAXLIST", isupport_maxlist, NULL); add_isupport("MODES", isupport_intptr, &maxmodes); add_isupport("NETWORK", isupport_stringptr, &ServerInfo.network_name); @@ -298,4 +345,6 @@ init_isupport(void) add_isupport("FNC", isupport_string, ""); add_isupport("TARGMAX", isupport_targmax, NULL); add_isupport("EXTBAN", isupport_extban, NULL); + add_isupport("WHOX", isupport_string, ""); + add_isupport("CLIENTVER", isupport_string, "3.0"); }