Author: Greg Sikorski <gte@atomicrevs.demon.co.uk>
[ircu2.10.12-pk.git] / ChangeLog
1 2000-06-09  Greg Sikorski <gte@atomicrevs.demon.co.uk>
2
3         * ircd/m_names.c: Clean up compiler warnings.
4
5 2000-06-09  Kevin L. Mitchell  <klmitch@mit.edu>
6
7         * ircd/channel.c (mode_parse_client): don't send warning if
8         there's not enough arguments for a +/-o/v; means the habit of
9         doing "/mode #channel +oooooo bob" doesn't result in a bunch of
10         error messages
11
12 2000-06-04  Greg Sikorski <gte@atomicrevs.demon.co.uk>
13
14         * ircd/m_names.c: Re-factor code to remove unneccessary
15         GlobalChannelList iteration every time someone joins a channel.
16
17 2000-06-02  Kevin L. Mitchell  <klmitch@mit.edu>
18
19         * ircd/s_user.c: add struct Gline * argument to register_user;
20         look up global glines and repropagate them if necessary; send
21         acknowledgement of gline to remote servers when registering users
22
23         * ircd/s_serv.c (server_estab): don't send acknowledgement of
24         local glines to remote servers; do send gline acknowledgement of
25         bursted users
26
27         * ircd/m_user.c (m_user): pass new struct Gline * argument to
28         register_user
29
30         * ircd/m_pong.c: pass new struct Gline * argument to register_user
31
32         * ircd/m_nick.c (ms_nick): document protocol change
33
34         * ircd/gline.c: support GLINE_LASTMOD
35
36         * include/s_user.h: add struct Gline * argument to register_user
37
38         * include/gline.h: add GLINE_LASTMOD to look up non-zero lastmods
39
40         * ircd/s_conf.c (find_kill): add unsigned int argument to
41         gline_lookup()
42
43         * ircd/gline.c: add GLINE_GLOBAL to lookup or find only global
44         glines; add unsigned int argument to gline_lookup()
45
46         * include/gline.h: add GLINE_GLOBAL flag; add unsigned int
47         argument to gline_lookup()
48
49         * ircd/m_server.c: Resend jupe only when there is no %<lastmod>
50         parameter, or when it falls out of bounds: see comments prior to
51         call to jupe_resend(); call server_estab with struct Jupe
52         parameter, so that we place the appropriate %<lastmod> in the
53         appropriate place.
54
55         * ircd/s_serv.c (server_estab): send %<lastmod> for introduced
56         server, as well as for servers when we're sending the BURST
57
58         * include/s_serv.h: add a struct Jupe * to the arguments for
59         server_estab() so that we can send the appropriate lastmod
60         parameter
61
62         * ircd/m_gline.c (ms_gline): actually, this should be the
63         slightest bit more efficient...
64
65         * ircd/m_jupe.c (ms_jupe): actually, this should be the slightest
66         bit more efficient...
67
68         * ircd/m_gline.c (ms_gline): inhibit GLINE processing resends
69         during netburst
70
71         * ircd/m_jupe.c (ms_jupe): inhibit JUPE processing resends during
72         netburst
73
74         * ircd/channel.c (joinbuf_join): really remove user from local
75         channels
76
77 2000-05-29  Perry Lorier       <Isomer@coders.net>
78         * ircd/m_names.c: Removed redundant space. 
79         * ircd/s_bsd.c: Fixed incorrect syntax on ERROR line.
80
81 2000-05-18  Kevin L. Mitchell  <klmitch@mit.edu>
82
83         * ircd/m_burst.c (ms_burst): er...that should have been a ",", not
84         a " "
85
86 2000-05-04  Kevin L. Mitchell  <klmitch@mit.edu>
87
88         * ircd/channel.c: replace bogus assertions with returns, which is
89         logically correct; only wipe out limit/key if they were originally
90         set in the first place; remove user from channel when doing a
91         PARTALL; only send MODE +o for user CREATEing channel if user is
92         not MyUser--CREATE will only be used if the channel did not
93         originally exist, therefore we can assume no one local is on the
94         channel anyway, and we don't exactly need for the user to see an
95         explicit +o for themselves
96
97         * doc/readme.gline: describe the syntax of the GLINE command
98
99         * doc/readme.jupe: update to reflect a couple of changes to JUPE
100
101         * ircd/gline.c: don't propagate local changes
102
103         * ircd/jupe.c: don't propagate local changes
104
105         * ircd/m_gline.c (mo_gline): force local flag when deactivating
106         glines with 0 lastmod
107
108         * ircd/gline.c (gline_deactivate): G-lines with zero lastmod time
109         are now removed instead of being deactivated
110
111         * ircd/m_gline.c (ms_gline): make G-lines of the form "GLINE *
112         -<mask>" be accepted
113
114         * ircd/channel.c (send_channel_modes): deal with one of the last
115         vestiges of sendbuf
116
117         * ircd/m_burst.c (ms_burst): debugged ban processing; removed
118         debugging hooks
119
120         * ircd/channel.c (modebuf_extract): remove debugging
121         sendto_opmask_butone calls
122
123 2000-05-03  Kevin L. Mitchell  <klmitch@mit.edu>
124
125         * ircd/channel.c: support a couple of new flags to support using
126         mode_parse; fix some bugs with 0 struct ModeBuf *; implementation
127         of modebuf_extract to extract added flags for use by ms_burst
128
129         * include/channel.h: a couple of new flags to support using
130         mode_parse inside ms_burst
131
132         * ircd/m_burst.c (ms_burst): brand new implementation of BURST
133
134         * ircd/m_endburst.c: add loop to processing of end_of_burst to
135         free empty channels after the BURST is over.
136
137         * ircd/m_server.c: convert to use new send.c functions--I wanted
138         to rewrite it from scratch, but the logic's pretty complex; I may
139         still rewrite it, though...
140
141 2000-05-02  Thomas Helvey <tomh@inxpress.net>
142
143         * ircd/ircd.c: fix broken header include ordering
144
145 2000-05-02  Thomas Helvey <tomh@inxpress.net>
146         
147         * ircd/IPcheck.c: cleanups for ZenShadow's cleanups
148         review emailed privately
149
150         * include/IPcheck.h: removed unneeded include
151
152 2000-05-02  Kevin L. Mitchell  <klmitch@mit.edu>
153
154         * ircd/s_user.c (hunt_server): throw in a comment so I know what
155         the sendto_one is for
156
157         * include/querycmds.h (Count_unknownbecomesclient): convert to
158         sendto_opmask_butone
159
160         * ircd/send.c: start removing dead code
161
162         * include/send.h: start removing dead code
163
164         * ircd/m_rping.c: convert to sendcmdto_one / send_reply /
165         hunt_server_cmd
166
167         * ircd/m_rpong.c: convert to sendcmdto_one / send_reply
168
169 2000-05-01  Kevin L. Mitchell  <klmitch@mit.edu>
170
171         * ircd/m_stats.c: convert to sendcmdto_one / send_reply
172
173         * ircd/m_kick.c: Completely reimplement m_kick
174
175         * ircd/channel.c: send_user_joins removed; it was dead code,
176         anyway...
177
178 2000-05-01  Perry Lorier <isomer@coders.net>
179         * ircd/m_invite.c: Fix for the rest of m_invite.c, and again.
180         * ircd/channels.c: My fix for the part problem.  Untested, probably
181                 won't work.  Can't be much worse than the current problem.
182                 it'll either work or core, take your pick.
183
184
185 2000-04-30  Perry Lorier <isomer@coders.net>
186         * config/config-sh.in: Fix for CONNEXIT
187         * ircd/s_{user,misc}.c: Fix for CONNEXIT
188         * ircd/m_invite.c: Fix for incorrectly numnickified invite.
189                         (Kev: Want to come talk to me about this?)
190
191 2000-04-30  Steven M. Doyle <steven@doyle.net>
192         * ircd/ircd.c
193           - general cleanups and readability enhancements
194           - rewrite of setuid/chroot code.
195           - server will no longer run as root
196           - -DPROFIL compile option removed
197           - Fixed IPcheck API calls
198  
199         * config/config-sh.in
200           - Fixed up chroot compile options
201           - Added options for debug and profile compiles
202  
203         * config/gen.ircd.Makefile
204           - Support for new debug/profile options
205  
206         * ircd/Makefile.in
207           - Support for new debug/profile options
208  
209         * ircd/ircd_signal.c
210           - Removed -DPROFIL
211
212         * include/IPcheck.h
213           - Removed old API prototypes, added new ones
214         
215         * ircd/IPcheck.c
216           - Readability cleanups (well, I -think-...)
217           - Changed IPRegistryEntry.last_connect to a time_t.  The previously
218             used unsigned short was probably causing interesting things after
219             a client had been connected longer than about 65,535 seconds...
220           - Removed old API functions.
221
222         * ircd/whocmds.c
223           - Removed IPcheck.h include
224         
225         * Additionally modified IPcheck API calls in:
226           - ircd/m_nick.c
227           - ircd/m_auth.c
228           - ircd/s_bsd.c
229           - ircd/s_conf.c
230           - ircd/s_misc.c
231           - ircd/s_serv.c
232           - ircd/s_user.c
233         
234         
235 2000-04-30  Perry Lorier <isomer@coders.net>
236         * ircd/s_bsd.c: Sigh. :)
237         * ircd/m_mode.c: fix for modeless channels by poptix.
238
239 2000-04-29  Kevin L. Mitchell  <klmitch@mit.edu>
240
241         * ircd/m_join.c: reimplement JOIN in terms of struct JoinBuf
242
243         * ircd/channel.c (clean_channelname): make clean_channelname also
244         truncate long channel names
245
246 2000-04-28  Kevin L. Mitchell  <klmitch@mit.edu>
247
248         * ircd/m_create.c: reimplement CREATE in terms of struct JoinBuf
249
250         * ircd/channel.c: implemented joinbuf_init, joinbuf_join,
251         joinbuf_flush
252
253         * include/channel.h: definitions and declarations for the struct
254         JoinBuf abstraction
255
256 2000-04-29  Perry Lorier <isomer@coders.net>
257         * ircd/s_bsd.c: Ok, so I thought I compiled and tested this...
258
259 2000-04-29  Perry Lorier <isomer@coders.net>
260         * ircd/s_bsd.c: Add debugging code to IPcheck
261
262 2000-04-28  Kevin L. Mitchell  <klmitch@mit.edu>
263
264         * include/ircd_reply.h (SND_EXPLICIT): use instead of RPL_EXPLICIT
265
266         * ircd/ircd_reply.c (send_reply): use SND_EXPLICIT instead of
267         RPL_EXPLICIT
268
269         * ircd/m_userhost.c (m_userhost): add a dead code comment
270
271         * ircd/m_desynch.c: forgot one...
272
273         * ircd/m_rehash.c (mo_rehash): er, duplicates :)
274
275         * ircd/m_proto.c (proto_send_supported): just change a comment so
276         it doesn't show up in my scans
277
278         * ircd/ircd_reply.c (send_reply): fix a slight bug...
279
280         * ircd/s_numeric.c (do_numeric): use new sendcmdto_* functions,
281         kinda hackish...
282
283         * ircd/parse.c (parse_server): argument wrangling to make
284         processing in do_numeric a little easier to deal with
285
286         * ircd/s_serv.c (server_estab): SERVER should come from
287         acptr->serv->up, not &me
288
289         * ircd/m_lusers.c: accidentally left out sptr for a %C
290
291         * ircd/send.c: hack to support doing wallchops...
292
293         * ircd/m_whowas.c: convert to new send functions
294
295         * ircd/m_whois.c: convert to new send functions
296
297         * ircd/m_who.c: convert to new send functions
298
299         * ircd/m_wallops.c: convert to new send functions
300
301         * ircd/m_wallchops.c: convert to new send functions
302
303         * ircd/m_version.c: convert to new send functions
304
305         * ircd/m_userip.c: convert to new send functions
306
307         * ircd/m_userhost.c: convert to new send functions
308
309         * ircd/m_uping.c: convert to new send functions
310
311         * ircd/m_trace.c: convert to new send functions
312
313         * ircd/m_topic.c: convert to new send functions
314
315         * ircd/m_time.c: convert to new send functions
316
317         * ircd/m_squit.c: convert to new send functions
318
319         * ircd/m_silence.c: convert to new send functions
320
321         * ircd/m_settime.c: convert to new send functions
322
323         * ircd/m_restart.c: convert to new send functions
324
325         * ircd/m_rehash.c: convert to new send functions
326
327         * ircd/m_privmsg.c: convert to new send functions
328
329         * ircd/m_pong.c: convert to new send functions
330
331         * ircd/m_ping.c: convert to new send functions
332
333         * ircd/m_pass.c: convert to new send functions
334
335         * ircd/m_opmode.c: convert to new send functions
336
337         * ircd/m_oper.c: convert to new send functions
338
339         * ircd/m_notice.c: convert to new send functions
340
341         * ircd/m_nick.c: convert to new send functions
342
343         * ircd/m_names.c: convert to new send functions
344
345         * ircd/m_motd.c: convert to new send functions
346
347         * ircd/m_mode.c: convert to new send functions
348
349         * ircd/m_map.c: convert to new send functions
350
351         * ircd/m_lusers.c: convert to new send functions
352
353         * ircd/m_list.c: convert to new send functions
354
355         * ircd/m_links.c: convert to new send functions
356
357         * ircd/m_kill.c: convert to new send functions
358
359         * ircd/m_jupe.c: convert to new send functions
360
361         * ircd/m_invite.c: convert to new send functions
362
363         * ircd/m_info.c: convert to new send functions
364
365         * ircd/m_help.c: convert to new send functions
366
367         * ircd/m_gline.c: convert to new send functions
368
369         * ircd/m_error.c: convert to new send functions
370
371         * ircd/m_endburst.c: convert to new send functions
372
373         * ircd/m_die.c: convert to new send functions
374
375         * ircd/m_destruct.c: convert to new send functions
376
377         * ircd/m_defaults.c: convert to new send functions
378
379         * ircd/m_connect.c: convert to new send functions
380
381 2000-04-28  Perry Lorier <isomer@coders.net>
382         * RELEASE.NOTES: Describe a few more undocumented features.
383         * config/config-sh.in: change the default paths for logging
384         and the recommended number of channels.
385         * include/supported.h: Rearrange slightly, added CHANTYPE's
386
387 2000-04-27  Kevin L. Mitchell  <klmitch@mit.edu>
388
389         * ircd/m_close.c: convert to send_reply
390
391         * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
392
393         * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
394
395         * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
396
397         * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
398         that takes cmd and tok arguments, etc.  NOTE: THIS IMPLEMENTATION
399         HAS A MAJOR HACK!!!  The whole hunt_server architecture should be
400         carefully rethought...
401
402         * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
403
404         * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
405
406         * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
407         numeric nick; therefore, we have to use the server name
408
409         * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
410
411         * ircd/send.c: fix minor bugs
412
413         * ircd/s_user.c (check_target_limit): mark dead code so I filter
414         it when I grep
415
416         * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
417         when I grep
418
419         * ircd/parse.c: mark dead code so I filter it when I grep
420
421         * ircd/map.c: mark dead code so I filter it when I grep
422
423         * ircd/ircd.c: mark dead code so I filter it when I grep
424
425         * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
426         functions
427
428         * ircd/channel.c: mark dead code so I filter it when I grep
429
430         * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
431         hope I'm not stepping on toes...
432
433         * ircd/s_conf.c: more sendto_opmask_butone / send_reply
434         conversions; use ircd_snprintf in a couple of cases to negate the
435         possibility of buffer overflow
436
437 2000-04-26  Kevin L. Mitchell  <klmitch@mit.edu>
438
439         * ircd/channel.c: convert as much as possible to new send
440         semantics
441
442         * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
443         test member->user->from->fd, not from->fd
444
445         * ircd/gline.c (gline_add): go ahead and add badchans; we just
446         won't look for them in m_gline; this way, they always work...
447
448         * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
449
450         * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
451         ircd_vsnprintf conversion specifiers
452
453         * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
454         I have my conversion specifiers
455
456         * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
457
458         * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
459         local users
460
461         * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
462         little less brain-dead
463
464         * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
465
466         * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
467         RPL_STATSDEBUG
468
469         * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
470         RPL_STATSDEBUG
471
472         * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
473         for RPL_STATSDEBUG
474
475         * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
476
477         * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
478
479         * ircd/s_user.c (register_user): use RPL_EXPLICIT for
480         ERR_INVALIDUSERNAME
481
482         * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
483
484         * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
485         a numeric as needing to use an explicit pattern, which will be the
486         first argument in the variable argument list
487
488         * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
489         non-prefixed nospoof PING
490
491         * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
492         non-prefixed SERVER login
493
494         * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
495         a numeric usage further up)
496
497         * include/send.h: declare sendrawto_one
498
499         * ircd/send.c (sendrawto_one): new function to use ONLY for
500         non-prefixed commands, like PING to client, or PASS/SERVER on
501         server registration
502
503 2000-04-25  Kevin L. Mitchell  <klmitch@mit.edu>
504
505         * ircd/ircd_snprintf.c (doprintf): implement %H for possible
506         future expansion (channel numerics?)
507
508         * include/ircd_snprintf.h: added documentation to # to explain use
509         with %C; added documentation for : to explain use with %C; added
510         documentation for %H for channels
511
512         * ircd/whocmds.c: use send_reply
513
514         * ircd/userload.c: use sendcmdto_one
515
516         * ircd/uping.c: use sendcmdto_one
517
518         * ircd/send.c: use new flags to %C format string; ':' prefixes
519         client name with a colon for local connects, '#' uses
520         nick!user@host form for local connects
521
522         * ircd/s_user.c: use send_reply, sendto_opmask_butone,
523         sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
524
525         * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
526
527         * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
528         sendcmdto_one
529
530         * ircd/s_auth.c: use sendto_opmask_butone
531
532         * ircd/res.c: use sendcmdto_one
533
534         * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
535         debugging assertions
536
537 2000-04-24  Kevin L. Mitchell  <klmitch@mit.edu>
538
539         * ircd/support.c: dumpcore is no longer used, so get rid of it
540
541         * ircd/parse.c: use send_reply, sendcmdto_one
542
543         * ircd/map.c: use send_reply
544
545         * ircd/listener.c: use send_reply
546
547         * ircd/jupe.c: use sendto_opmask_butone, send_reply
548
549         * ircd/ircd_reply.c: use send_reply
550
551         * ircd/ircd.c: use sendto_opmask_butone
552
553         * ircd/gline.c: use sendto_opmask_butone, send_reply
554
555         * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
556         registered clients; make FLAG_ALT print nick!user@host; make
557         FLAG_COLON print :blah
558
559         * ircd/class.c (report_classes): use send_reply instead of
560         sendto_one
561
562         * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
563
564         * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
565         sendto_one with sendcmdto_one
566
567 2000-04-21  Kevin L. Mitchell  <klmitch@mit.edu>
568
569         * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
570         MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
571         sendcmdto_match_butone
572
573         * include/send.h: declare sendcmdto_match_butone
574
575 2000-04-20  Kevin L. Mitchell  <klmitch@mit.edu>
576
577         * ircd/jupe.c: update to use send_reply()
578
579         * ircd/gline.c: update to use send_reply()
580
581         * include/ircd_reply.h: declare send_reply
582
583         * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
584         replies; uses ircd_snprintf
585
586         * ircd/send.c: added comments to redirect searchers to appropriate
587         sendcmdto_* function; moved new functions to end of file; added
588         explanatory comments; reordered arguments; defined new functions
589         mentioned below
590
591         * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
592
593         * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
594
595         * ircd/jupe.c: reorder arguments to sendcmdto_* functions
596
597         * ircd/gline.c: reorder arguments to sendcmdto_* functions
598
599         * include/send.h: reorder arguments, add explanatory comments,
600         declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
601         and vsendto_opmask_butone
602
603 2000-04-19  Kevin L. Mitchell  <klmitch@mit.edu>
604
605         * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
606         vsendto_op_mask that uses '*' instead of the receiving client
607         nickname
608
609         * include/send.h: declare sendcmdto_channel_butone; takes a skip
610         argument that allows you to skip (or not to skip) deaf users,
611         users behind bursting servers, and non channel operators
612
613 2000-04-17  Kevin L. Mitchell  <klmitch@mit.edu>
614
615         * ircd/send.c: new sendcmdto_channel_butserv -- note that old
616         sendto_channel_butserv has a subtle bug; also wrote
617         sendcmdto_common_channels.
618
619         * include/send.h: declare new sendcmdto_* functions
620
621         * ircd/jupe.c: support local deactivations of jupes
622
623         * ircd/gline.c: support local deactivations of glines
624
625         * include/jupe.h: JUPE_LDEACT allows jupes to be locally
626         deactivated; if they aren't locally deactivated, then it slaves to
627         the net-wide activation status; JupeIsRemActive() tests only
628         whether the jupe is active everywhere else
629
630         * include/gline.h: GLINE_LDEACT allows glines to be locally
631         deactivated; if they aren't locally deactivated, then it slaves to
632         the net-wide activation status; GlineIsRemActive() tests only
633         whether the gline is active everywhere else
634
635         * ircd/gline.c: detect overlapping G-lines; if an existing, wider
636         gline expires after the new one will, we drop the new one,
637         otherwise we add the G-line after that one (so the wide one will
638         apply first); if the new one contains an existing G-line and if it
639         will expire after the existing one, we drop the existing one to
640         save memory
641
642         * ircd/m_gline.c (mo_gline): opers could issue remote local
643         glines when CONFIG_OPERCMDS was off; fixed
644
645 2000-04-16  Kevin L. Mitchell  <klmitch@mit.edu>
646
647         * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
648         this is a local JUPE
649
650         * ircd/gline.c: add flags argument to gline_activate and
651         gline_deactivate for future expansion
652
653         * ircd/m_gline.c: pass flags to gline_activate and
654         gline_deactivate
655
656         * include/gline.h: add flags argument to gline_activate and
657         gline_deactivate
658
659         * ircd/jupe.c: add flags argument to jupe_activate and
660         jupe_deactivate for future expansion
661
662         * include/jupe.h: add flags argument to jupe_activate and
663         jupe_deactivate
664
665         * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
666         local, active; pass flags to jupe_activate and jupe_deactivate
667
668         * include/gline.h: remove dead code
669
670         * ircd/gline.c: make gline expire times relative to CurrentTime,
671         since that should be monotonically increasing, instead of
672         TStime(), which can be set backwards, and which can therefore
673         cause an expire time to increase; make local glines be removed
674         instead of just deactivated; don't let gline_find() look for
675         user@host glines if the mask being looked up is a channel mask
676
677         * ircd/send.c (vsendcmdto_one): forgot to account for the case
678         where origin is a server and destination is a user
679
680         * ircd/jupe.c: make jupe expire times relative to CurrentTime,
681         since that should be monotonically increasing, instead of
682         TStime(), which can be set backwards, and which can therefore
683         cause an expire time to increase; make local jupes be removed
684         instead of just deactivated
685
686         * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
687         limit is fine.  any other warnings I should know about?
688
689 2000-04-15  Thomas Helvey <tomh@inxpress.net>
690
691         * ircd/*.c: const correctness and type safety cleanups to
692         get code to compile with C++ compiler. Still has
693         signed/unsigned comparison warnings.
694
695 2000-04-15  Greg Sikorski <gte@atomicrevs.demon.co.uk>
696
697         * ircd/userload.c: change <sys/time.h> include to <time.h> for
698           portability.
699
700 2000-04-14  Kevin L. Mitchell  <klmitch@mit.edu>
701
702         * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
703         and convert acptr...
704
705         * ircd/s_user.c: move gline_lookup function call into
706         register_user, where it'll have a username to lookup!
707
708         * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
709         functions; also stuff send_error_to_client into return clauses
710
711         * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
712         functions; also use send_error_to_client where that makes sense
713
714         * ircd/jupe.c: modify to utilize new sendcmdto_* series of
715         functions; also use send_error_to_client where that makes sense
716
717         * ircd/gline.c: modify to utilize new sendcmdto_* series of
718         functions; also fix gline_lookup() to deal properly with remote
719         clients--boy, do struct Client and struct User need to be cleaned
720         up!
721
722         * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
723         too...
724
725         * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
726         sendcmdto_serv_butone(), all utilizing the %v conversion of
727         ircd_snprintf()
728
729         * include/send.h: define IRC_BUFSIZE, max size of a message;
730         declare sendcmdto_one(), vsendcmdto_one(), and
731         sendcmdto_serv_butone()
732
733         * include/msg.h: define all the CMD_* constants needed to utilize
734         the new sendcmdto_* series of functions
735
736         * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
737
738         * ircd/gline.c: remove old, dead code.
739
740         * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
741         unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
742         (don't advertise proxies); remove dead code
743
744         * ircd/parse.c: oper handler for JUPE only lists jupes unless
745         CONFIG_OPERCMDS is enabled
746
747         * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
748         CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
749
750         * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
751         always return ERR_DISABLED
752
753         * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
754         enabled, always return ERR_DISABLED
755
756         * ircd/s_err.c: add error message to indicate disabled commands
757
758         * include/numeric.h (ERR_DISABLED): to indicate disabled commands
759
760         * doc/Configure.help: add documentation for CONFIG_OPERCMDS
761
762         * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
763         CONFIG_NEW_MODE to 'y' for now
764
765         * ircd/gline.c (gline_list): fix a minor formatting bogon
766
767         * BUGS: since I fixed that bug, might as well mark it fixed.
768
769         * ircd/m_join.c: look up badchans with GLINE_EXACT
770
771         * ircd/m_gline.c: fix parc count problems; look up existing
772         G-lines with GLINE_EXACT; only set new lastmod when
773         activating/deactivating existing glines if old lastmod was not 0
774
775         * ircd/gline.c: forgot to copy the gline reason over; don't
776         propagate a gline with 0 lastmod if origin is user; add
777         GLINE_EXACT to force exact matching of gline mask
778
779         * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
780         flag properly
781
782         * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
783         but gline_lookup() actually takes a client--d'oh.
784
785 2000-04-13  Thomas Helvey <tomh@inxpress.net>
786         * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
787
788 2000-04-13  Greg Sikorski <gte@atomicrevs.demon.co.uk>
789
790         * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
791           "/who * x"
792           "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
793           (Found by Plexus).
794
795         * ircd/whocmds.c: Change idle time calc from socket idle to user
796           idle.
797
798 2000-04-13  Kevin L. Mitchell  <klmitch@mit.edu>
799
800         * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
801         too, for ircd_snprintf.c
802
803         * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
804         comments; mostly descended from the Linux manpage for printf, but
805         also documenting the extensions.
806
807         * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
808         client; make 'q' be the same as 'L'; remove __inline__; only
809         define EXTENSION if HAVE_LONG_LONG is defined
810
811         * include/handlers.h: declare m_gline()
812
813         * ircd/parse.c: gline can be called by users, but it only lists
814         the glines.
815
816         * ircd/s_user.c (set_nick_name): resend gline if a remote server
817         introduces a glined client
818
819         * ircd/s_serv.c (server_estab): burst glines, too
820
821         * ircd/gline.c: fix up all the expire times to be offsets;
822         simplify gline_resend()
823
824         * ircd/m_gline.c: begin coding replacements for ms_gline(),
825         mo_gline(), and m_gline()
826
827         * ircd/gline.c (gline_add): allow *@#channel to work correctly;
828         also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
829
830 2000-04-13  Greg Sikorski <gte@atomicrevs.demon.co.uk>
831
832         * tools/Bouncer/*: Add comments/documentation/tags.
833         * tools/Bouncer/*: Add debug defines, make task fork().
834
835 2000-04-12  Thomas Helvey <tomh@inxpress.net>
836         * ircd/s_err.c: Cleanup s_err.c make one table so we
837         don't have to do anything tricky to get an error string.
838
839 2000-04-12  Greg Sikorski <gte@atomicrevs.demon.co.uk>
840         * Add port bouncer for http (x/w)
841
842 2000-04-12  Kevin L. Mitchell  <klmitch@mit.edu>
843
844         * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
845         call to gline_find(); also used GlineReason() instead of direct
846         reference to structure member
847
848         * ircd/m_join.c (m_join): replace bad_channel() calls with calls
849         to gline_find(name, GLINE_BADCHAN), and also check to see if gline
850         is active
851
852         * ircd/channel.c: nothing seems to be called anywhere...
853
854         * ircd/s_err.c: update a couple of replies to dovetail with new
855         semantics
856
857         * ircd/gline.c: begin complete re-implementation of gline.c along
858         the lines of the final design of jupe.c
859
860         * include/gline.h: begin complete re-implementation of gline.c
861         along the lines of the final design of jupe.c
862
863         * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
864         %s by %s" message...
865
866         * ircd/ircd_snprintf.c: my new snprintf()-like functions
867
868         * include/ircd_snprintf.h: my new snprintf()-like functions
869
870 2000-04-11  Thomas Helvey <tomh@inxpress.net>
871         * ircd/IPcheck.c: removed old dead code
872         * ircd/s_user.c (send_user_info): removed non-standard
873           user not found message for userhost/userip
874
875 2000-04-11  Greg Sikorski <gte@atomicrevs.demon.co.uk>
876
877         * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
878         * doc/p10.html: Work on chapter 4.
879
880 2000-04-10  Kevin L. Mitchell  <klmitch@mit.edu>
881
882         * ircd/channel.c (mode_parse_client): fix coredump on /mode
883         #foobar +o nosuchnick
884
885 2000-04-10  Perry Lorier  <Isomer@coders.net>
886         * BUGS: Added bug.
887
888 2000-04-09  Thomas Helvey <tomh@inxpress.net>
889         * include/IPcheck.h: fix prototype
890         * ircd/s_user.c: fix usage of IPcheck_remote_connect
891         * ircd/IPcheck.c: removed unused args
892
893 2000-04-09  Thomas Helvey <tomh@inxpress.net>
894         * include/IPcheck.h: add proto for IPcheck_expire
895
896         * ircd/IPcheck.c: Rewrote
897
898         * ircd/ircd.c: Add IPcheck_expire to main message loop
899
900         * ircd/s_user.c: Redo target hashing, refactor target code
901
902         * include/numeric.h: Cleaned up numerics, added which ones are
903         in use by other networks and what they are in use for.
904
905         * ircd/channel.c: cleaned can_join(), allow anyone through anything
906         if /invited, simplified the function.  Opers overusing OPEROVERRIDE
907         will get a message explaining to them not to cheat.
908
909         * ircd/m_join.c: cleaned up the various join functions, should be
910         a lot more efficient.  Still needs work.  Now assumes that s<->s
911         won't send it a JOIN 0.  Service coders - note this and tread with
912         care.
913
914         * ircd/m_stats.c: added Gte-'s stats doc patch.
915
916         * ircd/m_version.c: /version now returns the 005 numeric as well.
917         as requested by Liandrin.
918
919
920 2000-04-07  Kevin L. Mitchell  <klmitch@mit.edu>
921
922         * ircd/m_clearmode.c: add include for support.h for write_log()
923
924         * configure: move ircd/crypt/* to tools/*
925
926 2000-04-06  Thomas Helvey <tomh@inxpress.net>
927         * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
928           set client host to server alias if connection from localhost
929
930 2000-04-06  Perry Lorier <isomer@coders.net>
931         * ircd/ircd.c: Fix core during pinging (oops)
932         
933 2000-04-06  Perry Lorier <isomer@coders.net>
934         * ircd/send.c: fixed wrong ident being sent to channels bug.
935         * include/numerics.h: Updated some of the numerics from other
936         networks.  Flagged some as 'unused' by undernet.
937
938 2000-03-30  Perry Lorier <isomer@coders.net>
939         * ircd/ircd.c: Lets see if this helps the ping problem at all.
940         * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
941         time for local clients. (as requested), extended who now returns all
942         the flags (@+!) so you can tell the complete state of a client.
943
944 2000-03-30  Thomas Helvey <tomh@inxpress.net>
945         * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
946
947 2000-03-30  Perry Lorier <isomer@coders.net>
948         * ircd/parse.c: oops, missed opers.
949
950 2000-03-30  Perry Lorier <isomer@coders.net>
951         * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
952         for so long.  Remember: m_ping MUST be in the parse array. :)
953
954 2000-03-30  Perry Lorier <isomer@coders.net>
955         * ircd/ircd.c: test in check_pings was wrong.  I move that we
956         disallow cvs commit after 10pm localtime....
957
958 2000-03-30  Perry Lorier <isomer@coders.net>
959         * ircd/m_pong.c: Fix it for servers too.
960
961 2000-03-30  Perry Lorier <isomer@coders.net>
962         * ircd/m_pong.c: Fix ping timeout bugs
963
964 2000-03-30  Perry Lorier <isomer@coders.net>
965         * ircd/channel.c: Bans had CurrentTime in their when field instead
966         of TStime()
967
968 2000-03-31  Thomas Helvey <tomh@ixpress.net>
969         * ircd/numnicks.c (SetXYYCapacity): fix for extended
970         numerics.
971
972 2000-03-30  Perry Lorier <isomer@coders.net>
973         * ircd/m_nick.c: send kills both ways so when we add nick change
974         on collision we don't desync the network.
975
976         * ircd/map.c: Fixup the map a bit more.
977
978 2000-03-31  Kevin L. Mitchell  <klmitch@mit.edu>
979
980         * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
981
982         * ircd/m_opmode.c: Log the mode changes to OPATH
983
984         * ircd/channel.c (modebuf_flush_int): Log the mode changes to
985         OPATH
986
987         * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
988         OPATH
989
990         * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
991
992         * config/config-sh.in: added OPATH for opmode log file
993
994         * ircd/m_clearmode.c (do_clearmode): updated uses of
995         modebuf_mode_string() for the new usage
996
997         * ircd/channel.c: added flag MODE_FREE and an int argument to
998         modebuf_mode_string() to indicate that the string must be free'd;
999         updated calls to modebuf_mode_string() for the new usage; called
1000         collapse(pretty_mask()) on the ban string and use allocated memory
1001         for it; added ban list length accounting; fixed a number of small
1002         bugs in ban processing
1003
1004         * include/channel.h: added flag MODE_FREE and an int argument to
1005         modebuf_mode_string() to indicate that the string must be free'd
1006
1007         * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
1008         keys and limits that are set
1009
1010 2000-03-30  Perry Lorier <isomer@coders.net>
1011         * ircd/ircd.c: rewrote check_pings() for maintainability
1012         and speed.  Also changed quit msg's so they don't have
1013         redundant nick[host] info in them.
1014
1015         * ircd/send.c: Changed write errors to report what error
1016         occured (if possible).
1017
1018         * ircd/gline.c: added gline comment to the quit.
1019
1020         * ircd/m_server.c: Added suggestions to server quits mentioning
1021         what went wrong so the admin can fix it earlier instead of asking
1022         questions...
1023
1024         * ircd/map.c: Changed m_map() to hide numerics, show a * beside
1025         servers that aren't fully burst yet.  And show '(--s)' for servers
1026         where its not sure.
1027
1028         * doc/example.conf: Fixed wrapped U:
1029
1030 2000-03-30  Kevin L. Mitchell  <klmitch@mit.edu>
1031
1032         * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
1033         mode_parse() (version selectable at compile time)
1034
1035         * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
1036
1037         * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
1038
1039         * config/config-sh.in: add new config option to enable new m_mode
1040         implementation
1041
1042         * doc/Configure.help: add documentation for new config option
1043         CONFIG_NEW_MODE
1044
1045         * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
1046         MODE -v : Not enough parameters
1047
1048         * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
1049         +k and +l even if they weren't set...
1050
1051         * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
1052
1053         * ircd/channel.c: make mode_process_clients() clear the DEOPPED
1054         flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
1055         for; test the 0-th member, not the i-th member, of the client
1056         change state stuff
1057
1058         * ircd/m_clearmode.c (do_clearmode): use the new
1059         mode_invite_clear() function
1060
1061         * ircd/channel.c: cleared up all the compile-time warnings and
1062         errors
1063
1064         * include/channel.h: added declarations for mode_ban_invalidate()
1065         and mode_invite_clear()
1066
1067         * ircd/channel.c: finished mode_parse(), then broke it up into a
1068         dozen or so helper functions to make the code easier to read
1069
1070 2000-03-29  Thomas Helvey <tomh@inxpress.net>
1071         * ircd/ircd.c: refactor server initialization a bit, use
1072         getopt for parsing command line, refactor init_sys, main,
1073         and other bits.
1074
1075         * ircd/s_bsd.c: add functions for initialization to clean
1076         up logic a bit and remove duplicated code.
1077
1078         * include/ircd.h: add struct for server process related
1079         variables.
1080
1081 2000-03-29  Kevin L. Mitchell  <klmitch@mit.edu>
1082
1083         * ircd/channel.c: initial definition of mode_parse(); flags to
1084         prevent doing the same thing multiple times; helper method
1085         send_notoper() to send a "Not oper"/"Not on channel" notice
1086
1087         * include/channel.h: declare mode_parse() and helper flags
1088
1089         * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
1090         sending to match the current action of set_mode() closely enough
1091         that hopefully there won't be major conflicts
1092
1093         * ircd/channel.c (modebuf_flush_int): consolidated the mode string
1094         building logic, reversed the order of the arguments to mode
1095         commands to have '-' preceed '+'
1096
1097 2000-03-29  Thomas Helvey <tomh@inxpress.net>
1098         * ircd/s_bsd.c (add_connection): don't disable socket options
1099         let OS tune itself and allow important performance tweaks to 
1100         work.
1101
1102 2000-03-28  Kevin L. Mitchell  <klmitch@mit.edu>
1103
1104         * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
1105         confused by set_mode, which is doing some really weird logic;
1106         guess what I'm going to rewrite next?  ;)
1107
1108 2000-03-28  Kevin L. Mitchell  <klmitch@emc.com>
1109
1110         * include/channel.h: added MODE_SAVE for the bounds checking stuff
1111         in modebuf_flush
1112
1113         * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
1114         make it do bounds checking on the buffer; all modes are sent only
1115         if the all parameter is 1; modebuf_flush is the exported wrapper
1116
1117         * include/channel.h: add BOUNCE, renumber flags to get a little
1118         more space
1119
1120         * ircd/channel.c (modebuf_flush): don't overload HACK2, add
1121         BOUNCE; send DESYNCH message
1122
1123 2000-03-27  Kevin L. Mitchell  <klmitch@emc.com>
1124
1125         * ircd/m_clearmode.c (do_clearmode): only mark the modes the
1126         channel actually has in effect for deletion
1127
1128         * ircd/channel.c: added explanatory comments to all added
1129         functions; made flushing take place at the correct place even if
1130         the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
1131         to bash some stupid bugs; made modebuf_flush() return if ModeBuf
1132         is empty, fixed the apparent source, removed some bogus string
1133         termination code, properly terminate the mode strings, add support
1134         for HACK2 and HACK3, made limit strings not be sent if the limit
1135         is being removed, changed where '+' and '-' come from in sent
1136         strings, added support for DEOP flag, set up bouncing code for
1137         HACK2
1138
1139         * ircd/Makefile.in: ran make depend
1140
1141         * include/channel.h: added new defines for future functionality,
1142         made modebuf_flush() return int so I can use tail recursion
1143
1144         * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
1145         to make it all compile
1146
1147         * ircd/m_opmode.c: add msg.h to includes...
1148
1149         * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
1150
1151         * ircd/channel.c (modebuf_flush): realized I forgot to
1152         nul-terminate addbuf/rembuf properly...
1153
1154         * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
1155
1156         * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
1157         sendto_serv_butone--blah^2
1158
1159         * ircd/send.c (sendto_serv_butone): stupid comments confused me
1160
1161         * ircd/channel.c (modebuf_flush): if there are no mode changes to
1162         propagate, we're done...
1163
1164         * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
1165         not sendto_all_butone
1166
1167         * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
1168
1169         * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
1170
1171         * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
1172         the list
1173
1174         * ircd/parse.c: added messages for opmode and clearmode
1175
1176         * include/handlers.h: added declarations for mo_opmode(),
1177         ms_opmode(), mo_clearmode(), and ms_clearmode()
1178
1179         * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
1180         TOK_CLEARMODE
1181
1182         * include/channel.h (MODEBUF_DEST_OPMODE): Define the
1183         MODEBUF_DEST_OPMODE flag
1184
1185         * ircd/channel.c (modebuf_flush): added new flag,
1186         MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
1187         to originate from source's server (or source itself, if
1188         IsServer(source)); also causes a server-level MODE to be sent as
1189         OPMODE instead
1190
1191         * include/channel.h: defined MODEBUF_DEST_SERVER,
1192         MODEBUF_DEST_HACK4
1193
1194         * ircd/channel.c: Add another argument to build_string() to handle
1195         numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
1196         servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
1197         to be sent out
1198
1199 2000-03-27  Perry Lorier <isomer@coders.net>
1200
1201         * ircd/s_bsd.c: fixed missing 'u' typo.
1202
1203 2000-03-26  Kevin L. Mitchell  <klmitch@emc.com>
1204
1205         * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
1206         _mode_string(), _mode_client(), _flush(); also implemented a
1207         simple build_string()
1208
1209         * include/channel.h: added definition of ModeBuf, modebuf_*
1210         manipulation functions, and a couple of helper macros
1211
1212 2000-03-24 Thomas Helvey <tomh@inxpress.net>
1213   * numicks.c: convert extended numerics to use original mask version
1214   * numnicks.h: ""
1215   * s_user.c:
1216 2000-03-23 Thomas Helvey <tomh@inxpress.net>
1217   * Merge in changes from production
1218 2000-03-22 Thomas Helvey <tomh@inxpress.net>
1219   * numicks.c: Tweak to numnick generator to reduce possibility of duplicates.
1220   * rfc1459.unet: Add Maniac's documentation for /names 0
1221 * Fix misc. jupe bugs that somehow made it into the tree
1222 * Escape /names 0 to mean /names --Maniac
1223 * Don't core when server asks for info --Maniac 
1224 * Add Kev's jupe patch --Bleep
1225 * Add Maniacs squit patch --Bleep
1226 * Merge in u2_10_10_beta07 changes --Bleep
1227 * Merge in u2_10_10_beta06 changes --Bleep
1228 * Start ircu2.10.11 development, beta branch u2_10_10 --Bleep
1229 #-----------------------------------------------------------------------------
1230 #
1231 # ChangeLog for ircu2.10.11
1232 #
1233 # $Id: ChangeLog,v 1.146 2000-06-09 20:56:03 gte Exp $
1234 #
1235 # Insert new changes at beginning of the change list.
1236 #