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_owner ? "a" : "",
+ ConfigChannel.use_halfop ? "h" : "",
+ ConfigChannel.use_owner ? "!" : "",
+ ConfigChannel.use_halfop ? "%" : "");
return result;
}
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);