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