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