1 2000-04-28 Kevin L. Mitchell <klmitch@mit.edu>
3 * ircd/ircd_reply.c (send_reply): fix a slight bug...
5 * ircd/s_numeric.c (do_numeric): use new sendcmdto_* functions,
8 * ircd/parse.c (parse_server): argument wrangling to make
9 processing in do_numeric a little easier to deal with
11 * ircd/s_serv.c (server_estab): SERVER should come from
12 acptr->serv->up, not &me
14 * ircd/m_lusers.c: accidentally left out sptr for a %C
16 * ircd/send.c: hack to support doing wallchops...
18 * ircd/m_whowas.c: convert to new send functions
20 * ircd/m_whois.c: convert to new send functions
22 * ircd/m_who.c: convert to new send functions
24 * ircd/m_wallops.c: convert to new send functions
26 * ircd/m_wallchops.c: convert to new send functions
28 * ircd/m_version.c: convert to new send functions
30 * ircd/m_userip.c: convert to new send functions
32 * ircd/m_userhost.c: convert to new send functions
34 * ircd/m_uping.c: convert to new send functions
36 * ircd/m_trace.c: convert to new send functions
38 * ircd/m_topic.c: convert to new send functions
40 * ircd/m_time.c: convert to new send functions
42 * ircd/m_squit.c: convert to new send functions
44 * ircd/m_silence.c: convert to new send functions
46 * ircd/m_settime.c: convert to new send functions
48 * ircd/m_restart.c: convert to new send functions
50 * ircd/m_rehash.c: convert to new send functions
52 * ircd/m_privmsg.c: convert to new send functions
54 * ircd/m_pong.c: convert to new send functions
56 * ircd/m_ping.c: convert to new send functions
58 * ircd/m_pass.c: convert to new send functions
60 * ircd/m_opmode.c: convert to new send functions
62 * ircd/m_oper.c: convert to new send functions
64 * ircd/m_notice.c: convert to new send functions
66 * ircd/m_nick.c: convert to new send functions
68 * ircd/m_names.c: convert to new send functions
70 * ircd/m_motd.c: convert to new send functions
72 * ircd/m_mode.c: convert to new send functions
74 * ircd/m_map.c: convert to new send functions
76 * ircd/m_lusers.c: convert to new send functions
78 * ircd/m_list.c: convert to new send functions
80 * ircd/m_links.c: convert to new send functions
82 * ircd/m_kill.c: convert to new send functions
84 * ircd/m_jupe.c: convert to new send functions
86 * ircd/m_invite.c: convert to new send functions
88 * ircd/m_info.c: convert to new send functions
90 * ircd/m_help.c: convert to new send functions
92 * ircd/m_gline.c: convert to new send functions
94 * ircd/m_error.c: convert to new send functions
96 * ircd/m_endburst.c: convert to new send functions
98 * ircd/m_die.c: convert to new send functions
100 * ircd/m_destruct.c: convert to new send functions
102 * ircd/m_defaults.c: convert to new send functions
104 * ircd/m_connect.c: convert to new send functions
106 2000-04-28 Perry Lorier <isomer@coders.net>
107 * RELEASE.NOTES: Describe a few more undocumented features.
108 * config/config-sh.in: change the default paths for logging
109 and the recommended number of channels.
110 * include/supported.h: Rearrange slightly, added CHANTYPE's
112 2000-04-27 Kevin L. Mitchell <klmitch@mit.edu>
114 * ircd/m_close.c: convert to send_reply
116 * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
118 * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
120 * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
122 * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
123 that takes cmd and tok arguments, etc. NOTE: THIS IMPLEMENTATION
124 HAS A MAJOR HACK!!! The whole hunt_server architecture should be
125 carefully rethought...
127 * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
129 * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
131 * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
132 numeric nick; therefore, we have to use the server name
134 * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
136 * ircd/send.c: fix minor bugs
138 * ircd/s_user.c (check_target_limit): mark dead code so I filter
141 * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
144 * ircd/parse.c: mark dead code so I filter it when I grep
146 * ircd/map.c: mark dead code so I filter it when I grep
148 * ircd/ircd.c: mark dead code so I filter it when I grep
150 * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
153 * ircd/channel.c: mark dead code so I filter it when I grep
155 * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
156 hope I'm not stepping on toes...
158 * ircd/s_conf.c: more sendto_opmask_butone / send_reply
159 conversions; use ircd_snprintf in a couple of cases to negate the
160 possibility of buffer overflow
162 2000-04-26 Kevin L. Mitchell <klmitch@mit.edu>
164 * ircd/channel.c: convert as much as possible to new send
167 * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
168 test member->user->from->fd, not from->fd
170 * ircd/gline.c (gline_add): go ahead and add badchans; we just
171 won't look for them in m_gline; this way, they always work...
173 * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
175 * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
176 ircd_vsnprintf conversion specifiers
178 * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
179 I have my conversion specifiers
181 * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
183 * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
186 * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
187 little less brain-dead
189 * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
191 * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
194 * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
197 * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
200 * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
202 * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
204 * ircd/s_user.c (register_user): use RPL_EXPLICIT for
207 * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
209 * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
210 a numeric as needing to use an explicit pattern, which will be the
211 first argument in the variable argument list
213 * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
214 non-prefixed nospoof PING
216 * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
217 non-prefixed SERVER login
219 * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
220 a numeric usage further up)
222 * include/send.h: declare sendrawto_one
224 * ircd/send.c (sendrawto_one): new function to use ONLY for
225 non-prefixed commands, like PING to client, or PASS/SERVER on
228 2000-04-25 Kevin L. Mitchell <klmitch@mit.edu>
230 * ircd/ircd_snprintf.c (doprintf): implement %H for possible
231 future expansion (channel numerics?)
233 * include/ircd_snprintf.h: added documentation to # to explain use
234 with %C; added documentation for : to explain use with %C; added
235 documentation for %H for channels
237 * ircd/whocmds.c: use send_reply
239 * ircd/userload.c: use sendcmdto_one
241 * ircd/uping.c: use sendcmdto_one
243 * ircd/send.c: use new flags to %C format string; ':' prefixes
244 client name with a colon for local connects, '#' uses
245 nick!user@host form for local connects
247 * ircd/s_user.c: use send_reply, sendto_opmask_butone,
248 sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
250 * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
252 * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
255 * ircd/s_auth.c: use sendto_opmask_butone
257 * ircd/res.c: use sendcmdto_one
259 * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
262 2000-04-24 Kevin L. Mitchell <klmitch@mit.edu>
264 * ircd/support.c: dumpcore is no longer used, so get rid of it
266 * ircd/parse.c: use send_reply, sendcmdto_one
268 * ircd/map.c: use send_reply
270 * ircd/listener.c: use send_reply
272 * ircd/jupe.c: use sendto_opmask_butone, send_reply
274 * ircd/ircd_reply.c: use send_reply
276 * ircd/ircd.c: use sendto_opmask_butone
278 * ircd/gline.c: use sendto_opmask_butone, send_reply
280 * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
281 registered clients; make FLAG_ALT print nick!user@host; make
282 FLAG_COLON print :blah
284 * ircd/class.c (report_classes): use send_reply instead of
287 * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
289 * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
290 sendto_one with sendcmdto_one
292 2000-04-21 Kevin L. Mitchell <klmitch@mit.edu>
294 * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
295 MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
296 sendcmdto_match_butone
298 * include/send.h: declare sendcmdto_match_butone
300 2000-04-20 Kevin L. Mitchell <klmitch@mit.edu>
302 * ircd/jupe.c: update to use send_reply()
304 * ircd/gline.c: update to use send_reply()
306 * include/ircd_reply.h: declare send_reply
308 * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
309 replies; uses ircd_snprintf
311 * ircd/send.c: added comments to redirect searchers to appropriate
312 sendcmdto_* function; moved new functions to end of file; added
313 explanatory comments; reordered arguments; defined new functions
316 * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
318 * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
320 * ircd/jupe.c: reorder arguments to sendcmdto_* functions
322 * ircd/gline.c: reorder arguments to sendcmdto_* functions
324 * include/send.h: reorder arguments, add explanatory comments,
325 declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
326 and vsendto_opmask_butone
328 2000-04-19 Kevin L. Mitchell <klmitch@mit.edu>
330 * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
331 vsendto_op_mask that uses '*' instead of the receiving client
334 * include/send.h: declare sendcmdto_channel_butone; takes a skip
335 argument that allows you to skip (or not to skip) deaf users,
336 users behind bursting servers, and non channel operators
338 2000-04-17 Kevin L. Mitchell <klmitch@mit.edu>
340 * ircd/send.c: new sendcmdto_channel_butserv -- note that old
341 sendto_channel_butserv has a subtle bug; also wrote
342 sendcmdto_common_channels.
344 * include/send.h: declare new sendcmdto_* functions
346 * ircd/jupe.c: support local deactivations of jupes
348 * ircd/gline.c: support local deactivations of glines
350 * include/jupe.h: JUPE_LDEACT allows jupes to be locally
351 deactivated; if they aren't locally deactivated, then it slaves to
352 the net-wide activation status; JupeIsRemActive() tests only
353 whether the jupe is active everywhere else
355 * include/gline.h: GLINE_LDEACT allows glines to be locally
356 deactivated; if they aren't locally deactivated, then it slaves to
357 the net-wide activation status; GlineIsRemActive() tests only
358 whether the gline is active everywhere else
360 * ircd/gline.c: detect overlapping G-lines; if an existing, wider
361 gline expires after the new one will, we drop the new one,
362 otherwise we add the G-line after that one (so the wide one will
363 apply first); if the new one contains an existing G-line and if it
364 will expire after the existing one, we drop the existing one to
367 * ircd/m_gline.c (mo_gline): opers could issue remote local
368 glines when CONFIG_OPERCMDS was off; fixed
370 2000-04-16 Kevin L. Mitchell <klmitch@mit.edu>
372 * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
375 * ircd/gline.c: add flags argument to gline_activate and
376 gline_deactivate for future expansion
378 * ircd/m_gline.c: pass flags to gline_activate and
381 * include/gline.h: add flags argument to gline_activate and
384 * ircd/jupe.c: add flags argument to jupe_activate and
385 jupe_deactivate for future expansion
387 * include/jupe.h: add flags argument to jupe_activate and
390 * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
391 local, active; pass flags to jupe_activate and jupe_deactivate
393 * include/gline.h: remove dead code
395 * ircd/gline.c: make gline expire times relative to CurrentTime,
396 since that should be monotonically increasing, instead of
397 TStime(), which can be set backwards, and which can therefore
398 cause an expire time to increase; make local glines be removed
399 instead of just deactivated; don't let gline_find() look for
400 user@host glines if the mask being looked up is a channel mask
402 * ircd/send.c (vsendcmdto_one): forgot to account for the case
403 where origin is a server and destination is a user
405 * ircd/jupe.c: make jupe expire times relative to CurrentTime,
406 since that should be monotonically increasing, instead of
407 TStime(), which can be set backwards, and which can therefore
408 cause an expire time to increase; make local jupes be removed
409 instead of just deactivated
411 * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
412 limit is fine. any other warnings I should know about?
414 2000-04-15 Thomas Helvey <tomh@inxpress.net>
416 * ircd/*.c: const correctness and type safety cleanups to
417 get code to compile with C++ compiler. Still has
418 signed/unsigned comparison warnings.
420 2000-04-15 Greg Sikorski <gte@atomicrevs.demon.co.uk>
422 * ircd/userload.c: change <sys/time.h> include to <time.h> for
425 2000-04-14 Kevin L. Mitchell <klmitch@mit.edu>
427 * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
430 * ircd/s_user.c: move gline_lookup function call into
431 register_user, where it'll have a username to lookup!
433 * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
434 functions; also stuff send_error_to_client into return clauses
436 * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
437 functions; also use send_error_to_client where that makes sense
439 * ircd/jupe.c: modify to utilize new sendcmdto_* series of
440 functions; also use send_error_to_client where that makes sense
442 * ircd/gline.c: modify to utilize new sendcmdto_* series of
443 functions; also fix gline_lookup() to deal properly with remote
444 clients--boy, do struct Client and struct User need to be cleaned
447 * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
450 * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
451 sendcmdto_serv_butone(), all utilizing the %v conversion of
454 * include/send.h: define IRC_BUFSIZE, max size of a message;
455 declare sendcmdto_one(), vsendcmdto_one(), and
456 sendcmdto_serv_butone()
458 * include/msg.h: define all the CMD_* constants needed to utilize
459 the new sendcmdto_* series of functions
461 * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
463 * ircd/gline.c: remove old, dead code.
465 * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
466 unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
467 (don't advertise proxies); remove dead code
469 * ircd/parse.c: oper handler for JUPE only lists jupes unless
470 CONFIG_OPERCMDS is enabled
472 * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
473 CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
475 * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
476 always return ERR_DISABLED
478 * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
479 enabled, always return ERR_DISABLED
481 * ircd/s_err.c: add error message to indicate disabled commands
483 * include/numeric.h (ERR_DISABLED): to indicate disabled commands
485 * doc/Configure.help: add documentation for CONFIG_OPERCMDS
487 * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
488 CONFIG_NEW_MODE to 'y' for now
490 * ircd/gline.c (gline_list): fix a minor formatting bogon
492 * BUGS: since I fixed that bug, might as well mark it fixed.
494 * ircd/m_join.c: look up badchans with GLINE_EXACT
496 * ircd/m_gline.c: fix parc count problems; look up existing
497 G-lines with GLINE_EXACT; only set new lastmod when
498 activating/deactivating existing glines if old lastmod was not 0
500 * ircd/gline.c: forgot to copy the gline reason over; don't
501 propagate a gline with 0 lastmod if origin is user; add
502 GLINE_EXACT to force exact matching of gline mask
504 * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
507 * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
508 but gline_lookup() actually takes a client--d'oh.
510 2000-04-13 Thomas Helvey <tomh@inxpress.net>
511 * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
513 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
515 * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
517 "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
520 * ircd/whocmds.c: Change idle time calc from socket idle to user
523 2000-04-13 Kevin L. Mitchell <klmitch@mit.edu>
525 * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
526 too, for ircd_snprintf.c
528 * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
529 comments; mostly descended from the Linux manpage for printf, but
530 also documenting the extensions.
532 * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
533 client; make 'q' be the same as 'L'; remove __inline__; only
534 define EXTENSION if HAVE_LONG_LONG is defined
536 * include/handlers.h: declare m_gline()
538 * ircd/parse.c: gline can be called by users, but it only lists
541 * ircd/s_user.c (set_nick_name): resend gline if a remote server
542 introduces a glined client
544 * ircd/s_serv.c (server_estab): burst glines, too
546 * ircd/gline.c: fix up all the expire times to be offsets;
547 simplify gline_resend()
549 * ircd/m_gline.c: begin coding replacements for ms_gline(),
550 mo_gline(), and m_gline()
552 * ircd/gline.c (gline_add): allow *@#channel to work correctly;
553 also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
555 2000-04-13 Greg Sikorski <gte@atomicrevs.demon.co.uk>
557 * tools/Bouncer/*: Add comments/documentation/tags.
558 * tools/Bouncer/*: Add debug defines, make task fork().
560 2000-04-12 Thomas Helvey <tomh@inxpress.net>
561 * ircd/s_err.c: Cleanup s_err.c make one table so we
562 don't have to do anything tricky to get an error string.
564 2000-04-12 Greg Sikorski <gte@atomicrevs.demon.co.uk>
565 * Add port bouncer for http (x/w)
567 2000-04-12 Kevin L. Mitchell <klmitch@mit.edu>
569 * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
570 call to gline_find(); also used GlineReason() instead of direct
571 reference to structure member
573 * ircd/m_join.c (m_join): replace bad_channel() calls with calls
574 to gline_find(name, GLINE_BADCHAN), and also check to see if gline
577 * ircd/channel.c: nothing seems to be called anywhere...
579 * ircd/s_err.c: update a couple of replies to dovetail with new
582 * ircd/gline.c: begin complete re-implementation of gline.c along
583 the lines of the final design of jupe.c
585 * include/gline.h: begin complete re-implementation of gline.c
586 along the lines of the final design of jupe.c
588 * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
591 * ircd/ircd_snprintf.c: my new snprintf()-like functions
593 * include/ircd_snprintf.h: my new snprintf()-like functions
595 2000-04-11 Thomas Helvey <tomh@inxpress.net>
596 * ircd/IPcheck.c: removed old dead code
597 * ircd/s_user.c (send_user_info): removed non-standard
598 user not found message for userhost/userip
600 2000-04-11 Greg Sikorski <gte@atomicrevs.demon.co.uk>
602 * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
603 * doc/p10.html: Work on chapter 4.
605 2000-04-10 Kevin L. Mitchell <klmitch@mit.edu>
607 * ircd/channel.c (mode_parse_client): fix coredump on /mode
608 #foobar +o nosuchnick
610 2000-04-10 Perry Lorier <Isomer@coders.net>
613 2000-04-09 Thomas Helvey <tomh@inxpress.net>
614 * include/IPcheck.h: fix prototype
615 * ircd/s_user.c: fix usage of IPcheck_remote_connect
616 * ircd/IPcheck.c: removed unused args
618 2000-04-09 Thomas Helvey <tomh@inxpress.net>
619 * include/IPcheck.h: add proto for IPcheck_expire
621 * ircd/IPcheck.c: Rewrote
623 * ircd/ircd.c: Add IPcheck_expire to main message loop
625 * ircd/s_user.c: Redo target hashing, refactor target code
627 * include/numeric.h: Cleaned up numerics, added which ones are
628 in use by other networks and what they are in use for.
630 * ircd/channel.c: cleaned can_join(), allow anyone through anything
631 if /invited, simplified the function. Opers overusing OPEROVERRIDE
632 will get a message explaining to them not to cheat.
634 * ircd/m_join.c: cleaned up the various join functions, should be
635 a lot more efficient. Still needs work. Now assumes that s<->s
636 won't send it a JOIN 0. Service coders - note this and tread with
639 * ircd/m_stats.c: added Gte-'s stats doc patch.
641 * ircd/m_version.c: /version now returns the 005 numeric as well.
642 as requested by Liandrin.
645 2000-04-07 Kevin L. Mitchell <klmitch@mit.edu>
647 * ircd/m_clearmode.c: add include for support.h for write_log()
649 * configure: move ircd/crypt/* to tools/*
651 2000-04-06 Thomas Helvey <tomh@inxpress.net>
652 * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
653 set client host to server alias if connection from localhost
655 2000-04-06 Perry Lorier <isomer@coders.net>
656 * ircd/ircd.c: Fix core during pinging (oops)
658 2000-04-06 Perry Lorier <isomer@coders.net>
659 * ircd/send.c: fixed wrong ident being sent to channels bug.
660 * include/numerics.h: Updated some of the numerics from other
661 networks. Flagged some as 'unused' by undernet.
663 2000-03-30 Perry Lorier <isomer@coders.net>
664 * ircd/ircd.c: Lets see if this helps the ping problem at all.
665 * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
666 time for local clients. (as requested), extended who now returns all
667 the flags (@+!) so you can tell the complete state of a client.
669 2000-03-30 Thomas Helvey <tomh@inxpress.net>
670 * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
672 2000-03-30 Perry Lorier <isomer@coders.net>
673 * ircd/parse.c: oops, missed opers.
675 2000-03-30 Perry Lorier <isomer@coders.net>
676 * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
677 for so long. Remember: m_ping MUST be in the parse array. :)
679 2000-03-30 Perry Lorier <isomer@coders.net>
680 * ircd/ircd.c: test in check_pings was wrong. I move that we
681 disallow cvs commit after 10pm localtime....
683 2000-03-30 Perry Lorier <isomer@coders.net>
684 * ircd/m_pong.c: Fix it for servers too.
686 2000-03-30 Perry Lorier <isomer@coders.net>
687 * ircd/m_pong.c: Fix ping timeout bugs
689 2000-03-30 Perry Lorier <isomer@coders.net>
690 * ircd/channel.c: Bans had CurrentTime in their when field instead
693 2000-03-31 Thomas Helvey <tomh@ixpress.net>
694 * ircd/numnicks.c (SetXYYCapacity): fix for extended
697 2000-03-30 Perry Lorier <isomer@coders.net>
698 * ircd/m_nick.c: send kills both ways so when we add nick change
699 on collision we don't desync the network.
701 * ircd/map.c: Fixup the map a bit more.
703 2000-03-31 Kevin L. Mitchell <klmitch@mit.edu>
705 * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
707 * ircd/m_opmode.c: Log the mode changes to OPATH
709 * ircd/channel.c (modebuf_flush_int): Log the mode changes to
712 * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
715 * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
717 * config/config-sh.in: added OPATH for opmode log file
719 * ircd/m_clearmode.c (do_clearmode): updated uses of
720 modebuf_mode_string() for the new usage
722 * ircd/channel.c: added flag MODE_FREE and an int argument to
723 modebuf_mode_string() to indicate that the string must be free'd;
724 updated calls to modebuf_mode_string() for the new usage; called
725 collapse(pretty_mask()) on the ban string and use allocated memory
726 for it; added ban list length accounting; fixed a number of small
727 bugs in ban processing
729 * include/channel.h: added flag MODE_FREE and an int argument to
730 modebuf_mode_string() to indicate that the string must be free'd
732 * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
733 keys and limits that are set
735 2000-03-30 Perry Lorier <isomer@coders.net>
736 * ircd/ircd.c: rewrote check_pings() for maintainability
737 and speed. Also changed quit msg's so they don't have
738 redundant nick[host] info in them.
740 * ircd/send.c: Changed write errors to report what error
741 occured (if possible).
743 * ircd/gline.c: added gline comment to the quit.
745 * ircd/m_server.c: Added suggestions to server quits mentioning
746 what went wrong so the admin can fix it earlier instead of asking
749 * ircd/map.c: Changed m_map() to hide numerics, show a * beside
750 servers that aren't fully burst yet. And show '(--s)' for servers
753 * doc/example.conf: Fixed wrapped U:
755 2000-03-30 Kevin L. Mitchell <klmitch@mit.edu>
757 * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
758 mode_parse() (version selectable at compile time)
760 * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
762 * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
764 * config/config-sh.in: add new config option to enable new m_mode
767 * doc/Configure.help: add documentation for new config option
770 * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
771 MODE -v : Not enough parameters
773 * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
774 +k and +l even if they weren't set...
776 * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
778 * ircd/channel.c: make mode_process_clients() clear the DEOPPED
779 flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
780 for; test the 0-th member, not the i-th member, of the client
783 * ircd/m_clearmode.c (do_clearmode): use the new
784 mode_invite_clear() function
786 * ircd/channel.c: cleared up all the compile-time warnings and
789 * include/channel.h: added declarations for mode_ban_invalidate()
790 and mode_invite_clear()
792 * ircd/channel.c: finished mode_parse(), then broke it up into a
793 dozen or so helper functions to make the code easier to read
795 2000-03-29 Thomas Helvey <tomh@inxpress.net>
796 * ircd/ircd.c: refactor server initialization a bit, use
797 getopt for parsing command line, refactor init_sys, main,
800 * ircd/s_bsd.c: add functions for initialization to clean
801 up logic a bit and remove duplicated code.
803 * include/ircd.h: add struct for server process related
806 2000-03-29 Kevin L. Mitchell <klmitch@mit.edu>
808 * ircd/channel.c: initial definition of mode_parse(); flags to
809 prevent doing the same thing multiple times; helper method
810 send_notoper() to send a "Not oper"/"Not on channel" notice
812 * include/channel.h: declare mode_parse() and helper flags
814 * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
815 sending to match the current action of set_mode() closely enough
816 that hopefully there won't be major conflicts
818 * ircd/channel.c (modebuf_flush_int): consolidated the mode string
819 building logic, reversed the order of the arguments to mode
820 commands to have '-' preceed '+'
822 2000-03-29 Thomas Helvey <tomh@inxpress.net>
823 * ircd/s_bsd.c (add_connection): don't disable socket options
824 let OS tune itself and allow important performance tweaks to
827 2000-03-28 Kevin L. Mitchell <klmitch@mit.edu>
829 * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
830 confused by set_mode, which is doing some really weird logic;
831 guess what I'm going to rewrite next? ;)
833 2000-03-28 Kevin L. Mitchell <klmitch@emc.com>
835 * include/channel.h: added MODE_SAVE for the bounds checking stuff
838 * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
839 make it do bounds checking on the buffer; all modes are sent only
840 if the all parameter is 1; modebuf_flush is the exported wrapper
842 * include/channel.h: add BOUNCE, renumber flags to get a little
845 * ircd/channel.c (modebuf_flush): don't overload HACK2, add
846 BOUNCE; send DESYNCH message
848 2000-03-27 Kevin L. Mitchell <klmitch@emc.com>
850 * ircd/m_clearmode.c (do_clearmode): only mark the modes the
851 channel actually has in effect for deletion
853 * ircd/channel.c: added explanatory comments to all added
854 functions; made flushing take place at the correct place even if
855 the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
856 to bash some stupid bugs; made modebuf_flush() return if ModeBuf
857 is empty, fixed the apparent source, removed some bogus string
858 termination code, properly terminate the mode strings, add support
859 for HACK2 and HACK3, made limit strings not be sent if the limit
860 is being removed, changed where '+' and '-' come from in sent
861 strings, added support for DEOP flag, set up bouncing code for
864 * ircd/Makefile.in: ran make depend
866 * include/channel.h: added new defines for future functionality,
867 made modebuf_flush() return int so I can use tail recursion
869 * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
870 to make it all compile
872 * ircd/m_opmode.c: add msg.h to includes...
874 * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
876 * ircd/channel.c (modebuf_flush): realized I forgot to
877 nul-terminate addbuf/rembuf properly...
879 * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
881 * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
882 sendto_serv_butone--blah^2
884 * ircd/send.c (sendto_serv_butone): stupid comments confused me
886 * ircd/channel.c (modebuf_flush): if there are no mode changes to
887 propagate, we're done...
889 * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
890 not sendto_all_butone
892 * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
894 * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
896 * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
899 * ircd/parse.c: added messages for opmode and clearmode
901 * include/handlers.h: added declarations for mo_opmode(),
902 ms_opmode(), mo_clearmode(), and ms_clearmode()
904 * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
907 * include/channel.h (MODEBUF_DEST_OPMODE): Define the
908 MODEBUF_DEST_OPMODE flag
910 * ircd/channel.c (modebuf_flush): added new flag,
911 MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
912 to originate from source's server (or source itself, if
913 IsServer(source)); also causes a server-level MODE to be sent as
916 * include/channel.h: defined MODEBUF_DEST_SERVER,
919 * ircd/channel.c: Add another argument to build_string() to handle
920 numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
921 servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
924 2000-03-27 Perry Lorier <isomer@coders.net>
926 * ircd/s_bsd.c: fixed missing 'u' typo.
928 2000-03-26 Kevin L. Mitchell <klmitch@emc.com>
930 * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
931 _mode_string(), _mode_client(), _flush(); also implemented a
932 simple build_string()
934 * include/channel.h: added definition of ModeBuf, modebuf_*
935 manipulation functions, and a couple of helper macros
937 2000-03-24 Thomas Helvey <tomh@inxpress.net>
938 * numicks.c: convert extended numerics to use original mask version
941 2000-03-23 Thomas Helvey <tomh@inxpress.net>
942 * Merge in changes from production
943 2000-03-22 Thomas Helvey <tomh@inxpress.net>
944 * numicks.c: Tweak to numnick generator to reduce possibility of duplicates.
945 * rfc1459.unet: Add Maniac's documentation for /names 0
946 * Fix misc. jupe bugs that somehow made it into the tree
947 * Escape /names 0 to mean /names --Maniac
948 * Don't core when server asks for info --Maniac
949 * Add Kev's jupe patch --Bleep
950 * Add Maniacs squit patch --Bleep
951 * Merge in u2_10_10_beta07 changes --Bleep
952 * Merge in u2_10_10_beta06 changes --Bleep
953 * Start ircu2.10.11 development, beta branch u2_10_10 --Bleep
954 #-----------------------------------------------------------------------------
956 # ChangeLog for ircu2.10.11
958 # $Id: ChangeLog,v 1.111 2000-04-28 16:16:06 kev Exp $
960 # Insert new changes at beginning of the change list.