*
* All unknown/unlisted modes are treated as type D.
*/
-/* ELIST=[tokens]:
- *
- * M = mask search
- * N = !mask search
- * U = user count search (< >)
- * C = creation time search (C> C<)
- * T = topic search (T> T<)
- */
#include "stdinc.h"
-#include "tools.h"
#include "client.h"
#include "common.h"
#include "numeric.h"
#include "ircd.h"
#include "s_conf.h"
#include "supported.h"
+#include "chmode.h"
rb_dlink_list isupportlist;
{
struct isupportitem *item;
- item = MyMalloc(sizeof(struct isupportitem));
+ item = rb_malloc(sizeof(struct isupportitem));
item->name = name;
item->func = func;
item->param = param;
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 = NULL;
+
+ 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)
{
rb_dlink_node *ptr, *next_ptr;
struct isupportitem *item;
- DLINK_FOREACH_SAFE(ptr, next_ptr, isupportlist.head)
+ RB_DLINK_FOREACH_SAFE(ptr, next_ptr, isupportlist.head)
{
item = ptr->data;
if (!strcmp(item->name, name))
{
rb_dlinkDelete(ptr, &isupportlist);
- MyFree(item);
+ rb_free(item);
}
}
}
extra_space += strlen(me.name) + 1 + strlen(form_str(RPL_ISUPPORT));
nchars = extra_space, nparams = 0, buf[0] = '\0';
- DLINK_FOREACH(ptr, isupportlist.head)
+ RB_DLINK_FOREACH(ptr, isupportlist.head)
{
item = ptr->data;
value = (*item->func)(item->param);
nchars = extra_space, nparams = 0, buf[0] = '\0';
}
if (nparams > 0)
- strlcat(buf, " ", sizeof buf), nchars++;
- strlcat(buf, item->name, sizeof buf);
+ rb_strlcat(buf, " ", sizeof buf), nchars++;
+ rb_strlcat(buf, item->name, sizeof buf);
if (!EmptyString(value))
{
- strlcat(buf, "=", sizeof buf);
- strlcat(buf, value, sizeof buf);
+ rb_strlcat(buf, "=", sizeof buf);
+ rb_strlcat(buf, value, sizeof buf);
}
nchars += l;
nparams++;
{
static char result[80];
- rb_snprintf(result, sizeof result, "%s%sbq,k,%slj,imnpst%scgzLP%s",
+ rb_snprintf(result, sizeof result, "%s%sbq,k,%slj,%s",
ConfigChannel.use_except ? "e" : "",
ConfigChannel.use_invex ? "I" : "",
ConfigChannel.use_forward ? "f" : "",
- rb_dlink_list_length(&service_list) ? "r" : "",
- ConfigChannel.use_forward ? "QF" : "");
+ cflagsbuf);
return result;
}
+static const char *
+isupport_chantypes(const void *ptr)
+{
+ return ConfigChannel.disable_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.disable_local_channels ? "#" : "&#", ConfigChannel.max_chans_per_user);
return result;
}
return result;
}
+static const char *
+isupport_nicklen(const void *ptr)
+{
+ static char result[200];
+
+ rb_snprintf(result, sizeof result, "%u", ConfigFileEntry.nicklen - 1);
+ return result;
+}
+
void
init_isupport(void)
{
static int maxmodes = MAXMODEPARAMS;
- static int nicklen = NICKLEN-1;
static int channellen = LOC_CHANNELLEN;
static int topiclen = TOPICLEN;
+ static int maxnicklen = NICKLEN - 1;
- 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("KNOCK", isupport_boolean, &ConfigChannel.use_knock);
add_isupport("STATUSMSG", isupport_string, "@+");
add_isupport("CALLERID", isupport_string, "g");
- add_isupport("SAFELIST", isupport_string, "");
- add_isupport("ELIST", isupport_string, "U");
add_isupport("CASEMAPPING", isupport_string, "rfc1459");
add_isupport("CHARSET", isupport_string, "ascii");
- add_isupport("NICKLEN", isupport_intptr, &nicklen);
+ add_isupport("NICKLEN", isupport_nicklen, NULL);
+ add_isupport("MAXNICKLEN", isupport_intptr, &maxnicklen);
add_isupport("CHANNELLEN", isupport_intptr, &channellen);
add_isupport("TOPICLEN", isupport_intptr, &topiclen);
add_isupport("ETRACE", isupport_string, "");
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");
}