0876d1def0f1dd000326d27d4317ac17c4d4284f
[ircu2.10.12-pk.git] / ChangeLog
1 2003-01-11  Thomas Helvey <tom.helvey@cox.net>
2         * ircd/client.c, ircd/ircd_feature.c: Bugfix, the feature
3         table data was in a different order than the feature data
4         structure, which resulted in a wild index being used in
5         feature_bool. The feature_bool function didn't check it's
6         index before indexing the features array resulting in
7         a core dump on /oper.
8 2003-01-10  Thomas Helvey <tom.helvey@cox.net>
9         * include/client.h, include/res.h, include/s_bsd.h,
10         ircd/ircd.c, ircd/list.c ircd/m_connect.c, ircd/res_adns.c,
11         ircd/res_libresolv.c, ircd/s_auth.c, ircd/s_bsd.c, ircd/s_conf.c:
12         Remove resolver cache wart, change hostent representation, cleanup
13         resolver clients.
14 2003-01-10  Thomas Helvey <tom.helvey@cox.net>
15         * ircd/map.c, ircd/Makefile.in, include/map.h: Remove 
16         HEAD_IN_SAND macros to get server to build, rebuild dependencies.
17 2003-01-08  Fredrik Soderblom <froo@quakenet.org>
18         * ircd/s_err.c, ircd/s_user.c (hide_hostmask): Simplify
19         RPL_HOSTHIDDEN and the use of it.
20
21 2003-01-07  Kevin L Mitchell  <klmitch@mit.edu>
22
23         * BUGS: removed from distribution
24
25         * ChangeLog.07: moved into doc/history
26
27         * ChangeLog.10: moved into doc/history
28
29         * INSTALL: pulled up from u2.10.11.04
30
31         * README: pulled up from u2.10.11.04
32
33         * README.FreeBSD: pulled up from u2.10.11.04
34
35         * README.Solaris: pulled up from u2.10.11.04
36
37         * RELEASE.NOTES: add sysctl note from u2.10.11.04
38
39         * TODO: removed from distribution
40
41         * configure.in: add extra check for res_mkquery; remove
42         --disable-headinsand since it no longer has any effect; pull up
43         "Enable" vs. "Disable" changes from u2.10.11.04
44
45         * doc/readme.asll: pulled up from u2.10.11.04
46
47         * doc/readme.features: pull up missing documentation, including a
48         couple of corrections
49
50         * doc/readme.log: correct text to read FACILITY instead of SYSLOG
51         in the documentation for configuring syslog facility
52
53         * include/channel.h: declare IsInvited()
54
55         * include/handlers.h: do some minor reorderings
56
57         * include/ircd_defs.h: remove deprecated NETWORK and URL_CLIENTS
58         #define's
59
60         * include/ircd_policy.h: removed from the distribution
61
62         * include/jupe.h: declare jupe_memory_count()
63
64         * include/msgq.h: remove MsgCounts structure
65
66         * include/numeric.h: add a blank line after RPL_STATSQLINE; add
67         RPL_HOSTHIDDEN
68
69         * include/s_stats.h: include ircd_features.h for definition of the
70         enum; remove extraneous declarations
71
72         * ircd/Makefile.in: add LDFLAGS to table_gen
73
74         * ircd/engine_poll.c: remove commented-out assertion
75
76         * ircd/ircd.c: include s_stats.h and call stats_init()
77
78         * ircd/ircd_features.c: feature names have to be case-sensitive
79         because of some of the HIS features
80
81         * ircd/ircd_relay.c: reorder includes
82
83         * ircd/m_account.c: include string.h for strlen()
84
85         * ircd/m_clearmode.c: remove extraneous clean_channelname(); make
86         sure to refer to chname, not parv[1]
87
88         * ircd/m_create.c: remove the broken code that squits servers that
89         are >5 minutes fast; fix "badop || CHFL_CHANOP" bug that caused op
90         desyncs
91
92         * ircd/m_gline.c: if it's a server, force the gline; don't
93         gline_find() before determining if the oper had the privilege
94
95         * ircd/m_kick.c: kicks by servers should appear to be from the
96         local server thanks to HIS
97
98         * ircd/m_lusers.c: needs ircd_features.h, not ircd_policy.h
99
100         * ircd/m_map.c: needs ircd_features.h, not ircd_policy.h
101
102         * ircd/m_nick.c: added an assertion and some explanatory comments
103         pulled up from u2.10.11.04
104
105         * ircd/m_opmode.c: no longer requiring oper to be on the channel;
106         search for quarantines before allowing ops
107
108         * ircd/m_privmsg.c: one character typo that probably means nothing
109
110         * ircd/m_settime.c: add back comments I left in the code
111
112         * ircd/m_squit.c: remove protocol_violation() notices
113
114         * ircd/m_userhost.c: return realhost if user is an oper
115
116         * ircd/m_wallvoices.c: only m_wallvoices() should add a +
117
118         * ircd/m_who.c: add handling for the 'a' field
119
120         * ircd/m_whois.c: correct a typo of FEAT_HIS_SERVERNAME for
121         FEAT_HIS_SERVERINFO
122
123         * ircd/s_bsd.c: close file descriptors 0, 1, and 2; pull up some
124         ancient bug fixes from the u2.10.11 branch
125
126         * ircd/s_debug.c: include gline.h, jupe.h, motd.h, and s_stats.h;
127         call motd_memory_count(), gline_memory_count(), and
128         jupe_memory_count() when reporting memory usage; add back a
129         comment regarding "DBuf caveats"
130
131         * ircd/s_err.c: add RPL_STATSQLINE, RPL_HOSTHIDDEN, and pull up
132         change to ERR_NOPRIVILEGES wording
133
134         * ircd/s_misc.c: include ircd_features.h and not ircd_policy.h
135
136         * ircd/s_stats.c: count from 0 and not 1 when initializing the
137         stats
138
139         * ircd/s_user.c: comment out assertion; remove extraneous
140         definition of FLAGS_HOST_HIDDEN; add in hikari's "your host is now
141         hidden" reply; don't detach oper confs unless sptr is not an oper
142
143         * ircd/table_gen.c: pull up change to NTL_CHPFX (removing +);
144         change channel name character range to be from '\041' (!) to
145         UCHAR_MAX
146
147         * ircd/whocmds.c: pull up fix to /who idle time from u2.10.11.04
148
149         * tools/linesync/linesync.conf: pull up from u2.10.11.04
150
151         * tools/linesync/linesync.sh: pull up from u2.10.11.04
152
153 2003-01-07 Andrew Miller <a1kmm@mware.virtualave.net>
154         * almost everything: Forward ported numerous changes from .11 to .12
155         
156 2002-07-05 Andrew Miller <a1kmm@mware.virtualave.net>
157         * ircd/packet.c(connect_dopacket): Pass the job on to server_dopacket
158         when they become a server.
159         * ircd/s_bsd.c(read_packet): Check they are now a server *after* the
160         packet is sent.
161         * ircd/class.c(make_class): Fixed an assert to be more useful.
162         
163 2002-07-05 Andrew Miller <a1kmm@mware.virtualave.net>
164         * ircd/packet.c
165         * ircd/packet.h: (connect_dopacket): Made a dopacket function for
166         connecting links which sends the messages through the correct message
167         handler.
168         * ircd/s_bsd.c(read_packet): Put packets through the correct handler
169         for connecting links. Properly handle unknown links becoming
170         connecting or servers.
171
172 2002-07-01 Andrew Miller <a1kmm@mware.virtualave.net>
173         * include/ircd_alloc.h (MyFree): Accept NULL pointers to do nothing
174         with, this is used quite a lot.
175         * ircd/class.c (make_class): Initialise the ref_count to 1 so that
176         we don't leak.
177         * ircd/class.c (add_class): When updating a class, free the old name
178         first to prevent leakage.
179         * ircd/class.c (class_delete_marked): Decrement the ref_count for the
180         class after it is removed from the linked list.
181         * ircd/ircd_parser.y: Changed a free to MyFree().
182         * ircd/ircd_parser.y: Removed a few debugging messages.
183
184 2002-07-01 Andrew Miller <a1kmm@mware.virtualave.net>
185         * s_bsd.c (read_packet): Our daily addition to the list of entities to
186         treat as servers - Connecting servers.
187         
188 2002-07-01 Andrew Miller <a1kmm@mware.virtualave.net>
189         * doc/debug_memleak_gc.patch,
190         * include/ircd_ircd_alloc.h,
191         * include/memdebug.h,
192         * configure.in,
193         * ircd/Makefile.in,
194         * ircd/memdebug.c: added a Boehm's gc based leak detector to find leaks
195         and notify the operators.
196         
197 2002-06-29  Andrew Miller <a1kmm@mware.virtualave.net>
198
199         * ircd/s_bsd.c (read_packet): don't make handshaking servers go through
200         the dbufs.
201         
202 2002-06-18  Andrew Miller <a1kmm@mware.virtualave.net>
203
204         * ircd/s_bsd.c (read_packet): don't allow unregistered clients to flood
205         the server.
206         
207 2002-06-18  Alex Badea  <vampire@p16.pub.ro>
208
209         * ircd/m_burst.c (ms_burst): kick local members if the channel
210         has a larger local TS and it's +i or +k remotely (anti net.ride)
211
212         * ircd/ircd_parser.y: fixed a bug that broke IP-based C:lines
213
214         * ircd/s_err.c: connection classes are now strings (RPL_STATSCLINE)
215
216         * include/s_conf.h: externalized lookup_confhost
217
218         * adns/Makefile.in: compilation-outside-source-tree fix
219
220 2002-06-17  Alex Badea  <vampire@p16.pub.ro>
221
222         * adns/*: added a slightly hacked copy of adns
223
224         * configure.in: added a --disable-adns switch if you want
225         to use the old libresolv res.c
226
227         * configure: ran autoconf
228
229         * ircd/res_libresolv.c: renamed from res.c
230
231         * ircd/res_adns.c: added adns resolver
232
233 2002-06-17  Alex Badea  <vampire@p16.pub.ro>
234
235         * ircd/ircd_parser.y: fixed 'Connect' block processing so now
236         you can actually connect to other servers
237
238 2002-06-04  Alex Badea  <vampire@p16.pub.ro>
239
240         * ircd/m_stats.c (report_servers_verbose): oops, fixed it so
241         it displays all servers, not just local connects
242
243 2002-05-30  Jean-Edouard Babin  <Jeb@jeb.com.fr>
244
245         * ircd/m_server.c (mr_server): fixed core bug on insufficient
246         arguments
247
248 2002-05-26  Jeekay  <jeekay@irc.planetarion.com>
249         
250         * ircd/m_join.c (HasControlChars): fixed unsigned vs signed
251
252 2002-05-26  Jeekay  <jeekay@irc.planetarion.com>
253  
254         * ircd/m_join.c (m_join,HasControlChars): check if a channel
255         name has any control chars (<=32) in it before allowing a
256         local user to join.
257  
258 2002-21-05 Andrew Miller <a1kmm@mware.virtualave.net>
259         * ircd/ircd_relay.c: stop an information leak about the
260         the network topography from relayed messages.
261
262 2002-04-19  Alex Badea  <vampire@p16.pub.ro>
263
264         * ircd/m_who.c (m_who): disallow non-opers to /who server.name
265
266 2002-04-18  Alex Badea  <vampire@p16.pub.ro>
267
268         * ircd/s_err.c (RPL_STATSILINE): connection classes are now
269         strings
270
271 2002-04-17  beware <steendijk@tomaatnet.nl>
272
273         * m_whois.c (m_whois): disallow remote queries for non-existent
274         local users when originated by a non-oper
275
276 2002-04-16  Alex Badea  <vampire@p16.pub.ro>
277
278         * ircd/s_user.c (hunt_server_cmd): also send a "no such server"
279         reply if the servername contains a '*' and it doesn't exist
280
281         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
282
283 2002-04-16  beware <steendijk@tomaatnet.nl>
284
285         * ircd/m_whois.c: the previous patch broke whois, fixed it
286         another way
287
288         * ircd/m_admin.c: cleaned up m_admin too while we're here,
289         hunt_server_cmd can do all the work for us
290
291 2002-04-15  Alex Badea  <vampire@p16.pub.ro>
292
293         * ircd/m_stats.c: added verbose server reporting (/stats v
294         or /stats V for machine-readable format) (bugzilla bug 52)
295
296         * include/numeric.h: added RPL_STATSVERBOSE 236
297
298         * ircd/s_err.c: added RPL_STATSVERBOSE
299
300         * ircd/s_stats.c: added help for stats 'v'
301
302 2002-04-15  Alex Badea  <vampire@p16.pub.ro>
303
304         * ircd/class.c (get_client_class): fixed typo which caused
305         /trace (and perhaps motd) to core
306
307 2002-04-15  beware <steendijk@tomaatnet.nl>
308
309         * ircd/m_whois.c: Fixed /whois servermask nomatch bug
310         where normal users could use the function to discover servers,
311         also the NOSUCHSERVER check code was missing.
312
313 2002-04-14  Alex Badea  <vampire@p16.pub.ro>
314
315         * ircd/ircd_parser.y: fixed cli_info(&me) not being set
316         from 'description' conf
317
318 2002-04-13  Stephane Thiell <mbuna@undernet.org>
319
320         * ircd/m_whois.c: removed FindUser() in ms_whois to fix
321         remote whois relaying.
322
323         * ircd/class.c: removed unused (and duplicated) code
324         get_client_ping().
325         
326         * include/class.h: removed unused function prototype.
327         
328         * config.guess: upgraded with latest
329         
330         * config.sub: upgraded with latest
331
332 2002-04-12  Alex Badea  <vampire@p16.pub.ro>
333
334         * ircd-patch: report which files failed the dry run (so the
335         user may force the patch if the rejects are in less-than-vital
336         files, such as ChangeLog or documentation)
337
338 2002-04-12  Alex Badea  <vampire@p16.pub.ro>
339
340         * ircd/m_invite.c: don't propagate invites for local channels
341
342         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
343
344 2002-04-10 Joseph Bongaarts <foxxe@wtfs.net>
345
346         * ircd/ircd.c: The last fix broke autoconnects completely.
347         Fixed it another way.
348         
349 2002-04-09  Brian Cline  <clineb@cs.winthrop.edu>
350
351         * ircd/ircd.c (try_connections): To avoid problems with infinite event
352         loops, don't try connecting to servers whose connect frequency is 0.
353         
354 2002-04-10  Alex Badea  <vampire@p16.pub.ro>
355
356         * ircd/ircd_parser.y: fixed a "features" block parse bug
357
358         * tools/convert-conf.py: added a configuration file converter
359         from 2.10.11 to 2.10.12 format
360
361         * ircd-patch: added GPL information to top of file
362
363 2002-04-09  Alex Badea  <vampire@p16.pub.ro>
364
365         * configure.in: added a human-readable report of configured
366         options at the end of the configure process
367
368         * configure: regenerated with autoconf
369
370 2002-04-08  Gavin Grieve  <ggrieve@ihug.co.nz>
371
372         * include/supported.h: change CHARSET to CASEMAPPING after
373         discussions as to what would be the preferred name.
374
375 2002-04-05 Andrew Miller <a1kmm@mware.virtualave.net>
376         * ircd/s_conf.c, ircd_parser.y, ircd_lexer.l: Add privilege
377         specification.
378         * Fix a minor parser bug that meant rehash didn't always
379         work correctly.
380
381 2002-04-03  Alex Badea  <vampire@p16.pub.ro>
382
383         * include/channel.h: fix compiler warnings (paratheses around &&)
384
385         * ircd/channel.c (modebuf_extract): fix compiler warnings
386         (uninitialized variables)
387
388         * ircd/Makefile.in: make ircd properly compile outside the
389         source tree
390
391 2002-04-03  Alex Badea  <vampire@p16.pub.ro>
392
393         * include/s_user.h: added a sptr parameter to InfoFormatter
394         function type
395
396         * ircd/m_who.c: don't match IPs for clients which have a hidden host,
397         except when the inquiring user is an oper
398
399         * ircd/whocmds.c: show the fake IP from FEAT_HIDDEN_IP if the
400         target has a hidden host, but show real IP to opers
401
402         * ircd/m_userip.c (userip_formatter): add sptr parameter; show the
403         fake IP from FEAT_HIDDEN_IP if the target has a hidden host, but
404         show real IP to opers
405
406         * ircd/m_userhost.c (userhost_formatter): add (unused) sptr parameter
407
408         * ircd/s_user.c (send_user_info): pass sptr to the formatting function
409
410         * include/ircd_features.h: new feature FEAT_HIDDEN_IP (stores which
411         fake IP to show for clients with a hidden host)
412
413         * ircd/ircd_features.c: new feature FEAT_HIDDEN_IP
414
415         * doc/example.conf: default value for FEAT_HIDDEN_IP
416
417         * doc/readme.features: documented FEAT_HIDDEN_IP
418
419 2002-04-03 Andrew Miller <a1kmm@mware.virtualave.net>
420         * doc/example.conf: Cleaned up some comments that ended up in
421           strange places due to problems in the merge process.
422         * ircd/m_nick.c: Cleaned up ms_nick, and fixed a bug that
423           probably dates back to Jarkko code.
424
425 2002-04-02  Kevin L Mitchell  <klmitch@mit.edu>
426
427         * ircd/m_kill.c: let ms_kill() and mo_kill() seperate the message
428         from the path before calling do_kill(); add a msg argument to
429         do_kill() and use it in preference to comment; remove all that old
430         code that fiddled with the buf and the comment
431
432         * ircd/ircd_log.c (log_write_kill): add a seperate msg argument
433
434         * include/ircd_log.h: add a seperate msg argument to
435         log_write_kill()
436
437         * ircd/ircd.c: display event engine and MAXCONNECTIONS information
438  
439 2002-04-02  Alex Badea <vampire@p16.pub.ro>
440
441         * ircd-patch: Automatically generate a version string from patches
442
443 2002-04-02  Alex Badea <vampire@p16.pub.ro>
444         
445         * ircd-patch: Test before doing anything dangerous, provide -f to
446                 to it anyway.  exit levels for easy scripting.
447
448 2002-04-01  Kevin L Mitchell  <klmitch@mit.edu>
449
450         * ircd/channel.c (joinbuf_join): don't add a channel to the list
451         in the joinbuf unless when we flush it, we empty the list
452
453 2002-04-02 Andrew Miller <a1kmm@mware.virtualave.net>
454         * ircd/ircd_parser.y: Added ircd parser, lexer, to replace the
455           old configuration file format.
456         * ircd/ircd_lexer.l
457         * ircd/s_conf.c
458         * doc/example.conf
459
460 2002-03-23 Bert Faes <bert.faes@pandora.be>
461
462         * s_misc.c made /trace reply always show the username
463         
464 2002-03-28  Kevin L Mitchell  <klmitch@mit.edu>
465
466         * configure.in: use AC_CHECK_FUNCS to define HAVE_* macros; test
467         for setrlimit, getrusage, and times
468
469         * configure: rerun auto-conf
470
471         * config.h.in: rerun autoheader
472
473 2002-03-27  Kevin L Mitchell  <klmitch@mit.edu>
474
475         * ircd/m_burst.c (ms_burst): use MODEBUF_DEST_NOKEY to suppress
476         sending of the key to the channel
477
478         * ircd/channel.c (modebuf_flush_int): when processing keys, only
479         include the actual key in the mode sent to the channel if
480         MODEBUF_DEST_NOKEY is not set
481
482         * include/channel.h: needed more bits for MODEBUF_DEST_*,
483         especially when adding MODEBUF_DEST_NOKEY to force keys in the
484         BURST to be reported as "*" to the channel
485
486         * ircd/m_oper.c (m_oper): clear the new oper's sendq so it gets
487         inherited from the class associated with the O-line
488
489 2002-03-25  Kevin L Mitchell  <klmitch@mit.edu>
490
491         * ircd/s_user.c (set_nick_name): invalidate all ban valid caching
492         when a user changes his nickname so we can catch if he now matches
493         a ban
494
495 2002-03-20 Reed Loden <reed@redmagnet.com>
496         * doc/example.conf: Added OPER_LIST_CHAN and LOCOP_LIST_CHAN.
497
498         * doc/readme.features: Added OPER_LIST_CHAN and LOCOP_LIST_CHAN.
499
500 2002-03-20 LordLuke <lordluke@undernet.org>
501         * ircd/client.c: Add LOCOP_LIST_CHAN feature.
502
503         * ircd/ircd_features.h: Add LOCOP_LIST_CHAN feature.
504
505 2002-03-19 Joseph Bongaarts <foxxe@wtfs.net>
506
507         * ircd/m_links.c: Make /links behave like /map for head_in_sand.
508         cleaned up excess code.
509
510         * ircd/map.c: Added map_dump_links_head_in_sand() Made changes in
511         map_add() and map_update() for links changes.
512
513         * include/map.h: Added info and prot to struct Map
514
515         * include/ircd_defs.h: Added MAP_CACHE_TIME for length of time
516         servers are cached in MapList
517
518         * ircd/s_misc.c: changed #ifdef for map_update()
519
520         * ircd/m_server.c: changed #ifdef for map_update()
521
522         * include/ircd_policy.h: added NO_HEAD_IN_SAND for easier removal of
523         hiding features.
524
525         * configure.in: add --disable-headinsand
526
527         * configure: Ran autoconf
528
529         * ircd/m_stats.c: Fixed a bug in /stats i and made /stats i show 
530         connect limits
531
532         * ircd/s_stats.c: Made /stats i report connect limits
533
534         * ircd/s_err.c: Modified RPL_STATSILINE to use %s instead of 
535         "*" for the password field.
536         
537 2002-03-19 LordLuke <lordluke@undernet.org>
538
539         * include/channel.h: Allow opers to view +s channels in /list
540
541         * include/client.h: Add "PRIV_LIST_CHAN" oper privilege
542
543         * include/ircd_features.h: added "LIST_CHAN" feature
544
545         * ircd/channel.c: Allow opers to view +s channels in /list
546
547         * ircd/client.c: Add "PRIV_LIST_CHAN"
548
549         * ircd/ircd_features.c: Add "LIST_CHAN" feature
550
551 2002-03-13 Joseph Bongaarts <foxxe@wtfs.net>
552
553         * ircd/m_kill.c: Last of the last of the bug fixes (Thanks Spike).
554         Must be more careful when forward porting by hand...
555         
556 2002-03-13  Carlo Wood  <run@alinoe.com>
557
558         * include/channel.h: CHFL_CHANNEL_MANAGER, new local
559         channel flag set when someone creates a channel or joins
560         using the Apass.  IsChannelManager(), SetChannelManager():
561         macros to manipulate new channel flag.
562         channel_modes: Added new argument to avoid calling
563         find_member_link more often than needed.
564
565         * include/numeric.h: RPL_APASSWARN, ERR_NOTLOWEROPLEVEL,
566         ERR_NOTMANAGER, ERR_CHANSECURED, ERR_UPASSSET,
567         ERR_UPASSNOTSET: new numeric replies.
568
569         * ircd/channel.c: is_level0_op: removed.
570         member_can_send_to_channel: disallow channel manager
571         to talk.  channel_modes: show upass to level0 ops.
572         mode_parse_upass: Only the channel manager is allowed
573         to change the upass.  Only allow to set upass when apass
574         is also set.  mode_parse_apass: Don't allow to change the
575         Apass if the channel is older than 48 hours.  Only allow
576         to remove the apass when upass is not set.  Send clear
577         warnings regarding the importance of apass.
578         mode_process_clients: Don't change the oplevel of an opped
579         member in a channel where upass is not set.
580
581         * ircd/destruct_event.c: exec_expired_destruct_events:
582         Bug fix: send DESTRUCT message when destructing a channel.
583
584         * ircd/m_destruct.c: ms_destruct: Bug fix: use self as
585         prefix for DESTRUCT message.
586
587         * ircd/m_join.c: m_join: Handle apass and upass.
588
589         * ircd/m_kick.c: m_kick: Don't allow to kick member with
590         a higher or equal op-level.
591
592         * ircd/m_mode.c: m_mode: Now pass member to channel_modes.
593         ms_mode: Allow server to do modes on channels with apass
594         set.
595
596         * ircd/s_err.c: RPL_APASSWARN, ERR_NOTLOWEROPLEVEL,
597         ERR_NOTMANAGER, ERR_CHANSECURED, ERR_UPASSSET,
598         ERR_UPASSNOTSET: new numeric replies.
599
600
601 2002-03-10 Joseph Bongaarts <foxxe@wtfs.net>
602
603         * ircd/m_kill.c: Last of the bug fixes for do_kill()
604
605         * ircd/list.c: Don't remove clients from the linked list
606         that aren't actually in the list.
607         
608 2002-03-08  Carlo Wood  <run@alinoe.com>
609         * include/channel.h: Added CHFL_BURST_ALREADY_OPPED
610         and CHFL_BURST_ALREADY_VOICED.
611
612         * ircd/m_burst.c: Allow BURST outside net-burst
613         and take into account that users are already joined
614         to the channel in that case.
615
616         * ircd/m_destruct.c: Implementation of DESTRUCT
617         handling code.
618
619         * ircd/m_join.c: Set the channel creationtime to
620         the timestamp of a message when that timestamp is
621         smaller.
622 2002-02-27 Reed Loden <reed@redmagnet.com>
623        * tools/crypter: Updated some variables, added another notice,
624        added CVS Id tag, and updated Perl location.
625
626        * tools/ringlog.c: Added IRC - Internet Relay Chat, 
627        tools/ringlog.c
628
629        * tools/ringlog.pl: Added IRC - Internet Relay Chat, 
630        tools/ringlog.pl
631
632        * tools/wrapper.c: Added IRC - Internet Relay Chat, 
633        tools/wrapper.c
634
635        * tools/mkpasswd.c: Added CVS Id tag
636
637        * tools/sums: Updated to comply with sums being moved to tools/
638        and added CVS Id tag
639
640        * tools/README: Updated location of file and partly rewrote to fit 
641        u2.10.11's Features
642
643        * tools/Makefile.crypt: Updated location of file and added CVS Id 
644        tag
645
646        * acconfig.h: Updated location of file
647
648        * config.h.in: Updated location of file
649
650        * tools/Bounce/bounce.conf: Added CVS Id tag
651
652        * tools/Bounce/Bounce.cpp: Updated location of file
653
654        * tools/Bounce/Bounce.h: Updated location of file
655
656        * tools/hashtoy: Added CVS Id Tag
657
658 2002-02-27  Carlo Wood  <run@alinoe.com>
659
660         * /ircd/ircd.c: check_pings: First check if a PING was sent at all.
661
662 2002-03-01  Carlo Wood  <run@alinoe.com>
663
664         * include/channel.h: struct Channel: new attribute destruct_event.
665         Prototype for destruct_channel().
666
667         * include/destruct_event.h: new header file for destruct_event.c.
668
669         * ircd/Makefile.in: New source file: destruct_event.c.
670
671         * ircd/channel.c: sub1_from_channel: Don't destruct channel
672         immedeately but instead schedule it for destruction after
673         some time when a channel becomes empty (and clear invite
674         only and limit in that case).
675         destruct_channel: new function, was previously the destructing
676         part of sub1_from_channel.
677         add_user_to_channel: remove destruction request if any.
678
679         * ircd/destruct_event.c: New file.  Implementation of functions
680         schedule_destruct_event_1m, schedule_destruct_event_48h,
681         remove_destruct_event and exec_expired_destruct_events.
682
683         * ircd/ircd.c: destruct_event_timer: new timer.
684         main: use destruct_event_timer to call exec_expired_destruct_events
685         once per minute.
686
687         * ircd/m_endburst.c: ms_end_of_burst: Don't complain about empty
688         channels.  Schedule new empty channels for destruction.
689
690         * ircd/m_join.c: m_join: Destruct just-created channel immedeately.
691
692 2002-03-01  Carlo Wood  <run@alinoe.com>
693         * ircd/s_misc.c: exit_client: Only call map_update()
694         for servers.
695
696 2002-02-28  Carlo Wood  <run@alinoe.com>
697         * include/channel.h: New attribute 'oplevel' in struct Membership.
698         Added defines MAXOPLEVELDIGITS and MAXOPLEVEL.
699         New macros:  OpLevel(member): returns op-level of member and
700         SetOpLevel(member, value): sets op-level of member.
701         Prototype of add_user_to_channel: add oplevel to parameters.
702         Prototype of mode_parse: add member to to parameters.
703
704         * include/numeric.h: added ERR_NOTLOWEROPLEVEL.
705
706         * ircd/s_err.c: idem.
707
708         * ircd/channel.c: Removed unmatched '{' braces from comments
709         (confuses vi).  add_user_to_channel: oplevel is passed to function
710         and added in the created MemberShip structure.  send_channel_modes:
711         Generate the nick:mode list of the BURST msg in the new style (with
712         op-levels).  DONE_UPASS/DONE_APASS: fixed typo in comment.  struct
713         ParseState: New attribute: member.  mode_process_clients: Disallow
714         deopping someone with an equal or higher op-level, take care of
715         inheritance of op-level.  mode_parse: member is passed to function      
716         and added in the created ParseState structure.  joinbuf_join: pass 0
717         as oplevel to add_user_to_channel as needed initialization of oplevel
718         in struct MemberShip.
719
720         * ircd/m_burst.c: ms_burst: Implementation of op-levels in the
721         decoding of a BURST message and passing on a BURST message.
722         Renamed default_mode to current_mode.
723
724         * ircd/m_mode.c: m_mode/ms_mode: pass on `member' to mode_parse.
725
726         * ircd/m_opmode.c: ms_opmode/mo_opmode: pass on NULL as member
727         to mode_parse (causes opped member to get op-level 0).                  
728
729 2002-02-25  Carlo Wood  <run@alinoe.com>
730         * include/channel.h: Added two new strings to struct Mode,
731         upass and apass, both with maximum length PASSLEN (a new
732         define in this file).  Two new mode defines MODE_UPASS and
733         MODE_APASS.
734
735         * ircd/channel.c: is_level0_op: Added as dummy function.
736         channel_modes/modebuf_flush_int/modebuf_extract/mode_parse:
737         Added support for MODE_APASS (+A) and MODE_UPASS (+u).
738         mode_parse_upass: New function to parse mode +u.
739         mode_parse_apass: New function to parse mode +A.
740
741         * ircd/s_err.c: Added 'A' and 'u' to mode list (RPL_MYINFO).            
742
743 2002-02-25  Carlo Wood  <carlo@alinoe.com>
744
745         * ircd/m_server.c: remove unused variables
746
747 2002-02-25 Joseph Bongaarts <foxxe@wtfs.net>
748
749         * ircd/m_map.c: Modified to show a useful output to non-opered
750           clients when HEAD_IN_SAND_MAP is defined. Servers are added to
751           the list when first seen (after receiving SERVER) and that list
752           is sent to clients. Servers are excluded from the list if they are
753           hubs, services, or have been missing for more than 1 week.
754         
755         * ircd/map.c: Created file for map_* functions
756
757         * include/map.h: Created file for map_* functions
758
759         * ircd/m_server.c: Added calls to map_update()
760
761         * ircd/s_misc.c: Added call to map_update()
762
763         * ircd/parse.c: Changed to use m_map() and mo_map()
764         
765 2002-02-22 Reed Loden <reed@redmagnet.com>
766
767        * ircd/m_connect.c: Removed an extra : in remote connect message.
768
769 2002-02-19 Joseph Bongaarts <foxxe@wtfs.net>
770
771         * ircd/whocmds.c: Local opers should also be able to
772         see servernames in /who
773
774         * ircd/gline.c: Fix core bug in gline_find()
775
776         * ircd/m_kill.c: Bug fix for HIS_KILLWHO
777
778 2002-02-19 John Buttery <john@io.com>
779
780         * ircd/ircd.c: Updated "No such file" error message.
781         
782 2002-02-18 Joseph Bongaarts <foxxe@wtfs.net>
783
784         * ircd/m_kill.c: Changed m_kill() to do_kill() because its not
785         a message handler, and some general cleanups and bug fixes. 
786
787         * include/ircd_policy.h: Added HEAD_IN_SAND_KILLWHO for hiding
788         kill source.
789         
790 2002-02-16  Tim Vogelsang <net@astrolink.org>
791
792         * ircd/m_kill.c: added a new static function, m_kill, which
793         performs the actual kill.
794         
795 2002-02-14 Joseph Bongaarts <foxxe@wtfs.net>
796
797         * Added support for LIST STOP
798         
799 2002-02-13 Joseph Bongaarts <foxxe@wtfs.net>
800
801         * Merged changes from u2_10_11 to main branch.
802         
803 2002-02-08  Tim Vogelsang  <net@astrolink.org>
804
805        * ircd/m_quit.c: don't prefix user quits with "Quit:" unless a
806        reason is supplied.
807
808 2002-02-06  Kevin L Mitchell  <klmitch@mit.edu>
809
810         * ircd/s_auth.c (read_auth_reply): left out an = in an
811         assertion--shouldn't have had any impact, though
812
813         * ircd/Makefile.in: add a hook for using ringlog; run make depend
814
815         * tools/ringlog.c: for the heck of it, add a comment including
816         rules for /etc/magic
817
818 2002-02-05  Kevin L Mitchell  <klmitch@mit.edu>
819
820         * tools/ringlog.pl: perl script to take output from ringlog and
821         pass it to addr2line to get function, file, and line number
822         information
823
824         * tools/ringlog.c: program/object to help in building function
825         trace information
826
827 2002-02-04  Alex Badea  <vampire@p16.pub.ro>
828
829         * include/ircd_features.h: added new feature MOTD_BANNER
830
831         * ircd/ircd_features.c: added new feature MOTD_BANNER
832
833         * ircd/motd.c (motd_signon): send a one-line banner from
834         FEAT_MOTD_BANNER if it's not NULL and FEAT_NODEFAULTMOTD
835         is set
836
837         * doc/example.conf: default value for MOTD_BANNER feature
838
839         * doc/readme.features: documented the MOTD_BANNER feature
840
841 2002-02-04  Kevin L Mitchell  <klmitch@mit.edu>
842
843         * ircd/s_debug.c (debug_serveropts): remove deprecated CHROOTDIR
844         check; added character 'A' to the server options string to
845         indicate when assertion checking is enabled
846
847 2002-02-03  Kevin L Mitchell  <klmitch@mit.edu>
848
849         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
850
851         * ircd/engine_kqueue.c (set_or_clear): don't generate an ET_ERROR
852         event if the errno is EBADF, since the caller probably already
853         knows about it and just hasn't gotten around to processing it yet
854
855         * ircd/ircd_events.c: set the GEN_ERROR flag if an ET_ERROR event
856         is generated; don't process socket_events() or socket_state() if
857         an error occurred; add GEN_ERROR to list of flags in gen_flags()
858
859         * include/ircd_events.h: define new GEN_ERROR flag; add a macro to
860         clear it
861
862 2002-02-01  Kevin L Mitchell  <klmitch@mit.edu>
863
864         * ircd/channel.c: change make_nick_user_{ip,host} to not use a
865         static buffer--instead, a buffer of the right size (NUH_BUFSIZE or
866         NUI_BUFSIZE--I confess they're not well-named) is allocated by the
867         caller
868
869 2002-02-02  Alex Badea  <vampire@p16.pub.ro>
870
871         * include/client.h: added user flag FLAGS_HIDDENHOST
872
873         * include/ircd_features.h: added FEAT_HOST_HIDING and
874         FEAT_HIDDEN_HOST
875
876         * include/numeric.h: defined numeric 338 (RPL_WHOISACTUALLY)
877         to report real hostnames and IPs to opers
878
879         * include/s_user.h: exported hide_hostmask()
880
881         * include/send.h: changed sendcmdto_channel_butserv to
882         sendcmdto_channel_butserv_butone; ditto for
883         sendcmdto_common_channels
884
885         * include/struct.h: added realhost to struct User
886
887         * include/whowas.h: added realhost to struct Whowas
888
889         * ircd/channel.c: match bans against both real and hidden
890         hostmasks; moved some calls to use sendcmdto_*_butone
891
892         * ircd/gline.c: match glines agains real host
893
894         * ircd/ircd_features.c: added FEAT_HOST_HIDING and
895         FEAT_HIDDEN_HOST
896
897         * ircd/m_account.c: call hide_hostmask() for possibly
898         hiding the user's host
899
900         * ircd/m_burst.c: moved some calls to use sendcmdto_*_butone
901
902         * ircd/m_topic.c: moved some calls to use sendcmdto_*_butone
903
904         * ircd/m_userip.c: report IP 127.0.0.1 if the user has a hidden
905         host
906
907         * ircd/m_who.c: match real hosts, if the query comes from an oper
908
909         * ircd/m_whois.c: report real hostname and IP to opers
910
911         * ircd/m_whowas.c: report real hostname to opers
912
913         * ircd/s_err.c: added user mode 'x' to the list of supported user
914         modes in RPL_MYINFO (004); added RPL_WHOISACTUALLY for reporting
915         real hostnames to opers
916
917         * ircd/s_misc.c: moved some calls to use sendcmdto_*_butone
918
919         * ircd/s_serv.c: send real hostname to servers
920
921         * ircd/s_user.c: send real hostname to servers; added processing
922         of usermode 'x'; added hide_hostmask() which actually does the work
923         of hiding a user's host; moved some calls to use sendcmdto_*_butone
924
925         * ircd/send.c: changed sendcmdto_channel_butserv to
926         sendcmdto_channel_butserv_butone; ditto for
927         sendcmdto_common_channels
928
929         * ircd/whocmds.c: extra letter 'x' in WHO reply if the user has
930         it's host hidden
931
932         * ircd/whowas.c: if needed, store a user's real host so we can
933         report it to opers later
934
935         * doc/readme.features: documented HOST_HIDING and HIDDEN_HOST
936         features
937
938         * doc/example.conf: default values for HOST_HIDING and
939         HIDDEN_HOST features
940
941 2002-02-01  Tim Vogelsang  <net@astrolink.org>
942
943         * ircd/send.c (sendwallto_group_butone): don't sent wallops to
944         ordinary users
945
946 2002-01-28  Kevin L Mitchell  <klmitch@mit.edu>
947
948         * ircd/jupe.c (jupe_activate): remove a bogus assertion
949
950         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
951
952         * ircd/s_err.c: added new channel mode 'r' to list of supported
953         channel modes in RPL_MYINFO (004); migrated RPL_USERIP to use
954         numeric 340 instead of 307; add ERR_NEEDREGGEDNICK (477) for
955         informing users why they can't join a +r channel
956
957         * ircd/m_clearmode.c (do_clearmode): add support for MODE_REGONLY
958         (+r) to do_clearmode(); note that it is *not* being added to the
959         default clearmode mask!
960
961         * ircd/channel.c: don't allow non-+r users to send messages to +r
962         channels from off the channel; add support for MODE_REGONLY (+r)
963         to channel_modes(); don't allow non-+r users to join +r channels
964         without an invite; add support for MODE_REGONLY to the modebuf_*()
965         family of functions (changes in modebuf_flush_int(),
966         modebuf_mode(), and modebuf_extract()); add support for
967         MODE_REGONLY to mode_parse()
968
969         * include/supported.h (FEATURESVALUES2): added the new channel
970         mode 'r' to the list of supported channel modes
971
972         * include/numeric.h: move RPL_USERIP to 340 to avoid the 307
973         conflict; add ERR_NEEDREGGEDNICK (477) for the new +r channels
974
975         * include/channel.h: remove unused MODE_SENDTS; add new
976         MODE_REGONLY
977
978         * ircd/s_bsd.c (read_packet): remove call to timer_verify()
979
980         * ircd/list.c: remove calls to timer_verify() from
981         alloc_connection() and dealloc_connection()
982
983         * ircd/ircd_events.c: turn off timer_verify(); remove calls to it
984         from timer_run()
985
986 2002-01-27  Kevin L Mitchell  <klmitch@mit.edu>
987
988         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
989
990         * ircd/ircd_events.c (timer_run): why did I ever use a next
991         pointer when the algorithm guarantees that the head pointer will
992         always be the next pointer?
993
994 2002-01-26  Kevin L Mitchell  <klmitch@mit.edu>
995
996         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
997
998         * ircd/s_bsd.c (read_packet): call timer_verify() after adding the
999         client process timer to catch any list corruption
1000
1001         * ircd/list.c: surround alloc_connection() and
1002         dealloc_connection() with calls to timer_verify()
1003
1004         * ircd/ircd_events.c: add sledgehammer known as timer_verify() to
1005         verify the timer list's structure; call it around timer_run()
1006
1007 2002-01-22  Kevin L Mitchell  <klmitch@mit.edu>
1008
1009         * ircd/send.c (sendcmdto_common_channels): don't send message to a
1010         channel that the source is a zombie on
1011
1012 2002-01-13  Kevin L Mitchell  <klmitch@mit.edu>
1013
1014         * ircd/ircd_events.c (timer_enqueue): one more assertion--make
1015         sure a timer has the ACTIVE flag set before enqueueing the timer
1016
1017         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
1018
1019         * ircd/list.c (dealloc_connection): assert that the process timer
1020         has been removed from the timer queue before dealloc_connection()
1021         is called
1022
1023 2002-01-12  Kevin L Mitchell  <klmitch@mit.edu>
1024
1025         * ircd/res.c: don't accept T_A when we're looking for T_PTR
1026
1027         * ircd/channel.c (modebuf_flush_int): nuke the code that would
1028         send a HACK DESYNCH notice on a HACK(2)--it would be far too
1029         chatty
1030
1031         * ircd/m_away.c (user_set_away): use AWAYLEN instead of TOPICLEN
1032
1033         * include/supported.h: add AWAYLEN to the list of supported
1034         features
1035
1036         * include/ircd_defs.h: add AWAYLEN to specify the maximum length
1037         of an away message
1038
1039         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
1040
1041         * ircd/m_mode.c (m_mode): pass extra parameter to channel_modes()
1042
1043         * ircd/channel.c: pass a buflen parameter to channel_modes() for
1044         pbuf--we were using sizeof(pbuf), which would always be
1045         sizeof(char*) before; change send_channel_modes() to pass extra
1046         parameter to channel_modes()
1047
1048         * include/channel.h: pass a buflen parameter to channel_modes()
1049         for pbuf
1050
1051         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
1052
1053         * ircd/uping.c (uping_start): initialize some timers
1054
1055         * ircd/s_bsd.c (read_packet): use new t_onqueue() macro to figure
1056         out when we need to re-add the process timer
1057
1058         * ircd/s_auth.c (make_auth_request): initialize a timer
1059
1060         * ircd/res.c (init_resolver): initialize some timers
1061
1062         * ircd/list.c (alloc_connection): initialize the client process
1063         timer
1064
1065         * ircd/ircd_events.c: add a function, timer_init(), to initialize
1066         a struct Timer; recast timer_add() to catch when adding a marked
1067         timer and not re-enqueue it--but mark it for re-enqueuing; update
1068         timer_del() to turn off the GEN_READD flag and to ignore reference
1069         counts when destroying the timer--we're using GEN_MARKED as an
1070         ersatz referance count; changed timer_run() to work with the new
1071         way of doing things; add GEN_ACTIVE and GEN_READD to gen_flags()'s
1072         map[]
1073
1074         * ircd/ircd.c: initialize some timers
1075
1076         * ircd/engine_select.c (engine_loop): initialize a timer
1077
1078         * ircd/engine_poll.c (engine_loop): initialize a timer
1079
1080         * ircd/engine_kqueue.c (engine_loop): initialize a timer
1081
1082         * ircd/engine_devpoll.c (engine_loop): initialize a timer
1083
1084         * ircd/IPcheck.c (IPcheck_init): initialize a timer
1085
1086         * include/ircd_events.h: add GEN_READD flag for timers to indicate
1087         that a timer must be readded; add t_onqueue() macro to check to
1088         see if a timer is on the queue (this is a hack, though); added
1089         timer_init() to initialize a struct Timer--we're no longer doing
1090         the initialization in timer_add()
1091
1092 2002-01-11  Kevin L Mitchell  <klmitch@mit.edu>
1093
1094         * ircd/engine_devpoll.c (engine_loop): relocate an assertion to
1095         prevent a core bug *in* the assertion
1096
1097         * doc/readme.features: document new POLLS_PER_LOOP feature; change
1098         documentation to reflect that OPER_SET now defaults to FALSE
1099
1100         * doc/p10.html: documented the new ACCOUNT stuff
1101
1102         * doc/example.conf: document new POLLS_PER_LOOP default; change
1103         default for OPER_SET
1104
1105         * RELEASE.NOTES: changed documentation to reflect the fact that
1106         assertions are now enabled by default and do not cause memory
1107         leaks
1108
1109         * ircd/res.c (make_cache): removed a bogus assertion we probably
1110         never caught because assertions haven't been enabled on production
1111         servers for any length of time before
1112
1113         * ircd/engine_devpoll.c (engine_loop): ditto for POLLS_PER_DEVPOLL
1114
1115         * ircd/engine_kqueue.c (engine_loop): stupid me forgot one
1116         instance of POLLS_PER_KQUEUE
1117
1118         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
1119
1120         * ircd/s_bsd.c (client_timer_callback): only clear the
1121         FREEFLAG_TIMER flag when the timer is being destroyed
1122
1123         * ircd/ircd_features.c: create a new feature, POLLS_PER_LOOP, and
1124         default it to 200; turn OPER_SET off by default
1125
1126         * ircd/engine_kqueue.c: dynamically allocate and reallocate the
1127         array of events to obtain from the kernel
1128
1129         * ircd/engine_devpoll.c: dynamically allocate and reallocate the
1130         array of events to obtain from the kernel
1131
1132         * include/ircd_features.h: add a new feature for tuning how many
1133         events to get from the kernel, for engines that support that
1134
1135         * ircd/Makefile.in: re-run make depend to correct dependancies
1136
1137         * ircd/m_who.c: remove unneeded inclusion of list.h
1138
1139         * ircd/ircd_events.c: remove unneeded inclusion of list.h
1140
1141         * ircd/whocmds.c (do_who): hide server name in /who unless
1142         requester is an operator; simplify hop count insertion
1143
1144         * ircd/s_misc.c (exit_one_client): make sure client's snomask is
1145         cleared
1146
1147         * ircd/parse.c: use mo_version and mo_admin when opers do /version
1148         or /admin
1149
1150         * ircd/m_whowas.c (m_whowas): use HEAD_IN_SAND_SERVERNAME instead
1151         of the static string "*.undernet.org"
1152
1153         * ircd/m_version.c: only let ordinary users get version
1154         information for the server they are on
1155
1156         * ircd/m_admin.c: only let ordinary users get admin information
1157         for the server they are on
1158
1159         * ircd/channel.c (client_can_send_to_channel): check is_banned()
1160         before letting the client speak on a channel s/he is not on
1161
1162         * include/supported.h: add NETWORK to feature list
1163
1164         * include/handlers.h: declare mo_admin() and mo_version()
1165
1166 2002-01-10  Kevin L Mitchell  <klmitch@mit.edu>
1167
1168         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
1169
1170         * ircd/s_debug.c (count_memory): conditionalize on MDEBUG instead
1171         of !NDEBUG
1172
1173         * ircd/m_stats.c: conditionalize /stats M on MDEBUG instead of
1174         !NDEBUG
1175
1176         * ircd/ircd_alloc.c: conditionalize on MDEBUG instead of on
1177         !NDEBUG
1178
1179         * ircd/fda.c: conditionalize on MDEBUG instead of on !NDEBUG
1180
1181         * ircd/Makefile.in: run make depend on chkconf.c as well
1182
1183         * include/ircd_alloc.h: instead of conditionalizing on !NDEBUG,
1184         conditionalize on MDEBUG
1185
1186         * include/fda.h: instead of conditionalizing on !NDEBUG,
1187         conditionalize on MDEBUG
1188
1189         * configure: rebuild configure script
1190
1191         * configure.in: enable assertion checking by default, since we
1192         have now decoupled memory debugging from the NDEBUG macro
1193
1194         * ircd/s_user.c (set_nick_name): remove calls to
1195         verify_client_list()
1196
1197         * ircd/s_misc.c (exit_one_client): remove calls to
1198         verify_client_list()
1199
1200         * ircd/s_conf.c (rehash): remove calls to verify_client_list()
1201
1202         * ircd/m_who.c (m_who): remove calls to verify_client_list()
1203
1204         * ircd/list.c: remove calls to verify_client_list(); keep
1205         verify_client_list() around just in case we ever need it again,
1206         but never compile it in
1207
1208         * ircd/ircd_events.c (event_execute): remove calls to
1209         verify_client_list()
1210
1211         * ircd/client.c (client_get_ping): remove calls to
1212         verify_client_list()
1213
1214         * include/list.h (send_listinfo): remove temporary debugging
1215         function verify_client_list()
1216
1217         * ircd/uping.c: don't die if the event type is ET_ERROR in socket
1218         callback functions
1219
1220         * ircd/res.c (res_callback): don't die if the event type is
1221         ET_ERROR
1222
1223         * ircd/listener.c (accept_connection): don't die if the event type
1224         is ET_ERROR
1225
1226 2002-01-09  Kevin L Mitchell  <klmitch@mit.edu>
1227
1228         * ircd/s_user.c (set_nick_name): bracket call to
1229         add_client_to_list() with calls to verify_client_list()
1230
1231         * include/patchlevel.h (PATCHLEVEL): bump patchlevel (again)
1232
1233         * ircd/list.c (verify_client_list): add a probabilistic loop
1234         detector: for every client added, there is a 2% probability that
1235         it will be used to replace the value of sentinel; if at any time,
1236         sentinel is found again, we know we're in a loop
1237
1238         * ircd/ircd_events.c (event_execute): add verify_client_list()
1239         calls wrapping event_execute; at the very least, I'll figure out
1240         what event the corruption occurred in
1241
1242         * ircd/list.c: moved verify_client_list() to try to keep it from
1243         being inlined
1244
1245         * ircd/Makefile.in (version.c): version.c wasn't dependant on
1246         version.h and patchlevel.h, like it was supposed to be
1247
1248         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
1249
1250         * ircd/s_auth.c (destroy_auth_request): overload send_reports
1251         argument to also indicate whether or not to call
1252         release_auth_client() and thereby enter the client into the linked
1253         list
1254
1255         * ircd/engine_devpoll.c (engine_loop): remove bogus assertion
1256
1257         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
1258
1259         * ircd/list.c (free_client): verify that destroy_auth_request()
1260         didn't automagically re-add us to the list; we might have to think
1261         about this interaction more carefully, actually
1262
1263         * ircd/s_auth.c (auth_kill_client): zero the auth pointer before
1264         calling free_client(); otherwise, free_client() will try to free
1265         the auth by calling destroy_auth_request(), which will call
1266         add_client_to_list()
1267
1268         * ircd/s_misc.c (exit_one_client): liberally sprinkle calls to
1269         verify_client_list() around to catch any corruption that might
1270         occur here
1271
1272         * ircd/s_conf.c (rehash): liberally sprinkle calls to
1273         verify_client_list() here, since this is about the only routine I
1274         can think of that could cause the "core on kill -HUP" bug
1275
1276         * ircd/m_who.c: sprinkle calls to verify_client_list() around
1277         liberally, since we've seen crashes here; temporarily include the
1278         otherwise unneeded list.h header
1279
1280         * ircd/list.c: sprinkle calls to verify_client_list() around quite
1281         liberally; add debugging asserts to list manipulation functions to
1282         catch strange settings for next and prev pointers; define
1283         verify_client_list(), which walks the client list and verifies
1284         that everything is as it's supposed to be
1285
1286         * ircd/client.c: wrap client_get_ping with calls to
1287         verify_client_list() to see if that's where we're dying
1288
1289         * include/patchlevel.h (PATCHLEVEL): bump to 03
1290
1291         * include/list.h: declare verify_client_list() if DEBUGMODE
1292         enabled; otherwise, define it to be empty
1293
1294 2002-01-08  Kevin L Mitchell  <klmitch@mit.edu>
1295
1296         * ircd/m_quit.c (m_quit): remove an unused variable
1297
1298         * include/patchlevel.h (PATCHLEVEL): bump PATCHLEVEL to 2
1299
1300         * ircd/s_user.c: when building the user mode to send to the user,
1301         don't include +r; add an extra set of parens to squelch a warning
1302
1303         * ircd/m_quit.c (m_quit): use exit_client_msg()
1304
1305         * include/patchlevel.h (PATCHLEVEL): bump patch level, so we can
1306         keep track of who's running what version
1307
1308         * ircd/m_squit.c (ms_squit): remove debugging calls to
1309         protocol_violation()
1310
1311         * Makefile.in: change MAKEFILES to IRCD_MAKEFILES to work around a
1312         new gmake "feature" (pull-up from trunk)
1313
1314         * ircd/m_quit.c (m_quit): prefix user quits with "Quit:" (pull-up
1315         from trunk)
1316
1317 2002-01-07  Kevin L Mitchell  <klmitch@mit.edu>
1318
1319         * ircd/s_user.c: add FLAGS_ACCOUNT, represented as 'r', to the
1320         list of user modes; process account name as part of user mode in
1321         NICK decoding (set_nick_name()); add account name to usermode when
1322         building the usermode to incorporate in outgoing NICK messages
1323
1324         * ircd/s_err.c: add RPL_WHOISACCOUNT for reporting what account a
1325         user is logged in to
1326
1327         * ircd/parse.c: define the new ACCOUNT command, usable only by
1328         servers and ignored by everything else
1329
1330         * ircd/m_whois.c: report what account name is associated with a
1331         user, if any
1332
1333         * ircd/m_account.c: implement the ACCOUNT command
1334
1335         * ircd/Makefile.in: add m_account.c to the list of sources; ran
1336         make depend
1337
1338         * include/struct.h: add an account field to struct User
1339
1340         * include/numeric.h: add a reply, RPL_WHOISACCOUNT, for reporting
1341         what username a user is logged in under
1342
1343         * include/msg.h: add ACCOUNT command and token (AC)
1344
1345         * include/ircd_defs.h: define ACCOUNTLEN to be 12--this matches
1346         the maximum length of a username for X
1347
1348         * include/handlers.h: add declaration for ms_account()
1349
1350         * include/client.h: add FLAGS_ACCOUNT to flag when a user account
1351         name has been set; added FLAGS_ACCOUNT to SEND_UMODES; added
1352         IsAccount() and SetAccount() to manipulate the flag
1353
1354         * ircd/m_squit.c (ms_squit): if we call FindNServer() on a server
1355         name like "Amsterdam2.NL.EU.undernet.org", we get the struct
1356         Client for the server with numeric "Am", which happens to be
1357         stockholm!  To fix this, we look up the full name *first*; if that
1358         doesn't get it, *then* we look up by numeric.
1359
1360 2001-12-24  Perry Lorier <isomer@coders.net>
1361         * ircd/m_server.c: cleanups, maybe this will make the bug easier
1362         to find.
1363
1364         * ircd/m_stats.c: display maximum number of connects in an I:
1365
1366 2001-11-22  Perry Lorier  <isomer@coders.net>
1367         * ircd/m_squit.c: Bug fix in squit
1368
1369 2001-11-03  Greg Sikorski <gte@atomicrevs.demon.co.uk>
1370         * ircd/parse.c, include/handlers.h: Give remote whois the correct
1371         handler.
1372         
1373 2001-11-01  Kevin L Mitchell  <klmitch@mit.edu>
1374
1375         * ircd/send.c: some minor white-space fiddling; recast selector
1376         test in sendwallto_group_butone() to remove a warning regarding
1377         putting & within parentheses
1378
1379         * ircd/m_create.c (ms_create): use time_t instead of int as a
1380         declaration for rate
1381
1382         * ircd/ircd_reply.c (protocol_violation): it's supposed to be
1383         WALL_DESYNCH, not CMD_DESYNCH, if I understand things right--no
1384         wonder we weren't seeing any protocol violations!
1385
1386         * include/send.h: include time.h for time_t; move WALL_* closer to
1387         the function they're used in; some white-space fiddling; add
1388         declaration of sendto_opmask_butone_ratelimited()
1389
1390         * ircd/m_squit.c (ms_squit): add protocol_violation() calls in the
1391         cases where we ignore a squit, so we aren't taken by surprise, at
1392         least...
1393
1394         * ircd/m_create.c (ms_create): Display origin server, not origin
1395         user
1396
1397         * ircd/m_create.c (ms_create): Fix "Timestamp drift" server notice
1398
1399 2001-10-31  Perry Lorier  <isomer@coders.net>
1400         * include/m_ping.c: Forward port ping bug
1401
1402 2001-10-31  Perry Lorier  <isomer@coders.net>
1403         * include/patchlevel.h: We're beta now
1404
1405 2001-10-31  Perry Lorier  <isomer@coders.net>
1406         * ircd/s_user.c: fixed hunt_server
1407
1408 2001-09-21  Perry Lorier  <isomer@coders.net>
1409         * ircd/send.c and various: replace sendcmdto_flag_butone with
1410         sendwallto_group_butone
1411
1412 2001-09-21  Vampire-  <unknown>
1413         * ircd/ircd_string.c: unique_name_vector round II.
1414
1415 2001-09-21  mbuna  <mbuna@undernet.org>
1416         * configure.in: Add support for darwin
1417
1418 2001-09-21  Perry Lorier  <isomer@coders.net>
1419         * ircd/s_user.c I'm stupid, s/acptr/from/, Hektik pointed it out
1420
1421 2001-09-20  Perry Lorier  <isomer@coders.net>
1422
1423         * Pullups from 2.10.10.pl16
1424         * Added some warnings, and the concept of rate limited snotices
1425
1426 2001-08-31  Kevin L Mitchell  <klmitch@mit.edu>
1427
1428         * ircd/channel.c: use "%u" to format limit arguments; use
1429         strtoul() to process limit arguments in a /mode command--note:
1430         most clients seem to truncate the integer, probably because
1431         they're using atoi, and perhaps signed ints
1432
1433 2001-08-17  Kevin L Mitchell  <klmitch@mit.edu>
1434
1435         * ircd/numnicks.c: include stdlib.h for exit()
1436
1437         * ircd/ircd_log.c: include stdlib.h for exit()
1438
1439         * ircd/ircd_events.c: include stdlib.h for exit()
1440
1441         * ircd/s_stats.c: remove description of /stats v, since it's gone
1442
1443         * ircd/m_wallops.c (mo_wallops): add "*" to the beginning of
1444         /wallops to distinguish wallops from wallusers
1445
1446         * ircd/m_error.c (mr_error): ignore ERROR from clients that aren't
1447         in the "handshake" or "connecting" states--I think the latter will
1448         never happen, but...
1449
1450         * doc/Authors: apply delete's Authors patch
1451
1452         * RELEASE.NOTES: rewrite RELEASE.NOTES, basing it a little on
1453         Braden's version
1454
1455         * README: rewrite README
1456
1457 2001-07-31  Kevin L. Mitchell  <klmitch@mit.edu>
1458
1459         * ircd/s_serv.c (server_estab): remove unused variable split
1460
1461         * ircd/parse.c: add mr_error to the parse table
1462
1463         * ircd/m_error.c (mr_error): add mr_error() to handle ERRORs from
1464         unregistered connections--if IsUserPort() is true, the ERROR is
1465         ignored, otherwise, the message is saved
1466
1467 2001-07-28  Kevin L. Mitchell  <klmitch@mit.edu>
1468
1469         * ircd/m_kill.c (ms_kill): another minor typo *sigh*
1470
1471         * ircd/s_user.c (send_supported): oops, minor typo...
1472
1473         * ircd/s_user.c: implement send_supported() to send two ISUPPORT
1474         messages containing our feature buffers; make register_user() use
1475         send_supported()
1476
1477         * ircd/s_misc.c (exit_client): make sure not to give away a remote
1478         server in the ERROR message sent to the client; if the killer is a
1479         server, we substitute our name in its place
1480
1481         * ircd/m_version.c (m_version): use send_supported() to send the
1482         ISUPPORT values to the user
1483
1484         * ircd/m_nick.c: shave nick collision kills here a bit, too, for
1485         the same reasons as for m_kill.c
1486
1487         * ircd/m_kill.c: shave kills a bit so that the results look
1488         exactly the same no matter where you are; if we didn't do this, it
1489         would be possible to map the network by looking at the differences
1490         between kills originating under various circumstances
1491
1492         * include/supported.h: split the features into two, so as to not
1493         bust the parameter count when sending the features list
1494
1495         * include/s_user.h: declare new send_supported() function to send
1496         the ISUPPORT information
1497
1498 2001-07-27  Kevin L. Mitchell  <klmitch@mit.edu>
1499
1500         * ircd/s_bsd.c: disable IP (*not* TCP) options to prevent
1501         source-routed spoofing attacks; this is only available under
1502         u2.10.11, so don't even bother, since no one but testers are using
1503         the source base
1504
1505 2001-07-25  Kevin L. Mitchell  <klmitch@mit.edu>
1506
1507         * include/ircd_policy.h: enable HEAD_IN_SAND_REMOTE by default
1508
1509         * ircd/s_err.c: put in a . for reporting link version on /trace,
1510         to match what /version does
1511
1512 2001-07-21  Kevin L. Mitchell  <klmitch@mit.edu>
1513
1514         * ircd/s_misc.c (exit_client): servers don't understand what the
1515         numeric nick ERROR is supposed to mean, so they ignore error
1516         messages, resulting in not knowing why we were rejected; use
1517         sendcmdto_one for servers and sendrawto_one for clients
1518
1519 2001-07-17  Kevin L. Mitchell  <klmitch@mit.edu>
1520
1521         * ircd/m_burst.c (ms_burst): in the case of a modeless channel and
1522         a nick collide, a bare BURST may be propagated; adjust the
1523         enforced parameter count to accept the bare BURST
1524
1525 2001-07-12  Kevin L. Mitchell  <klmitch@mit.edu>
1526
1527         * ircd/s_bsd.c: mark a client as having been IP checked
1528
1529         * ircd/IPcheck.c (ip_registry_check_remote): remove unneeded
1530         second call to SetIPChecked()
1531
1532 2001-07-11  Kevin L. Mitchell  <klmitch@mit.edu>
1533
1534         * ircd/engine_poll.c: deal with POLLHUP properly (hopefully)
1535
1536         * ircd/engine_devpoll.c: deal with POLLHUP properly (hopefully)
1537
1538 2001-07-09  Kevin L. Mitchell  <klmitch@mit.edu>
1539
1540         * ircd/os_bsd.c (os_get_rusage): move buf into the two ifdef'd
1541         sections so that if neither is used, the declaration of buf will
1542         not elicit an "unused variable" warning under NetBSD
1543
1544         * ircd/m_map.c: include string.h to declare strcpy (fix warnings
1545         on alpha)
1546
1547         * ircd/m_away.c: include string.h to declare strcpy/strlen (fix
1548         warnings on alpha)
1549
1550         * ircd/ircd_log.c: include string.h to declare strcpy/strlen (fix
1551         warnings on alpha)
1552
1553         * ircd/client.c: include string.h to declare memset (fix warnings
1554         on alpha)
1555
1556         * ircd/channel.c: remove unused functions next_overlapped_ban,
1557         del_banid, and is_deopped (fix warnings under -O1)
1558
1559         * ircd/IPcheck.c: include string.h to declare memset/memcpy (fix
1560         warnings on alpha)
1561
1562 2001-06-29  Kevin L. Mitchell  <klmitch@mit.edu>
1563
1564         * ircd/s_user.c (set_user_mode): clear the snomask if the user
1565         isn't supposed to receive server notices anymore
1566
1567         * ircd/ircd_features.c: change CONFIG_OPERCMDS to default to FALSE
1568
1569         * configure.in: use AC_MSG_CHECKING/AC_MSG_RESULT when checking
1570         installation prefix; default devpoll and kqueue to on (they get
1571         turned off if the required headers aren't present)
1572
1573         * ircd/whocmds.c (do_who): use ircd_snprintf() instead of
1574         sprintf_irc(); it's a bit hackish, but it'll do for now
1575
1576         * ircd/support.c: remove unused #include
1577
1578         * ircd/send.c: remove unused #include
1579
1580         * ircd/s_user.c: use ircd_snprintf() instead of sprintf_irc()
1581
1582         * ircd/s_serv.c: remove unused #include
1583
1584         * ircd/s_misc.c: use ircd_snprintf() and friends instead of
1585         sprintf_irc() and friends
1586
1587         * ircd/s_err.c: moved atoi_tab[] from ircd/sprintf_irc.c to
1588         ircd/s_err.c, which is the only other file to refer to it
1589
1590         * ircd/s_conf.c (conf_add_deny): use ircd_snprintf() instead of
1591         sprintf_irc()
1592
1593         * ircd/s_bsd.c (connect_server): use ircd_snprintf() instead of
1594         sprintf_irc()
1595
1596         * ircd/s_auth.c: use ircd_snprintf() instead of sprintf_irc()
1597
1598         * ircd/res.c: use ircd_snprintf() instead of sprintf_irc()
1599
1600         * ircd/m_version.c: use ircd_snprintf() instead of sprintf_irc()
1601
1602         * ircd/m_kill.c: use ircd_snprintf() instead of sprintf_irc()
1603
1604         * ircd/listener.c: use ircd_snprintf() instead of sprintf_irc()
1605
1606         * ircd/gline.c: use ircd_snprintf() instead of sprintf_irc()
1607
1608         * ircd/channel.c: don't include sprintf_irc.h; use ircd_snprintf()
1609         instead of sprintf_irc()
1610
1611         * ircd/Makefile.in: remove sprintf_irc.c from sources list; run
1612         make depend
1613
1614         * include/ircd_string.h: remove declaration of sprintf_irc() (what
1615         was it doing here anyway?)
1616
1617         * include/sprintf_irc.h: removed unneeded source file
1618
1619         * ircd/sprintf_irc.c: removed unneeded source file
1620
1621         * ircd/s_debug.c (count_memory): remove some dead code
1622
1623         * ircd/s_auth.c: remove some dead code
1624
1625         * ircd/res.c (update_list): remove some dead code
1626
1627         * ircd/m_whowas.c: remove some dead code
1628
1629         * ircd/m_whois.c: remove some dead code
1630
1631         * ircd/m_who.c: remove some dead code
1632
1633         * ircd/m_wallusers.c: remove some dead code
1634
1635         * ircd/m_wallops.c: remove some dead code
1636
1637         * ircd/m_wallchops.c: remove some dead code
1638
1639         * ircd/m_version.c: remove some dead code
1640
1641         * ircd/m_userip.c: remove some dead code
1642
1643         * ircd/m_userhost.c: remove some dead code
1644
1645         * ircd/m_uping.c: remove some dead code
1646
1647         * ircd/m_trace.c: remove some dead code
1648
1649         * ircd/m_topic.c: remove some dead code
1650
1651         * ircd/m_tmpl.c: remove some dead code
1652
1653         * ircd/m_time.c: remove some dead code
1654
1655         * ircd/m_squit.c: remove some dead code
1656
1657         * ircd/m_silence.c: remove some dead code
1658
1659         * ircd/m_settime.c: remove some dead code
1660
1661         * ircd/m_set.c: remove some dead code
1662
1663         * ircd/m_server.c: remove some dead code
1664
1665         * ircd/m_rpong.c: remove some dead code
1666
1667         * ircd/m_rping.c: remove some dead code
1668
1669         * ircd/m_restart.c: remove some dead code
1670
1671         * ircd/m_reset.c: remove some dead code
1672
1673         * ircd/m_rehash.c: remove some dead code
1674
1675         * ircd/m_quit.c: remove some dead code
1676
1677         * ircd/m_proto.c: remove some dead code
1678
1679         * ircd/m_privs.c: remove some dead code
1680
1681         * ircd/m_privmsg.c: remove some dead code
1682
1683         * ircd/m_pong.c: remove some dead code
1684
1685         * ircd/m_ping.c: remove some dead code
1686
1687         * ircd/m_pass.c: remove some dead code
1688
1689         * ircd/m_part.c: remove some dead code
1690
1691         * ircd/m_opmode.c: remove some dead code
1692
1693         * ircd/m_oper.c: remove some dead code
1694
1695         * ircd/m_notice.c: remove some dead code
1696
1697         * ircd/m_nick.c: remove some dead code
1698
1699         * ircd/m_map.c: remove some dead code
1700
1701         * ircd/m_lusers.c: remove some dead code
1702
1703         * ircd/m_list.c: remove some dead code
1704
1705         * ircd/m_links.c: remove some dead code
1706
1707         * ircd/m_kill.c: remove some dead code
1708
1709         * ircd/m_kick.c: remove some dead code
1710
1711         * ircd/m_jupe.c: remove some dead code
1712
1713         * ircd/m_join.c: remove some dead code
1714
1715         * ircd/m_ison.c: remove some dead code
1716
1717         * ircd/m_invite.c: remove some dead code
1718
1719         * ircd/m_info.c: remove some dead code
1720
1721         * ircd/m_help.c: remove some dead code
1722
1723         * ircd/m_gline.c: remove some dead code
1724
1725         * ircd/m_get.c: remove some dead code
1726
1727         * ircd/m_error.c: remove some dead code
1728
1729         * ircd/m_endburst.c: remove some dead code
1730
1731         * ircd/m_die.c: remove some dead code
1732
1733         * ircd/m_desynch.c: remove some dead code
1734
1735         * ircd/m_destruct.c: remove some dead code
1736
1737         * ircd/m_defaults.c: remove some dead code
1738
1739         * ircd/m_create.c: remove some dead code, along with an #if 1
1740
1741         * ircd/m_cprivmsg.c: remove some dead code
1742
1743         * ircd/m_connect.c: remove some dead code
1744
1745         * ircd/m_close.c: remove some dead code
1746
1747         * ircd/m_clearmode.c: remove some dead code
1748
1749         * ircd/m_burst.c: remove some dead code
1750
1751         * ircd/m_away.c: remove some dead code
1752
1753         * ircd/m_admin.c: remove some dead code
1754
1755         * ircd/listener.c (accept_connection): remove some dead code
1756
1757         * ircd/ircd_reply.c (need_more_params): remove some dead code
1758
1759         * ircd/channel.c (add_banid): remove some dead code
1760
1761         * include/support.h: remove some dead code
1762
1763         * include/querycmds.h: remove some dead code
1764
1765         * doc/readme.chroot: document how to do chroot operation
1766
1767 2001-06-28  Kevin L. Mitchell  <klmitch@mit.edu>
1768
1769         * ircd/Makefile.in: tune for VPATH builds/installs; add a rule to
1770         force bin directory to be created if necessary prior to
1771         installation; run make depend
1772
1773         * doc/Makefile.in (install): tune for VPATH installs by cd'ing to
1774         the ${srcdir}
1775
1776         * Makefile.in: tune to detect Makefile.in changes in
1777         subdirectories and to create installation directory indicated by
1778         ${prefix}
1779
1780         * ircd/whocmds.c (count_users): routine to count the number of
1781         users matching a given user@host mask
1782
1783         * ircd/s_err.c: add error messages for ERR_LONGMASK,
1784         ERR_TOOMANYUSERS, and ERR_MASKTOOWIDE
1785
1786         * ircd/m_gline.c: look for and advance past '!' flag on G-lines
1787         from operators; only set GLINE_OPERFORCE flag if oper has the
1788         PRIV_WIDE_GLINE privilege
1789
1790         * ircd/ircd_features.c: add GLINEMAXUSERCOUNT, which is the
1791         maximum number of users a G-line can impact before it has to be
1792         forced; OPER_WIDE_GLINE, to allow operators to use ! to force a
1793         wide G-line to be set; and LOCOP_WIDE_GLINE, to allow local
1794         operators to use ! to force a wide G-line to be set
1795
1796         * ircd/gline.c: make make_gline() be called with separate user and
1797         host arguments, and not call canon_userhost() directly; implement
1798         gline_checkmask() to verify that a host mask is acceptable; move
1799         BADCHAN check up in gline_add(), and check passed-in mask under
1800         certain circumstances for acceptability; fix call to
1801         sendto_opmask_butone() to handle separation of userhost into user
1802         and host in gline_add(); update call to make_gline()
1803
1804         * ircd/client.c: use FEAT_OPER_WIDE_GLINE and
1805         FEAT_LOCOP_WIDE_GLINE to set PRIV_WIDE_GLINE for an operator; add
1806         PRIV_WIDE_GLINE to privtab[] for client_report_privs()
1807
1808         * include/whocmds.h (count_users): declare routine to count users
1809         matching a given user@host mask
1810
1811         * include/numeric.h: added three new error returns: ERR_LONGMASK
1812         -- mask can't be formatted into a buffer; ERR_TOOMANYUSERS -- too
1813         many users would be impacted by the mask; ERR_MASKTOOWIDE -- mask
1814         contains wildcards in the wrong places
1815
1816         * include/ircd_features.h: add FEAT_GLINEMAXUSERCOUNT,
1817         FEAT_OPER_WIDE_GLINE, and FEAT_LOCOP_WIDE_GLINE
1818
1819         * include/gline.h (GLINE_OPERFORCE): provides a way for m_gline()
1820         to signal to gline_add() that the operator attempted to force the
1821         G-line to be set
1822
1823         * include/client.h (PRIV_WIDE_GLINE): new privilege for operators
1824
1825         * doc/readme.gline: update to document new "!" prefix to a G-line
1826         user@host mask
1827
1828         * doc/readme.features: document GLINEMAXUSERCOUNT,
1829         OPER_WIDE_GLINE, and LOCOP_WIDE_GLINE
1830
1831         * doc/example.conf: update to mention new features along with
1832         their defaults
1833
1834 2001-06-27  Kevin L. Mitchell  <klmitch@mit.edu>
1835
1836         * doc/example.conf: updated example.conf from Braden
1837         <dbtem@yahoo.com>
1838
1839         * include/supported.h: forward-port from pl15
1840
1841 2001-06-25  Kevin L. Mitchell  <klmitch@mit.edu>
1842
1843         * ircd/whocmds.c: include ircd_policy.h and implement
1844         HEAD_IN_SAND_WHO_OPCOUNT--forward-port from pl15
1845
1846         * ircd/m_whois.c: forward-port of the idle-time hiding code from
1847         pl15; this also required passing parc into do_whois(), which also
1848         meant passing parc into do_wilds()--*sigh*
1849
1850         * include/ircd_policy.h: add a couple more HEAD_IN_SAND
1851         #define's--WHOIS_IDLETIME and WHO_HOPCOUNT
1852
1853 2001-06-22  Kevin L. Mitchell  <klmitch@mit.edu>
1854
1855         * tools/wrapper.c: add a wrapper program that can be used to
1856         adjust file descriptor limits and root directories; program must
1857         be run as root--NOT SETUID!--and given appropriate -u arguments
1858
1859         * doc/readme.log: documentation of how to configure logging
1860
1861         * doc/readme.features: documentation of each feature (except for
1862         logging)
1863
1864 2001-06-21  Kevin L. Mitchell  <klmitch@mit.edu>
1865
1866         * Makefile.in (config): add a deprecation notice with a pointer to
1867         tools/transition
1868
1869         * tools/transition: shell script to convert old compile-time
1870         options into new compile-time options and appropriate F-lines
1871
1872         * tools/mkchroot: shell-script to prepare the chroot area by
1873         copying over all the necessary libraries so they can be found
1874
1875 2001-06-20  Kevin L. Mitchell  <klmitch@mit.edu>
1876
1877         * INSTALL: partial update of INSTALL for u2.10.11 release...
1878
1879 2001-06-14  Kevin L. Mitchell  <klmitch@mit.edu>
1880
1881         * ircd/table_gen.c (makeTables): finally got tired of the
1882         "overflow in implicit conversion" warning, so just got rid of it
1883         by explicitly casting UCHAR_MAX to a (default) char; diffs show no
1884         differences in the tables generated
1885
1886 2001-06-11  Kevin L. Mitchell  <klmitch@mit.edu>
1887
1888         * ircd/send.c (sendcmdto_match_butone): don't let the server crash
1889         if a client is in the STAT_CONNECTING status
1890
1891 2001-06-10  Kevin L. Mitchell  <klmitch@mit.edu>
1892
1893         * ircd/send.c: remove unused vsendcmdto_one(), consolidating it
1894         into sendcmdto_one(); define new sendcmdto_prio_one(), which
1895         places the message into the priority queue
1896
1897         * ircd/s_user.c (hunt_server_prio_cmd): definition of
1898         hunt_server_prio_cmd(), which simply calls sendcmdto_prio_one()
1899         instead of sendcmdto_one()
1900
1901         * ircd/m_settime.c: use sendcmdto_prio_one() and
1902         hunt_server_prio_cmd() to send SETTIME
1903
1904         * ircd/m_server.c: use sendcmdto_prio_one() to send SETTIME
1905
1906         * include/send.h: removed declaration for unused vsendcmdto_one();
1907         added a declaration for sendcmdto_prio_one()
1908
1909         * include/s_user.h: declare hunt_server_prio_cmd(), which calls
1910         sendcmdto_prio_one()
1911
1912         * ircd/send.c (sendcmdto_flag_butone): oops; /wallops should be
1913         put in the server's priority queue, too...
1914
1915         * ircd/ircd.c: don't check LPATH for accessibility at all
1916
1917 2001-06-08  Kevin L. Mitchell  <klmitch@mit.edu>
1918
1919         * ircd/s_serv.c (server_estab): send a +h flag in our SERVER
1920         command if we're configured as a hub; send individual server flags
1921         in SERVER commands
1922
1923         * ircd/s_bsd.c (completed_connection): send a +h flag in our
1924         SERVER command if we're configured as a hub
1925
1926         * ircd/m_server.c: implement parv[7] as a mode-like string; +h
1927         sets the FLAGS_HUB flag for a server; +s sets the FLAGS_SERVICE
1928         flag for a server; +hs sets both flags; also modify CMD_SERVER
1929         format string to send the flags
1930
1931         * include/client.h: define two new flags, FLAGS_HUB and
1932         FLAGS_SERVICE to mark services and hubs as such; define testing
1933         macros, setting macros
1934
1935         * ircd/s_user.c: remove deprecated struct Gline* argument to
1936         register_user(); remove GLINE rebroadcast; do not send GLINE
1937         acknowledgement parameter to NICK; do not look for GLINE
1938         acknowledgement parameter to NICK while parsing
1939
1940         * ircd/s_serv.c (server_estab): remove deprecated struct Jupe*
1941         argument to server_estab(); do not send JUPE/GLINE acknowledgement
1942         parameters for SERVER or NICK
1943
1944         * ircd/m_user.c (m_user): remove deprecated argument to
1945         register_user()
1946
1947         * ircd/m_server.c: remove deprecated argument to server_estab();
1948         remove documentation comment regarding JUPE acknowledgement
1949         parameter to SERVER; remove JUPE rebroadcast
1950
1951         * ircd/m_pong.c (mr_pong): remove deprecated argument to
1952         register_user()
1953
1954         * ircd/m_nick.c: remove documentation comment regarding GLINE
1955         acknowledgement parameter to NICK
1956
1957         * ircd/jupe.c: use user's real name in JUPE server notices if
1958         HEAD_IN_SAND_SNOTICES is defined
1959
1960         * ircd/ircd.c: remove deprecated chroot() code; remove deprecated
1961         setuid code; correct ancient DEBUG vs DEBUGMODE typo
1962
1963         * ircd/gline.c: use user's real name in GLINE server notices if
1964         HEAD_IN_SAND_SNOTICES is defined
1965
1966         * ircd/channel.c (modebuf_flush_int): make apparent source be
1967         local server, not oper's server; use user's real name in hack
1968         notices and DESYNC notices if HEAD_IN_SAND_SNOTICES is defined
1969
1970         * include/s_user.h: remove struct Gline pre-declaration; remove
1971         deprecated struct Gline argument from register_user()
1972
1973         * include/s_serv.h: remove struct Jupe pre-declaration; remove
1974         deprecated struct Jupe argument from server_estab()
1975
1976 2001-06-07  Kevin L. Mitchell  <klmitch@mit.edu>
1977
1978         * ircd/s_stats.c (hunt_stats): forward-port from pl15 of all the
1979         changes required to control remote stats
1980
1981         * ircd/s_numeric.c (do_numeric): rewrite numeric origins if
1982         recipient is not an operator and HEAD_IN_SAND_REWRITE is defined
1983         [forward-port from pl15]
1984
1985         * ircd/m_whowas.c (m_whowas): report server name only if requester
1986         is an operator [forward-port from pl15]
1987
1988         * ircd/m_whois.c (do_whois): /whois <mynick> now correctly reports
1989         my server; if HEAD_IN_SAND_REMOTE is 1, ignore the middle argument
1990         and obtain the report from the user's server [forward-port from
1991         pl15]
1992
1993         * ircd/m_who.c: add missing include for ircd_policy.h
1994         [forward-port from pl15]
1995
1996         * ircd/m_version.c (m_version): require oper access for remote
1997         /version if HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
1998
1999         * ircd/m_time.c (m_time): require oper access for remote /time if
2000         HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
2001
2002         * ircd/m_stats.c: pass extra argument to hunt_stats(); correct
2003         missing semicolon [forward-port from pl15]
2004
2005         * ircd/m_nick.c (ms_nick): hide the origin of certain collision
2006         kills [forward-port from pl15]
2007
2008         * ircd/m_motd.c (m_motd): require oper access for remote /motd if
2009         HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
2010
2011         * ircd/m_lusers.c (m_lusers): require oper access for remote
2012         /lusers if HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
2013
2014         * ircd/m_burst.c (ms_burst): server-added bans are stored using
2015         local server name, to hide remote server names; modes also are to
2016         originate from the local server [forward-port from pl15]
2017
2018         * ircd/m_admin.c (m_admin): require oper access for remote /admin
2019         if HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
2020
2021         * ircd/channel.c (add_banid): if a server is adding a ban, use my
2022         server name to hide the remote server's name [forward-port from
2023         pl15]
2024
2025         * ircd/Makefile.in: ran make depend
2026
2027         * include/s_stats.h: hunt_stats() has to have an extra argument to
2028         support the forward-port from pl15
2029
2030         * include/ircd_policy.h: #define HEAD_IN_SAND_STATS_P; add
2031         HEAD_IN_SAND_{BANWHO,REWRITE,REMOTE} [forward-port from pl15]
2032
2033         * ircd/engine_poll.c (engine_loop): remove bogus assert that I
2034         forgot to check in the events branch
2035
2036 2001-06-06  Kevin L. Mitchell  <klmitch@mit.edu>
2037
2038         * ircd/res.c (init_resolver): don't start DNS expires with a 0
2039         relative timeout--if the server starts slow, timeouts could be
2040         messy...there's probably a better solution, but this'll do for now
2041
2042         * ircd/os_solaris.c: _XOPEN_SOURCE doesn't get along with Solaris
2043         headers very well; include stropts.h; define an os_set_tos()
2044
2045         * ircd/os_generic.c (os_set_tos): added an os_set_tos() for
2046         os_generic.c
2047
2048         * ircd/ircd.c: if there are no C-lines, we don't want to have a
2049         timer that expires at the absolute time of 0--it kinda blocks all
2050         the other timers!
2051
2052         * ircd/engine_devpoll.c: some includes for open(); declare errcode
2053         and codesize in engine_loop()
2054
2055         * ircd/list.c (free_client): remove bogus check on timer active
2056         flag
2057
2058         * ircd/s_auth.c: pull out destruction code in
2059         auth_timeout_request() into an externally-visible
2060         destroy_auth_request(); manage cli_auth pointer in client
2061         structure; use it for an extra assertion check
2062
2063         * ircd/list.c: include s_auth.h for destroy_auth_request(); add
2064         debugging notices to show flow when deallocating
2065         connections/clients; call destroy_auth_request() when free'ing a
2066         client that has an auth outstanding; don't free the connection if
2067         the process timer is unmarked but still active
2068
2069         * ircd/ircd_events.c: set GEN_ACTIVE when initializing a generator
2070         and reset it before calling the event handler for an ET_DESTROY
2071         event
2072
2073         * include/s_auth.h (destroy_auth_request): declare
2074         destroy_auth_request(), which can be used to destroy an
2075         outstanding auth request if a client socket goes away before the
2076         auth exchange is completed
2077
2078         * include/ircd_events.h: add an active flag to keep track of
2079         whether or not particular generators are active, for the
2080         convenience of functions using the API
2081
2082         * include/client.h: add a pointer for auth requests to struct
2083         Connection so we can kill outstanding auth requests if a client
2084         socket closes unexpectedly
2085
2086         * ircd/s_bsd.c: cli_connect() could become 0 during the course of
2087         the sock or timer callback; take that into account in the assert
2088
2089         * ircd/list.c: add magic number checking and setting--magic
2090         numbers are zero'd on frees to detect double-frees; add back
2091         setting of cli_from() to 0 to break the back-link from the struct
2092         Connection (duh)
2093
2094         * ircd/ircd.c: set me's magic number correctly
2095
2096         * include/client.h: define magic numbers and accessor/verifier
2097         macros
2098
2099         * ircd/list.c: assert that dealloc_client() is called with
2100         cli_connect(cptr) == 0; set cli_connect(cptr) to 0 before calling
2101         dealloc_client(); don't mess with cli_from(cptr)
2102
2103         * ircd/s_bsd.c: only attempt to dealloc a connection if the
2104         associated client has already been destroyed, or at least delinked
2105
2106 2001-06-05  Kevin L. Mitchell  <klmitch@mit.edu>
2107
2108         * ircd/list.c (free_client): only try to delete the socket when
2109         the fd hasn't already been closed, avoiding a double-free
2110
2111         * ircd/list.c (free_connection): make sure the client is really
2112         gone before doing away with the connection
2113
2114         * ircd/s_bsd.c: record that socket has been added in con_freeflag
2115         field; queue a socket_del() as soon as the socket is close()'d;
2116         use con_freeflag & FREEFLAG_TIMER instead of con_timer; clear
2117         FREEFLAG_SOCKET on ET_DESTROY event in client_sock_callback(),
2118         then dealloc the connection if safe; mark socket as dead when
2119         there's a read error or EOF; clear FREEFLAG_TIMER flag upon entry
2120         to client_timer_callback(); dealloc connection if safe upon
2121         ET_DESTROY event in client_timer_callback()
2122
2123         * ircd/list.c: use con_freeflag instead of con_timer; only dealloc
2124         the connection if both socket and timer have been destroyed;
2125         destroy both socket and timer explicitly and carefully
2126
2127         * include/client.h: replace the con_timer field with a
2128         con_freeflag field, to indicate what still needs freeing; define
2129         the freeflags
2130
2131         * ircd/engine_select.c (engine_loop): duh...sockList[i] could
2132         become 0
2133
2134         * ircd/engine_devpoll.c (engine_loop): duh...sockList[i] could
2135         become 0
2136
2137         * ircd/s_bsd.c: add some extra assertions to try to track down a
2138         corruption problem
2139
2140         * ircd/engine_select.c (engine_loop): add an extra assert to try
2141         to track down a corruption problem
2142
2143         * ircd/engine_poll.c (engine_loop): add an extra assert to try to
2144         track down a corruption problem
2145
2146         * ircd/engine_kqueue.c (engine_loop): add an extra assert to try
2147         to track down a corruption problem
2148
2149         * ircd/engine_devpoll.c (engine_loop): skip slots that have become
2150         empty during processing; add an extra assert to try to track down
2151         a corruption problem
2152
2153         * ircd/engine_kqueue.c (engine_delete): make sure to zero deleted
2154         entries
2155
2156 2001-06-04  Kevin L. Mitchell  <klmitch@mit.edu>
2157
2158         * ircd/s_bsd.c (client_sock_callback): client is no longer
2159         blocked, so we must mark it as unblocked
2160
2161         * ircd/engine_select.c: add Debug() calls galore; add handling for
2162         SS_NOTSOCK; use a dummy sock variable to keep things from
2163         disappearing on us; correct timeout calculation; update nfds for
2164         efficiency
2165
2166         * ircd/engine_poll.c: use new debugging level (DEBUG_ENGINE);
2167         remove a spurious "if (sock)" which will always be true; update
2168         nfds for efficiency
2169
2170         * ircd/engine_kqueue.c: add Debug() calls galore; add handling for
2171         SS_NOTSOCK (just in case); correct timeout calculation
2172
2173         * ircd/engine_devpoll.c: add Debug() calls galore; add handling
2174         for SS_NOTSOCK; correct timeout calculation; add EAGAIN handling
2175
2176         * include/s_debug.h (DEBUG_ENGINE): add new debugging level;
2177         pretty-indent numbers
2178
2179         * ircd/engine_poll.c (engine_loop): break out SS_NOTSOCK
2180         case--it's not a socket; the check for writability is most likely
2181         not needed, but present for completeness
2182
2183 2001-05-24  Kevin L. Mitchell  <klmitch@mit.edu>
2184
2185         * ircd/s_bsd.c: add Debug messages; call read_packet() even if the
2186         no newline flag is set; call read_packet() when the timer expires,
2187         regardless of what's in the buffer--read_packet() should be able
2188         to deal properly
2189
2190         * ircd/IPcheck.c (ip_registry_connect_succeeded): correct a NOTICE
2191         sent to clients to include the client nickname (duh)
2192
2193         * ircd/ircd_events.c: don't destroy a timer if it's already marked
2194         for destruction; replace a missing ! in socket_del()
2195
2196         * ircd/engine_poll.c (engine_loop): reference a temporary variable
2197         so we don't have to worry about sockList[i] going away
2198
2199         * ircd/s_bsd.c (client_sock_callback): add Debug messages
2200
2201         * ircd/s_auth.c: add Debug messages all over the place
2202
2203         * ircd/ircd_events.c: add and edit some Debug messages; add a list
2204         of routines to convert some of the enums and flags from numbers
2205         into human-readable strings for the Debug messages
2206
2207         * ircd/engine_poll.c: hack some Debug messages to use the new name
2208         conversion routines in ircd_events.c; add an extra assert for a
2209         condition that shouldn't ever happen; apparently recv() can return
2210         EAGAIN when poll() returns readable--I wonder why...
2211
2212         * include/ircd_events.h: declare some helper routines under
2213         DEBUGMODE
2214
2215 2001-05-23  Kevin L. Mitchell  <klmitch@mit.edu>
2216
2217         * ircd/s_bsd.c (client_sock_callback): add an extra assertion
2218         check
2219
2220         * ircd/s_auth.c: add more Debug messages
2221
2222         * ircd/list.c (make_client): add an extra assertion check
2223
2224         * ircd/ircd_events.c (socket_events): don't call the engine events
2225         changer if we haven't actually made any changes to the event mask
2226
2227         * ircd/uping.c: add some Debug messages
2228
2229         * ircd/s_stats.c: document new /STATS e
2230
2231         * ircd/s_err.c: add RPL_STATSENGINE to report the engine name
2232
2233         * ircd/s_bsd.c: remove static client_timer variable; in
2234         read_packet(), if there's still data in the client's recvQ after
2235         parsing, add a 2 second timer (con_proc); fix the ET_DESTROY case
2236         of client_sock_callback to handle destroying the timer properly;
2237         rewrote client_timer_callback from scratch to be called on an
2238         individual client
2239
2240         * ircd/m_stats.c: add /STATS e to report the engine name
2241
2242         * ircd/list.c: deal with con_timer field in struct Connection
2243         properly; correct a core-level bug in remove_client_from_list--if
2244         the client is the only one in the list, we try to update
2245         GlobalClientList's cli_prev pointer--not good
2246
2247         * ircd/ircd.c: remove call to init_client_timer()
2248
2249         * ircd/engine_poll.c: made Debug messages more uniform by
2250         prepending "poll:" to them all; corrected an off-by-one error that
2251         caused poll_count to be 1 less than the actual count and removed
2252         my work-around; added Debug messages to indicate which socket is
2253         being checked and what the results are
2254
2255         * ircd/Makefile.in: ran a make depend
2256
2257         * include/s_bsd.h: remove init_client_timer(), since we're doing
2258         it differently now
2259
2260         * include/numeric.h (RPL_STATSENGINE): a stats reply to report the
2261         engine name
2262
2263         * include/ircd_policy.h (HEAD_IN_SAND_STATS_E): turn off /stats e
2264         reports for non-opers
2265
2266         * include/client.h: add con_timer and con_proc fields to struct
2267         Connection and define accessor macros--con_timer marks that
2268         con_proc contains a valid timer, and con_proc is used to pace user
2269         data
2270
2271         * ircd/s_bsd.c (close_connection): let free_client() destroy the
2272         socket
2273
2274         * ircd/s_auth.c (start_auth): add a Debug call to indicate when
2275         auth has begun on a client
2276
2277         * ircd/ircd_events.c: ensure that event_execute() is called with a
2278         non-NULL event; modify event_add() macro to properly zero list
2279         bits; modify gen_dequeue() to not try to clip it out of a list
2280         it's already been clipped out of; change signal socket
2281         initialization to use state SS_NOTSOCK; permit timeout values of
2282         0 in add_timer(); add many Debug calls; change socket_del() and
2283         timer_del() to always set the GEN_DESTROY flag; use GEN_MARKED in
2284         timer_run() instead of GEN_DESTROY so that event_generate() will
2285         pass on the events; remove the switch and replace with a simpler
2286         if-then-else tree in timer_run(); don't allow destroyed sockets to
2287         be destroyed again, nor their states or event masks to be changed
2288
2289         * ircd/ircd.c: initialize "running" to 1
2290
2291         * ircd/engine_poll.c: deal with SS_NOTSOCK "sockets"; add Debug
2292         messages all over the place; fix a counting problem in
2293         engine_add(); turn wait into a signed integer and set it to -1
2294         only if timer_next() returns 0; adjust wait time to be relative;
2295         don't call gen_ref_dec() if socket disappeared while we were
2296         processing it
2297
2298         * include/ircd_events.h: the pipe for signals is not a socket, so
2299         we must mark it as such--added SS_NOTSOCK for that special socket;
2300         events won't be generated if GEN_DESTROY is on, so add GEN_MARKED
2301         for the benefit of timer_run()
2302
2303         * configure.in: add --enable-pedantic and --enable-warnings to
2304         turn on (and off) -Wall -pedantic in CFLAGS
2305
2306 2001-05-21  Kevin L. Mitchell  <klmitch@mit.edu>
2307
2308         * ircd/s_conf.c: change "s_addr" element accesses to "address"
2309         element accesses
2310
2311         * include/s_conf.h: on some systems, "s_addr" is a macro; use
2312         "address" instead
2313
2314 2001-05-18  Kevin L. Mitchell  <klmitch@mit.edu>
2315
2316         * ircd/engine_kqueue.c: include ircd_alloc.h; set_or_clear returns
2317         void in this file; add a missing semi-colon; declare errcode,
2318         codesize
2319
2320         * ircd/uping.c (uping_sender_callback): it's pptr, not uping
2321
2322         * ircd/s_user.c (register_user): comment out spurious reference to
2323         nextping
2324
2325         * ircd/s_serv.c (server_estab): comment out spurious reference to
2326         nextping
2327
2328         * ircd/s_conf.c (read_configuration_file): comment out spurious
2329         reference to nextping and nextconnect
2330
2331         * ircd/s_bsd.c: comment out some spurious references to formerly
2332         global (now non-existant) variables; correct a couple of typos
2333
2334         * ircd/s_auth.c: pre-declare some functions referenced in the
2335         callback; correct a typo
2336
2337         * ircd/res.c (start_resolver): pass errno value of ENFILE
2338
2339         * ircd/listener.c (accept_connection): you know your API is messed
2340         up when...variables that shouldn't have been global crop up in
2341         other files
2342
2343         * ircd/list.c (free_client): substitution of == for =
2344
2345         * ircd/ircd_signal.c: include assert.h for assertion checking;
2346         check ev_data() to find out what signal generated event
2347
2348         * ircd/ircd_events.c: some references to the variable "timer"
2349         should have been references to the variable "ptr"
2350
2351         * ircd/engine_select.c: it's struct fd_set, not struct fdset;
2352         ev_timer(ev) is already a timer pointer; declare codesize as a
2353         size_t to correct signedness issue; use timer_next(), not
2354         time_next()
2355
2356         * ircd/engine_poll.c: ev_timer(ev) is already a timer pointer;
2357         select fd out of struct pollfd in assertion checking; declare
2358         errcode and codesize; use timer_next(), not time_next()
2359
2360         * ircd/engine_kqueue.c: ev_timer(ev) is already a timer pointer;
2361         use function timer_next(), not time_next()
2362
2363         * ircd/engine_devpoll.c: ev_timer(ev) is already a timer pointer;
2364         use function timer_next(), not time_next()
2365
2366         * ircd/Makefile.in (IRCD_SRC): add ircd_events.c to the list of
2367         compiled sources; do make depend
2368
2369         * include/list.h: pre-declare struct Connection
2370
2371         * include/ircd_events.h (gen_ref_inc): cast to the right structure
2372         name
2373
2374         * include/s_auth.h: duh; missing */
2375
2376 2001-05-10  Kevin L. Mitchell  <klmitch@mit.edu>
2377
2378         * ircd/send.c: update write events status after sending data or
2379         accumulating data to be sent
2380
2381         * ircd/m_list.c (m_list): update write events status after
2382         canceling a running /list
2383
2384         * ircd/channel.c (list_next_channels): update write events status
2385         after listing a few channels
2386
2387         * ircd/s_bsd.c: extensive changes to update to new events model;
2388         remove on_write_unblocked() and the two implementations of
2389         read_message(), which have been deprecated by this change
2390
2391         * ircd/s_auth.c: set the socket events we're interested in for
2392         clients; simplify some logic that does the connect_nonb followed
2393         by the socket_add
2394
2395         * ircd/list.c: define free_connection() to free a connection
2396         that's become freeable once the struct Socket has been
2397         deallocated; fix up free_client() to take this new behavior into
2398         account
2399
2400         * ircd/ircd.c: call init_client_timer()
2401
2402         * include/s_bsd.h: declare new REGISTER_ERROR_MESSAGE when unable
2403         to register connect-in-progress with events system; declare
2404         init_client_timer() (HACK!) to preserve rate-limiting behavior
2405
2406         * include/list.h: declare new free_connection()
2407
2408         * include/client.h: add a struct Socket to struct Connection
2409
2410 2001-05-09  Kevin L. Mitchell  <klmitch@mit.edu>
2411
2412         * ircd/ircd_signal.c: massage the handlers for SIGHUP, SIGINT, and
2413         SIGTERM into event callbacks; perform the actions in the
2414         callbacks, since they're not called in the context of the signal;
2415         set up the signal callbacks in the event engine
2416
2417         * ircd/ircd_events.c (signal_callback): we're supposed to look for
2418         a specific signal; don't generate an event if there is no signal
2419         structure for it
2420
2421         * ircd/ircd.c: nuke nextconnect and nextping and replace them with
2422         connect_timer and ping_timer; massage try_connections() and
2423         check_pings() into timer callbacks that re-add themselves at the
2424         right time; remove ircd.c's "event_loop()"; initialize the event
2425         system and the connect_timer and ping_timer
2426
2427         * ircd/uping.c: correct a couple more typos
2428
2429         * ircd/s_auth.c: rework to use new events system
2430
2431         * ircd/os_solaris.c (os_connect_nonb): update to new interface
2432
2433         * ircd/os_openbsd.c (os_connect_nonb): update to new interface
2434
2435         * ircd/os_linux.c (os_connect_nonb): update to new interface
2436
2437         * ircd/os_generic.c (os_connect_nonb): update to new interface
2438
2439         * ircd/os_bsd.c (os_connect_nonb): update to new interface
2440
2441         * include/s_auth.h: remove deprecated members of struct
2442         AuthRequest, replacing them with struct Socket and struct Timer
2443         structures; add flags to indicate when these structures have been
2444         released by the event system; remove the deprecated
2445         timeout_auth_queries()
2446
2447         * include/ircd_osdep.h (os_connect_nonb): connect could complete
2448         immediately, so change the interface to handle that possibility
2449
2450         * ircd/uping.c (uping_server): noticed and corrected a typo
2451
2452         * ircd/listener.c: set up to use ircd_event's struct Socket by
2453         adding an socket_add() call to inetport(), replacing
2454         free_listener() with socket_del() in close_listener(), and
2455         reworking accept_connection to be called as the callback
2456
2457         * ircd/ircd.c: add a call to IPcheck_init()
2458
2459         * ircd/IPcheck.c: remove IPcheck_expire(); rework
2460         ip_registry_expire() to be called from a timer; write
2461         IPcheck_init() to set up the expiration timer (hard-coded for a
2462         60-second expiration time)
2463
2464         * include/listener.h: add a struct Socket to the struct Listener;
2465         remove accept_connection()
2466
2467         * include/IPcheck.h: add IPcheck_init(), remove IPcheck_expire()
2468
2469 2001-05-08  Kevin L. Mitchell  <klmitch@mit.edu>
2470
2471         * ircd/ircd_events.c: include config.h; use USE_KQUEUE and
2472         USE_DEVPOLL instead of HAVE_KQUEUE and HAVE_DEVPOLL_H
2473
2474         * ircd/engine_select.c: include config.h; set FD_SETSIZE to
2475         MAXCONNECTIONS, not IRCD_FD_SETSIZE...
2476
2477         * ircd/engine_poll.c: include config.h
2478
2479         * ircd/engine_kqueue.c: include config.h
2480
2481         * ircd/engine_devpoll.c: include config.h
2482
2483         * ircd/Makefile.in: include engine sources in compilation and make
2484         depend steps
2485
2486         * configure.in: add checks for enabling the /dev/poll- and
2487         kqueue-based engines
2488
2489         * acconfig.h: add lines for USE_DEVPOLL and USE_KQUEUE
2490
2491         * ircd/Makefile.in: work in the engine sources
2492
2493 2001-05-07  Kevin L. Mitchell  <klmitch@mit.edu>
2494
2495         * ircd/m_settime.c: include ircd_snprintf.h
2496
2497         * ircd/ircd_relay.c: stomp a couple of gcc warnings suggesting
2498         parens around a construct that had both || and &&
2499
2500         * ircd/chkconf.c: #include "config.h" to get some important
2501         definitions
2502
2503         * ircd/Makefile.in: revamp ircd makefile for new build system
2504
2505         * doc/Makefile.in: revamp doc makefile for new build system
2506
2507         * config/*: Removed old build system files
2508
2509         * stamp-h.in: a stamp file
2510
2511         * install-sh: install-sh for new build system
2512
2513         * configure.in: configure.in for new build system
2514
2515         * configure: configure script for new build system (built by
2516         autoconf)
2517
2518         * config.sub: config.sub for new build system
2519
2520         * config.h.in: config.h.in for new build system (built by
2521         autoheader)
2522
2523         * config.guess: config.guess for new build system
2524
2525         * aclocal.m4: aclocal.m4 for new build system (built by aclocal
2526         1.4)
2527
2528         * acinclude.m4: aclocal.m4 macros for new build system
2529
2530         * acconfig.h: config.h skeleton for new build system
2531
2532         * Makefile.in: modify for new build system
2533
2534 2001-05-01  Kevin L. Mitchell  <klmitch@mit.edu>
2535
2536         * ircd/s_err.c: get rid of the last vestiges of TIME_T_FMT
2537
2538         * ircd/m_settime.c: get rid of the last vestiges of TIME_T_FMT
2539
2540         * ircd/m_server.c: get rid of the last vestiges of TIME_T_FMT
2541
2542 2001-05-01  Perry Lorier       <Isomer@coders.net>
2543         * doc/iauth.doc: Protocol for iauth server. (from hybrid).
2544         * doc/linux-poll.patch: Patch to make Linux under 2.2 not deadlock
2545                 when you have far far too many sockets in use.
2546         * {include,ircd}/iauth.c: A start on iauth support.
2547
2548 2001-05-01  Perry Lorier       <Isomer@coders.net>
2549         * ircd/s_err.c: Suggested wording change.
2550         * ircd/s_user.c: Users aren't target limited against +k users.
2551         * ircd/chkconf.c: Made it compile again, who knows if it works, but
2552                 now I can at least make install
2553         * various: Cleanups on m_*.c files.
2554
2555
2556 2001-04-23  Kevin L. Mitchell  <klmitch@mit.edu>
2557
2558         * ircd/s_misc.c (exit_client): make netsplit server notice say the
2559         right thing
2560
2561         * ircd/m_links.c (m_links_redirect): forward-port RPL_ENDOFLINKS
2562         change to make Khaled happy...
2563
2564         * ircd/m_whois.c (do_whois): pull-up of m_whois() fix
2565         (do_whois): duh...
2566
2567 2001-04-21  Kevin L. Mitchell  <klmitch@mit.edu>
2568
2569         * ircd/msgq.c: finally remove the msgq_integrity() hack, as it's
2570         turned up no more bugs
2571
2572         * ircd/ircd.c: use /* */ comments instead of // comments--all the
2573         world's not gcc :(
2574
2575         * ircd/s_conf.c (conf_add_server): use /* */ comments instead of
2576         // comments--all the world's not gcc :(
2577
2578         * ircd/runmalloc.c: finally garbage-collect unused file
2579
2580         * include/runmalloc.h: finally garbage-collect unused file
2581
2582         * ircd/<multiple files>: addition of '#include "config.h"' before
2583         all other includes in most .c files
2584
2585         * include/<multiple files>: remove includes of config.h, which are
2586         now going into the raw .c files
2587
2588 2001-04-20  Kevin L. Mitchell  <klmitch@mit.edu>
2589
2590         * ircd/m_whois.c (do_whois): display proper server name if the
2591         user is looking up himself
2592
2593         * ircd/m_who.c (m_who): disable match by servername or display of
2594         server names by non-opers
2595
2596         * include/ircd_policy.h: add define for
2597         HEAD_IN_SAND_WHO_SERVERNAME to cover full intent of sub-motion 15
2598         of CFV 165
2599
2600 2001-04-18  Kevin L. Mitchell  <klmitch@mit.edu>
2601
2602         * ircd/s_conf.c: keep the $R in memory so we can see it clearly
2603         when we do a /stats k
2604
2605         * ircd/s_user.c (set_user_mode): pull-up of changes to prevent
2606         users from turning on +s and +g
2607
2608         * ircd/s_misc.c (exit_client): pull-up of changes to turn off
2609         net.split notice
2610
2611         * ircd/parse.c: pull-up of changes to disable /trace, /links, and
2612         /map for users
2613
2614         * ircd/m_whois.c (do_whois): pull-up of server name masking for
2615         /whois
2616
2617         * ircd/m_user.c (m_user): removal of umode and snomask defaulting
2618         functions, pull-up
2619
2620         * ircd/m_stats.c (m_stats): pull-up of stats-disabling stuff
2621
2622         * ircd/m_map.c (m_map_redirect): pull-up of m_map_redirect()
2623
2624         * ircd/m_links.c (m_links_redirect): pull-up of m_links_redirect()
2625
2626         * ircd/channel.c (channel_modes): pull-up of channel key display
2627         as *
2628
2629         * include/ircd_policy.h: pull-up of ircd_policy.h
2630
2631         * include/client.h: pull-up of Set/ClearServNotice()
2632
2633         * ircd/gline.c (do_gline): report client name in G-line message
2634         (pull-up)
2635
2636         * ircd/s_user.c (register_user): pull-up--show IP address in some
2637         server notices dealing only with users; report which connection
2638         class has filled up
2639
2640         * ircd/s_stats.c (report_deny_list): use conf->flags &
2641         DENY_FLAGS_IP insteaf of conf->ip_kill
2642
2643         * ircd/m_stats.c (report_klines): use conf->flags & DENY_FLAGS_IP
2644         insteaf of conf->ip_kill
2645
2646         * ircd/s_conf.c: use flags field in struct DenyConf; pull-up of
2647         K-line by real name
2648
2649         * include/s_conf.h: use a flags field in struct DenyConf; define
2650         DENY_FLAGS_FILE, DENY_FLAGS_IP, and DENY_FLAGS_REALNAME for
2651         pull-up of K-line by real name
2652
2653         * ircd/m_trace.c: pull-up of IP show for user connections
2654
2655         * doc/example.conf: pull-up of the realname K-line documentation
2656
2657         * ircd/ircd.c: forward port of pid file advisory locking mechanism
2658
2659 2001-04-16  Kevin L. Mitchell  <klmitch@mit.edu>
2660
2661         * ircd/send.c (sendcmdto_flag_butone): recast to just broadcast to
2662         all servers, rather than to only servers that have +w/+g/whatever
2663         users on them; among other things, this removes that atrocity
2664         known as sentalong[] from this function
2665
2666         * ircd/m_admin.c: must include ircd.h to declare "me"; must
2667         include hash.h to declare FindUser()
2668
2669         * ircd/m_wallusers.c: implementation of WALLUSERS
2670
2671         * ircd/m_desynch.c (ms_desynch): only send DESYNCHs to opers
2672
2673         * ircd/m_wallops.c: only send WALLOPS to opers
2674
2675         * ircd/parse.c: add WALLUSERS command to parser table
2676
2677         * include/handlers.h: declare wallusers handlers
2678
2679         * include/msg.h: add WALLUSERS command
2680
2681         * ircd/send.c (sendcmdto_flag_butone): if FLAGS_OPER is or'd with
2682         flag, send only to appropriate opers
2683
2684 2001-04-13  Kevin L. Mitchell  <klmitch@mit.edu>
2685
2686         * ircd/uping.c: refit to use the new events interface
2687
2688         * ircd/res.c: refit to use the new events interface
2689
2690         * ircd/ircd_events.c: create timer_chg(), which permits a
2691         (non-periodic) timer's expire time to be modified; change the
2692         logic in timer_run() so that timers that were re-added while the
2693         event was being processed will not be destroyed prematurely
2694
2695         * include/uping.h: include the events header, declare some extra
2696         fields in struct UPing, remove timeout value, and define some
2697         flags for marking which cleanup items have yet to be done
2698
2699         * include/ircd_events.h: add a prototype for timer_chg() to change
2700         the expire time of a running timer
2701
2702 2001-03-13 Joseph Bongaarts <foxxe@wtfs.net>
2703         * ircd/os_openbsd.c: Tweaked the openbsd hack a bit.
2704         
2705 2001-03-07  Joseph Bongaarts  <foxxe@wtfs.net>
2706
2707         * config/configure.in: Add check for OpenBSD
2708
2709         * ircd/os_openbsd.c: Add seperate os dep file for openbsd which
2710         differs from generic BSD, particularly in its handling of
2711         _XOPEN_SOURCE.
2712         
2713 2001-02-12  Kevin L. Mitchell  <klmitch@mit.edu>
2714
2715         * ircd/m_gline.c (ms_gline): propagate a G-line that happened to
2716         have been added by a U-lined server, rather than going through the
2717         activate/deactivate logic; propagate G-line removals by U-lined
2718         servers as well
2719
2720         * ircd/gline.c: rename propagate_gline() to gline_propagate();
2721         make gline_propagate() return an int 0 (convenience return); only
2722         update lastmod in gline_activate() and gline_deactivate() if the
2723         current lastmod is non-zero, since 0 lastmod is our flag of a
2724         U-lined server having added a G-line
2725
2726         * include/gline.h (gline_propagate): exporting the G-line
2727         propagation function
2728
2729         * ircd/m_list.c (m_list): duh; permit explicit channel name
2730         specification only when /list gets two arguments ("Kev
2731         #wasteland") rather than when /list gets more than two
2732         arguments--nice braino
2733
2734 2001-01-29  Thomas Helvey <twhelvey1@home.com>
2735
2736         * ircd/ircd_reply.c (need_more_params): fix bug that allowed
2737         unregistered clients to spam opers with protocol violation
2738         messages. Note: the bugfix may have eliminated some useful
2739         protocol violation messages.
2740         Please send protocol violation messages explicitly from the
2741         functions they are discovered in, you have much better context
2742         for the error there and it helps to document the behavior of the
2743         server. This was also a design bug in that it violated the
2744         "A function should do one thing" heuristic. Patching this one
2745         would have resulted in a continuous spawning of other bugs over
2746         the next 3 years, so I killed it. Check around for stuff this
2747         broke and readd the calls to protocol_violation in the functions
2748         that need to send the message.
2749
2750 2001-01-29  Kevin L. Mitchell  <klmitch@mit.edu>
2751
2752         * ircd/channel.c (mode_parse_ban): stopper a tiny leak--if a ban
2753         already existed, then the logic would (attempt to) skip it, but
2754         would not free the ban string; now the ban string is free'd and
2755         the ban count is decremented, releasing the ban for use
2756
2757         * ircd/s_user.c: make send_umode_out() take a prop argument
2758         instead of testing for the PRIV_PROPAGATE privilege itself; fix
2759         set_umode() to use this new argument, calculating it before
2760         calculating the new privileges for a -o'd user
2761
2762         * ircd/m_oper.c (m_oper): pass the new prop argument to
2763         send_umode_out()
2764
2765         * ircd/channel.c (mode_parse_ban): turn off MODE_ADD bit in bans
2766         that we're not actually going to add because they already exist;
2767         test that particular bit before adding to the linked list
2768
2769         * include/s_user.h: add a prop argument to send_umode_out() to
2770         indicate whether or not to propagate the user mode
2771
2772 2001-01-24  Kevin L. Mitchell  <klmitch@mit.edu>
2773
2774         * ircd/msgq.c: ircd_vsnprintf() returns the number of bytes that
2775         it would have written; upper-bound the number to prevent overflows
2776         by proxy; also, tune buffer size given to ircd_vsnprintf() to take
2777         into account the fact that ircd_vsnprintf() already takes the
2778         terminal \0 into account
2779
2780 2001-01-22  Kevin L. Mitchell  <klmitch@mit.edu>
2781
2782         * ircd/msgq.c: add an incredibly ugly hack to attempt to track
2783         down an apparent buffer overflow; remove msgq_map(), since it's no
2784         longer used anywhere; slight tweaks to prevent off-by-one errors,
2785         but these can't explain the problems we've seen
2786
2787         * include/msgq.h: remove msgq_map(), since it's no longer used
2788         anywhere
2789
2790 2001-01-18  Kevin L. Mitchell  <klmitch@mit.edu>
2791
2792         * ircd/s_user.c (set_nick_name): call client_set_privs() after
2793         parsing user modes
2794
2795 2001-01-17  Kevin L. Mitchell  <klmitch@mit.edu>
2796
2797         * ircd/s_bsd.c (read_message): fix a typo in the select version of
2798         read_message()
2799
2800         * ircd/whowas.c (whowas_free): MyFree() is a macro that expects
2801         its argument to be an lvalue, which means we can't use
2802         whowas_clean()'s handy-dandy "return ww" feature
2803
2804         * ircd/ircd_features.c: default LOCOP_KILL to TRUE--oops...
2805
2806 2001-01-16  Kevin L. Mitchell  <klmitch@mit.edu>
2807
2808         * ircd/ircd_events.c (timer_run): it's possible that the timer got
2809         deleted during the callback processing, so don't go to the bother
2810         of requeuing it if the destroy flag is set
2811
2812         * ircd/engine_select.c: define FD_SETSIZE to be IRCD_FD_SETSIZE
2813         out of config.h if this is a *BSD; include errno.h (oops);
2814         decrement error count after an hour using a timer; use FD_SETSIZE
2815         constant instead of IRCD_FD_SETSIZE constant; fill in event
2816         processing code
2817
2818         * ircd/engine_poll.c: include errno.h (oops); decrement error
2819         count after an hour using a timer; fill in event processing code
2820
2821         * ircd/engine_kqueue.c: include errno.h (oops); decrement error
2822         count after an hour using a timer; assert events filter is either
2823         EVFILT_READ or EVFILT_WRITE; fill in event processing code
2824
2825         * ircd/engine_devpoll.c: include errno.h (oops); decrement error
2826         count after an hour using a timer; fill in event processing code
2827
2828 2001-01-15  Kevin L. Mitchell  <klmitch@mit.edu>
2829
2830         * ircd/client.c: fixed feattab; basically, when I changed features
2831         to use small integers specifying bit positions, instead of the
2832         bits themselves, I forgot to update feattab to not | these
2833         privileges together; also fixed a bug in the antiprivs masking
2834         loop in client_set_privs()--last index wouldn't get parsed
2835
2836 2001-01-11  Kevin L. Mitchell  <klmitch@mit.edu>
2837
2838         * ircd/ircd_events.c: call event_generate() with new data
2839         argument; make it set that field in struct Event; make
2840         socket_add() return the value of the eng_add callback
2841
2842         * ircd/engine_select.c: make engine_add() return a
2843         successful/unsuccessful status; add bounds-checking outside of an
2844         assert; use accessor macros; use log_write(), not the deprecated
2845         ircd_log(); add an assert to engine_loop() to double-check for
2846         data structure corruption
2847
2848         * ircd/engine_poll.c: make engine_add() return a
2849         successful/unsuccessful status; add bounds-checking outside of an
2850         assert; use accessor macros; use log_write(), not the deprecated
2851         ircd_log(); add an assert to engine_loop() to double-check for
2852         data structure corruption
2853
2854         * ircd/engine_kqueue.c: implementation of an engine for kqueue()
2855
2856         * ircd/engine_devpoll.c: implementation of an engine for /dev/poll
2857
2858         * include/ircd_events.h: define some accessor macros; add ev_data
2859         to struct Event for certain important data--errno values, for
2860         instance; make EngineAdd callback tell us if it was successful or
2861         not; add extra argument to event_generate(); make socket_add()
2862         return the status from EngineAdd
2863
2864 2001-01-10  Kevin L. Mitchell  <klmitch@mit.edu>
2865
2866         * ircd/ircd_events.c: pass initializer information about how many
2867         total _filedescriptors_ may be opened at once
2868
2869         * ircd/ircd.c: use exported "running" instead of unexported
2870         thisServer.running
2871
2872         * ircd/engine_select.c: implementation of an event engine based on
2873         select()
2874
2875         * ircd/engine_poll.c: implementation of an event engine based on
2876         poll()
2877
2878         * include/ircd_events.h: pass the engine initializer an integer
2879         specifing how many _filedescriptors_ may be opened at once
2880
2881         * include/ircd.h: running has to be exported for the engine_*
2882         event loops
2883
2884 2001-01-09  Kevin L. Mitchell  <klmitch@mit.edu>
2885
2886         * ircd/ircd_events.c: include some needed headers; add some
2887         comments; make evEngines[] const; bundle sig_sock and sig_fd into
2888         a struct named sigInfo; rework struct evInfo to have a queue of
2889         _generators_, and only when threaded; added a gen_init() function
2890         to centralize generator initialization; fix various compile-time
2891         errors; rework event_add() for new queueing scheme and checked for
2892         compile-time errors; add casts where needed; spell evEngines[]
2893         correctly; make engine_name() return const char*
2894
2895         * include/ircd_events.h: type EventCallBack depends on struct
2896         Event, so pre-declare it; put _event_ queue into generators, and
2897         only when threaded; give engine data a union to store both ints
2898         and pointers; make engine name a const; fix gen_ref_dec() macro;
2899         make engine_name() return a const char*
2900
2901         * ircd/ircd_events.c: gen_dequeue() is now exported, so move it
2902         down with the non-static functions; modify event_execute() to use
2903         the new gen_ref_dec() to simplify code; make sure event_generate()
2904         does not generate new events for generators marked for destruction
2905
2906         * include/ircd_events.h: the engines, at least, may need to modify
2907         reference counts to keep generators from going away while
2908         something still points at them, so add reference counter
2909         manipulators and export gen_dequeue() for them
2910
2911         * ircd/ircd_events.c: set up the list of engines to try; set up
2912         the signal struct Socket; rename netInfo to evInfo; move static
2913         functions near the beginning of the file; do away with
2914         signal_signal() (since we no longer keep a signal count ourselves)
2915         and call event_generate() directly from signal_callback--also
2916         renamed some functions; allow signal_callback() to read up to
2917         SIGS_PER_SOCK at once from the signal pipe; add event_init() to
2918         initialize the entire event system; add event_loop() to call the
2919         engine's event loop; initialize new struct GenHeader member,
2920         gh_engdata; remove timer_next(); add socket_add() function to add
2921         a socket; add socket_del() to mark a socket for deletion; add
2922         socket_state() to transition a socket between states; add
2923         socket_events() to set what events we're interested in on the
2924         socket; add engine_name() to retrieve event engine's name
2925
2926         * include/ircd_events.h: add engine data field to struct
2927         GenHeader; rename SOCK_ACTION_REMOVE to SOCK_ACTION_DEL; add a
2928         note about states vs s_events; remove signal count; fold union
2929         Generator back into struct Event; remove count members from struct
2930         Generators; redefine engine callbacks to not take a struct
2931         Engine*; add explanatory comments to callback definitions; add
2932         some engine callbacks to handle operations; remove struct Engine
2933         flag member--can detect single flag from eng_signal member; add
2934         event_init(), event_loop(), engine_name(), and the socket_*()
2935         functions; make timer_next() a macro to avoid a function call
2936
2937 2001-01-08  Kevin L. Mitchell  <klmitch@mit.edu>
2938
2939         * include/ircd_events.h: rename to ircd_events.h, since it handles
2940         events, not just networking stuff; add signal support; more
2941         structural rearrangement
2942
2943         * ircd/ircd_events.c: rename to ircd_events.c, since it handles
2944         events, not just networking stuff; add signal support; more
2945         structural rearrangement
2946
2947 2001-01-07  Kevin L. Mitchell  <klmitch@mit.edu>
2948
2949         * ircd/ircd_network.c: implement timer API; add reference counts
2950         appropriately
2951
2952         * include/ircd_network.h: firm up some pieces of the interface;
2953         split out members everything has into a separate structure; add
2954         reference counts; add timer API
2955
2956 2001-01-06  Kevin L. Mitchell  <klmitch@mit.edu>
2957
2958         * ircd/ircd_network.c: static data and event manipulation
2959         functions for new event processing system
2960
2961         * include/ircd_network.h: data structures for new event processing
2962         system
2963
2964 2001-01-03  Kevin L. Mitchell  <klmitch@mit.edu>
2965
2966         * ircd/whowas.c: Completely re-did the old allocation scheme by
2967         turning it into a linked list, permitting the
2968         NICKNAMEHISTORYLENGTH feature to be changed on the fly
2969
2970         * ircd/s_debug.c (count_memory): use FEAT_NICKNAMEHISTORYLENGTH
2971         feature instead of old #define
2972
2973         * ircd/ircd_features.c: add NICKNAMEHISTORYLENGTH feature as an
2974         integer feature with a notify callback (whowas_realloc)
2975
2976         * ircd/client.c (client_set_privs): second memset was supposed to
2977         be over antiprivs, not privs; thanks, Chris Behrens
2978         <cbehrens@xo.com> for pointing that out...
2979
2980         * include/whowas.h: new elements for an extra linked list in
2981         struct Whowas; a notify function for feature value changes
2982
2983         * include/ircd_features.h: new feature--FEAT_NICKNAMEHISTORYLENGTH
2984
2985         * config/config-sh.in: NICKNAMEHISTORYLENGTH is now a feature
2986
2987 2001-01-02  Kevin L. Mitchell  <klmitch@mit.edu>
2988
2989         * config/config-sh.in: get rid of DEFAULT_LIST_PARAMETER
2990         compile-time option--now in features subsystem
2991
2992         * ircd/motd.c (motd_init): rework motd_init() to be called as the
2993         notify function for MPATH and RPATH features (should probably
2994         split it up a bit, though...)
2995
2996         * ircd/m_privs.c (mo_privs): if called with no parameters, return
2997         privs of the caller, rather than an error
2998
2999         * ircd/m_list.c: pull usage message into its own function; pull
3000         list parameter processing into its own function that does not
3001         modify the contents of the parameter; add list_set_default() to
3002         set the default list parameter (uses the notify hook); rework
3003         m_list() to make use of these functions; removed dead code
3004
3005         * ircd/ircd_log.c (log_feature_mark): make sure to return 0, since
3006         we have no notify handler
3007
3008         * ircd/ircd_features.c: add notify callback for notification of
3009         value changes; give mark callback an int return value to indicate
3010         whether or not to call the notify callback; fix up feature macros
3011         for new notify callback; add DEFAULT_LIST_PARAM feature; rewrite
3012         string handling in feature_set() to deal with def_str being a null
3013         pointer; wrote feature_init() to set up all defaults appropriately
3014
3015         * ircd/ircd.c (main): call feature_init() instead of
3016         feature_mark(), to avoid calling notify functions while setting up
3017         defaults
3018
3019         * ircd/client.c: updated to deal with new privileges structure
3020
3021         * ircd/class.c: updated so init_class() can be called should one
3022         of PINGFREQUENCY, CONNECTFREQUENCY, MAXIMUM_LINKS, or
3023         DEFAULTMAXSENDQLENGTH be changed
3024
3025         * include/ircd_log.h: log_feature_mark() updated to fit with new
3026         API changes
3027
3028         * include/ircd_features.h: added DEFAULT_LIST_PARAM feature and
3029         feature_init() function (found necessary since adding the notify
3030         stuff and notifying motd.c during start-up...before we defined
3031         RPATH!)
3032
3033         * include/client.h: move privs around to enable addition of more
3034         bits if necessary; based on the FD_* macros
3035
3036         * include/channel.h: declare list_set_default (actually located in
3037         m_list.c *blanche*)
3038
3039         * ircd/s_user.c: retrieve MAXSILES and MAXSILELENGTH (now
3040         AVBANLEN*MAXSILES) from features subsystem
3041
3042         * ircd/s_debug.c (debug_serveropts): CMDLINE_CONFIG doesn't go to
3043         anything anymore
3044
3045         * ircd/s_bsd.c: retrieve HANGONGOODLINK and HANGONRETRYDELAY from
3046         the features subsystem
3047
3048         * ircd/s_auth.c (start_auth): NODNS migrated to the features
3049         subsystem
3050
3051         * ircd/random.c: created random_seed_set() function to set seed
3052         value, along with some stuff to make ircrandom() a little more
3053         random--state preserving, xor of time instead of direct usage,
3054         etc.; it's still a pseudo-random number generator, though, and
3055         hopefully I haven't broken the randomness
3056
3057         * ircd/m_version.c: FEATUREVALUES makes use of feature_int() calls
3058
3059         * ircd/m_join.c: use features interface to retrieve
3060         MAXCHANNELSPERUSER
3061
3062         * ircd/ircd_features.c: add NODISP flag for super-secret features;
3063         add a whole bunch of new features migrated over from make config
3064
3065         * ircd/ircd.c: use features interface to retrieve PINGFREQUENCY,
3066         CONNECTTIMEOUT, and TIMESEC
3067
3068         * ircd/client.c (client_get_ping): use features interface to
3069         retrieve PINGFREQUENCY
3070
3071         * ircd/class.c: use features interface to retrieve PINGFREQUENCY,
3072         CONNECTFREQUENCY, MAXIMUM_LINKS, and DEFAULTMAXSENDQLENGTH
3073
3074         * ircd/chkconf.c (DEFAULTMAXSENDQLENGTH): since it's now in the
3075         features subsystem, we have to add something explicit
3076
3077         * ircd/channel.c: use features interface to retrieve
3078         KILLCHASETIMELIMIT, MAXBANLENGTH, MAXBANS, and MAXCHANNELSPERUSER;
3079         note that MAXBANLENGTH is now calculated dynamically from MAXBANS
3080         and AVBANLEN
3081
3082         * ircd/Makefile.in: run make depend
3083
3084         * include/supported.h (FEATURESVALUES): update to reference
3085         feature settings
3086
3087         * include/random.h: add prototype for random_seed_set
3088
3089         * include/ircd_features.h: add several more features
3090
3091         * include/channel.h: move MAXBANS and MAXBANLENGTH into feature
3092         subsystem
3093
3094         * config/config-sh.in: feature-ized some more stuff
3095
3096         * include/motd.h: some new elements in motd.h for motd.c changes
3097
3098         * ircd/motd.c: motd_cache() now searches a list of already cached
3099         MOTD files; saves us from having duplicate caches in memory if
3100         there are two identical T-lines for two different sites...
3101
3102 2001-01-02  Perry Lorier <isomer@coders.net>
3103         * ircd/motd.c: don't core if the motd isn't found.  Bug found by
3104         Amarande.
3105
3106 2001-01-02  Perry Lorier <isomer@coders.net>
3107         * ircd/s_err.c: Added third param to 004 - the channel modes that tage params.  Used by hybrid/epic.
3108         * ircd/s_channels.c: Added fix for msg'ing a -n+m channel - thanks
3109                 to guppy for noticing, and hektik for providing the fix.
3110         * misc others: Minor cleanups, added more protocol_violations, ripped
3111                 out more P09 stuffs, bit more protocol neg stuff.
3112
3113 2000-12-19  Kevin L. Mitchell  <klmitch@mit.edu>
3114
3115         * ircd/m_ison.c (m_ison): Dianora says that ISON has to end with a
3116         space (*sigh* stupid clients...)
3117
3118         * ircd/s_user.c: make WALLOPS_OPER_ONLY a feature managed through
3119         ircd_features.[ch]
3120
3121         * ircd/s_err.c: get rid of GODMODE conditionals
3122
3123         * ircd/s_debug.c (debug_serveropts): switch to using appropriate
3124         calls into the features subsystem for various serveropts
3125         characters
3126
3127         * ircd/s_conf.c (find_conf_entry): get rid of USEONE conditional
3128
3129         * ircd/s_bsd.c: remove GODMODE conditional; use features subsystem
3130         to get value of VIRTUAL_HOST and CLIENT_FLOOD; remove
3131         NOFLOWCONTROL conditional
3132
3133         * ircd/s_auth.c: use features subsystem to determine value of
3134         KILL_IPMISMATCH
3135
3136         * ircd/parse.c: get rid of NOOPER and GODMODE conditionals; use
3137         features subsystem to determine the setting of IDLE_FROM_MSG
3138
3139         * ircd/numnicks.c: get rid of EXTENDED_NUMERICS conditionals
3140
3141         * ircd/motd.c: get value of NODEFAULTMOTD from features subsystem;
3142         use features subsystem to get motd file names
3143
3144         * ircd/m_settime.c: get value of RELIABLE_CLOCK from features
3145         subsystem
3146
3147         * ircd/m_server.c: get rid of CRYPT_LINK_PASSWORD, since it does
3148         us no good; use features subsystem to figure out if we need to do
3149         HUB-type stuff; make TESTNET debugging sendto_opmask_butone's use
3150         the Debug(()) macro instead; get value of RELIABLE_CLOCK from
3151         features subsystem
3152
3153         * ircd/m_privmsg.c: get IDLE_FROM_MSG from the features subsystem
3154
3155         * ircd/m_oper.c: get CRYPT_OPER_PASSWORD from the features
3156         subsystem
3157
3158         * ircd/m_connect.c: get SERVER_PORT from the features subsystem
3159
3160         * ircd/ircd_log.c (log_set_file): fix a bug that kept log files
3161         from getting marked if they were already set to something...
3162
3163         * ircd/ircd_features.c: add a flag to indicates read-only access;
3164         add several new features that used to be compile-time selected
3165
3166         * ircd/ircd.c: grab pidfile out of feature subsystem; don't check
3167         access to motd files (what the heck?); make sure to initialize the
3168         feature subsystem before trying to write the config file
3169
3170         * ircd/dbuf.c: use feature_int() to retrieve BUFFERPOOL settings;
3171         use feature_bool() to figure out if we're using the FERGUSON
3172         flusher
3173
3174         * ircd/Makefile.in: MPATH and RPATH are now done differently, so
3175         remove the clause that creates empty files of that name; also ran
3176         make depend
3177
3178         * include/sys.h: CLIENT_FLOOD is now a feature; unfortunately,
3179         there is no easy way to bounds-check it at present
3180
3181         * include/querycmds.h: make sure ircd_features.h is included; use
3182         feature_str(FEAT_DOMAINNAME) in calls to match()
3183
3184         * include/ircd_features.h: many new features that used to be
3185         compile-time selected
3186
3187         * config/config-sh.in: add * to DOMAINNAME; try also using first
3188         argument to search in /etc/resolv.conf; removed many compile-time
3189         options that now can be configured through the features system
3190
3191 2000-12-18  Kevin L. Mitchell  <klmitch@mit.edu>
3192
3193         * doc/api/log.txt: how to use the logging API
3194
3195         * doc/api/features.txt: how to use the features API
3196
3197         * doc/api/api.txt: how to write API documentation
3198
3199         * include/ircd_features.h: rearranged a couple of features for
3200         neatness purposes
3201
3202         * ircd/ircd_features.c: cleaned up the macros some; rearranged
3203         some code to all go into the switch; rearranged a couple of
3204         features for neatness purposes
3205
3206 2000-12-16  Greg Sikorski <gte@atomicrevs.demon.co.uk>
3207         * ircd/os_bsd.c: Added os_set_tos for BSD users.
3208
3209 2000-12-16  Kevin L. Mitchell  <klmitch@mit.edu>
3210
3211         * ircd/ircd_features.c: Isomer almost got it right; you need to
3212         use F_I(), since it's an integer value, not a boolean value.  The
3213         asserts in feature_int would catch you out...  Also made the F_*
3214         macros take flags
3215
3216         * ircd/s_err.c: define RPL_PRIVS reply
3217
3218         * ircd/parse.c: put new PRIVS command into command table
3219
3220         * ircd/m_privs.c (mo_privs): message handler to report operator
3221         privileges
3222
3223         * ircd/ircd_features.c: declare new features OPER_SET and
3224         LOCOP_SET; redo boolean testing routine to accept TRUE, YES, and
3225         ON for boolean TRUE, and FALSE, NO, and OFF for boolean FALSE
3226
3227         * ircd/client.c: simplify client_set_privs() with a table that
3228         defines what features to test for; add new client_report_privs()
3229
3230         * ircd/Makefile.in: compile new m_privs.c; run make depend
3231
3232         * include/numeric.h (RPL_PRIVS): new reply numeric for displaying
3233         an operator's privileges
3234
3235         * include/msg.h: define new command: PRIVS
3236
3237         * include/ircd_features.h: create new features OPER_SET and
3238         LOCOP_SET for controlling access to /set
3239
3240         * include/handlers.h (mo_privs): declare message handler for
3241         reporting oper privileges
3242
3243         * include/client.h (client_report_privs): declare function to
3244         report what privileges an oper has
3245
3246         * ircd/m_whois.c (do_whois): fix a bug that caused /whois to
3247         report that a user is an oper if the oper doing the /whois had
3248         PRIV_SEE_OPERS
3249
3250 2000-12-17  Isomer <Isomer@coders.net>
3251         * ircd/listener.c: added support for TOS twiddling as a 'feature'.
3252
3253 2000-12-17  Isomer <Isomer@coders.net>
3254         * ircd/os_linux.c: add TOS stuffs
3255
3256         * ircd/listener.c: add TOS stuffs
3257
3258 2000-12-16  Kevin L. Mitchell  <klmitch@mit.edu>
3259
3260         * ircd/whocmds.c (do_who): use HasPriv to determine whether or not
3261         to indicate a user is an oper
3262
3263         * ircd/s_user.c: clear privileges setting when deopping; don't
3264         propagate +o unless user has PRIV_PROPAGATE privilege
3265
3266         * ircd/s_debug.c (debug_serveropts): created debug_serveropts()
3267         function and replaced how the server option string is generated
3268
3269         * ircd/parse.c: remove conditional on CONFIG_OPERCMDS
3270
3271         * ircd/m_whois.c (do_whois): use HasPriv to determine whether or
3272         not to indicate the user is an operator
3273
3274         * ircd/m_who.c: use HasPriv to determine whether or not a user
3275         should be displayed in the list of opers
3276
3277         * ircd/m_version.c: call debug_serveropts() to get server option
3278         string
3279
3280         * ircd/m_userip.c (userip_formatter): use HasPriv to determine
3281         whether or not to show oper status
3282
3283         * ircd/m_userhost.c (userhost_formatter): use HasPriv to determine
3284         whether or not to show oper status
3285
3286         * ircd/m_restart.c (mo_restart): replace ugly #ifdef conditional
3287         checks with HasPriv check; remove dead code
3288
3289         * ircd/m_rehash.c (mo_rehash): replace ugly #ifdef conditional
3290         checks with HasPriv check
3291
3292         * ircd/m_opmode.c (mo_opmode): use HasPriv to check permissions;
3293         use feature_bool to check if disabled
3294
3295         * ircd/m_oper.c (m_oper): set oper priviliges
3296
3297         * ircd/m_mode.c (m_mode): replace #ifdef conditional with HasPriv
3298         check
3299
3300         * ircd/m_kill.c (mo_kill): use HasPriv checks to determine if we
3301         can kill
3302
3303         * ircd/m_kick.c (m_kick): replace #ifdef conditional with HasPriv
3304         check
3305
3306         * ircd/m_jupe.c (mo_jupe): rework permissions checking structure;
3307         use feature_bool to check if disabled
3308
3309         * ircd/m_join.c (m_join): remove BADCHAN conditional; replace
3310         #ifdef conditional with a HasPriv check
3311
3312         * ircd/m_gline.c (mo_gline): rework permissions checking
3313         structure; use feature_bool to check if any part is disabled
3314
3315         * ircd/m_die.c: replace ugly #ifdef conditionals with HasPriv
3316         check; remove dead code
3317
3318         * ircd/m_clearmode.c: use feature_bool() to detect if we're
3319         disabled; use HasPriv to figure out what we're permitted to do;
3320         only allow clearmode on moded channels
3321
3322         * ircd/ircd_features.c: define various features; use HasPriv to
3323         verify permissions to set/reset
3324
3325         * ircd/gline.c (gline_add): use HasPriv instead of #ifdef
3326         conditionals
3327
3328         * ircd/client.c (client_set_privs): function to set an oper's
3329         privileges
3330
3331         * ircd/channel.c: use HasPriv calls instead of #ifdef conditionals
3332
3333         * include/whocmds.h: deconditionalize several macros and
3334         substitute appropriate calls to HasPriv()
3335
3336         * include/s_debug.h: get rid of global serveropts[]; define new
3337         function debug_serveropts() to build that string on the fly
3338
3339         * include/ircd_features.h: define some features
3340
3341         * include/client.h: add privs member to struct Connection; define
3342         various priviledges
3343
3344         * include/channel.h: no longer using IsOperOnLocalChannel; remove
3345         conditional of MAGIC_OPER_OVERRIDE on OPER_WALK_THROUGH_LMODES
3346
3347         * doc/Configure.help: remove help information for deprecated
3348         options
3349
3350         * config/config-sh.in: remove certain deprecated options having to
3351         do with what opers can and cannot do--first stage in moving
3352         compile-time constants into the .conf
3353
3354 2000-12-16  Isomer <Isomer@coders.net>
3355         * ircd/parse.c: detect if the prefix is missing and try and recover
3356         instead of coring.
3357
3358 2000-12-15  Kevin L. Mitchell  <klmitch@mit.edu>
3359
3360         * ircd/ircd_log.c: found and fixed some bugs in the debug logging
3361         code that would sometimes result in the log file not being
3362         reopened--which meant that a user could connect and get the
3363         logging output--oops
3364
3365         * ircd/Makefile.in: run make depend...
3366
3367         * ircd/s_stats.c: get rid of report_feature_list()
3368
3369         * ircd/s_err.c: add the 'bad value' error message, shift error
3370         messages over somewhat
3371
3372         * ircd/s_debug.c (debug_init): call log_debug_init with the
3373         use_tty flag
3374
3375         * ircd/s_conf.c (read_configuration_file): unmark features before
3376         reading the config file, then reset unmarked features after
3377         reading the config file
3378
3379         * ircd/m_stats.c: use feature_report() instead of
3380         report_feature_list()
3381
3382         * ircd/ircd_log.c: fix log_debug_file (bogus assertion); add
3383         special 'mark' flags and use them; add the stuff needed by the
3384         features API
3385
3386         * ircd/ircd_features.c: rework the features API and add gobs of
3387         comments to try to explain what some of these complex functions
3388         are actually doing
3389
3390         * include/s_stats.h: get rid of report_feature_list(); use
3391         feature_report() instead
3392
3393         * include/numeric.h: added a new error message and shifted old
3394         values over some--this is, after all, an alpha
3395
3396         * include/ircd_log.h: log_debug_init now takes an integer to tell
3397         it if it should be using the tty; added a couple of functions
3398         required by the features API
3399
3400         * include/ircd_features.h: add an enum and some more functions to
3401         flesh out the feature API--it should now be possible to put all
3402         those compile-time constants in the config file!
3403
3404         * ircd/send.c: got the direction of the assert incorrect...
3405
3406         * ircd/send.c: implement the efficiency of flush_connections by
3407         creating a linked list of struct Connection's with queued data;
3408         also get rid of flush_sendq_except and make sure to yank
3409         connections out of the list when their sendQs become empty (notice
3410         the assertion in flush_connections!)
3411
3412         * ircd/s_bsd.c (close_connection): must yank the Connection out of
3413         the sendq list
3414
3415         * ircd/list.c (dealloc_connection): must yank the Connection out
3416         of the sendq list
3417
3418         * ircd/dbuf.c (dbuf_put): call flush_connections instead of the
3419         deprecated flush_sendq_except
3420
3421         * ircd/client.c: define a couple new helper functions for sendq
3422         threading--this will make the flush_connections function in send.c
3423         considerably more efficient by creating a linked list of
3424         Connections that have queued data to send
3425
3426         * include/send.h: remove flush_sendq_except, as it's not used
3427         anymore
3428
3429         * include/client.h: declare a couple new helper functions for the
3430         sendq threading system
3431
3432 2000-12-14  Kevin L. Mitchell  <klmitch@mit.edu>
3433
3434         * ircd/m_ison.c (m_ison): Apply Diane Bruce's patch to make ISON
3435         parse all arguments
3436
3437         * ircd/s_debug.c (count_memory): modify to report for clients and
3438         connections, not local clients and remote clients
3439
3440         * ircd/list.c: fiddle with the client-fiddling functions to take
3441         into account the divorce of struct Connection from struct Client
3442
3443         * ircd/ircd.c: define a struct Connection for me, initialize it,
3444         and link it into the right place (ewww, globals!)
3445
3446         * include/client.h: remove CLIENT_{LOCAL,REMOTE}_SIZE; split
3447         struct Client into struct Client and struct Connection; redefine
3448         local-portion accessor macros to go through struct Client to the
3449         struct Connection; define struct Connection accessor macros
3450
3451 2000-12-13  Kevin L. Mitchell  <klmitch@mit.edu>
3452
3453         * ircd/whowas.c: missed a couple of accesses to a struct Client
3454
3455         * ircd/uping.c: missed a couple of accesses to a struct Client
3456
3457         * ircd/send.c: missed a couple of accesses to a struct Client
3458
3459         * ircd/s_user.c: missed a couple of accesses to a struct Client
3460
3461         * ircd/s_misc.c: missed a couple of accesses to a struct Client
3462
3463         * ircd/s_conf.c: missed a couple of accesses to a struct Client
3464
3465         * ircd/s_bsd.c: missed a couple of accesses to a struct Client
3466
3467         * ircd/s_auth.c: missed a couple of accesses to a struct Client
3468
3469         * ircd/res.c: missed a couple of accesses to a struct Client
3470
3471         * ircd/parse.c: missed a couple of accesses to a struct Client
3472
3473         * ircd/m_whois.c: use new accessor macros for struct Client
3474
3475         * ircd/m_who.c: use new accessor macros for struct Client
3476
3477         * ircd/m_wallchops.c: use new accessor macros for struct Client
3478
3479         * ircd/m_version.c: use new accessor macros for struct Client
3480
3481         * ircd/m_userip.c: use new accessor macros for struct Client
3482
3483         * ircd/m_userhost.c: use new accessor macros for struct Client
3484
3485         * ircd/m_user.c: use new accessor macros for struct Client
3486
3487         * ircd/m_uping.c: use new accessor macros for struct Client
3488
3489         * ircd/m_trace.c: use new accessor macros for struct Client
3490
3491         * ircd/m_topic.c: use new accessor macros for struct Client
3492
3493         * ircd/m_time.c: use new accessor macros for struct Client
3494
3495         * ircd/m_stats.c: use new accessor macros for struct Client
3496
3497         * ircd/m_squit.c: use new accessor macros for struct Client
3498
3499         * ircd/m_silence.c: use new accessor macros for struct Client
3500
3501         * ircd/m_server.c: use new accessor macros for struct Client;
3502         remove dead code
3503
3504         * ircd/m_rpong.c: use new accessor macros for struct Client
3505
3506         * ircd/m_rping.c: use new accessor macros for struct Client
3507
3508         * ircd/m_quit.c: use new accessor macros for struct Client
3509
3510         * ircd/m_privmsg.c: use new accessor macros for struct Client
3511
3512         * ircd/m_pong.c: use new accessor macros for struct Client; remove
3513         dead code
3514
3515         * ircd/m_ping.c: use new accessor macros for struct Client
3516
3517         * ircd/m_pass.c: use new accessor macros for struct Client
3518
3519         * ircd/m_part.c: use new accessor macros for struct Client
3520
3521         * ircd/m_oper.c: use new accessor macros for struct Client
3522
3523         * ircd/m_notice.c: use new accessor macros for struct Client
3524
3525         * ircd/m_nick.c: use new accessor macros for struct Client
3526
3527         * ircd/m_names.c: use new accessor macros for struct Client
3528
3529         * ircd/m_mode.c: use new accessor macros for struct Client
3530
3531         * ircd/m_map.c: use new accessor macros for struct Client
3532
3533         * ircd/m_list.c: use new accessor macros for struct Client
3534
3535         * ircd/m_links.c: use new accessor macros for struct Client;
3536         remove some dead code
3537
3538         * ircd/m_kill.c: use new accessor macros for struct Client; remove
3539         some dead code
3540
3541         * ircd/m_kick.c: use new accessor macros for struct Client
3542
3543         * ircd/m_join.c: use new accessor macros for struct Client; remove
3544         some dead code
3545
3546         * ircd/m_ison.c: use new accessor macros for struct Client
3547
3548         * ircd/m_invite.c: use new accessor macros for struct Client
3549
3550         * ircd/m_info.c: use new accessor macros for struct Client
3551
3552         * ircd/m_gline.c: use new accessor macros for struct Client
3553
3554         * ircd/m_error.c: use new accessor macros for struct Client
3555
3556         * ircd/m_create.c: use new accessor macros for struct Client
3557
3558         * ircd/m_connect.c: use new accessor macros for struct Client;
3559         removed some dead code
3560
3561         * ircd/m_burst.c: use new accessor macros for struct Client
3562
3563         * ircd/m_away.c: use new accessor macros for struct Client
3564
3565         * ircd/m_admin.c: use new accessor macros for struct Client
3566
3567         * ircd/hash.c: missed a couple of accesses to a struct Client
3568
3569         * ircd/gline.c: missed a couple of accesses to a struct Client
3570
3571         * ircd/crule.c: missed a couple of accesses to a struct Client
3572
3573         * ircd/class.c: missed an access to a struct Client
3574
3575         * ircd/channel.c: missed a couple of accesses to a struct Client
3576
3577         * ircd/IPcheck.c: missed an access to a struct Client
3578
3579         * include/querycmds.h: fix a couple of stats macros to use
3580         structure accessor macros
3581
3582         * include/client.h: change structure member names to highlight any
3583         places in the code I've missed
3584
3585 2000-12-12  Kevin L. Mitchell  <klmitch@mit.edu>
3586
3587         * ircd/whowas.c: use new struct Client accessor macros
3588
3589         * ircd/whocmds.c: use new struct Client accessor macros
3590
3591         * ircd/send.c: use new struct Client accessor macros
3592
3593         * ircd/s_user.c: use new struct Client accessor macros; removed
3594         some dead code
3595
3596         * ircd/s_serv.c: use new struct Client accessor macros; removed
3597         some dead code
3598
3599         * ircd/s_numeric.c: use new struct Client accessor macros
3600
3601         * ircd/s_misc.c: use new struct Client accessor macros
3602
3603         * ircd/s_debug.c: use new struct Client accessor macros
3604
3605         * ircd/s_conf.c: use new struct Client accessor macros
3606
3607         * ircd/s_bsd.c: use new struct Client accessor macros
3608
3609         * ircd/s_auth.c: use new struct Client accessor macros
3610
3611         * ircd/parse.c: use new struct Client accessor macros
3612
3613         * ircd/packet.c: use new struct Client accessor macros
3614
3615         * ircd/numnicks.c: use new struct Client accessor macros
3616
3617         * ircd/motd.c: use new struct Client accessor macros
3618
3619         * ircd/listener.c: use new struct Client accessor macros
3620
3621         * ircd/list.c: use new struct Client accessor macros
3622
3623         * ircd/jupe.c: use new struct Client accessor macros
3624
3625         * ircd/ircd_snprintf.c: use new struct Client accessor macros
3626
3627         * ircd/ircd_reply.c: use new struct Client accessor macros
3628
3629         * ircd/ircd_relay.c: use new struct Client accessor macros
3630
3631         * ircd/ircd.c: use new struct Client accessor macros
3632
3633         * ircd/gline.c: catch some instances of me.<stuff> I missed
3634         previously
3635
3636         * ircd/client.c: use cli_ instead of con_
3637
3638         * ircd/class.c: use cli_ instead of con_
3639
3640         * ircd/channel.c: use cli_ instead of con_
3641
3642         * ircd/IPcheck.c: use cli_ instead of con_; catch some instances
3643         of me.<stuff> I missed previously
3644
3645         * include/client.h: use cli_ instead of con_...seemed like a good
3646         idea at the time *shrug*
3647
3648 2000-12-11  Kevin L. Mitchell  <klmitch@mit.edu>
3649
3650         * ircd/hash.c: use struct Client accessor macros
3651
3652         * ircd/gline.c: use struct Client accessor macros
3653
3654         * ircd/crule.c: use struct Client accessor macros
3655
3656         * ircd/client.c: use struct Client accessor macros; remove some
3657         dead code
3658
3659         * ircd/class.c: use struct Client accessor macros
3660
3661         * ircd/channel.c: use struct Client accessor macros; remove some
3662         dead code
3663
3664         * ircd/IPcheck.c: use struct Client accessor macros
3665
3666         * include/numnicks.h: use struct Client accessor macros
3667
3668         * include/client.h: first step to divorcing struct Client and
3669         struct Connection--define accessor macros and use them
3670
3671         * ircd/gline.c: When Uworld removed Uworld-set G-lines, only the
3672         uplink would remove them.  This is because the removal protocol
3673         message wasn't being sent to the uplinks.  This is fixed by fixing
3674         propagate_gline() to send the proper number of arguments depending
3675         on whether or not we're adding or deleting the Uworld gline, and
3676         by having gline_deactivate() make sure to turn off the active bit
3677         and call propagate_gline() if it's a Uworld gline
3678
3679 2000-12-10  Kevin L. Mitchell  <klmitch@mit.edu>
3680
3681         * ircd/os_generic.c: make sure IOV_MAX gets defined, just in case
3682
3683         * ircd/os_bsd.c: apparently BSD doesn't have IOV_MAX defined
3684         anywhere intelligent...
3685
3686 2000-12-09  Kevin L. Mitchell  <klmitch@mit.edu>
3687
3688         * ircd/send.c (send_queued): call deliver_it with appropriate
3689         arguments
3690
3691         * ircd/s_serv.c: reorder a couple of headers--cosmetic
3692
3693         * ircd/s_bsd.c (deliver_it): make deliver_it work with a struct
3694         MsgQ
3695
3696         * ircd/os_solaris.c (os_sendv_nonb): function for calling writev
3697         with appropriate iovec
3698
3699         * ircd/os_linux.c (os_sendv_nonb): function for calling writev
3700         with appropriate iovec
3701
3702         * ircd/os_generic.c (os_sendv_nonb): function for calling writev
3703         with appropriate iovec
3704
3705         * ircd/os_bsd.c (os_sendv_nonb): function for calling writev with
3706         appropriate iovec
3707
3708         * ircd/msgq.c (msgq_mapiov): add a len_p argument for totalling up
3709         exactly how much we're trying to write out to the fd
3710
3711         * include/s_bsd.h: make deliver_it take a struct MsgQ
3712
3713         * include/msgq.h: add a len_p argument to msgq_mapiov to help
3714         detect short writes that indicate possible socket blocking
3715
3716         * include/ircd_osdep.h: declare os_sendv_nonb()
3717
3718         * ircd/channel.c (modebuf_mode): don't add empty modes...
3719
3720 2000-12-08  Kevin L. Mitchell  <klmitch@mit.edu>
3721
3722         * include/send.h: add prio argument to send_buffer to select
3723         between normal and priority queues
3724
3725         * ircd/s_user.c (send_user_info): add prio argument to send_buffer
3726         call
3727
3728         * ircd/m_ison.c (m_ison): add prio argument to send_buffer call
3729
3730         * ircd/ircd_reply.c (send_reply): add prio argument to send_buffer
3731         call
3732
3733         * ircd/channel.c (send_channel_modes): add prio argument to
3734         send_buffer call
3735
3736         * ircd/send.c (send_buffer): add a prio argument to select the
3737         priority queue; update send.c functions to use it
3738
3739         * ircd/msgq.c (msgq_add): remove msgq_prio; fold msgq_link and
3740         msgq_add; add a prio argument to msgq_add to select the priority
3741         queue
3742
3743         * include/msgq.h: remove msgq_prio; add a prio argument to
3744         msgq_add
3745
3746         * ircd/send.c: remove sendbuf; remove GODMODE code; switch to
3747         using msgq functions instead of dbuf functions; remove old, dead
3748         sendto_* functions; redo send_buffer to take a struct MsgBuf;
3749         rework sendcmdto_* functions to make use of the new struct MsgBuf
3750
3751         * ircd/s_user.c: remove hunt_server; restructure send_user_info to
3752         make appropriate use of struct MsgBuf
3753
3754         * ircd/s_debug.c (count_memory): count memory used by the MsgQ
3755         system and report it
3756
3757         * ircd/s_conf.c (read_configuration_file): use
3758         sendto_opmask_butone instead of the now dead sendto_op_mask
3759
3760         * ircd/s_bsd.c: switch to using appropriate MsgQLength and other
3761         calls on sendQ
3762
3763         * ircd/parse.c (parse_server): get rid of a piece of GODMODE code
3764
3765         * ircd/msgq.c: add msgq_append and msgq_bufleft; fix a bug in
3766         msgq_clean
3767
3768         * ircd/m_version.c: fix spelling in comments marking dead code
3769
3770         * ircd/m_userip.c (userip_formatter): restructure to make use of
3771         struct MsgBuf
3772
3773         * ircd/m_userhost.c (userhost_formatter): restructure to make use
3774         of struct MsgBuf
3775
3776         * ircd/m_stats.c: use MsgQLength on a sendQ
3777
3778         * ircd/m_settime.c: use MsgQLength instead of DBufLength on a
3779         sendQ; mark a piece of dead code
3780
3781         * ircd/m_names.c: use send_reply instead of sendto_one
3782
3783         * ircd/m_mode.c: use new mode; remove old dead code
3784
3785         * ircd/m_ison.c (m_ison): restructure to make use of struct MsgBuf
3786
3787         * ircd/m_burst.c: use BUFSIZE instead of IRC_BUFSIZE; remove old
3788         dead code
3789
3790         * ircd/listener.c (accept_connection): use sendto_opmask_butone
3791         instead of sendto_op_mask
3792
3793         * ircd/list.c (free_client): use MsgQClear to clear sendQ
3794
3795         * ircd/ircd_reply.c: remove send_error_to_client; restructure
3796         send_reply to make use of struct MsgBuf
3797
3798         * ircd/dbuf.c (dbuf_put): remove argument to flush_sendq_except,
3799         since its no longer used (at least currently)
3800
3801         * ircd/channel.c: restructure send_channel_modes to make use of
3802         struct MsgBuf; remove set_mode, add_token_to_sendbuf, cancel_mode,
3803         and send_hack_notice; use BUFSIZE instead of IRC_BUFSIZE
3804
3805         * ircd/Makefile.in: add msgq.c to list of sources; run make depend
3806
3807         * ircd/IPcheck.c: use sendcmdto_one instead of sendto_one
3808
3809         * include/send.h: send_buffer now takes a struct MsgBuf * instead
3810         of a char *; flush_sendq_except now takes no arguments, as sendq
3811         flushing currently only happens in dbuf.h and sendQ is a struct
3812         MsgQ; remove prototypes for a lot of old sendto_* functions that
3813         aren't used anymore; remove sendbuf and IRC_BUFSIZE--the former is
3814         no longer needed, and the latter is identical to BUFSIZE in
3815         ircd_defs.h
3816
3817         * include/s_user.h: make InfoFormatter take a struct MsgBuf*
3818         instead of a char *; also make it return void, instead of char *
3819
3820         * include/msgq.h: add msgq_append and msgq_bufleft functions
3821
3822         * include/client.h: use a struct MsgQ instead of a struct DBuf for
3823         sendq
3824
3825         * doc/Configure.help: Remove help for compile-time options that
3826         have gone away
3827
3828         * config/config-sh.in: remove CONFIG_NEWMODE
3829
3830         * ircd/m_server.c (mr_server): don't send server IPs in any server
3831         notices
3832
3833         * ircd/msgq.c (msgq_vmake): add \r\n to messages
3834
3835 2000-12-07  Kevin L. Mitchell  <klmitch@mit.edu>
3836
3837         * include/msgq.h: declare the MsgQ API
3838
3839         * ircd/msgq.c: implementation of new MsgQ system
3840
3841 2000-12-06  Kevin L. Mitchell  <klmitch@mit.edu>
3842
3843         * ircd/ircd_features.c: #include was supposed to be for
3844           ircd_features.h, not features.h--missed when I had to do a
3845           rename because of namespace collision
3846
3847 2000-12-05  Greg Sikorski <gte@atomicrevs.demon.co.uk>
3848         * ircd/m_topic.c: Added missing braces that caused all remote
3849           topics to be ignored.
3850
3851 2000-12-04  Kevin L. Mitchell  <klmitch@mit.edu>
3852
3853         * ircd/m_create.c: I'm tired of the exit_client warning :)
3854         (ms_create): discovered that exit_client() was being called with
3855         too few arguments
3856
3857         * ircd/s_misc.c (exit_client): remove all dependance on
3858         FNAME_USERLOG, since that's now gone; log only to LS_USER
3859
3860         * ircd/s_debug.c: USE_SYSLOG no longer means anything
3861
3862         * ircd/m_oper.c (m_oper): no longer log to LS_OPERLOG--we already
3863         log to LS_OPER
3864
3865         * ircd/m_kill.c: no longer conditionalize on SYSLOG_KILL
3866
3867         * ircd/ircd_log.c: remove LS_OPERLOG, LS_USERLOG
3868
3869         * include/ircd_log.h: remove LS_OPERLOG, LS_USERLOG--they serve
3870         the same purpose as LS_USER and LS_OPER
3871
3872         * config/config-sh.in: remove no longer relevant log config
3873         variables
3874
3875         * ircd/uping.c (uping_init): use log_write instead of ircd_log
3876
3877         * ircd/s_misc.c (exit_client): use log_write instead of ircd_log
3878
3879         * ircd/s_conf.c: use log_write instead of ircd_log
3880
3881         * ircd/s_bsd.c (report_error): use log_write instead of ircd_log
3882
3883         * ircd/s_auth.c (timeout_auth_queries): use log_write instead of
3884         ircd_log
3885
3886         * ircd/res.c (send_res_msg): use log_write instead of ircd_log
3887
3888         * ircd/m_who.c: use log_write instead of write_log; no longer
3889         conditionalize on WPATH; mark dead ircd_log calls
3890
3891         * ircd/m_uping.c: mark dead ircd_log call
3892
3893         * ircd/m_server.c (mr_server): use log_write instead of ircd_log
3894
3895         * ircd/m_restart.c: use log_write instead of ircd_log; mark dead
3896         ircd_log calls
3897
3898         * ircd/m_rehash.c (mo_rehash): use log_write instead of ircd_log
3899
3900         * ircd/m_oper.c: use log_write instead of ircd_log; no longer
3901         conditionalize on FNAME_OPERLOG; mark dead ircd_log calls
3902
3903         * ircd/m_kill.c: mark dead ircd_log calls
3904
3905         * ircd/m_connect.c: use log_write instead of ircd_log; mark dead
3906         ircd_log
3907
3908         * ircd/m_clearmode.c: use log_write instead of write_log; no
3909         longer conditionalize on OPATH
3910
3911         * ircd/jupe.c: use log_write instead of write_log; no longer
3912         conditionalize on JPATH
3913
3914         * ircd/ircd_log.c: add USER subsystem; remove ircd_log() compat
3915         function; fix a couple of bugs
3916
3917         * ircd/ircd_alloc.c: fixed a comment
3918
3919         * ircd/ircd.c: use log_write instead of ircd_log; fold server
3920         notice generation in a couple of cases
3921
3922         * ircd/gline.c: use log_write instead of write_log; no longer
3923         conditionalize on GPATH
3924
3925         * ircd/channel.c (modebuf_flush_int): use log_write instead of
3926         write_log; no longer conditionalize on OPATH
3927
3928         * ircd/Makefile.in: run make depend, since dependencies have
3929         changed
3930
3931         * doc/example.conf: add system USER to documentation
3932
3933         * include/ircd_log.h: add system USER; remove old ircd_log()
3934         declarations
3935
3936 2000-12-04  Isomer <isomer@coders.net>
3937         * ircd/m_names.c: Add NAMES_EON to do_names to say add a
3938         'end_of_names' reply when done.
3939         * ircd/m_join.c: use NAMES_EON as mentioned above
3940
3941 2000-12-01  net  <simms@LUCIDA.QC.CA>
3942
3943         * ircd/motd.c: add a freelist for struct Motds
3944
3945 2000-11-30  Kevin L. Mitchell  <klmitch@mit.edu>
3946
3947         * ircd/s_stats.c (report_feature_list): report features--only
3948         local opers can see logging configuration, since it doesn't really
3949         mean anything to users
3950
3951         * ircd/s_err.c: add reply messages for new feature subsystem
3952
3953         * ircd/s_conf.c: add F lines to .conf
3954
3955         * ircd/parse.c: add the message descriptions for /set, /reset, and
3956         /get
3957
3958         * ircd/m_stats.c: add /stats f
3959
3960         * ircd/m_set.c (mo_set): implement /set
3961
3962         * ircd/m_reset.c (mo_reset): implement /reset
3963
3964         * ircd/m_rehash.c: /rehash m now flushes MOTD cache, and /rehash l
3965         reopens log files (for log file rotation)
3966
3967         * ircd/m_get.c (mo_get): implement /get
3968
3969         * ircd/ircd_log.c: use int instead of void return value; add
3970         log_report_features() and log_canon(); fix a function that
3971         disappears if DEBUGMODE not #define'd
3972
3973         * ircd/ircd_features.c: functions to manipulate feature settings
3974         either from the config file or with the new /set, /reset, and /get
3975         commands
3976
3977         * ircd/Makefile.in: add new .c files, run make depend
3978
3979         * include/s_stats.h: declare report_feature_list() (/stats f
3980         handler)
3981
3982         * include/numeric.h: add RPL_STATSFLINE, RPL_FEATURE,
3983         ERR_NOFEATURE, ERR_BADLOGTYPE, ERR_BADLOGSYS, and ERR_BADLOGVALUE
3984         reply numerics
3985
3986         * include/msg.h: add defines for SET, RESET, and GET
3987
3988         * include/ircd_log.h: add a function to canonicalize subsystem
3989         names; change some void return values to int
3990
3991         * include/ircd_features.h: new features subsystem handles all the
3992         manipulation of special features, like log files
3993
3994         * include/handlers.h: declare new mo_{s,res,g}et message handlers
3995         for fiddling with features run-time
3996
3997         * include/client.h (SNO_DEFAULT): don't set SNO_DEBUG by default;
3998         seemed like a good idea at the time...
3999
4000         * doc/example.conf: document new F lines
4001
4002 2000-11-29  Kevin L. Mitchell  <klmitch@mit.edu>
4003
4004         * ircd/s_debug.c: rewrite debug_init() and vdebug() in terms of
4005         new logging functions, which have special support for the debug
4006         log; added loop detection to vdebug(), so that I can
4007         sendto_opmask_butone() from log_vwrite() without incurring another
4008         call to vdebug()
4009
4010         * ircd/s_conf.c (rehash): call log_reopen() from rehash routine;
4011         this allows log file rotations
4012
4013         * ircd/m_kill.c: call log_write_kill() instead of ircd_log_kill()
4014
4015         * ircd/ircd_log.c: much more work fleshing out the interface;
4016         removed old interface; included backwards-compat ircd_log()
4017         function that logs to subsystem LS_OLDLOG
4018
4019         * ircd/ircd.c: switch to new log_init()/log_close()/log_reopen()
4020         functions
4021
4022         * include/ircd_log.h: include stdarg.h for va_list; move ordering
4023         warning to top of file; fill out LogSys enum; declare new
4024         log_debug_init(), log_vwrite(), log_write_kill(), and
4025         log_[sg]et_*() functions; add flags argument to log_write();
4026         defined flags to inhibit various logging actions
4027
4028         * include/client.h: added support for new SNO_DEBUG, enabled only
4029         if DEBUGMODE is defined
4030
4031 2000-11-28  Kevin L. Mitchell  <klmitch@mit.edu>
4032
4033         * ircd/ircd_log.c: make sure the various LOG_* constants are
4034         defined (probably not needed, since #include <syslog.h> isn't
4035         conditional); various static data needed for the new logging
4036         functions; definitions of new logging functions
4037
4038         * include/ircd_log.h: new LogSys enum, declarations for part of
4039         new logging API
4040
4041         * ircd/motd.c: we were setting type to MOTD_CLASS unconditionally,
4042         which was of course stupid; switched to using switch/case in
4043         initialization in motd_create(); zero the MotdList.other pointer
4044         from motd_clear()
4045
4046         * ircd/ircd.c (main): motd_init() has to come before init_conf(),
4047         or we overwrite init_conf()'s hard work with respect to T-lines
4048
4049 2000-11-27  Kevin L. Mitchell  <klmitch@mit.edu>
4050
4051         * ircd/s_stats.c: comment out report_motd_list and include a
4052         reference to motd_report()
4053
4054         * ircd/s_conf.c: rip out the old MOTD manipulation functions; call
4055         motd_add() from the conf parser; call motd_clear() from the rehash
4056         routine; remove the no longer needed memory clearing and reloading
4057         stuff from the rehash service routine
4058
4059         * ircd/motd.c: loads new API, including static internal functions
4060         to do allocation/deallocation, etc.
4061
4062         * ircd/m_stats.c: use new motd_report() instead of
4063         report_motd_list()
4064
4065         * ircd/m_motd.c: use new syntax for motd_send()
4066
4067         * ircd/ircd.c: use new motd_init() function
4068
4069         * ircd/Makefile.in (SRC): forgot to add motd.c to SRC in
4070         Makefile.(in); also ran make depend
4071
4072         * include/motd.h: don't need config.h, but now do need time.h;
4073         define new structures and constants; redefine old API and define
4074         new functions
4075
4076 2000-11-22  Kevin L. Mitchell  <klmitch@mit.edu>
4077
4078         * ircd/s_user.c (register_user): use motd_signon() instead of
4079         calling m_motd; much cleaner this way
4080
4081         * ircd/motd.c: write the new motd_* stuff to make MOTD handling
4082         less of a crock
4083
4084         * ircd/m_motd.c: rewrite m{,s}_motd to call out to new motd_*
4085         functions
4086
4087         * include/motd.h: define new MOTD API stuff
4088
4089 2000-11-20  Kevin L. Mitchell  <klmitch@mit.edu>
4090
4091         * ircd/ircd_reply.c (protocol_violation): rewrite
4092         protocol_violation so it'll actually work
4093
4094         oh, yeah, use %s -> cptr->name, instead of %c -> cptr, so we get
4095         the client's real name in there.
4096
4097         * ircd/m_motd.c (m_motd): Iso's addition of get_client_class(sptr)
4098         resulted in core dumps if NODEFAULTMOTD is defined, because m_motd
4099         gets called from register_user with a NULL sptr.  This is probably
4100         a design problem, but this bandaid will do for now...
4101
4102 2000-11-19  Isomer <isomer@coders.net>
4103         * ircd/ircd_reply.c: added 'protocol_violation', thus alerting us
4104         to problems in the server<->server protocol.
4105
4106         * ircd/m_connect.c: allow remote connects with a port of '0'
4107         meaning to use the port in the config file.
4108
4109         * ircd/m_create.c: Enable hacking protection, lets see how far we
4110         get.
4111
4112         * ircd/m_error.c: The RFC says never accept ERROR from unreg'd
4113         clients, so we don't any more.
4114
4115         * ircd/m_kill.c: The kill path is now made up of numnicks of servers,
4116         and the user@host is displayed of the victim.
4117
4118         * ircd/m_map.c: reloaded 'dump_map'.
4119
4120         * ircd/m_trace.c: allow per class T:
4121
4122         * ircd/m_stats.c: allow local opers /remote stats anywhere on the 'net.
4123
4124 2000-11-17  Isomer <isomer@coders.net>
4125
4126         * ircd/m_topic.c: Fixed bug where we'd only send to clients topics
4127         that were the *same* instead of different.  Oh the embarrasment!
4128
4129         * ircd/IPcheck.c: Merged net's fix.
4130
4131 2000-11-02  Kevin L. Mitchell  <klmitch@mit.edu>
4132
4133         * ircd/m_whois.c: remove compiler warning by adding a newline to
4134         end of file
4135
4136         * ircd/m_names.c: moved the flags up to s_user.h
4137
4138         * ircd/m_join.c: call do_names instead of m_names; restructure
4139         ms_join to never transmute a JOIN into a CREATE, but use the TS in
4140         the JOIN (if present) to timestamp the channel
4141
4142         * ircd/channel.c: send JOINs individually, instead of grouping
4143         them, so that we can send the channel's creation time
4144
4145         * include/s_user.h: declare do_names()
4146
4147 2000-10-30  Isomer <isomer@coders.net>
4148         * ircd/m_oper.c: Fixed warning
4149
4150 2000-10-30  Isomer <isomer@coders.net>
4151         * ircd/m_oper.c: Fixed over agressive cut and no paste
4152
4153 2000-10-30  Isomer <isomer@coders.net>
4154
4155         * ircd/m_topic.c: Restructured, fixed bug where topics on local
4156         channels are propergated (I forget who pointed this out to me, but
4157         thanks anyway).  Also to save bandwidth don't send the topic to
4158         users if the topic is already the same on the server (but still
4159         propergate to other servers).  X/W's "autotopic" feature must
4160         chew a lot of bandwidth, hopefully this will help reduce this.
4161
4162         * doc/rfc1459.rfc: Updated documentation on /topic.
4163
4164         * ircd/listener.c: snotice warnings about failed accept()'s
4165         potentially warning admins that they're running out of fd's.
4166
4167         * ircd/stats.c, ircd/class.c: Removed /stats v, added number of
4168         people in a class in /stats y
4169
4170         * ircd/m_create.c: Checks for timewarp hacking and squit's
4171         evil servers. (currently disabled)
4172         
4173
4174 2000-10-30  net <simms@lucida.qc.ca>
4175         
4176         * ircd/gline.c: Fixed various bugs Isomer left behind.
4177
4178 2000-10-26  Kevin L. Mitchell  <klmitch@mit.edu>
4179
4180         * ircd/m_join.c (m_join): reply on attempt to join a BADCHANed
4181         channel is now ERR_BANNEDFROMCHAN instead of ERR_BADCHANNAME
4182
4183 2000-10-24  Kevin L. Mitchell  <klmitch@mit.edu>
4184
4185         * ircd/channel.c: ok, now last mode rules; mode +ps will always
4186         result in +s (and won't send a mode if the channel is already +s);
4187         mode +sp will always result in +p; -n+n on a +n channel results in
4188         no mode change; -n+n on a -n channel results in a +n mode change;
4189         etc.
4190
4191 2000-10-23  Kevin L. Mitchell  <klmitch@mit.edu>
4192
4193         * ircd/channel.c: add "add" and "del" elements to ParseState to
4194         avoid not-too-pretty -p+s when +s is sufficient; fix a bug in
4195         mode_parse_limit that caused it to clear all channel modes
4196         prematurely; restructure mode_parse_mode to avoid calling
4197         modebuf_mode too early (ties in with first mentioned change);
4198         better logic for +p/+s mutual exclusivity; initialize "add" and
4199         "del" elements in mode_parse; send simple modes down to
4200         modebuf_mode after the loop in mode_parse
4201
4202 2000-09-28  Greg Sikorski <gte@atomicrevs.demon.co.uk>
4203         * ircd/m_names.c: Fixed a non-lethal logic error that 
4204         triggers an assert() in find_member_link while debugging.
4205         (Spotted by Maniac-).
4206 2000-09-19  Thomas Helvey <helveytw@home.com>
4207         * ircd/s_conf.c: move K:lines to their own list and data
4208         structures, add supporting code.
4209         * ircd/m_stats.c: cleanup stats processing a bit move
4210         kline listing code to a new function, haven't figured
4211         out where it goes yet tho'
4212         * ircd/s_stats.c: added K:line bulk lister
4213         * include/s_conf.h: added new DenyConf struct
4214         * *[ch]: fixeup code that depended on changes
4215
4216 2000-09-17  Thomas Helvey <helveytw@home.com>
4217         * ircd/class.c: encapsulate class list
4218         * include/class.h: clean up classes
4219         * * fixup code that depended on changes
4220
4221 2000-09-17  Thomas Helvey <helveytw@home.com>
4222         * ircd/s_conf.c: add me to local conf
4223         * include/s_conf.h: move CONF_ME macro to chkconf.c
4224         * ircd/s_bsd.c: cleanup initialization, allow virtual host
4225         to be changed by rehash
4226
4227 2000-09-17  Thomas Helvey <helveytw@home.com>
4228         * include/class.h: add missing prototype
4229         * ircd/class.c: make argument to get_conf_class const
4230
4231 2000-09-17  Thomas Helvey <helveytw@home.com>
4232         * ircd/*.c: merged in changes from 2.10.10.pl12, cleanup
4233         merge conflicts.
4234         * ircd/*.h: merged in changes from 2.10.10.pl12, cleanup
4235         merge conflicts
4236
4237 2000-09-16  Thomas Helvey <helveytw@home.com>
4238         * ircd/s_conf.c: add code for server struct
4239         * ircd/client.c: copy of class.c sort of, new file for client
4240         specific operations, will move things here as appropriate,
4241         currently only one function is exported from here.
4242         * ircd/*.c: general logic cleanups, convert negatives to
4243         positives in places.
4244
4245 2000-09-16  Thomas Helvey <helveytw@home.com>
4246         * ircd/s_conf.c: add code for new crule data structs, strip quotes
4247         * ircd/crule.c: clean up scary casting a bit, type safety stuff
4248         * include/s_conf.h: add CRuleConf struct and support, remove
4249         unused constants
4250         * include/crule.h: type safety cleanups
4251         * ircd/*.c: fixup code that depended on stuff I changed
4252
4253 2000-09-15  Thomas Helvey <helveytw@home.com>
4254         * ircd/s_conf.c: start adding code for new conf data structs, changed
4255         listeners, admin line, motd lines, class lines. Move validate_hostent
4256         to resolver. General mayhem.
4257         * include/s_conf.h: new data structs and accessors
4258         * ircd/res.c: move validate_hostent here, rewrite, use regular
4259         expression for validation.
4260         * doc/example.conf: update docs for port
4261
4262 2000-09-14  Thomas Helvey <helveytw@home.com>
4263         * ircd/s_conf.c (conf_init): rewrite conf file parser, start to break
4264         up conf_init into managable chunks.
4265         * ircd/listener.c (set_listener_mask): fix logic bug core dump.
4266         * include/s_conf.h: add new data struct for local info (unwinding the mess).
4267
4268 2000-09-13  Thomas Helvey <helveytw@home.com>
4269         * ircd/list.c: put Clients in free lists, pre-allocate MAXCONNECTIONS
4270         local clients.
4271         * ircd/list.c: put SLinks in free lists
4272         * ircd/channel.c: put Memberships in free lists
4273         * ircd/ircd.c: rearrange initializations a bit in main
4274         Note: With these changes, ircd NEVER frees Clients, SLinks or
4275         Memberships. It will also rarely need to allocate new
4276         ones during net bursts and other disruptions. This should
4277         cut down on memory fragmentation a bit as well.
4278
4279 2000-08-30  Kevin L. Mitchell  <klmitch@mit.edu>
4280
4281         * ircd/m_names.c (do_names): pull-up from do_names fix in
4282         u2.10.10.pl11
4283
4284 2000-07-15  Perry Lorier       <Isomer@coders.net>
4285         * various: IP only k:'s and G:'s now do bit tests instead of two(!) 
4286                  match()'s.  Major Major cpu savings.  Also speed up the
4287                  other case slightly.  As a side effect you can now
4288                  k/Gline *@10.0.0.0/8.  I'll do bans tomorrow, it's nearing
4289                  3am.
4290
4291 2000-07-15  Perry Lorier       <Isomer@coders.net>
4292         * various: Fixed warnings after compiling on an alpha.
4293 2000-07-09  Perry Lorier       <Isomer@coders.net>
4294         * doc/ircd.8: Applied grammitical changes by Liandrin, applied
4295                       changes suggested by various other people.
4296         * ircd/IPcheck.c: More bug fixes.  Current problem appears to be
4297                         that it gets a corrupt entry somehow.
4298 2000-07-09  Greg Sikorski <gte@atomicrevs.demon.co.uk>
4299         * ircd/m_oper.c: Clean up compiler warning.
4300
4301 2000-07-08  Perry Lorier       <Isomer@coders.net>
4302         * doc/ircd.8: Updated the documentation, it was slightly out of date
4303                       being updated around 1989.
4304         * ircd/m_whois.c: Rewrote for clarity, and probably a bit more speed.
4305                           fixed a few minor glitches.
4306         * doc/rfc1459.unet: Updated.
4307         * ircd/IPcheck.c: Fixed more bugs.
4308         * ircd/s_bsd.c: We now keep track of servers we've conected.
4309
4310 2000-07-02  Perry Lorier       <Isomer@coders.net>
4311         * ircd/s_misc.c: Fixed remote IPcheck bug.  Ok, I'm a moron, so sue
4312                         me.  Thanks to Hektik, thanks thanks thanks thanks
4313                         thanks thanks thanks thanks thank thanks thank thanks
4314
4315 2000-07-01  Perry Lorier       <Isomer@coders.net>
4316         * ircd/s_conf.c: "Fixed" the "bug" where people would "evade" K:'s.
4317         * ircd/s_conf.c, include/IPcheck.h: Fixed compile warnings.
4318
4319 2000-06-22  Perry Lorier       <Isomer@coders.net>
4320         * ircd/IPcheck.c: Large chunks redone.
4321         * ircd/s_conf.c: Changes due to IPcheck - ONE nolonger supported,
4322                         single AND double digit limits are allowed now.
4323         * misc other: Changes to IPcheck.
4324
4325 2000-06-30  Perry Lorier       <Isomer@coders.net>
4326         * ircd/ircd.c: Fix command line parameter bugs.
4327
4328 2000-06-30  Perry Lorier       <Isomer@coders.net>
4329         * ircd/m_kill.c: Fixed bug with LOCAL_KILL_ONLY
4330         * ircd/m_nick.c: Tidied things up.
4331
4332 2000-06-12 Joseph Bongaarts <foxxe@trms.com>
4333         * ircd/m_stats.c: Iso forgot mo_stats when he added /stats v
4334         
4335 2000-05-29  Perry Lorier       <Isomer@coders.net>
4336         * ircd/m_stats.c: add /stats v to do only the last part of the /trace
4337         * ircd/IPcheck.c: Cosmetic change, if we meddle with it enough do
4338                         you think it'll get bored and fix itself?
4339
4340 2000-06-09  Greg Sikorski <gte@atomicrevs.demon.co.uk>
4341
4342         * ircd/m_names.c: Clean up compiler warnings.
4343
4344 2000-06-09  Kevin L. Mitchell  <klmitch@mit.edu>
4345
4346         * ircd/channel.c (mode_parse_client): don't send warning if
4347         there's not enough arguments for a +/-o/v; means the habit of
4348         doing "/mode #channel +oooooo bob" doesn't result in a bunch of
4349         error messages
4350
4351 2000-06-04  Greg Sikorski <gte@atomicrevs.demon.co.uk>
4352
4353         * ircd/m_names.c: Re-factor code to remove unneccessary
4354         GlobalChannelList iteration every time someone joins a channel.
4355
4356 2000-06-02  Kevin L. Mitchell  <klmitch@mit.edu>
4357
4358         * ircd/s_user.c: add struct Gline * argument to register_user;
4359         look up global glines and repropagate them if necessary; send
4360         acknowledgement of gline to remote servers when registering users
4361
4362         * ircd/s_serv.c (server_estab): don't send acknowledgement of
4363         local glines to remote servers; do send gline acknowledgement of
4364         bursted users
4365
4366         * ircd/m_user.c (m_user): pass new struct Gline * argument to
4367         register_user
4368
4369         * ircd/m_pong.c: pass new struct Gline * argument to register_user
4370
4371         * ircd/m_nick.c (ms_nick): document protocol change
4372
4373         * ircd/gline.c: support GLINE_LASTMOD
4374
4375         * include/s_user.h: add struct Gline * argument to register_user
4376
4377         * include/gline.h: add GLINE_LASTMOD to look up non-zero lastmods
4378
4379         * ircd/s_conf.c (find_kill): add unsigned int argument to
4380         gline_lookup()
4381
4382         * ircd/gline.c: add GLINE_GLOBAL to lookup or find only global
4383         glines; add unsigned int argument to gline_lookup()
4384
4385         * include/gline.h: add GLINE_GLOBAL flag; add unsigned int
4386         argument to gline_lookup()
4387
4388         * ircd/m_server.c: Resend jupe only when there is no %<lastmod>
4389         parameter, or when it falls out of bounds: see comments prior to
4390         call to jupe_resend(); call server_estab with struct Jupe
4391         parameter, so that we place the appropriate %<lastmod> in the
4392         appropriate place.
4393
4394         * ircd/s_serv.c (server_estab): send %<lastmod> for introduced
4395         server, as well as for servers when we're sending the BURST
4396
4397         * include/s_serv.h: add a struct Jupe * to the arguments for
4398         server_estab() so that we can send the appropriate lastmod
4399         parameter
4400
4401         * ircd/m_gline.c (ms_gline): actually, this should be the
4402         slightest bit more efficient...
4403
4404         * ircd/m_jupe.c (ms_jupe): actually, this should be the slightest
4405         bit more efficient...
4406
4407         * ircd/m_gline.c (ms_gline): inhibit GLINE processing resends
4408         during netburst
4409
4410         * ircd/m_jupe.c (ms_jupe): inhibit JUPE processing resends during
4411         netburst
4412
4413         * ircd/channel.c (joinbuf_join): really remove user from local
4414         channels
4415
4416 2000-05-29  Perry Lorier       <Isomer@coders.net>
4417         * ircd/m_names.c: Removed redundant space. 
4418         * ircd/s_bsd.c: Fixed incorrect syntax on ERROR line.
4419
4420 2000-05-18  Kevin L. Mitchell  <klmitch@mit.edu>
4421
4422         * ircd/m_burst.c (ms_burst): er...that should have been a ",", not
4423         a " "
4424
4425 2000-05-04  Kevin L. Mitchell  <klmitch@mit.edu>
4426
4427         * ircd/channel.c: replace bogus assertions with returns, which is
4428         logically correct; only wipe out limit/key if they were originally
4429         set in the first place; remove user from channel when doing a
4430         PARTALL; only send MODE +o for user CREATEing channel if user is
4431         not MyUser--CREATE will only be used if the channel did not
4432         originally exist, therefore we can assume no one local is on the
4433         channel anyway, and we don't exactly need for the user to see an
4434         explicit +o for themselves
4435
4436         * doc/readme.gline: describe the syntax of the GLINE command
4437
4438         * doc/readme.jupe: update to reflect a couple of changes to JUPE
4439
4440         * ircd/gline.c: don't propagate local changes
4441
4442         * ircd/jupe.c: don't propagate local changes
4443
4444         * ircd/m_gline.c (mo_gline): force local flag when deactivating
4445         glines with 0 lastmod
4446
4447         * ircd/gline.c (gline_deactivate): G-lines with zero lastmod time
4448         are now removed instead of being deactivated
4449
4450         * ircd/m_gline.c (ms_gline): make G-lines of the form "GLINE *
4451         -<mask>" be accepted
4452
4453         * ircd/channel.c (send_channel_modes): deal with one of the last
4454         vestiges of sendbuf
4455
4456         * ircd/m_burst.c (ms_burst): debugged ban processing; removed
4457         debugging hooks
4458
4459         * ircd/channel.c (modebuf_extract): remove debugging
4460         sendto_opmask_butone calls
4461
4462 2000-05-03  Kevin L. Mitchell  <klmitch@mit.edu>
4463
4464         * ircd/channel.c: support a couple of new flags to support using
4465         mode_parse; fix some bugs with 0 struct ModeBuf *; implementation
4466         of modebuf_extract to extract added flags for use by ms_burst
4467
4468         * include/channel.h: a couple of new flags to support using
4469         mode_parse inside ms_burst
4470
4471         * ircd/m_burst.c (ms_burst): brand new implementation of BURST
4472
4473         * ircd/m_endburst.c: add loop to processing of end_of_burst to
4474         free empty channels after the BURST is over.
4475
4476         * ircd/m_server.c: convert to use new send.c functions--I wanted
4477         to rewrite it from scratch, but the logic's pretty complex; I may
4478         still rewrite it, though...
4479
4480 2000-05-02  Thomas Helvey <tomh@inxpress.net>
4481
4482         * ircd/ircd.c: fix broken header include ordering
4483
4484 2000-05-02  Thomas Helvey <tomh@inxpress.net>
4485         
4486         * ircd/IPcheck.c: cleanups for ZenShadow's cleanups
4487         review emailed privately
4488
4489         * include/IPcheck.h: removed unneeded include
4490
4491 2000-05-02  Kevin L. Mitchell  <klmitch@mit.edu>
4492
4493         * ircd/s_user.c (hunt_server): throw in a comment so I know what
4494         the sendto_one is for
4495
4496         * include/querycmds.h (Count_unknownbecomesclient): convert to
4497         sendto_opmask_butone
4498
4499         * ircd/send.c: start removing dead code
4500
4501         * include/send.h: start removing dead code
4502
4503         * ircd/m_rping.c: convert to sendcmdto_one / send_reply /
4504         hunt_server_cmd
4505
4506         * ircd/m_rpong.c: convert to sendcmdto_one / send_reply
4507
4508 2000-05-01  Kevin L. Mitchell  <klmitch@mit.edu>
4509
4510         * ircd/m_stats.c: convert to sendcmdto_one / send_reply
4511
4512         * ircd/m_kick.c: Completely reimplement m_kick
4513
4514         * ircd/channel.c: send_user_joins removed; it was dead code,
4515         anyway...
4516
4517 2000-05-01  Perry Lorier <isomer@coders.net>
4518         * ircd/m_invite.c: Fix for the rest of m_invite.c, and again.
4519         * ircd/channels.c: My fix for the part problem.  Untested, probably
4520                 won't work.  Can't be much worse than the current problem.
4521                 it'll either work or core, take your pick.
4522
4523
4524 2000-04-30  Perry Lorier <isomer@coders.net>
4525         * config/config-sh.in: Fix for CONNEXIT
4526         * ircd/s_{user,misc}.c: Fix for CONNEXIT
4527         * ircd/m_invite.c: Fix for incorrectly numnickified invite.
4528                         (Kev: Want to come talk to me about this?)
4529
4530 2000-04-30  Steven M. Doyle <steven@doyle.net>
4531         * ircd/ircd.c
4532           - general cleanups and readability enhancements
4533           - rewrite of setuid/chroot code.
4534           - server will no longer run as root
4535           - -DPROFIL compile option removed
4536           - Fixed IPcheck API calls
4537  
4538         * config/config-sh.in
4539           - Fixed up chroot compile options
4540           - Added options for debug and profile compiles
4541  
4542         * config/gen.ircd.Makefile
4543           - Support for new debug/profile options
4544  
4545         * ircd/Makefile.in
4546           - Support for new debug/profile options
4547  
4548         * ircd/ircd_signal.c
4549           - Removed -DPROFIL
4550
4551         * include/IPcheck.h
4552           - Removed old API prototypes, added new ones
4553         
4554         * ircd/IPcheck.c
4555           - Readability cleanups (well, I -think-...)
4556           - Changed IPRegistryEntry.last_connect to a time_t.  The previously
4557             used unsigned short was probably causing interesting things after
4558             a client had been connected longer than about 65,535 seconds...
4559           - Removed old API functions.
4560
4561         * ircd/whocmds.c
4562           - Removed IPcheck.h include
4563         
4564         * Additionally modified IPcheck API calls in:
4565           - ircd/m_nick.c
4566           - ircd/m_auth.c
4567           - ircd/s_bsd.c
4568           - ircd/s_conf.c
4569           - ircd/s_misc.c
4570           - ircd/s_serv.c
4571           - ircd/s_user.c
4572         
4573         
4574 2000-04-30  Perry Lorier <isomer@coders.net>
4575         * ircd/s_bsd.c: Sigh. :)
4576         * ircd/m_mode.c: fix for modeless channels by poptix.
4577
4578 2000-04-29  Kevin L. Mitchell  <klmitch@mit.edu>
4579
4580         * ircd/m_join.c: reimplement JOIN in terms of struct JoinBuf
4581
4582         * ircd/channel.c (clean_channelname): make clean_channelname also
4583         truncate long channel names
4584
4585 2000-04-28  Kevin L. Mitchell  <klmitch@mit.edu>
4586
4587         * ircd/m_create.c: reimplement CREATE in terms of struct JoinBuf
4588
4589         * ircd/channel.c: implemented joinbuf_init, joinbuf_join,
4590         joinbuf_flush
4591
4592         * include/channel.h: definitions and declarations for the struct
4593         JoinBuf abstraction
4594
4595 2000-04-29  Perry Lorier <isomer@coders.net>
4596         * ircd/s_bsd.c: Ok, so I thought I compiled and tested this...
4597
4598 2000-04-29  Perry Lorier <isomer@coders.net>
4599         * ircd/s_bsd.c: Add debugging code to IPcheck
4600
4601 2000-04-28  Kevin L. Mitchell  <klmitch@mit.edu>
4602
4603         * include/ircd_reply.h (SND_EXPLICIT): use instead of RPL_EXPLICIT
4604
4605         * ircd/ircd_reply.c (send_reply): use SND_EXPLICIT instead of
4606         RPL_EXPLICIT
4607
4608         * ircd/m_userhost.c (m_userhost): add a dead code comment
4609
4610         * ircd/m_desynch.c: forgot one...
4611
4612         * ircd/m_rehash.c (mo_rehash): er, duplicates :)
4613
4614         * ircd/m_proto.c (proto_send_supported): just change a comment so
4615         it doesn't show up in my scans
4616
4617         * ircd/ircd_reply.c (send_reply): fix a slight bug...
4618
4619         * ircd/s_numeric.c (do_numeric): use new sendcmdto_* functions,
4620         kinda hackish...
4621
4622         * ircd/parse.c (parse_server): argument wrangling to make
4623         processing in do_numeric a little easier to deal with
4624
4625         * ircd/s_serv.c (server_estab): SERVER should come from
4626         acptr->serv->up, not &me
4627
4628         * ircd/m_lusers.c: accidentally left out sptr for a %C
4629
4630         * ircd/send.c: hack to support doing wallchops...
4631
4632         * ircd/m_whowas.c: convert to new send functions
4633
4634         * ircd/m_whois.c: convert to new send functions
4635
4636         * ircd/m_who.c: convert to new send functions
4637
4638         * ircd/m_wallops.c: convert to new send functions
4639
4640         * ircd/m_wallchops.c: convert to new send functions
4641
4642         * ircd/m_version.c: convert to new send functions
4643
4644         * ircd/m_userip.c: convert to new send functions
4645
4646         * ircd/m_userhost.c: convert to new send functions
4647
4648         * ircd/m_uping.c: convert to new send functions
4649
4650         * ircd/m_trace.c: convert to new send functions
4651
4652         * ircd/m_topic.c: convert to new send functions
4653
4654         * ircd/m_time.c: convert to new send functions
4655
4656         * ircd/m_squit.c: convert to new send functions
4657
4658         * ircd/m_silence.c: convert to new send functions
4659
4660         * ircd/m_settime.c: convert to new send functions
4661
4662         * ircd/m_restart.c: convert to new send functions
4663
4664         * ircd/m_rehash.c: convert to new send functions
4665
4666         * ircd/m_privmsg.c: convert to new send functions
4667
4668         * ircd/m_pong.c: convert to new send functions
4669
4670         * ircd/m_ping.c: convert to new send functions
4671
4672         * ircd/m_pass.c: convert to new send functions
4673
4674         * ircd/m_opmode.c: convert to new send functions
4675
4676         * ircd/m_oper.c: convert to new send functions
4677
4678         * ircd/m_notice.c: convert to new send functions
4679
4680         * ircd/m_nick.c: convert to new send functions
4681
4682         * ircd/m_names.c: convert to new send functions
4683
4684         * ircd/m_motd.c: convert to new send functions
4685
4686         * ircd/m_mode.c: convert to new send functions
4687
4688         * ircd/m_map.c: convert to new send functions
4689
4690         * ircd/m_lusers.c: convert to new send functions
4691
4692         * ircd/m_list.c: convert to new send functions
4693
4694         * ircd/m_links.c: convert to new send functions
4695
4696         * ircd/m_kill.c: convert to new send functions
4697
4698         * ircd/m_jupe.c: convert to new send functions
4699
4700         * ircd/m_invite.c: convert to new send functions
4701
4702         * ircd/m_info.c: convert to new send functions
4703
4704         * ircd/m_help.c: convert to new send functions
4705
4706         * ircd/m_gline.c: convert to new send functions
4707
4708         * ircd/m_error.c: convert to new send functions
4709
4710         * ircd/m_endburst.c: convert to new send functions
4711
4712         * ircd/m_die.c: convert to new send functions
4713
4714         * ircd/m_destruct.c: convert to new send functions
4715
4716         * ircd/m_defaults.c: convert to new send functions
4717
4718         * ircd/m_connect.c: convert to new send functions
4719
4720 2000-04-28  Perry Lorier <isomer@coders.net>
4721         * RELEASE.NOTES: Describe a few more undocumented features.
4722         * config/config-sh.in: change the default paths for logging
4723         and the recommended number of channels.
4724         * include/supported.h: Rearrange slightly, added CHANTYPE's
4725
4726 2000-04-27  Kevin L. Mitchell  <klmitch@mit.edu>
4727
4728         * ircd/m_close.c: convert to send_reply
4729
4730         * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
4731
4732         * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
4733
4734         * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
4735
4736         * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
4737         that takes cmd and tok arguments, etc.  NOTE: THIS IMPLEMENTATION
4738         HAS A MAJOR HACK!!!  The whole hunt_server architecture should be
4739         carefully rethought...
4740
4741         * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
4742
4743         * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
4744
4745         * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
4746         numeric nick; therefore, we have to use the server name
4747
4748         * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
4749
4750         * ircd/send.c: fix minor bugs
4751
4752         * ircd/s_user.c (check_target_limit): mark dead code so I filter
4753         it when I grep
4754
4755         * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
4756         when I grep
4757
4758         * ircd/parse.c: mark dead code so I filter it when I grep
4759
4760         * ircd/map.c: mark dead code so I filter it when I grep
4761
4762         * ircd/ircd.c: mark dead code so I filter it when I grep
4763
4764         * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
4765         functions
4766
4767         * ircd/channel.c: mark dead code so I filter it when I grep
4768
4769         * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
4770         hope I'm not stepping on toes...
4771
4772         * ircd/s_conf.c: more sendto_opmask_butone / send_reply
4773         conversions; use ircd_snprintf in a couple of cases to negate the
4774         possibility of buffer overflow
4775
4776 2000-04-26  Kevin L. Mitchell  <klmitch@mit.edu>
4777
4778         * ircd/channel.c: convert as much as possible to new send
4779         semantics
4780
4781         * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
4782         test member->user->from->fd, not from->fd
4783
4784         * ircd/gline.c (gline_add): go ahead and add badchans; we just
4785         won't look for them in m_gline; this way, they always work...
4786
4787         * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
4788
4789         * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
4790         ircd_vsnprintf conversion specifiers
4791
4792         * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
4793         I have my conversion specifiers
4794
4795         * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
4796
4797         * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
4798         local users
4799
4800         * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
4801         little less brain-dead
4802
4803         * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
4804
4805         * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
4806         RPL_STATSDEBUG
4807
4808         * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
4809         RPL_STATSDEBUG
4810
4811         * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
4812         for RPL_STATSDEBUG
4813
4814         * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
4815
4816         * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
4817
4818         * ircd/s_user.c (register_user): use RPL_EXPLICIT for
4819         ERR_INVALIDUSERNAME
4820
4821         * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
4822
4823         * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
4824         a numeric as needing to use an explicit pattern, which will be the
4825         first argument in the variable argument list
4826
4827         * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
4828         non-prefixed nospoof PING
4829
4830         * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
4831         non-prefixed SERVER login
4832
4833         * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
4834         a numeric usage further up)
4835
4836         * include/send.h: declare sendrawto_one
4837
4838         * ircd/send.c (sendrawto_one): new function to use ONLY for
4839         non-prefixed commands, like PING to client, or PASS/SERVER on
4840         server registration
4841
4842 2000-04-25  Kevin L. Mitchell  <klmitch@mit.edu>
4843
4844         * ircd/ircd_snprintf.c (doprintf): implement %H for possible
4845         future expansion (channel numerics?)
4846
4847         * include/ircd_snprintf.h: added documentation to # to explain use
4848         with %C; added documentation for : to explain use with %C; added
4849         documentation for %H for channels
4850
4851         * ircd/whocmds.c: use send_reply
4852
4853         * ircd/userload.c: use sendcmdto_one
4854
4855         * ircd/uping.c: use sendcmdto_one
4856
4857         * ircd/send.c: use new flags to %C format string; ':' prefixes
4858         client name with a colon for local connects, '#' uses
4859         nick!user@host form for local connects
4860
4861         * ircd/s_user.c: use send_reply, sendto_opmask_butone,
4862         sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
4863
4864         * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
4865
4866         * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
4867         sendcmdto_one
4868
4869         * ircd/s_auth.c: use sendto_opmask_butone
4870
4871         * ircd/res.c: use sendcmdto_one
4872
4873         * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
4874         debugging assertions
4875
4876 2000-04-24  Kevin L. Mitchell  <klmitch@mit.edu>
4877
4878         * ircd/support.c: dumpcore is no longer used, so get rid of it
4879
4880         * ircd/parse.c: use send_reply, sendcmdto_one
4881
4882         * ircd/map.c: use send_reply
4883
4884         * ircd/listener.c: use send_reply
4885
4886         * ircd/jupe.c: use sendto_opmask_butone, send_reply
4887
4888         * ircd/ircd_reply.c: use send_reply
4889
4890         * ircd/ircd.c: use sendto_opmask_butone
4891
4892         * ircd/gline.c: use sendto_opmask_butone, send_reply
4893
4894         * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
4895         registered clients; make FLAG_ALT print nick!user@host; make
4896         FLAG_COLON print :blah
4897
4898         * ircd/class.c (report_classes): use send_reply instead of
4899         sendto_one
4900
4901         * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
4902
4903         * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
4904         sendto_one with sendcmdto_one
4905
4906 2000-04-21  Kevin L. Mitchell  <klmitch@mit.edu>
4907
4908         * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
4909         MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
4910         sendcmdto_match_butone
4911
4912         * include/send.h: declare sendcmdto_match_butone
4913
4914 2000-04-20  Kevin L. Mitchell  <klmitch@mit.edu>
4915
4916         * ircd/jupe.c: update to use send_reply()
4917
4918         * ircd/gline.c: update to use send_reply()
4919
4920         * include/ircd_reply.h: declare send_reply
4921
4922         * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
4923         replies; uses ircd_snprintf
4924
4925         * ircd/send.c: added comments to redirect searchers to appropriate
4926         sendcmdto_* function; moved new functions to end of file; added
4927         explanatory comments; reordered arguments; defined new functions
4928         mentioned below
4929
4930         * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
4931
4932         * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
4933
4934         * ircd/jupe.c: reorder arguments to sendcmdto_* functions
4935
4936         * ircd/gline.c: reorder arguments to sendcmdto_* functions
4937
4938         * include/send.h: reorder arguments, add explanatory comments,
4939         declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
4940         and vsendto_opmask_butone
4941
4942 2000-04-19  Kevin L. Mitchell  <klmitch@mit.edu>
4943
4944         * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
4945         vsendto_op_mask that uses '*' instead of the receiving client
4946         nickname
4947
4948         * include/send.h: declare sendcmdto_channel_butone; takes a skip
4949         argument that allows you to skip (or not to skip) deaf users,
4950         users behind bursting servers, and non channel operators
4951
4952 2000-04-17  Kevin L. Mitchell  <klmitch@mit.edu>
4953
4954         * ircd/send.c: new sendcmdto_channel_butserv -- note that old
4955         sendto_channel_butserv has a subtle bug; also wrote
4956         sendcmdto_common_channels.
4957
4958         * include/send.h: declare new sendcmdto_* functions
4959
4960         * ircd/jupe.c: support local deactivations of jupes
4961
4962         * ircd/gline.c: support local deactivations of glines
4963
4964         * include/jupe.h: JUPE_LDEACT allows jupes to be locally
4965         deactivated; if they aren't locally deactivated, then it slaves to
4966         the net-wide activation status; JupeIsRemActive() tests only
4967         whether the jupe is active everywhere else
4968
4969         * include/gline.h: GLINE_LDEACT allows glines to be locally
4970         deactivated; if they aren't locally deactivated, then it slaves to
4971         the net-wide activation status; GlineIsRemActive() tests only
4972         whether the gline is active everywhere else
4973
4974         * ircd/gline.c: detect overlapping G-lines; if an existing, wider
4975         gline expires after the new one will, we drop the new one,
4976         otherwise we add the G-line after that one (so the wide one will
4977         apply first); if the new one contains an existing G-line and if it
4978         will expire after the existing one, we drop the existing one to
4979         save memory
4980
4981         * ircd/m_gline.c (mo_gline): opers could issue remote local
4982         glines when CONFIG_OPERCMDS was off; fixed
4983
4984 2000-04-16  Kevin L. Mitchell  <klmitch@mit.edu>
4985
4986         * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
4987         this is a local JUPE
4988
4989         * ircd/gline.c: add flags argument to gline_activate and
4990         gline_deactivate for future expansion
4991
4992         * ircd/m_gline.c: pass flags to gline_activate and
4993         gline_deactivate
4994
4995         * include/gline.h: add flags argument to gline_activate and
4996         gline_deactivate
4997
4998         * ircd/jupe.c: add flags argument to jupe_activate and
4999         jupe_deactivate for future expansion
5000
5001         * include/jupe.h: add flags argument to jupe_activate and
5002         jupe_deactivate
5003
5004         * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
5005         local, active; pass flags to jupe_activate and jupe_deactivate
5006
5007         * include/gline.h: remove dead code
5008
5009         * ircd/gline.c: make gline expire times relative to CurrentTime,
5010         since that should be monotonically increasing, instead of
5011         TStime(), which can be set backwards, and which can therefore
5012         cause an expire time to increase; make local glines be removed
5013         instead of just deactivated; don't let gline_find() look for
5014         user@host glines if the mask being looked up is a channel mask
5015
5016         * ircd/send.c (vsendcmdto_one): forgot to account for the case
5017         where origin is a server and destination is a user
5018
5019         * ircd/jupe.c: make jupe expire times relative to CurrentTime,
5020         since that should be monotonically increasing, instead of
5021         TStime(), which can be set backwards, and which can therefore
5022         cause an expire time to increase; make local jupes be removed
5023         instead of just deactivated
5024
5025         * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
5026         limit is fine.  any other warnings I should know about?
5027
5028 2000-04-15  Thomas Helvey <tomh@inxpress.net>
5029
5030         * ircd/*.c: const correctness and type safety cleanups to
5031         get code to compile with C++ compiler. Still has
5032         signed/unsigned comparison warnings.
5033
5034 2000-04-15  Greg Sikorski <gte@atomicrevs.demon.co.uk>
5035
5036         * ircd/userload.c: change <sys/time.h> include to <time.h> for
5037           portability.
5038
5039 2000-04-14  Kevin L. Mitchell  <klmitch@mit.edu>
5040
5041         * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
5042         and convert acptr...
5043
5044         * ircd/s_user.c: move gline_lookup function call into
5045         register_user, where it'll have a username to lookup!
5046
5047         * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
5048         functions; also stuff send_error_to_client into return clauses
5049
5050         * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
5051         functions; also use send_error_to_client where that makes sense
5052
5053         * ircd/jupe.c: modify to utilize new sendcmdto_* series of
5054         functions; also use send_error_to_client where that makes sense
5055
5056         * ircd/gline.c: modify to utilize new sendcmdto_* series of
5057         functions; also fix gline_lookup() to deal properly with remote
5058         clients--boy, do struct Client and struct User need to be cleaned
5059         up!
5060
5061         * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
5062         too...
5063
5064         * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
5065         sendcmdto_serv_butone(), all utilizing the %v conversion of
5066         ircd_snprintf()
5067
5068         * include/send.h: define IRC_BUFSIZE, max size of a message;
5069         declare sendcmdto_one(), vsendcmdto_one(), and
5070         sendcmdto_serv_butone()
5071
5072         * include/msg.h: define all the CMD_* constants needed to utilize
5073         the new sendcmdto_* series of functions
5074
5075         * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
5076
5077         * ircd/gline.c: remove old, dead code.
5078
5079         * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
5080         unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
5081         (don't advertise proxies); remove dead code
5082
5083         * ircd/parse.c: oper handler for JUPE only lists jupes unless
5084         CONFIG_OPERCMDS is enabled
5085
5086         * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
5087         CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
5088
5089         * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
5090         always return ERR_DISABLED
5091
5092         * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
5093         enabled, always return ERR_DISABLED
5094
5095         * ircd/s_err.c: add error message to indicate disabled commands
5096
5097         * include/numeric.h (ERR_DISABLED): to indicate disabled commands
5098
5099         * doc/Configure.help: add documentation for CONFIG_OPERCMDS
5100
5101         * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
5102         CONFIG_NEW_MODE to 'y' for now
5103
5104         * ircd/gline.c (gline_list): fix a minor formatting bogon
5105
5106         * BUGS: since I fixed that bug, might as well mark it fixed.
5107
5108         * ircd/m_join.c: look up badchans with GLINE_EXACT
5109
5110         * ircd/m_gline.c: fix parc count problems; look up existing
5111         G-lines with GLINE_EXACT; only set new lastmod when
5112         activating/deactivating existing glines if old lastmod was not 0
5113
5114         * ircd/gline.c: forgot to copy the gline reason over; don't
5115         propagate a gline with 0 lastmod if origin is user; add
5116         GLINE_EXACT to force exact matching of gline mask
5117
5118         * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
5119         flag properly
5120
5121         * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
5122         but gline_lookup() actually takes a client--d'oh.
5123
5124 2000-04-13  Thomas Helvey <tomh@inxpress.net>
5125         * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
5126
5127 2000-04-13  Greg Sikorski <gte@atomicrevs.demon.co.uk>
5128
5129         * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
5130           "/who * x"
5131           "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
5132           (Found by Plexus).
5133
5134         * ircd/whocmds.c: Change idle time calc from socket idle to user
5135           idle.
5136
5137 2000-04-13  Kevin L. Mitchell  <klmitch@mit.edu>
5138
5139         * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
5140         too, for ircd_snprintf.c
5141
5142         * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
5143         comments; mostly descended from the Linux manpage for printf, but
5144         also documenting the extensions.
5145
5146         * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
5147         client; make 'q' be the same as 'L'; remove __inline__; only
5148         define EXTENSION if HAVE_LONG_LONG is defined
5149
5150         * include/handlers.h: declare m_gline()
5151
5152         * ircd/parse.c: gline can be called by users, but it only lists
5153         the glines.
5154
5155         * ircd/s_user.c (set_nick_name): resend gline if a remote server
5156         introduces a glined client
5157
5158         * ircd/s_serv.c (server_estab): burst glines, too
5159
5160         * ircd/gline.c: fix up all the expire times to be offsets;
5161         simplify gline_resend()
5162
5163         * ircd/m_gline.c: begin coding replacements for ms_gline(),
5164         mo_gline(), and m_gline()
5165
5166         * ircd/gline.c (gline_add): allow *@#channel to work correctly;
5167         also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
5168
5169 2000-04-13  Greg Sikorski <gte@atomicrevs.demon.co.uk>
5170
5171         * tools/Bouncer/*: Add comments/documentation/tags.
5172         * tools/Bouncer/*: Add debug defines, make task fork().
5173
5174 2000-04-12  Thomas Helvey <tomh@inxpress.net>
5175         * ircd/s_err.c: Cleanup s_err.c make one table so we
5176         don't have to do anything tricky to get an error string.
5177
5178 2000-04-12  Greg Sikorski <gte@atomicrevs.demon.co.uk>
5179         * Add port bouncer for http (x/w)
5180
5181 2000-04-12  Kevin L. Mitchell  <klmitch@mit.edu>
5182
5183         * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
5184         call to gline_find(); also used GlineReason() instead of direct
5185         reference to structure member
5186
5187         * ircd/m_join.c (m_join): replace bad_channel() calls with calls
5188         to gline_find(name, GLINE_BADCHAN), and also check to see if gline
5189         is active
5190
5191         * ircd/channel.c: nothing seems to be called anywhere...
5192
5193         * ircd/s_err.c: update a couple of replies to dovetail with new
5194         semantics
5195
5196         * ircd/gline.c: begin complete re-implementation of gline.c along
5197         the lines of the final design of jupe.c
5198
5199         * include/gline.h: begin complete re-implementation of gline.c
5200         along the lines of the final design of jupe.c
5201
5202         * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
5203         %s by %s" message...
5204
5205         * ircd/ircd_snprintf.c: my new snprintf()-like functions
5206
5207         * include/ircd_snprintf.h: my new snprintf()-like functions
5208
5209 2000-04-11  Thomas Helvey <tomh@inxpress.net>
5210         * ircd/IPcheck.c: removed old dead code
5211         * ircd/s_user.c (send_user_info): removed non-standard
5212           user not found message for userhost/userip
5213
5214 2000-04-11  Greg Sikorski <gte@atomicrevs.demon.co.uk>
5215
5216         * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
5217         * doc/p10.html: Work on chapter 4.
5218
5219 2000-04-10  Kevin L. Mitchell  <klmitch@mit.edu>
5220
5221         * ircd/channel.c (mode_parse_client): fix coredump on /mode
5222         #foobar +o nosuchnick
5223
5224 2000-04-10  Perry Lorier  <Isomer@coders.net>
5225         * BUGS: Added bug.
5226
5227 2000-04-09  Thomas Helvey <tomh@inxpress.net>
5228         * include/IPcheck.h: fix prototype
5229         * ircd/s_user.c: fix usage of IPcheck_remote_connect
5230         * ircd/IPcheck.c: removed unused args
5231
5232 2000-04-09  Thomas Helvey <tomh@inxpress.net>
5233         * include/IPcheck.h: add proto for IPcheck_expire
5234
5235         * ircd/IPcheck.c: Rewrote
5236
5237         * ircd/ircd.c: Add IPcheck_expire to main message loop
5238
5239         * ircd/s_user.c: Redo target hashing, refactor target code
5240
5241         * include/numeric.h: Cleaned up numerics, added which ones are
5242         in use by other networks and what they are in use for.
5243
5244         * ircd/channel.c: cleaned can_join(), allow anyone through anything
5245         if /invited, simplified the function.  Opers overusing OPEROVERRIDE
5246         will get a message explaining to them not to cheat.
5247
5248         * ircd/m_join.c: cleaned up the various join functions, should be
5249         a lot more efficient.  Still needs work.  Now assumes that s<->s
5250         won't send it a JOIN 0.  Service coders - note this and tread with
5251         care.
5252
5253         * ircd/m_stats.c: added Gte-'s stats doc patch.
5254
5255         * ircd/m_version.c: /version now returns the 005 numeric as well.
5256         as requested by Liandrin.
5257
5258
5259 2000-04-07  Kevin L. Mitchell  <klmitch@mit.edu>
5260
5261         * ircd/m_clearmode.c: add include for support.h for write_log()
5262
5263         * configure: move ircd/crypt/* to tools/*
5264
5265 2000-04-06  Thomas Helvey <tomh@inxpress.net>
5266         * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
5267           set client host to server alias if connection from localhost
5268
5269 2000-04-06  Perry Lorier <isomer@coders.net>
5270         * ircd/ircd.c: Fix core during pinging (oops)
5271         
5272 2000-04-06  Perry Lorier <isomer@coders.net>
5273         * ircd/send.c: fixed wrong ident being sent to channels bug.
5274         * include/numerics.h: Updated some of the numerics from other
5275         networks.  Flagged some as 'unused' by undernet.
5276
5277 2000-03-30  Perry Lorier <isomer@coders.net>
5278         * ircd/ircd.c: Lets see if this helps the ping problem at all.
5279         * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
5280         time for local clients. (as requested), extended who now returns all
5281         the flags (@+!) so you can tell the complete state of a client.
5282
5283 2000-03-30  Thomas Helvey <tomh@inxpress.net>
5284         * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
5285
5286 2000-03-30  Perry Lorier <isomer@coders.net>
5287         * ircd/parse.c: oops, missed opers.
5288
5289 2000-03-30  Perry Lorier <isomer@coders.net>
5290         * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
5291         for so long.  Remember: m_ping MUST be in the parse array. :)
5292
5293 2000-03-30  Perry Lorier <isomer@coders.net>
5294         * ircd/ircd.c: test in check_pings was wrong.  I move that we
5295         disallow cvs commit after 10pm localtime....
5296
5297 2000-03-30  Perry Lorier <isomer@coders.net>
5298         * ircd/m_pong.c: Fix it for servers too.
5299
5300 2000-03-30  Perry Lorier <isomer@coders.net>
5301         * ircd/m_pong.c: Fix ping timeout bugs
5302
5303 2000-03-30  Perry Lorier <isomer@coders.net>
5304         * ircd/channel.c: Bans had CurrentTime in their when field instead
5305         of TStime()
5306
5307 2000-03-31  Thomas Helvey <tomh@ixpress.net>
5308         * ircd/numnicks.c (SetXYYCapacity): fix for extended
5309         numerics.
5310
5311 2000-03-30  Perry Lorier <isomer@coders.net>
5312         * ircd/m_nick.c: send kills both ways so when we add nick change
5313         on collision we don't desync the network.
5314
5315         * ircd/map.c: Fixup the map a bit more.
5316
5317 2000-03-31  Kevin L. Mitchell  <klmitch@mit.edu>
5318
5319         * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
5320
5321         * ircd/m_opmode.c: Log the mode changes to OPATH
5322
5323         * ircd/channel.c (modebuf_flush_int): Log the mode changes to
5324         OPATH
5325
5326         * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
5327         OPATH
5328
5329         * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
5330
5331         * config/config-sh.in: added OPATH for opmode log file
5332
5333         * ircd/m_clearmode.c (do_clearmode): updated uses of
5334         modebuf_mode_string() for the new usage
5335
5336         * ircd/channel.c: added flag MODE_FREE and an int argument to
5337         modebuf_mode_string() to indicate that the string must be free'd;
5338         updated calls to modebuf_mode_string() for the new usage; called
5339         collapse(pretty_mask()) on the ban string and use allocated memory
5340         for it; added ban list length accounting; fixed a number of small
5341         bugs in ban processing
5342
5343         * include/channel.h: added flag MODE_FREE and an int argument to
5344         modebuf_mode_string() to indicate that the string must be free'd
5345
5346         * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
5347         keys and limits that are set
5348
5349 2000-03-30  Perry Lorier <isomer@coders.net>
5350         * ircd/ircd.c: rewrote check_pings() for maintainability
5351         and speed.  Also changed quit msg's so they don't have
5352         redundant nick[host] info in them.
5353
5354         * ircd/send.c: Changed write errors to report what error
5355         occured (if possible).
5356
5357         * ircd/gline.c: added gline comment to the quit.
5358
5359         * ircd/m_server.c: Added suggestions to server quits mentioning
5360         what went wrong so the admin can fix it earlier instead of asking
5361         questions...
5362
5363         * ircd/map.c: Changed m_map() to hide numerics, show a * beside
5364         servers that aren't fully burst yet.  And show '(--s)' for servers
5365         where its not sure.
5366
5367         * doc/example.conf: Fixed wrapped U:
5368
5369 2000-03-30  Kevin L. Mitchell  <klmitch@mit.edu>
5370
5371         * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
5372         mode_parse() (version selectable at compile time)
5373
5374         * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
5375
5376         * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
5377
5378         * config/config-sh.in: add new config option to enable new m_mode
5379         implementation
5380
5381         * doc/Configure.help: add documentation for new config option
5382         CONFIG_NEW_MODE
5383
5384         * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
5385         MODE -v : Not enough parameters
5386
5387         * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
5388         +k and +l even if they weren't set...
5389
5390         * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
5391
5392         * ircd/channel.c: make mode_process_clients() clear the DEOPPED
5393         flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
5394         for; test the 0-th member, not the i-th member, of the client
5395         change state stuff
5396
5397         * ircd/m_clearmode.c (do_clearmode): use the new
5398         mode_invite_clear() function
5399
5400         * ircd/channel.c: cleared up all the compile-time warnings and
5401         errors
5402
5403         * include/channel.h: added declarations for mode_ban_invalidate()
5404         and mode_invite_clear()
5405
5406         * ircd/channel.c: finished mode_parse(), then broke it up into a
5407         dozen or so helper functions to make the code easier to read
5408
5409 2000-03-29  Thomas Helvey <tomh@inxpress.net>
5410         * ircd/ircd.c: refactor server initialization a bit, use
5411         getopt for parsing command line, refactor init_sys, main,
5412         and other bits.
5413
5414         * ircd/s_bsd.c: add functions for initialization to clean
5415         up logic a bit and remove duplicated code.
5416
5417         * include/ircd.h: add struct for server process related
5418         variables.
5419
5420 2000-03-29  Kevin L. Mitchell  <klmitch@mit.edu>
5421
5422         * ircd/channel.c: initial definition of mode_parse(); flags to
5423         prevent doing the same thing multiple times; helper method
5424         send_notoper() to send a "Not oper"/"Not on channel" notice
5425
5426         * include/channel.h: declare mode_parse() and helper flags
5427
5428         * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
5429         sending to match the current action of set_mode() closely enough
5430         that hopefully there won't be major conflicts
5431
5432         * ircd/channel.c (modebuf_flush_int): consolidated the mode string
5433         building logic, reversed the order of the arguments to mode
5434         commands to have '-' preceed '+'
5435
5436 2000-03-29  Thomas Helvey <tomh@inxpress.net>
5437         * ircd/s_bsd.c (add_connection): don't disable socket options
5438         let OS tune itself and allow important performance tweaks to 
5439         work.
5440
5441 2000-03-28  Kevin L. Mitchell  <klmitch@mit.edu>
5442
5443         * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
5444         confused by set_mode, which is doing some really weird logic;
5445         guess what I'm going to rewrite next?  ;)
5446
5447 2000-03-28  Kevin L. Mitchell  <klmitch@emc.com>
5448
5449         * include/channel.h: added MODE_SAVE for the bounds checking stuff
5450         in modebuf_flush
5451
5452         * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
5453         make it do bounds checking on the buffer; all modes are sent only
5454         if the all parameter is 1; modebuf_flush is the exported wrapper
5455
5456         * include/channel.h: add BOUNCE, renumber flags to get a little
5457         more space
5458
5459         * ircd/channel.c (modebuf_flush): don't overload HACK2, add
5460         BOUNCE; send DESYNCH message
5461
5462 2000-03-27  Kevin L. Mitchell  <klmitch@emc.com>
5463
5464         * ircd/m_clearmode.c (do_clearmode): only mark the modes the
5465         channel actually has in effect for deletion
5466
5467         * ircd/channel.c: added explanatory comments to all added
5468         functions; made flushing take place at the correct place even if
5469         the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
5470         to bash some stupid bugs; made modebuf_flush() return if ModeBuf
5471         is empty, fixed the apparent source, removed some bogus string
5472         termination code, properly terminate the mode strings, add support
5473         for HACK2 and HACK3, made limit strings not be sent if the limit
5474         is being removed, changed where '+' and '-' come from in sent
5475         strings, added support for DEOP flag, set up bouncing code for
5476         HACK2
5477
5478         * ircd/Makefile.in: ran make depend
5479
5480         * include/channel.h: added new defines for future functionality,
5481         made modebuf_flush() return int so I can use tail recursion
5482
5483         * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
5484         to make it all compile
5485
5486         * ircd/m_opmode.c: add msg.h to includes...
5487
5488         * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
5489
5490         * ircd/channel.c (modebuf_flush): realized I forgot to
5491         nul-terminate addbuf/rembuf properly...
5492
5493         * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
5494
5495         * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
5496         sendto_serv_butone--blah^2
5497
5498         * ircd/send.c (sendto_serv_butone): stupid comments confused me
5499
5500         * ircd/channel.c (modebuf_flush): if there are no mode changes to
5501         propagate, we're done...
5502
5503         * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
5504         not sendto_all_butone
5505
5506         * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
5507
5508         * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
5509
5510         * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
5511         the list
5512
5513         * ircd/parse.c: added messages for opmode and clearmode
5514
5515         * include/handlers.h: added declarations for mo_opmode(),
5516         ms_opmode(), mo_clearmode(), and ms_clearmode()
5517
5518         * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
5519         TOK_CLEARMODE
5520
5521         * include/channel.h (MODEBUF_DEST_OPMODE): Define the
5522         MODEBUF_DEST_OPMODE flag
5523
5524         * ircd/channel.c (modebuf_flush): added new flag,
5525         MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
5526         to originate from source's server (or source itself, if
5527         IsServer(source)); also causes a server-level MODE to be sent as
5528         OPMODE instead
5529
5530         * include/channel.h: defined MODEBUF_DEST_SERVER,
5531         MODEBUF_DEST_HACK4
5532
5533         * ircd/channel.c: Add another argument to build_string() to handle
5534         numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
5535         servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
5536         to be sent out
5537
5538 2000-03-27  Perry Lorier <isomer@coders.net>
5539
5540         * ircd/s_bsd.c: fixed missing 'u' typo.
5541
5542 2000-03-26  Kevin L. Mitchell  <klmitch@emc.com>
5543
5544         * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
5545         _mode_string(), _mode_client(), _flush(); also implemented a
5546         simple build_string()
5547
5548         * include/channel.h: added definition of ModeBuf, modebuf_*
5549         manipulation functions, and a couple of helper macros
5550