diff options
author | dane dane@31f1291d-b8d6-0310-a050-a5561fc1590b <dane dane@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864> | 2005-03-29 03:18:40 +0000 |
---|---|---|
committer | dane dane@31f1291d-b8d6-0310-a050-a5561fc1590b <dane dane@31f1291d-b8d6-0310-a050-a5561fc1590b@5417fbe8-f217-4b02-8779-1006273d7864> | 2005-03-29 03:18:40 +0000 |
commit | e97d88fa34fa8e96b1d4468536bb8f6debd606b9 (patch) | |
tree | 3f46859ec8c96d8784bf67ec803760551ed6aceb /src | |
parent | 049a272fa4f45afa40075e33d82c5ba25fbef04b (diff) |
BUILD : 1.7.8 (651) BUGS : none NOTES : Applied shadowirc.c patch from nenolod.
git-svn-id: svn://svn.anope.org/anope/trunk@651 31f1291d-b8d6-0310-a050-a5561fc1590b
git-svn-id: http://anope.svn.sourceforge.net/svnroot/anope/trunk@499 5417fbe8-f217-4b02-8779-1006273d7864
Diffstat (limited to 'src')
-rw-r--r-- | src/shadowircd.c | 23 |
1 files changed, 15 insertions, 8 deletions
diff --git a/src/shadowircd.c b/src/shadowircd.c index e9a74b104..0f7924a3f 100644 --- a/src/shadowircd.c +++ b/src/shadowircd.c @@ -24,7 +24,8 @@ const char flood_mode_char_set[] = ""; /* mode char for FLOOD mode on set */ const char flood_mode_char_remove[] = ""; /* mode char for FLOOD mode on remove */ int UseTSMODE = 1; -int ts6nickcount = 0; +/* 6 slot array, 35 possible combinations per slot, exponential. */ +int ts6nickcount[6] = { 0, 0, 0, 0, 0, 0 }; IRCDVar ircd[] = { {"ShadowIRCd 4.0+", /* ircd name */ @@ -786,7 +787,7 @@ void moduleAddIRCDMsgs(void) m = createMessage("SERVER", anope_event_server); addCoreMessage(IRCD,m); m = createMessage("SQUIT", anope_event_squit); addCoreMessage(IRCD,m); m = createMessage("TOPIC", anope_event_topic); addCoreMessage(IRCD,m); - m = createMessage("TB", anope_event_tburst); addCoreMessage(IRCD,m); + m = createMessage("TBURST", anope_event_tburst); addCoreMessage(IRCD,m); m = createMessage("USER", anope_event_null); addCoreMessage(IRCD,m); m = createMessage("WALLOPS", anope_event_null); addCoreMessage(IRCD,m); m = createMessage("WHOIS", anope_event_whois); addCoreMessage(IRCD,m); @@ -858,7 +859,8 @@ void anope_cmd_topic(char *whosets, char *chan, char *whosetit, Uid *ud; ud = find_uid(whosets); - send_cmd((ud ? ud->uid : whosets), "TOPIC %s :%s", chan, topic); + send_cmd((ud ? ud->uid : whosets), "TOPIC %s %s %ld :%s", chan, + whosetit, when, topic); } void anope_cmd_vhost_off(User * u) @@ -995,12 +997,17 @@ void anope_cmd_bot_nick(char *nick, char *user, char *host, char *real, { char nicknumbuf[10]; EnforceQlinedNick(nick, NULL); - snprintf(nicknumbuf, 10, "%sAAAAA%c", Numeric, (ts6nickcount + 'A')); + snprintf(nicknumbuf, 10, "%sAAAA%c%c", Numeric, + (ts6nickcount[1] + 'A'), (ts6nickcount[0] + 'A')); send_cmd(TS6SID, "UID %s 1 %ld %s %s %s 0.0.0.0 %s %s :%s", nick, (long int) time(NULL), modes, user, host, nicknumbuf, host, real); new_uid(nick, nicknumbuf); - ts6nickcount++; + ts6nickcount[0]++; + if (ts6nickcount[0] > 35) { /* AAAAA9 */ + ts6nickcount[1]++; + ts6nickcount[0] = 0; /* AAAABA */ + } anope_cmd_sqline(nick, "Reserved for services"); } @@ -1464,12 +1471,12 @@ void anope_cmd_nick(char *nick, char *name, char *mode) { char nicknumbuf[10]; EnforceQlinedNick(nick, NULL); - snprintf(nicknumbuf, 10, "%sAAAAA%c", TS6SID, (ts6nickcount + 'A')); + snprintf(nicknumbuf, 10, "%sAAAAA%c", TS6SID, (ts6nickcount[0] + 'A')); send_cmd(TS6SID, "UID %s 1 %ld %s %s %s 0.0.0.0 %s %s :%s", nick, (long int) time(NULL), mode, ServiceUser, ServiceHost, nicknumbuf, ServiceHost, name); new_uid(nick, nicknumbuf); - ts6nickcount++; + ts6nickcount[0]++; anope_cmd_sqline(nick, "Reserved for services"); } @@ -1599,7 +1606,7 @@ int anope_event_mode(char *source, int ac, char **av) u = find_byuid(source); u2 = find_byuid(av[0]); av[0] = u2->nick; - do_umode(u->nick, ac, av); + do_umode((u ? u->nick : source), ac, av); } return MOD_CONT; } |