Delete obsolete convert-conf.py.
[ircu2.10.12-pk.git] / ChangeLog
1 2005-11-16  Michael Poole <mdpoole@troilus.org>
2
3         * tools/convert-conf.py: Delete obsolete code.
4
5 2005-11-16  Michael Poole <mdpoole@troilus.org>
6
7         * ircd/m_names.c (m_names): Fix handling of NAMES #a,#b.
8         (ms_names): Likewise.
9
10 2005-11-15  Michael Poole <mdpoole@troilus.org>
11
12         * ircd/m_nick.c (ms_nick): Clarify message when an older nick
13         overrules a newer nick.  When killing a client for a nick
14         collision, make sure to use the numnick as the first argument.
15
16 2005-11-14  Michael Poole <mdpoole@troilus.org>
17
18         * ircd/channel.c (member_can_send_to_channel): After prodding from
19         reed, always allow remote users to send to a channel.  He also
20         pointed out a bug in the first version of this change.
21
22 2005-11-14  Carlo Wood <run@alinoe.com>
23
24         * ircd/channel.c (modebuf_flush_int): Fix test for limitdel.
25         (modebuf_mode_uint): Make sure the limit is included as an
26         argument when necessary (and only when necessary) in a bounce.
27
28         * ircd/m_destruct.c (ms_destruct): Generate a mode bounce instead
29         of burst to resynchronize a non-empty destructed channel.
30
31 2005-11-14  Michael Poole <mdpoole@troilus.org>
32
33         * ircd/channel.c (find_no_nickchange_channel): Disallow nick
34         changes by voiceless no-account users on a +r channel.
35
36 2005-11-14  Michael Poole <mdpoole@troilus.org>
37
38         * ircd/m_kick.c (ms_kick): Fix test for whether a client's own
39         server is kicking him.
40
41 2005-11-13  Michael Poole <mdpoole@troilus.org>
42
43         * include/patchlevel.h (PATCHLEVEL): Bump for pre04.
44
45 2005-11-13  Michael Poole <mdpoole@troilus.org>
46
47         * include/patchlevel.h (PATCHLEVEL): Update for release.
48
49 2005-11-13  Carlo Wood <run@alinoe.com>
50
51         * ircd/m_create (ms_create): Accept CREATE for zannels.
52
53         * ircd/m_join.c (m_join): MODE +o for a zannel must come from the
54         server for compatibility with older versions.
55
56 2005-11-12  Michael Poole <mdpoole@troilus.org>
57
58         * include/patchlevel.h (PATCHLEVEL): Bump for pre03.
59
60 2005-11-12  Michael Poole <mdpoole@troilus.org>
61
62         * include/patchlevel.h (PATCHLEVEL): Update for release.
63
64 2005-11-11  Michael Poole <mdpoole@troilus.org>
65
66         * ircd/ircd_res.c (proc_answer): Follow CNAME when doing A
67         and AAAA lookups as well as PTR.
68
69 2005-11-07  Michael Poole <mdpoole@troilus.org>
70
71         * ircd/channel.c (mode_parse_client): Allow clients to specify
72         oplevel in MODE #channel +o.
73         (mode_process_clients): Allow oplevel 999 to deop another 999.
74
75         * ircd/kick.c (m_kick): Allow oplevel 999 to kick another 999.
76
77 2005-10-31  Michael Poole <mdpoole@troilus.org>
78         (Based on a patch by Romain Bignon <progs@ir3.org>)
79
80         * ircd/channel.c: Some modes (currently only WASDELJOINS) should
81         not be propagated to remote servers.
82
83 2005-10-30  Michael Poole <mdpoole@troilus.org>
84
85         * ircd/channel.c (mode_parse_apass): Move all send_reply() errors
86         inside an if (MyUser(state->sptr)) test.
87
88         * ircd/m_join.c (m_join): Reorganize zannel join check to match
89         surrounding code.
90
91 2005-10-30  Carlo Wood <run@alinoe.com>
92
93         * ircd/channel.c (sub1_from_channel): Delay destruction for -A
94         channels.  They become zombie channels (zannels).
95         (mode_parse_upass): Add duration to ERR_NOMANAGER message.
96         (mode_parse_apass): Likewise.  Unconditionally set the member who
97         sets Apass as oplevel 0.  Clear Upass when clearing Apass.
98         (joinbuf_join): Remove code to pass oplevel in JOIN.
99
100         * ircd/m_burst.c (ms_burst): Handle zannels.
101
102         * ircd/m_join.c (m_join): Handle a join to a zannel.  If the user
103         is joining with ops and/or an oplevel, send those.
104         (ms_join): Stop trying to parse oplevels in JOIN.  Copy join
105         timestamp when a user joins a zannel.
106
107         * ircd/m_mode.c (ms_mode): Never generate HACK3.  Silently allow a
108         user to op himself if he is the only one in a channel.
109
110         * ircd/s_err.c (ERR_UPASSSET): Remove extra space.
111         (ERR_UPASSNOTSET): Likewise.
112         (ERR_NOMANAGER): Add field for channel lifetime.
113
114 2005-10-30  Michael Poole <mdpoole@troilus.org>
115
116         * ircd/m_join.c (m_join): Fix check for OVERRIDE when the real
117         channel key is OVERRIDE.  (Reworked patch from a1kmm.)
118
119 2005-10-30  Michael Poole <mdpoole@troilus.org>
120
121         * .cvsignore: Add autom4te.cache.
122
123         * ircd/.cvsignore: Add convert-conf.
124
125         * ircd/test/.cvsignore: Add ircd_match_t.
126
127         * patches/.cvsignore: Add marks.
128
129 2005-10-28  Alex Badea  <vamposdecampos@gmail.com>
130
131         * ircd/m_kick.c (ms_kick): Fix format string typo (bug #1339538)
132
133 2005-10-17  Diane Bruce  <db@db.net>
134
135         * ircd/ircd_res.c: Don't send retries if the client did
136         not resolve (SERVFAIL); this fixes a bug causing a flurry
137         of retries in this case
138
139 2005-10-14  Michael Poole <mdpoole@troilus.org>
140
141         * include/patchlevel.h (PATCHLEVEL): Update to pre02.
142
143 2005-10-14  Michael Poole <mdpoole@troilus.org>
144
145         * doc/readme.cvs: Document tag name consistently with the release
146         name.
147
148         * include/patchlevel.h (PATCHLEVEL): Bump patchlevel for release
149         of 2.10.12.01.
150
151 2005-10-12  Michael Poole <mdpoole@troilus.org>
152
153         * doc/example.conf: Update documentation to match this change.
154
155         * ircd/client.c (client_set_privs): Make default global oper
156         privileges match what was in 2.10.11.
157
158 2005-10-11  Michael Poole <mdpoole@troilus.org>
159
160         * ircd/os_generic.c (os_get_rusage): Make conditional on DEBUGMODE
161         to mitigate bug #1313429.
162
163 2005-10-12  Perry Lorier <isomer@undernet.org>
164
165         * include/s_stats.h: Add new "Local" only flag to /stats.
166
167         * ircd/m_stats.c: Consult it.
168
169         * ircd/s_stats.c: Use the flag.
170
171 2004-01-04  Kevin L Mitchell  <klmitch@mit.edu>
172
173         * ircd/s_numeric.c (do_numeric): fix a crash when a numeric is
174         sent to a channel...
175
176 2005-10-06  Michael Poole <mdpoole@troilus.org>
177
178         * ircd/m_join.c (m_join): Report too-long channel names as
179         non-existent.
180
181 2005-10-05  Michael Poole <mdpoole@troilus.org>
182
183         * ircd/m_names.c (m_names): Fix format string when forwarding
184         /names -D to other servers.
185         (ms_names): Likewise.  Add support for remote /names -D.
186
187 2005-10-05  Michael Poole <mdpoole@troilus.org>
188
189         * ircd/class.c (do_find_class): Fix bug from previous commit.
190
191         * ircd/ircd_parser.y (clientblock): Allow setting Client port.
192
193         * ircd/s_conf.c (check_limit_and_attach): Merge into attach_iline.
194         (attach_iline): Only set FLAG_DOID when we are sure we will attach
195         this Client block to the client. [Credit: Jukka Ollila and others]
196
197 2005-10-04  Michael Poole <mdpoole@troilus.org>
198         [Based on a patch by Jukka Ollila]
199
200         * include/class.h (find_class): Rename to do_find_class().
201
202         * ircd/class.c (class_delete_marked): Keep invalid classes in list
203         until next rehash.
204         (add_class): Use new parameter to do_find_class() to allow a class
205         to be "resurrected".
206         (find_class): Rename.
207         (report_classes): Use 'y' instead of 'Y' when reporting invalid
208         classes.
209
210 2005-10-01  Michael Poole <mdpoole@troilus.org>
211
212         * ircd/m_kick.c (ms_kick): If the kick target is join-delayed,
213         only send the KICK to the kicker.  Spotted by Cesar_.
214
215 2005-10-01  Michael Poole <mdpoole@troilus.org>
216
217         * include/patchlevel.h (PATCHLEVEL): Update to pre1.
218
219         * ircd/class.c (init_class): Only set default class's ->next
220         pointer when first allocating it.
221
222 2005-09-30  Michael Poole <mdpoole@troilus.org>
223
224         * ircd/m_who.c (m_who): Handle matchsel & WHO_FIELD_ACC when
225         matching users.
226
227 2005-09-30  Michael Poole <mdpoole@troilus.org>
228
229         * include/patchlevel.h: Update for release.
230
231 2005-09-28  Michael Poole <mdpoole@troilus.org>
232
233         * ircd/m_kick.c (ms_kick): Use correct oplevel when bouncing a
234         chanop being kicked.
235
236 2005-09-26  Michael Poole <mdpoole@troilus.org>
237
238         * ircd/whocmds.c (do_who): Fix uninitialized variable warning
239         about 'chan'.
240
241 2005-09-26  Michael Poole <mdpoole@troilus.org>
242
243         * ircd/parse.c (del_msg_element): Only delete empty subtrees, and
244         leave subtrees that may still contain data.
245
246 2005-09-26  Michael Poole <mdpoole@troilus.org>
247
248         * include/channel.h (struct ModeBuf): Add mbm_oplevel to args
249         array.
250         (MB_OPLEVEL): New corresponding macro.
251         (modebuf_mode_client): Add corresponding argument.
252
253         * ircd/channel.c (modebuf_flush_int): Adjust worst-case buffer
254         usage to include :999 suffix.  Change format for oplevel passing.
255         (modebuf_mode_client): Set oplevel field in mbuf args array.
256         (struct ParseState): Add oplevel field to cli_change array.
257         (mode_parse_client): Accept and record oplevel suffix from
258         servers; fix it up if we're bouncing a deop.
259         (mode_process_clients): If a valid oplevel was parsed, use it.
260
261         * ircd/m_burst.c (ms_burst): Pass oplevel to modebuf_mode_client().
262
263         * ircd/m_clearmode.c (do_clearmode): Likewise.
264
265         * ircd/m_create.c (ms_create): Likewise.
266
267         * ircd/m_kick.c (ms_kick): Likewise.
268
269 2005-09-23  Michael Poole <mdpoole@troilus.org>
270
271         * include/whocmds.h (WHOSELECT_DELAY): Define new constant.
272
273         * ircd/m_who.c (m_who): Accept 'd'/'D' as a way to set
274         WHOSELECT_DELAY, just like 'o' for WHOSELECT_OPER.  Do not skip
275         join-delayed users if WHOSELECT_DELAY is set.
276
277         * ircd/whocmds.c (do_who): Remember membership for shared channel
278         if one exists.  Use it when displaying flags, adding '<' for
279         join-delayed users.
280
281 2005-09-22  Michael Poole <mdpoole@troilus.org>
282
283         * ircd/channel.c (mode_parse_key): Only accept the new key when
284         the current one is empty or "greater" than the new one.
285         (mode_parse_upass): Likewise, for upass.
286         (mode_parse_apass): Likewise, for apass.
287
288 2005-09-22  Michael Poole <mdpoole@troilus.org>
289
290         * ircd/gline.c (gline_checkmask): Add missing digit in mask length
291         check.
292
293 2005-09-21  Michael Poole <mdpoole@troilus.org>
294
295         * doc/example.conf: Remove confused and outdated references to
296         Martians.
297
298 2005-09-20  Michael Poole <mdpoole@troilus.org>
299
300         * ircd/Makefile.in: Regenerate "make depend" dependencies.
301
302         * ircd/test/Makefile.in: Likewise.
303
304 2005-09-16  Kevin L. Mitchell  <klmitch@mit.edu>
305
306         * ircd/m_join.c (last0): fix problem leading to protocol
307         violations on certain combinations of /join 0 from remote servers
308         (probably from local users, too) [bug #1291029]; remove redundant
309         !IsChannelChar() check
310
311 2005-09-14  Michael Poole <mdpoole@troilus.org>
312
313         * doc/readme.cvs: Document the branching scheme for 2.10.12.
314
315 2005-09-14  Michael Poole <mdpoole@troilus.org>
316
317         * include/patchlevel.h (PATCHLEVEL): Increment to reflect the
318         pre-release code freeze.
319
320 2005-09-14  Michael Poole <mdpoole@troilus.org>
321
322         * ircd/channel.c (find_ban): Fix the sense of another check.
323
324 2005-09-13  Michael Poole <mdpoole@troilus.org>
325
326         * include/channel.h (clean_channelname): Remove prototype.
327
328         * ircd/m_invite.c (m_invite): Do not clean channel name; just
329         reject invalid channel names.
330
331         * ircd/m_join.c (m_join): Likewise.
332
333         * ircd/m_mode.c (m_mode): Do not clean channel name.
334
335         * ircd/m_names.c (m_names): Likewise.
336
337         * ircd/m_opmode.c (mo_opmode): Likewise.
338
339 2005-09-13  Michael Poole <mdpoole@troilus.org>
340
341         * ircd/channel.c (find_ban): Revert to older style of comparison,
342         fixing the sense of one check.  Spotted by Alex Badea.
343
344 2005-09-13  Alex Badea <vamposdecampos@gmail.com>
345
346         * ircd/ircd.c (try_connections): modify autoreconnect logic to
347         allow FEAT_CONNECTFREQUENCY to be smaller than Class connectfreq
348
349 2005-09-13  Alex Badea <vamposdecampos@gmail.com>
350
351         * ircd/s_conf.c (close_mappings): NULL out GlobalServiceMapList,
352         otherwise the linked list has an invalid ending sentinel on rehash
353
354 2005-09-12  Michael Poole <mdpoole@troilus.org>
355
356         * ircd/channel.c (find_ban): Compare ban mask against hostname
357         even when it looks like an IP, to match things like *!*@1.* when
358         users have a hostname like 1.2.3.example.com.
359
360 2005-09-12  Michael Poole <mdpoole@troilus.org>
361
362         * RELEASE.NOTES: Note the resolution of ambiguous ipmasks.
363
364         * ircd/ircd_string.c (ipmask_parse): Implement it.
365
366 2005-09-12  Michael Poole <mdpoole@troilus.org>
367
368         * ircd/m_join.c (m_join): If we find an empty key, null out the
369         key pointer.
370
371 2005-09-11  Michael Poole <mdpoole@troilus.org>
372
373         * RELEASE.NOTES: Mention the side benefits of this change.
374
375         * include/ircd_string.h (ipmask_parse): Declare function here.
376         (ircd_aton): Becomes a special case of ipmask_parse().
377
378         * include/match.h (check_if_ipmask): Undeclare function.
379         (ipmask_parse): Remove function prototype from this file.
380
381         * ircd/ircd_string.c (ircd_aton_ip4): Add nullable pbits parameter
382         to accept ipmask length.  Rework to fill that in.
383         (ircd_aton): Rework into...
384         (ipmask_parse): this function, which knows how to fill in its own
385         pbits parameter.
386
387         * ircd/m_burst.c (ms_burst): Rely on make_ban() to set the ban
388         flags correctly, to avoid call to check_if_ipmask().
389
390         * ircd/match.c (ipmask_parse_ipv4): Delete function.
391         (check_if_ipmask): Likewise.
392         (ipmask_parse): Delete this version in favor of ircd_string.c's.
393
394         * ircd/test/ircd_in_addr_t.c (ipmask_test): New struct type.
395         (test_masks): New array of ipmask_test.
396         (test_ipmask): Function to run one of those tests.
397         (main): Call test_ipmask().
398
399 2005-09-11  Alex Badea <vamposdecampos@gmail.com>
400
401         * ircd/m_ping.c (ms_ping, mo_ping): misplaced chunk of code
402         (probably during the forward port) which broke AsLL; fixed.
403
404 2005-09-01  Michael Poole <mdpoole@troilus.org>
405
406         * ircd/gline.c (make_gline): Remove debug output from when IPv6
407         support was being debugged.
408         (do_gline): Likewise.
409         (gline_lookup): Likewise, plus remove redundant code.
410
411 2005-09-01  Michael Poole <mdpoole@troilus.org>
412
413         * ircd/channel.c (joinbuf_join): Ignore joinbuf type when joining
414         0, since no other call passes a null channel.
415
416         * ircd/m_join.c: Remove comment discussing argument meanings.
417         (last0): Make this also handle the JOIN 0 logic, doxyfy.
418         (join0): Merge into last0.
419         (m_join): Doxygenate.  Remove check for join0.  Further
420         reorganize, so new versus old channel handling are moved to just
421         one place each within this function.
422         (ms_join): Doxygenate.  Remove check for join0.
423
424 2005-09-01  Michael Poole <mdpoole@troilus.org>
425
426         * RELEASE.NOTES: Bump revision date and highlight this change.
427
428         * include/channel.h (MAGIC_OPER_OVERRIDE): Remove.
429         (can_join): Remove declaration.
430
431         * ircd/channel.c (compall): Remove.
432         (can_join): Remove.
433
434         * ircd/m_join.c (m_join): Remove redundant check for control
435         characters (clean_channelname() will get them). Reorganize initial
436         flags calculation.  Accept channel keys like RFC 1459 says; this
437         requires the old compall()/can_join() logic to modify 'keys', so
438         inline the code and reorganize it.
439
440 2005-08-30  Michael Poole <mdpoole@troilus.org>
441
442         * include/channel.h (PASSLEN): Remove; use KEYLEN instead.
443
444         * ircd/channel.c (mode_parse_upass): Likewise.
445         (mode_parse_apass): Likewise.
446         The inconsistency (in clean_key()) was reported by Reed.
447
448 2005-08-30  Michael Poole <mdpoole@troilus.org>
449
450         * RELEASE.NOTES: Document +D and +d channel modes.
451
452 2005-08-29  Michael Poole <mdpoole@troilus.org>
453
454         * include/numeric.h (ERR_NOMANAGER_LONG): Undefine.
455         (ERR_NOMANAGER_SHORT): Rename to ERR_NOMANAGER.
456
457         * ircd/s_err.c (replyTable): Change to reflect that.
458
459         * ircd/channel.c (clean_key): New function.
460         (mode_parse_key): Use it, and check that keys do not start with :.
461         (mode_parse_upass): Likewise, and adjust for ERR_NOMANAGER.
462         (mode_parse_apass): Likewise.
463         The key and password changes fix bugs reported by coekie.
464
465 2005-08-27  Michael Poole <mdpoole@troilus.org>
466
467         * ircd/channel.c (add_user_to_channel): Use SetOpLevel() instead
468         of assigning directly to member->oplevel.
469         (mode_parse_apass): Likewise.
470         (mode_process_clients): Users opped by outsiders should get
471         oplevel 1, since they are not channel managers.
472
473         * ircd/m_burst.c (ms_burst): Use SetOpLevel() instead of assigning
474         directly to member->oplevel.
475
476 2005-08-25  Michael Poole <mdpoole@troilus.org>
477
478         * ircd/channel.c (member_can_send_to_channel): At coekie's
479         suggestion, disallow channel manager talking after Apass is set,
480         so they set and use Upass sooner.
481
482         * ircd/class.c (init_class): Default class should have 1 link.
483         (report_classes): Return links count minus one to match old output.
484
485         * ircd/m_trace.c (do_trace): Fix links count here, too (spotted by
486         Reed).
487
488 2005-08-25  Michael Poole <mdpoole@troilus.org>
489
490         * ircd/channel.c (mode_parse): Accept +A/+U from servers
491         regardless of FEAT_OPLEVELS.
492
493 2005-08-24  Michael Poole <mdpoole@troilus.org>
494
495         * ircd/ircd.c (parse_command_line): Mention epoll engine when run
496         with -v.
497
498 2005-08-24  Michael Poole <mdpoole@troilus.org>
499
500         * include/patchlevel.h (PATCHLEVEL): Increment.
501
502         * ircd/channel.c (joinbuf_join): Double check that oplevel is 0 or
503         1 when propagating JOIN <level>:#channel, to avoid PV on receiver.
504
505         * ircd/engine_epoll.c: Add system call numbers for more CPU types.
506
507         * ircd/ircd_log.c (log_open): Remove NFS-oriented alarm() calls;
508         anyone who writes logs over NFS is mental.  (Thanks to D. Bruce.)
509
510 2005-08-21  Michael Poole <mdpoole@troilus.org>
511
512         * include/s_conf.h (free_mapping): Declare new function.
513
514         * ircd/ircd_parser.y (pseudoblock): Use it.
515
516         * ircd/s_conf.c (free_mapping): Define it.
517         (close_mappings): New function.
518         (rehash): Call close_mappings() before reading file.
519
520         * ircd/m_kill.c (do_kill): Revert 2005-08-18 change.
521
522 2005-08-19  Michael Poole <mdpoole@troilus.org>
523
524         * ircd/parse.c (tok_tree): Re-add token tree structure.
525         (initmsgtree): Populate it.
526         (parse_server): Prefer it to full message tree.
527
528 2005-08-18  Michael Poole <mdpoole@troilus.org>
529
530         * ircd/m_kill.c (do_kill): When FEAT_HIS_KILLWHO, change apparent
531         source of KILLs to &his instead of &me.
532
533 2005-08-16  Michael Poole <mdpoole@troilus.org>
534
535         * ircd/channel.c (mode_parse_ban): Avoid overwriting part of
536         newban->banstr[] when the source is a server.  (Spotted by jcq.)
537
538 2005-08-16  Michael Poole <mdpoole@troilus.org>
539
540         * ircd/channel.c (joinbuf_join): Switch to &his instead of &me for
541         announcements to local users in a channel.
542
543         * ircd/m_burst.c (ms_burst): Likewise.
544
545         * ircd/m_invite.c (m_invite): Likewise.
546         (ms_invite): Likewise.
547
548         * ircd/m_kick.c (ms_kick): Likewise.
549
550         * ircd/m_topic.c (do_settopic): Another &me -> &his change for
551         HIS, and use that apparent source for the channel localcast.
552
553 2005-08-16  Jukka Ollila <jaollila@niksula.hut.fi>
554
555         * ircd/s_user.c (hide_hostmask): Use HIS_SERVERNAME instead of the
556         real thing for the post-mode-x rejoin.
557
558 2005-08-15  Michael Poole <mdpoole@troilus.org>
559
560         * include/supported.h (FEATURESVALUES2): Add +d channel mode.
561
562         * ircd/IPcheck.c (ip_registry_new_entry): Clarify that this is not
563         a varadic function.  (Suggested by Ian Kumlien.)
564
565         * ircd/convert-conf.c (finish_operators): Likewise.
566
567         * ircd/listener.c (close_listeners): Likewise.
568
569         * ircd/channel.c (CheckDelayedJoins): Use HIS server name to
570         remove channel mode +d.
571
572 2005-08-12  Michael Poole <mdpoole@troilus.org>
573
574         * ircd/channel.c (pretty_mask): Recognize ':' as unique to the
575         host part of a ban mask.
576
577 2005-08-03  Jan Krueger <jast@heapsort.de>
578
579         * ircd/m_kick.c (m_kick): Send JOIN prior to confirming KICK on
580         invisible member.
581
582 2005-08-08  Michael Poole <mdpoole@troilus.org>
583
584         * ircd/channel.c (find_ban): For non-IPmask bans, match the ban
585         string against the string form of the client's IP address.
586
587 2005-07-16  Michael Poole <mdpoole@troilus.org>
588
589         * configure.in: Apply a test for socklen_t that Reed found.
590
591         * configure: Regenerate.
592
593 2005-07-16  Michael Poole <mdpoole@troilus.org>
594
595         * RELEASE.NOTES: Mention that 2.10.11 does not support oplevels.
596
597         * README.FreeBSD: Remove (merged into README).
598
599         * README.Solaris: Remove (merged into README).
600
601         * README: Merge in the above; also update for 2.10.12.
602
603         * doc/example.conf: Change mention of K-lines to say Kill blocks
604         instead.
605
606         * doc/iauth.txt: Remove (out of date).
607
608         * doc/readme.features: Update to reflect that 2.10.11 is not the
609         current release.  Change mention of various config lines to use
610         the equivalent config entries or blocks instead.
611
612         * doc/readme.log: Likewise.
613
614         * doc/api/features.txt: Change F-line mentions to say Feature
615         entry instead.
616
617         * doc/api/modebuf.txt: Change U-line mention to say Uworld entry.
618
619         * doc/api/motd.txt: Change T-line mentions to say Motd entry.
620
621 2005-07-15  Michael Poole <mdpoole@troilus.org>
622
623         * ircd/ircd_features.c (feature_init): Always call
624         feature_notify_server*() so that 'his' is initialized.
625
626         * ircd/m_whois.c (do_whois): Unswap sense of comparison to choose
627         between user->server and &his.
628
629 2005-07-14  Michael Poole <mdpoole@troilus.org>
630
631         * ircd/channel.c (mode_parse_apass): Update oplevels when setting
632         or removing the +A password.  Partial credit goes to Reed Loden.
633
634 2005-07-14  Michael Poole <mdpoole@troilus.org>
635
636         * include/ircd_features.h: Declare new "his" pseudo-server to hold
637         FEAT_HIS_SERVERNAME and FEAT_HIS_SERVERINFO in a convenient place.
638
639         * ircd/ircd_features.c: Initialize and update it.
640
641         * ircd/channel.c (modebuf_flush_int): Use it as the apparent
642         source for opmodes and server mode changes (also when the source
643         is me).
644
645         * ircd/m_burst.c (ms_burst): Use it as the apparent source for net
646         rider kicks.
647
648         * ircd/m_whois.c (do_whois): Use it to simplify code here.
649
650         * ircd/s_misc.c (exit_client): Use it as the apparent killer.
651
652 2005-07-14  Michael Poole <mdpoole@troilus.org>
653
654         * doc/example.conf (General): Update comment about vhost to match
655         the code change below.
656
657         * ircd/ircd_parser.y (generalvhost): Accept vhost="*"; as a
658         synonym for the default behavior (for backwards compatibility).
659         Spotted by Kev.
660
661         * ircd/channel.c (sub1_from_channel): Remove stale code and
662         comment, replacing with an up-to-date comment.  Spotted by skx.
663
664 2005-07-11  Michael Poole <mdpoole@troilus.org>
665
666         * ircd/engine_select.c: Remove outdated comment about USE_POLL.
667
668         * ircd/parse.c (msgtab): #if out CAP handler until we have caps.
669
670         * RELEASE.NOTES: Remove mention of capabilities for now.
671
672 2005-07-11  Stephan Peijnik <speijnik@gmail.com>
673
674         * ircd/gline.c (gline_add): It's only a protocol violation when a
675         server issues a "whacky" gline.  If it's an oper, only tell opers
676         with SNO_GLINE.
677
678         * ircd/ircd_auth.c (iauth_protocol_violation): Likewise, the whole
679         network is not likely to care about IAuth PVs, so only tell opers
680         with SNO_CONNEXIT.
681
682 2005-07-11  Michael Poole <mdpoole@troilus.org>
683
684         * doc/readme.features: Document FEAT_CHANNELLEN.
685
686         * doc/example.conf: Give an example of it.
687
688         * ircd/m_join.c (ms_join): Do not clean channel names from remote
689         servers, to avoid desynchs.
690
691         * ircd/m_names.c (ms_names): Likewise.
692
693 2005-07-11  Stephan Peijnik <speijnik@gmail.com>
694
695         * include/ircd_features.h: Declare new FEAT_CHANNELLEN.
696
697         * include/supported.h: Add it to the ISUPPORT display.
698
699         * ircd/channel.c (clean_channelname): Impose the lower limit
700         between FEAT_CHANNELLEN and CHANNELLEN.
701
702         * ircd/ircd_features.c: Define FEAT_CHANNELLEN.
703
704 2005-07-11  Reed Loden <reed@reedloden.com>
705
706         * include/sys.h: Move FD_SETSIZE redefinition to engine_select.c.
707
708         * ircd/s_bsd.c: Move FD_SETSIZE sanity check to engine_select.c
709         Remove unused #include <sys/poll.h>.
710
711         * ircd/engine_select.c: Put FD_SETSIZE redefinition and sanity
712         checks here, since they are not used elsewhere in the daemon.
713         [Order slightly changed by Michael Poole to compile.]
714
715 2005-07-03  Michael Poole <mdpoole@troilus.org>
716
717         * ircd/convert-conf.c: New file.
718
719         * ircd/Makefile: Compile it.
720
721 2005-06-27  Michael Poole <mdpoole@troilus.org>
722
723         * ircd/s_bsd.c (add_connection): Split logic for server versus
724         client listeners; only do IPcheck for client connections.
725
726         * ircd/s_serv.c (server_estab): There is no longer a need to
727         remove IPcheck reference, so don't.
728
729 2005-06-27  Michael Poole <mdpoole@troilus.org>
730
731         * include/client.h (struct Connection): Remove con_dns_reply (and
732         associated macros).
733
734         * include/res.h (gethost_byname): Change calling signature to
735         clarify memory ownership.
736         (gethost_byaddr): Likewise.
737
738         * include/s_bsd.h (release_dns_reply): Remove function.
739
740         * ircd/hash.c: #include "match.h" to quash warning.
741
742         * ircd/ircd_auth.c (struct IAuth): Remove i_query field.
743         (iauth_dns_callback): Adjust for new gethost_byname signature.
744         (iauth_reconnect): Likewise.
745
746         * ircd/ircd_res.c (struct reslist): Make elements of query field
747         inline rather than in a contained structure.
748         (make_request): Reflect removal of DNSQuery.
749         (do_query_name): Likewise.
750         (do_query_number): Likewise.
751         (make_dnsreply): Remove now-unused function.
752         (timeout_resolver): Adjust to new callback signature.
753         (delete_resolver_queries): Reflect removal of DNSQuery.
754         (gethost_byname): Update to new signature.
755         (gethost_byaddr): Likewise.
756         (res_readreply): Reflect removal of DNSReply.
757
758         * ircd/list.c (dealloc_connection): con_dns_reply no longer
759         exists, so do not free it.
760
761         * ircd/s_auth.c (auth_verify_hostname): constify.
762         (auth_dns_callback): Adjust to new callback signature.
763         (start_auth): Adjust to new gethost_byaddr() signature.
764
765         * ircd/s_bsd.c (connect_dns_callback): Adjust to new callback
766         signature.
767         (release_dns_reply): Remove unused function.
768         (connect_server): Adjust to new gethost_byname() signature.
769
770         * ircd/s_conf.c (conf_dns_callback): Adjust to new callback
771         signature.
772         (conf_dns_lookup): Adjust to new gethost_byname() signature.
773         (attach_iline): Use cli_sockhost() instead of DNS reply.
774         (conf_check_server): Simplify use of DNS results.
775
776         * ircd/s_serv.c (server_estab): Remove call to removed function.
777
778         * ircd/s_user.c (register_user): Remove call to removed function.
779
780 2005-06-27  Michael Poole <mdpoole@troilus.org>
781
782         * include/s_misc.h (get_sockhost): Remove the unused (and
783         deceptively named) get_sockhost().
784
785         * ircd/s_misc.c (get_sockhost): Likewise.
786
787 2005-06-25  Andrew Miller  <a1kmm@amxl.com>
788
789         * ircd/ircd_crypt.c (ircd_crypt): strdup is not allowed, change to
790         DupStr so memdebug works.
791
792         * doc/debug_memleak_gc.patch : Update to gc6.5
793         
794 2005-06-24  Andrew Miller  <a1kmm@amxl.com>
795         * ircd/m_invite.c (m_invite): Don't propagate invites to local channels.
796         
797 2005-06-21  Andrew Miller  <a1kmm@amxl.com>
798
799         * ircd/m_list.c (param_parse): Add support for channel wildcards.
800         * ircd/m_list.c (show_usage): Document the new format.
801         * ircd/hash.c (list_next_channels): Check channel wildcard in list.
802         * include/channel.h (ListingArgs): Add the wildcard member.
803
804 2005-06-19  Andrew Miller  <a1kmm@amxl.com>
805
806         * ircd/ircd_res.c (proc_answer): Deal with unexpected record types more
807         gracefully.
808
809         * ircd/ircd_res.c (res_readreply): Check res_ourserver before walking
810         the pending request list, to make DoS attacks harder.
811
812         * ircd/m_invite.c (m_invite): Give no such channel rather than not on
813         channel when the channel being invited to does not exist.
814         
815 2005-06-18  Michael Poole <mdpoole@troilus.org>
816
817         * ircd/s_debug.c (count_memory): Consolidate several lines; make
818         initial letter capitalization consistent.
819
820 2005-06-19  Andrew Miller  <a1kmm@amxl.com>
821
822         * ircd/s_stats.c: Remove the "debug only" label on memusage stats,
823         since it no longer applies.
824
825 2005-05-16  Michael Poole <mdpoole@troilus.org>
826
827         * include/channel.h (struct Ban): Make 'who' and 'banstr' direct
828         arrays, rather than pointers.
829
830         * ircd/channel.c (bans_alloc): New variable to count number of ban
831         structures allocated.
832         (bans_inuse): New variable to count number of ban structures
833         currently in use.
834         (set_banmask): Adapt to changes in struct Ban.
835         (make_ban): Likewise, and update ban counts.
836         (free_ban): Likewise.
837         (bans_send_meminfo): New function.
838         (apply_ban): Adapt to changes in struct Ban.
839         (mode_parse_ban): Likewise.
840         (mode_process_bans): Likewise.
841         (mode_parse): Likewise.
842         (RevealDelayedJoin): Fix brace placement.
843         (CheckDelayedJoins): Fix brace placement and whitespace.
844
845         * ircd/list.c (struct liststats): Add new fields to eliminate the
846         separate count variables.
847         (init_list): Adapt to those changes.
848         (alloc_client): Likewise.
849         (dealloc_client): Likewise.
850         (alloc_connection): Likewise.
851         (dealloc_connection): Likewise.
852         (make_server): Likewise.
853         (remove_client_from_list): Likewise.
854         (verify_client_list): Likewise.
855         (make_link): Likewise.
856         (free_link): Likewise.
857         (send_liststats): New function.
858         (send_listinfo): Rewrite to use new struct liststats layout.
859
860         * ircd/m_burst.c (ms_burst): Adapt to changes in struct Ban.
861
862         * ircd/m_clearmode.c (do_clearmode): Adapt to changes in struct
863         Ban.
864
865         * ircd/s_stats.c (stats_meminfo): Define unconditionally and call
866         bans_send_meminfo().
867         (statsinfo): Always give access to stats_meminfo.
868
869 2005-06-16  Michael Poole <mdpoole@troilus.org>
870
871         * include/ircd_string.h: Include necessary <string.h> header.
872
873         * ircd/test/.cvsignore: Ignore log output files.
874
875         * ircd/test/Makefile.in: Remove log output files.
876
877         * ircd/test/kill-block-1.cmd: Add sleeps to try to trigger Kills.
878
879         * ircd/test/run-tests.sh: Switch sense of argument.  Send an IRC
880         debug dump to log files.
881
882 2005-06-13  Michael Poole <mdpoole@troilus.org>
883
884         * ircd/s_user.c (make_user): Unconditionally increment userCount.
885         (free_user): Unconditionally decrement it here.
886
887         * ircd/s_conf.c (make_conf): Unconditionally increment
888         GlobalConfCount.
889         (free_conf): Unconditionally decrement it here.
890
891         * ircd/s_debug.c (count_memory): Fix termination condition for
892         ban-walking loop.  Add missing "e" to "members".
893
894
895 2005-06-10  Michael Poole <mdpoole@troilus.org>
896
897         * ircd/match.c (check_if_ipmask): Strings that contain '?' cannot
898         be true IP masks.
899
900 2005-05-30  Michael Poole <mdpoole@troilus.org>
901
902         * ircd/test/Makefile.in: Add LDFLAGS variable for profiling purposes.
903
904         * ircd/test/ircd_match_t.c: Test recovery from backtracking.
905
906         * ircd/test/channel-1.cmd: Modify to improve code coverage.
907
908         * ircd/test/client-1.cmd: Likewise.
909
910         * ircd/test/gline-1.cmd: Likewise.
911
912         * ircd/test/ircd-t1.conf: Likewise.
913
914         * ircd/test/stats-1.cmd: Likewise.
915
916         * ircd/test/run-tests.sh: Explicitly start ircds.  Add new test scripts.
917
918         * ircd/test/test-driver.pl: Silently handle more signals from IRC.
919
920         * ircd/test/commands-1.cmd: New test script.
921
922         * ircd/test/feature-1.cmd: New test script.
923
924         * ircd/test/jupe-1.cmd: New test script.
925
926         * ircd/test/kill-block-1.cmd: New test script.
927
928         * ircd/test/ircd-t1-2.conf: New configuration file for test scripts.
929
930         * ircd/test/ircd-t2.conf: Likewise.
931
932 2005-05-30  Michael Poole <mdpoole@troilus.org>
933
934         * ircd/s_debug.c (count_memory): Use count_listener_memory() to
935         report memory used by listener structures.
936
937 2005-05-30  Michael Poole <mdpoole@troilus.org>
938
939         * include/class.h (get_con_freq): Remove unused function.
940
941         * include/list.h (find_user_link): Remove unused function.
942
943         * include/class.c (get_con_freq): Remove.
944
945         * ircd/list.c (find_user_link): Remove.
946
947         * include/string.h (string_is_hostname, string_is_address,
948         strnChattr): Remove unused functions.
949         (init_string): Remove function that becomes a noop.
950
951         * ircd/string.h (init_string): Remove.
952         (string_is_hostname, string_is_address, strnChattr): Likewise.
953
954         * ircd/ircd.c (main): Remove call to init_string().
955
956 2005-05-30  Michael Poole <mdpoole@troilus.org>
957
958         * include/numeric.h (RPL_TRACELOG, RPL_MYPORTIS,
959         RPL_NOTOPERANYMORE): Undefine unused numeric replies.
960
961         * ircd/s_err.c (replyTable): Fix format fields for certain numeric
962         arguments.  Remove some unused entries.
963
964         * ircd/s_stats.c (stats_configured_links): Move invariant
965         parameters to message format string.
966
967 2005-05-30  Michael Poole <mdpoole@troilus.org>
968
969         * ircd/client.c (privtab): Add missing LIST_CHAN privilege, move
970         WIDE_GLINE to reflect its enumerated value.
971
972         * ircd/s_debug.c (count_memory): Use user_count_memory() function
973         to count User structs in-use.
974
975         * ircd/m_server.c (mr_server): Change "C:line" to "Connect block".
976
977         * ircd/s_bsd.c (connect_server): Likewise.
978
979         * ircd/s_conf.c (conf_check_server): Likewise.
980
981         * ircd/s_err.c (replyTable): Change "O-lines" to "Operator block".
982
983 2005-05-30  Michael Poole <mdpoole@troilus.org>
984
985         * ircd/match.c (match): Rewrite to handle globs that end in an
986         escaped wildcard (and hopefully clarify the code).
987
988         * ircd/test/Makefile.in: Add new ircd_match_t test program.
989
990         * ircd/test/ircd_match_t.c: New file.
991
992         * ircd/test/test_stub.c: Emite newlines after log and debug
993         messages.
994
995 2005-05-25  Reed Loden <reed@reedloden.com>
996
997         * ircd/s_err.c (replyTable): Allow for the specification of 'O' or
998         'o' in RPL_STATSOLINE.
999
1000         * ircd/s_stats.c (stats_configured_links): In /stats o/O, display
1001         'O' if either the oper block or the connection class has
1002         PRIV_PROPAGATE (global oper) and 'o' if neither has PRIV_PROPAGATE
1003         (local oper).
1004
1005 2005-05-30  Michael Poole <mdpoole@troilus.org>
1006
1007         * ircd/IPcheck.c: Add Debug()s to try to track why the connected
1008         count underflows.
1009
1010         * ircd/m_endburst.c (ms_endofburst): Avoid dereferencing 'chan'
1011         after it may be freed (in sub1_from_channel).
1012
1013         * ircd/s_user.c (register_user): Rearrange code to reduce number
1014         of "if (MyConnect(sptr))" checks.
1015
1016 2005-05-12  Michael Poole <mdpoole@troilus.org>
1017
1018         * configure.in: Do not try to outsmart the default CFLAGS.
1019         Simply add parameters explicitly requested by the user.
1020
1021         * configure: Regenerate.
1022
1023         * ircd/ircd_crypt_native.c: Use _XOPEN_SOURCE 600 (which is
1024         used in os_generic.c) to get crypt() on NetBSD.
1025
1026 2005-05-11  Kevin L. Mitchell  <klmitch@mit.edu>
1027
1028         * ircd/ircd.c: if debugging is enabled (both DEBUGMODE defined and
1029         -x given), reserve fd 2 for the use of the debugging log;
1030         otherwise, some engines may attempt to use fd 2, which would end
1031         up getting closed by debug_init() (actually, by
1032         log_debug_reopen(), called by log_debug_init(), called by
1033         debug_init())
1034
1035 2005-08-10  Michael Poole <mdpoole@troilus.org>
1036
1037         * ircd/channel.c (joinbuf_join): Do not send a MODE +o when a
1038         local user creates a channel.
1039
1040         * ircd/umkpasswd.c (crypt_pass): Allocate the proper amount of
1041         memory for the tagged output string.
1042
1043         * ircd/test/test-driver.pl: Add -vhost=... option.
1044
1045         * ircd/test/ircd-t1.conf: Add new Operator blocks.
1046
1047         * ircd/test/*.cmd: Rearrange and add more coverage tests.
1048
1049 2005-08-09  Michael Poole <mdpoole@troilus.org>
1050
1051         * ircd/ircd_parser.y: Move error tokens to top level of parse, and
1052         make ';' a synchronizing token for them.  This avoids crashes in
1053         situations like missing ';' between two Kill blocks.  Move several
1054         ';'s earlier for earlier detection of syntax errors.
1055
1056         * ircd/motd.c (motd_memory_count): Use size_t for memory counts to
1057         match the format strings used for those variables.
1058
1059         * ircd/msgq.c (msgq_histogram): tmp.sizes[] is an array of
1060         unsigned int, not unsigned long; use correct format string.
1061
1062         * ircd/s_stats.c (stats_crule_list): Restore display of 'D' vs 'd'
1063         based on crule type, rather than query type.
1064         (statsinfo): Remove STAT_FLAG_VARPARAM from the "modules" and
1065         "help" stats, which don't use the varparam.
1066
1067         * ircd/test/test-driver.pl: Interpreter for test scripts.b
1068
1069         * ircd/test/ircd-t1.conf: Configuration file for test scripts.
1070
1071         * ircd/test/*.cmd: New test scripts for test-driver.pl.
1072
1073 2005-05-08  Jukka Ollila <jaollila@niksula.hut.fi>
1074         (Adapted slightly by Michael Poole.)
1075
1076         * ircd/os_generic.c (sockaddr_to_irc): Change to use v4compat
1077         addresses event when !defined(IPV6).
1078
1079 2005-05-07  Michael Poole <mdpoole@troilus.org>
1080
1081         * ircd/channel.c (joinbuf_join): Be smarter about what source to
1082         use when opping a user that joins a channel.
1083
1084 2005-05-04  Reed Loden <reed@reedloden.com>
1085
1086         * ircd/m_trace.c (do_trace): Show the real nickname instead of the
1087         numnick.
1088
1089 2005-05-02  Jan Krueger <jast@heapsort.de>
1090
1091         * ircd/channel.c (member_can_send_to_channel): if the channel can only
1092         be joined by users with accounts (+r), do not allow users without
1093         accounts to speak.
1094
1095 2005-05-07  Michael Poole <mdpoole@troilus.org>
1096
1097         * ircd/numnicks.c (base64toip): Fix bugs in parsing IPv6
1098         addresses.
1099         * ircd/test/ircd_in_addr_t.c (test_addrs): Add new entry.
1100         (test_address): Test base64toip() as well.
1101
1102 2005-05-05  Michael Poole <mdpoole@troilus.org>
1103
1104         * ircd/s_user.c (umode_str): Only clear the operator flag when not
1105         propagating; never set it.
1106
1107 2005-05-04  Michael Poole <mdpoole@troilus.org>
1108
1109         * ircd/channel.c (joinbuf_join): Include channel manager flag in
1110         determination of oplevel.  If opping the user for a non-local
1111         non-create, include oplevel in message to other servers.  Send
1112         "MODE +o <client>" to local users whenever opping the client.
1113
1114         * ircd/m_join.c (m_join): Remove logic that moved into
1115         joinbuf_join().
1116         (ms_join): Look for level 0 and 1 joins from remote servers
1117         and adjust value of 'flags' appropriately.
1118
1119 2005-05-04  Michael Poole <mdpoole@troilus.org>
1120
1121         * include/numeric.h: Remap oplevel numerics to new range.
1122
1123         * ircd/s_err.c: Likewise.
1124
1125 2005-05-03  Michael Poole <mdpoole@troilus.org>
1126
1127         * ircd/s_stats.c (stats_access): Update to use new CONF_CLIENT
1128         fields, fixing crash found by nighty.
1129
1130 2005-05-02  Michael Poole <mdpoole@troilus.org>
1131
1132         * include/numeric.h (ERR_UPASS_SAME_APASS): New error message when
1133         trying to set +U pass to the same as the +A pass.
1134
1135         * ircd/channel.c (mode_parse_upass): Use it.
1136
1137         * ircd/ircd_auth.c (iauth_exit_client): Only send ExitUser if
1138         there is an active IAuth connection, fixing PR#1193808.
1139         (iauth_dispose_request): Only delete the timer if it is active.
1140
1141         * ircd/m_invite.c (m_invite): Always forward the invite in the
1142         correct direction, and then skip it as 'one' if announcing.
1143         (ms_invite): Likewise.
1144
1145         * ircd/numnicks.c (base64toip): Do not interpret AAAAAA as
1146         ::ffff:0.0.0.0; keep it as ::.
1147
1148         * ircd/s_err.c (replyTable): Add ERR_UPASS_SAME_APASS.
1149
1150 2005-05-01  Michael Poole <mdpoole@troilus.org>
1151
1152         * doc/readme.log: Document IAUTH log target, remove docs for
1153         OLDLOG log target.
1154
1155         * include/ircd_log.h: Add LS_IAUTH target, remove LS_OLDLOG.
1156
1157         * ircd/ircd_log.c (logDesc): Likewise.
1158
1159         * ircd/engine_epoll.c (engine_loop): Handle EPOLLHUP for all
1160         sockets (e.g. when connecting) and do not generate read/write
1161         events in the same pass as error or EOF events.
1162
1163         * ircd/ircd_auth.c: Convert old sendto and debug messages to use
1164         the LS_IAUTH log target.  Consistently use IAUTH_CONNECTED flag
1165         instead of comparing fd to -1.
1166         (iauth_reconnect): If already connected, disconnect and schedule a
1167         reconnect later, since an immediate reconnect can cause assertion
1168         failure in the event engine.  Also schedule a reconnect when the
1169         connection attempt fails.
1170         (iauth_read): Reconnect on IO_FAILURE.
1171         (iauth_sock_callback): Disconnect and schedule a reconnect on both
1172         error (after reporting the error) and EOF.
1173         (iauth_start_client): Record the IAuth request in the client.
1174         (iauth_exit_client): Report the client exit.
1175
1176         * ircd/s_misc.c (exit_one_client): Fix formatting.
1177
1178 2005-04-30  Michael Poole <mdpoole@troilus.org>
1179
1180         * ircd/ircd_auth.c (iauth_connect): Initialize (but do not add)
1181         timer here and set fd to -1.
1182         (iauth_schedule_reconnect): Rewrite to handle previously
1183         initialized timer.
1184         (iauth_reconnect): If server is connected, disconnect first.
1185         Update socket generator fd before calling socket_add().
1186         (iauth_read): When reading 0 bytes (EOF), reconnect.
1187
1188 2005-04-27  Michael Poole <mdpoole@troilus.org>
1189
1190         * ircd/ircd_parser.y: Report non-existent class names as errors
1191         earlier, and do not fall back to "default" for Client blocks.
1192
1193 2005-04-25  Reed Loden  <reed@reedloden.com>
1194
1195         * ircd/ircd_lexer.l: Add missing header to squash a warning.
1196
1197 2005-04-25  Michael Poole <mdpoole@troilus.org>
1198
1199         * ircd/s_user.c (register_user): Replace call with set_user_mode()
1200         with a direct parsing of user modes.  To match this, revert the
1201         initial display of usermode to how it was done before.
1202
1203 2005-04-24  Michael Poole <mdpoole@troilus.org>
1204
1205         * doc/example.conf: Document new autoconnect field of Connect.
1206
1207         * include/s_conf.h: Add CONF_AUTOCONNECT and field for it.
1208
1209         * ircd/ircd.c (try_connections): Skip non-autoconnect servers.
1210
1211         * ircd/ircd_lexer.l: Recognize autoconnect token.
1212
1213         * ircd/ircd_parser.y: Add autoconnect= option to Connect block.
1214
1215         * ircd/m_invite.c (m_invite): Avoid sending channel timestamp to
1216         user being invited.
1217         (ms_invite): Likewise.
1218
1219         * ircd/s_user.c (register_user): Show class name rather than
1220         pointer-as-integer.
1221
1222 2005-04-24  Michael Poole <mdpoole@troilus.org>
1223
1224         * ircd/ircd_parser.y: Rewrite so each error condition gets its own
1225         error message, and so that invalid parameters are printed out.
1226
1227 2005-04-23  Michael Poole <mdpoole@troilus.org>
1228
1229         * ircd/channel.c (apply_ban): Consistently free newban->banstr
1230         when the function fails.
1231         (mode_process_bans): Free banstr for all BAN_DEL bans.
1232
1233         * ircd/ircd_parser.y: Fix a few memory leaks from previous commit.
1234
1235 2005-04-23  Michael Poole <mdpoole@troilus.org>
1236
1237         * include/patchlevel.h: Bump to being a beta.
1238
1239         * ircd/ircd_lexer.l (QSTRING): Return a copy of the string so that
1240         parser actions don't have to be immediately after a QSTRING.
1241
1242         * ircd/ircd_parser.y (FNAME): Remove unused token.
1243         (QSTRING): Adjust for QSTRING being an already-copied version.
1244
1245 2005-04-23  Michael Poole <mdpoole@troilus.org>
1246
1247         * doc/example.conf (UWorld): Illustrate new config extension.
1248
1249         * ircd/ircd_parser.y (uworldblock): Do the expected thing when
1250         multiple name= entries are present.
1251
1252 2005-04-22  Michael Poole <mdpoole@troilus.org>
1253
1254         * RELEASE.NOTES: Silence exceptions use ~, not -.  Oops!
1255
1256         * doc/example.conf: Fix typo in example Kill block.
1257
1258         * ircd/channel.c (mode_parse_ban): Use correct test for flag_p.
1259
1260         * ircd/m_silence.c (apply_silence): Make mask pretty so that later
1261         processing does not convert * to @ (and match no one).
1262
1263 2005-04-21  Kevin L. Mitchell  <klmitch@mit.edu>
1264
1265         * ircd/m_userip.c (userip_formatter): /userip should *never*
1266         report the user's real IP unless its answering the user
1267         him/herself
1268
1269         * ircd/m_userhost.c (userhost_formatter): /userhost should *never*
1270         report the user's real host unless its answering the user
1271         him/herself
1272
1273 2005-04-20  Michael Poole <mdpoole@troilus.org>
1274
1275         * ircd/ircd.c (parse_command_line): Update usage text.
1276
1277         * ircd/numnicks.c (base64toip): Use v4mapped address range instead
1278         of v4compat address range, fixing IPv4-based /who.
1279
1280 2005-04-19  Michael Poole <mdpoole@troilus.org>
1281
1282         * configure.in: When --enable-profile, add -pg to LDFLAGS.
1283
1284         * configure: Regenerate.
1285
1286 2005-04-19  Michael Poole <mdpoole@troilus.org>
1287
1288         * ircd/match.c (check_if_ipmask): Fix brown-paper-bag typo.
1289
1290         * ircd/s_conf.c (conf_debug_iline): Look for matching Kill blocks
1291         once a matching Client block is found.
1292
1293         * ircd/m_whowas.c (m_whowas): Change strcmp() to ircd_strcmp().
1294
1295 2005-04-18  Michael Poole <mdpoole@troilus.org>
1296
1297         * ircd/match.c (check_if_ipmask): Do not interpret masks that
1298         start with . or / as IP-based host masks.
1299
1300 2005-04-17  Michael Poole <mdpoole@troilus.org>
1301
1302         * ircd/channel.c (mode_process_clients): Only prohibit deops of
1303         users with the same or higher oplevel where apass is set.
1304         Likewise, when opping users, give them MAXOPLEVEL for non-apass
1305         channels.
1306         (joinbuf_join): Give new ops MAXOPLEVEL for non-apass channels.
1307
1308         * ircd/m_kick.c (m_kick): Only prohibit kicks of users with the
1309         same or higher oplevel where apass is set.
1310
1311         * ircd/s_user.c (register_user): Fix order of server version vs
1312         various mode strings.
1313
1314         * tools/linesync/linesync.sh: Add revision id field.
1315
1316 2005-04-17  Michael Poole <mdpoole@troilus.org>
1317
1318         * tools/linesync/linesync.sh: Fix typo comment.  Check for
1319         multiple blocks per line in the linesync input.
1320
1321 2005-04-17  Dan <daniel@undernet.org>
1322
1323         * tools/linesync/linesync.sh: Update to support new syntax and to
1324         avoid rehashing the ircd when the config is the same.
1325
1326         * tools/linesync/linesync.conf: Update allowed conf items.
1327
1328 2005-04-16  Michael Poole <mdpoole@troilus.org>
1329
1330         * doc/example.conf (Kill): Document newly supported syntax.
1331
1332         * include/s_conf.h (DenyConf): Split realname mask into its own
1333         field.  Remove the unused DENY_FLAGS_{IP,REALNAME}.
1334
1335         * ircd/ircd_parser.y (Kill): Only require one of usermask,
1336         hostmask, realmask to be set for a valid block.
1337         (killitem): Add new production killusername.
1338
1339         * ircd/s_conf.c (conf_erase_deny_list): Free realmask field.
1340         (find_kill): Rearrange slightly to clarify control flow.
1341
1342         * ircd/s_err.c (RPL_STATSKLINE): Stick usermask before hostmask,
1343         so the old usermask field can be adopted for realname mask.  Add
1344         double quotes around the realmask field.
1345
1346         * ircd/s_stats.c (report_deny_list): Do so.
1347         (stats_klines): Likewise.
1348
1349 2005-04-17  Perry Lorier <isomer@undernet.org>
1350         
1351         * tools/convert-conf.py: Fix lots of conversion problems with
1352         oper privielges (now they are converted), 
1353         features (deprecated features commented out, most converted to
1354         priviliges), 
1355         realname klines (also add host= lines)
1356         quarintines (generate blocks for them), 
1357         connect blocks (don't generate empty port config lines)
1358         etc...
1359
1360 2005-04-16  Michael Poole <mdpoole@troilus.org>
1361
1362         * ircd/gline.c (do_gline): Fix typo when activating IP-based
1363         G-lines.
1364
1365 2005-04-16  Michael Poole <mdpoole@troilus.org>
1366
1367         * ircd/class.c (free_class): Free default_umode field.
1368
1369         * ircd/ircd_parser.y (classblock): Free default_umode field before
1370         overwriting it.
1371
1372         * ircd/s_conf.c (free_conf): Free username, origin_name, hub_limit
1373         fields.
1374         (find_kill): Realname Kill blocks no longer have $R at the start,
1375         so do not skip over the first two characters of the mask.
1376
1377 2005-04-15  Michael Poole <mdpoole@troilus.org>
1378
1379         * doc/example.conf (Operator): Properly qualify plaintext password.
1380         (Quarantine): Document (new) syntax.
1381
1382         * ircd/ircd.c: Add <sys/time.h> to make <sys/resource.h> compile
1383         correctly on BSDs.
1384
1385         * ircd/ircd_parser.y (qconf): Remove global variable.
1386         (killuhost): Null terminate username when present.
1387         (quarantineblock): Replace with a syntax that works.
1388
1389         * ircd/s_stats.c: #include <querycmds.h> for UserStats.
1390         (stats_server_verbose): Reinstate check for UserStats.
1391
1392 2005-04-09  Kevin L. Mitchell  <klmitch@mit.edu>
1393
1394         * ircd/ircd.c: conditionally include sys/resource.h; otherwise,
1395         RLIMIT_CORE will not be defined and so set_core_limit() will never
1396         be defined, much less run.
1397
1398         * configure.in: add sys/resource.h to the list of headers to
1399         search for
1400
1401         * configure: regenerate configure
1402
1403         * config.h.in: rerun autoheader to add HAVE_SYS_RESOURCE_H to
1404         config.h.in
1405
1406 2005-04-08  Michael Poole <mdpoole@troilus.org>
1407
1408         * include/s_conf.h (conf_debug_iline): Declare new function.
1409
1410         * ircd/ircd.c (dbg_client): New file-scoped variable.
1411         (parse_command_line): Set it from the new -c option.
1412         (main): If dbg_client is set during chkconf, use it.
1413
1414         * ircd/ircd_string.c (ircd_aton): Generate IPv4-mapped addresses,
1415         not IPv4-compatible addresses, to match ipmask_parse().
1416
1417         * ircd/m_whowas.c (m_whowas): Split display of real host to a
1418         separate line, in hopes of not confusing opers in the future.
1419
1420         * ircd/s_conf.c (conf_debug_iline): Implement new function.
1421
1422 2005-04-06  Michael Poole <mdpoole@troilus.org>
1423
1424         * ircd/m_burst.c (ms_burst): Clear channel manager bit when wiping
1425         out locally opped and voiced channel members.
1426
1427 2005-04-06  Michael Poole <mdpoole@troilus.org>
1428
1429         * include/numeric.h (RPL_APASSWARN): Replace with three distinct
1430         values.
1431         (ERR_NOMANAGER_LONG): Assign new numeric.
1432         (ERR_NOMANAGER_SHORT): Assign new numeric.
1433
1434         * ircd/channel.c (parse_mode_upass): Adapt to new formats for
1435         ERR_NOTMANAGER separation.
1436         (parse_mode_apass): Likewise.  Also adapt to RPL_APASSWARN split.
1437
1438         * ircd/s_err.c (RPL_APASSWARN): Replace with three message
1439         strings, to avoid embedding long message strings in the logic
1440         implementation.
1441         (ERR_NOTMANAGER): Likewise (but not the same strings).
1442
1443 2005-04-06  Michael Poole <mdpoole@troilus.org>
1444
1445         * ircd/ircd_parser.y (clientblock): Use the password field.
1446
1447         * ircd/s_user.c (register_user): Allow aconf->password to be a
1448         single digit, since per-IP limit is now in a separate field.
1449
1450 2005-04-06  Michael Poole <mdpoole@troilus.org>
1451
1452         * acinclude.m4 (unet_PIPE_CFLAGS): Remove; -pipe is obsolete in
1453         current gcc releases and is slower than files for previous
1454         releases on most OSes.
1455
1456         * configure.in (AC_PREREQ): Bump to 2.59 because of AS_HELP_STRING.
1457         (unet_PIPE_CFLAGS): Remove use of macro.
1458
1459         * aclocal.m4: Regenerate.
1460
1461         * configure: Likewise.
1462
1463 2005-04-04  Michael Poole <mdpoole@troilus.org>
1464
1465         * configure.in: For developers' ease, allow passing an option to
1466         configure to persistently set optimization CFLAGS.
1467
1468         * configure: Regenerate.
1469
1470 2005-04-04  Michael Poole <mdpoole@troilus.org>
1471
1472         * doc/example.conf (Jupe): Make the default Jupe block follow
1473         CFV-0255.  (Thanks to FrankP for pointing me at this and to DinTn
1474         for getting me a copy of the CFV.)
1475
1476 2005-04-04  Michael Poole <mdpoole@troilus.org>
1477
1478         * include/capab.h (CAPFL_STICKY): Define.
1479         (CAPLIST): Remove the entries used for testing.
1480
1481         * include/client.h (Connection): Clarify comment about the
1482         distinction between con_capab and con_active.
1483
1484         * ircd/m_cap.c: Add doxygen comments and replace the long
1485         discussion of m_handler functions with an xref to it.
1486         (send_caplist): Add new parameters and change the terminal vs
1487         non-terminal line distinction to make compliant with current draft
1488         specification.
1489         (cap_empty): Rename to cap_ls().
1490         (cap_req): Track modified capabilities bitwise, so that the
1491         responding ACK contains all the appropriate flags.
1492         (cap_ack): Add comment explaining why there is no response.
1493         (cap_clear): Build and send a list of cleared capabilities, as
1494         required by the current draft.
1495         (cap_list): Send capability list using LIST subcommand.
1496         (cmdlist): Add handler for LS subcommand.  Remove entries for the
1497         empty and LSL subcommands, which are no longer allowed.
1498         (m_cap): Require at least one argument from user.
1499
1500 2005-04-01  Michael Poole <mdpoole@troilus.org>
1501
1502         * include/s_conf.h (SMAP_FAST): Define.
1503         (s_map): Add 'flags' field.
1504
1505         * ircd/ircd_lexer.l: Recognize 'FAST' token.
1506
1507         * ircd/ircd_parser.y (FAST): New token.
1508         (pseudoitem): Add pseudoflags alternative.
1509         (pseudoflags): New production, recognizing FAST token.
1510
1511         * ircd/parse.c (register_mapping): Set MFLG_SLOW conditionally.
1512         Remove outdated comment.
1513
1514 2005-04-01  Michael Poole <mdpoole@troilus.org>
1515
1516         * include/handlers.h (ms_privs): Declare.
1517
1518         * include/msg.h (TOK_PRIVS): Assign token.
1519         (CMD_PRIVS): Define.
1520
1521         * ircd/m_privs.c: Add doxygen comments and replace the long
1522         discussion of m_handler functions with an xref to it.
1523         (mo_privs): Forward requests for non-local users
1524         to their own server.
1525         (ms_privs): Implement.
1526
1527         * ircd/parse.c (PRIVS): Dispatch to ms_privs when a server sends
1528         the message.
1529
1530 2005-03-30  Michael Poole <mdpoole@troilus.org>
1531
1532         * include/client.h (struct Client): Explain where cli_username
1533         comes from.
1534
1535         * include/struct.h (struct User): Explain where this username
1536         comes from, too
1537
1538         * ircd/ircd_res.c (timeout_resolver): Update parameter name in
1539         Doxygen comment, too.
1540
1541         * ircd/s_misc.c (get_client_name): Reorganize to have less
1542         indentation and behave like 2.10.11 when client is not idented.
1543
1544 2005-03-29  Michael Poole <mdpoole@troilus.org>
1545
1546         * doc/example.conf: Remove no-longer-used HIS_STATS_h.
1547
1548         * doc/readme.features: Likewise.
1549
1550         * include/ircd_features.h: Likewise.
1551
1552         * ircd/ircd_features.c: Likewise.
1553
1554 2005-03-20  Reed Loden <reed@reedloden.com>
1555
1556         * include/ircd_features.h: Alphabetize HIS_STATS_? features.
1557
1558         * ircd/ircd_features.c: Likewise.
1559
1560 2005-03-29  Michael Poole <mdpoole@troilus.org>
1561         (The previously unapplied part of another patch (by Carlo Wood?).)
1562
1563         * ircd/m_part.c (ms_part): Remove a check that should already be
1564         done by the user's own server.
1565
1566 2005-03-29  Michael Poole <mdpoole@troilus.org>
1567
1568         * doc/example.conf: Add HIS_STATS_J entry.
1569
1570         * doc/readme.features: Likewise.
1571
1572 2005-03-25  Reed Loden <reed@reedloden.com>
1573
1574         * include/hash.h: Add needed prototypes for new
1575         stats_nickjupes() function.
1576
1577         * include/ircd_features.h: Add FEAT_HIS_STATS_J.
1578
1579         * include/numeric.h: Add RPL_STATSJLINE (222) for new nick
1580         jupes stats. Correct a typo in a comment.
1581
1582         * ircd/hash.c: Add stats_nickjupes() function to report all
1583         nick jupes to an oper. Because of the nature of hash tables,
1584         there is no way to sort this list so the results look weird.
1585
1586         * ircd/ircd_features.c: Add FEAT_HIS_STATS_J (default: TRUE).
1587
1588         * ircd/s_err.c: Add RPL_STATSJLINE (222) for new nick jupes
1589         stats.
1590
1591         * ircd/s_stats.c: Add RPL_STATSJLINE (222) for new nick jupes
1592         stats. Make 'j' case sensitive. Modify the comment for stats
1593         uworld.
1594
1595 2005-03-27  Michael Poole <mdpoole@troilus.org>
1596
1597         * ircd/m_burst.c (ms_burst): Do not send numeric oplevels in a -A
1598         channel when forwarding a channel burst line.
1599
1600 2005-03-25  Michael Poole <mdpoole@troilus.org>
1601
1602         * ircd/m_server.c (set_server_flags): New function.  Unlike the
1603         old code, this recognizes the IPv6 flag.  (Spotted by Reed.)
1604         (mr_server): Use the new function.
1605         (ms_server): Likewise.  Also don't show "Net junction:" message if
1606         any closer server is still bursting (also spotted by Reed).
1607         Finally, forward the +6 flag to other servers.
1608
1609         * ircd/s_serv.c (server_estab): Forward the +6 flag here, too.
1610
1611         * ircd/s_bsd.c (client_sock_callback): Re-set cli_error() after it
1612         may be cleared by completed_connection().
1613
1614 2005-03-23  Michael Poole <mdpoole@troilus.org>
1615
1616         * ircd/m_burst.c (ms_burst): Remove limit and keys when a channel
1617         is wiped out during burst.
1618
1619 2005-03-22  Michael Poole <mdpoole@troilus.org>
1620
1621         * ircd/ircd_res.c (check_resolver_timeout): I give up.  Use the
1622         kludgy earlier version of the timeout fix.
1623
1624 2005-03-22  Michael Poole <mdpoole@troilus.org>
1625
1626         * ircd/channel.c (send_channel_modes): Fix test for when to send
1627         membership mode suffix, to avoid sending it more than once.
1628
1629 2005-03-22  Michael Poole <mdpoole@troilus.org>
1630         (Many thanks to nex and Reed for helping hunt this down and
1631         doing the testing of various patches.)
1632
1633         * ircd/ircd_events.c (timer_chg): Properly change a timer that is
1634         in the middle of executing its expiration event.
1635
1636         * ircd/ircd_res.c (check_resolver_timeout): Simplify the test for
1637         whether to use timer_chg() or timer_add().
1638         On second thought, use timer_add() unconditionally; the server
1639         connection loop does.
1640         (timeout_resolver): Do not try to re-schedule the DNS timeout
1641         unless it is the expiration event.
1642         (do_query_number): Properly initialize request->state.
1643         (res_readreply): Mention the response code that was bad.
1644
1645 2005-03-22  Michael Poole <mdpoole@troilus.org>
1646
1647         * ircd/engine_kqueue.c (engine_delete): The kernel removes
1648         close()'d FDs from the activity list, so don't try to remove the
1649         FD here (the caller may have already close()'d it).
1650
1651 2005-03-20  Michael Poole <mdpoole@troilus.org>
1652
1653         * ircd/IPcheck.c: Fix typos in comments and strings to reduce
1654         future slumming for credit.
1655
1656         * ircd/channel.c, ircd/crule.c, ircd/engine_epoll.c: Likewise.
1657         * ircd/fileio.c, ircd/hash.c, ircd/ircd.c: Likewise.
1658         * ircd/ircd_auth.c, ircd/ircd_crypt.c: Likewise.
1659         * ircd/ircd_crypt_native.c, ircd/ircd_crypt_smd5.c: Likewise.
1660         * ircd/ircd_features.c, ircd/ircd_log.c: Likewise.
1661         * ircd/ircd_parser.y, ircd/ircd_res.c: Likewise.
1662         * ircd/ircd_reslib.c, ircd/ircd_string.c, ircd/list.c: Likewise.
1663         * ircd/m_burst.c, ircd/m_clearmode.c, ircd/m_destruct.c: Likewise.
1664         * ircd/m_invite.c, ircd/m_ison.c, ircd/m_kill.c: Likewise.
1665         * ircd/m_server.c, ircd/m_squit.c, ircd/m_topic.c: Likewise.
1666         * ircd/m_who.c, ircd/m_whois.c, ircd/m_whowas.c: Likewise.
1667         * ircd/match.c, ircd/msgq.c, ircd/numnicks.c: Likewise.
1668         * ircd/os_generic.c, ircd/parse.c, ircd/s_auth.c: Likewise.
1669         * ircd/s_bsd.c, ircd/s_conf.c, ircd/s_debug.c: Likewise.
1670         * ircd/s_misc.c, ircd/s_numeric.c, ircd/s_serv.c: Likewise.
1671         * ircd/s_stats.c, ircd/s_user.c, ircd/table_gen.c: Likewise.
1672         * ircd/umkpasswd.c, ircd/uping.c, ircd/whowas.c: Likewise.
1673
1674         * ircd/test/test_stub.c: Make exit_client() argument list
1675         consistent with that in s_misc.c so doxygen is not confused.
1676
1677 2005-03-20  Michael Poole <mdpoole@troilus.org>
1678         (Thanks to Reed Loden for pointing these out.)
1679
1680         * ircd/channel.c: Fix typos in comments.
1681
1682         * ircd/m_create.c: Likewise.
1683
1684         * ircd/m_list.c: Likewise.
1685
1686         * ircd/m_names.c: Likewise.
1687
1688         * ircd/numnicks.c: Likewise.
1689
1690         * ircd/s_bsd.c: Likewise.
1691
1692 2005-03-20  Michael Poole <mdpoole@troilus.org>
1693         (Thanks to Reed Loden for pointing these out.)
1694
1695         * doc/Configure.help: Remove outdated file.
1696
1697         * doc/exaconf.2: Likewise.
1698
1699         * doc/snomask.html: Add missing <tr>, SNO_AUTO, SNO_DEBUG, and
1700         update SNO_OPERDEFAULT list.
1701
1702         * tools/mkpasswd.c: Remove outdated file (use ircd/umkpasswd
1703         instead).
1704
1705         * tools/Makefile.crypt: Remove outdated file.
1706
1707         * tools/mkpasswd.c: Likewise.
1708
1709         * tools/transition: Likewise.
1710
1711 2005-03-19  Michael Poole <mdpoole@troilus.org>
1712
1713         * ircd/channel.c (sub1_from_channel): Check apass rather than mode
1714         to determine whether an apass is set (MODE_KEY/APASS/UPASS are not
1715         set in mode.mode).
1716         (send_channel_modes): Use the same change when determining how to
1717         send oplevels for channels.
1718
1719 2005-03-19  Michael Poole <mdpoole@troilus.org>
1720
1721         * include/IPcheck.h (IPcheck_connect_fail): Take a Client
1722         parameter instead of irc_in_addr.
1723
1724         * ircd/IPcheck.c (IPcheck_connect_fail): Likewise.  Assert that
1725         the client has been IP-checked.
1726         (IPcheck_remote_connect): Assert that the client has not yet been
1727         charged for connecting.
1728         (IPcheck_connect_succeeded): Assert that the client has been
1729         charged for connecting.
1730         (IPcheck_disconnect): Likewise.
1731
1732         * ircd/m_nick.c (m_nick): Pass rejected client to
1733         IPcheck_connect_fail() when somebody takes the nick first.
1734         (ms_nick): Likewise.
1735
1736         * ircd/s_serv.c (server_estab): Pass new server to
1737         IPcheck_connect_fail().
1738
1739         * ircd/s_user.c (register_user): When rejecting a user, pass
1740         the struct Client to IPcheck_connect_fail().
1741
1742 2005-03-19  Michael Poole <mdpoole@troilus.org>
1743
1744         * doc/example.conf (Connect): Remove a buggy comment about leaf
1745         directives; refer the reader to the Connect block instead.
1746
1747         * tools/convert-conf.py: Set "leaf;" rather than "leaf = yes;"
1748
1749 2005-03-19  Michael Poole <mdpoole@troilus.org>
1750
1751         * doc/example.conf (Operator): Correct the comment explaining
1752         hashed passwords.
1753
1754         * ircd/m_oper.c (oper_password_match): Check correct variable to
1755         determine whether the hashed password matched.
1756
1757 2005-03-08  Michael Poole <mdpoole@troilus.org>
1758
1759         * ircd/match.c (ipmask_parse): Explicitly zero-initialize the mask
1760         and bit count for "*".
1761         (ipmask_check): Make more robust to similar errors.
1762
1763 2005-03-07  Michael Poole <mdpoole@troilus.org>
1764
1765         * configure.in: Consistently use a constant in AC_DEFINE().
1766
1767         * configure: Regenerate.
1768
1769         * doc/example.conf (Port): Add comment about the mask option.
1770         (Port): Fix the vhosted Port example.
1771
1772         * ircd/ircd_parser.y (clientblock): Correctly initialize the IP
1773         address and addrbits for a Client block with no IP mask.
1774
1775         * ircd/match.c (ipmask_parse): Accept * as a zero-bit mask.
1776
1777         * ircd/s_auth.c (start_auth_query): Count socket allocation
1778         failure as a failed auth check, as .11 does.
1779
1780         * ircd/s_debug.c (debug_serveropts): Add '6' to server options
1781         when compiled with IPv6 support.
1782
1783 2005-02-23  Michael Poole <mdpoole@troilus.org>
1784
1785         * doc/example.conf: Explain apass_opmode privilege, pointing out
1786         that, unlike previous privs, the default is OFF for global opers.
1787
1788         * include/client.h (PRIV_APASS_OPMODE): Define new privilege.
1789
1790         * ircd/channel.c (mode_parse_upass): Only prevent local opers
1791         without the apass_opmode privilege from forcing a +U change.
1792         (mode_parse_apass): Likewise, for +A.
1793
1794         * ircd/client.c (client_set_privs): Turn off PRIV_APASS_OPMODE in
1795         the default privileges for global opers.
1796
1797         * ircd/ircd_lexer.l (apass_opmode): Recognize keyword.
1798
1799         * ircd/ircd_parser.y (TPRIV_APASS_OPMODE): New token.
1800         (privtype): Fix typo for local_badchan privilege value.
1801         Accept apass_opmode token.
1802
1803 2005-02-23  Michael Poole <mdpoole@troilus.org>
1804
1805         * doc/example.conf: Fix comment's description of "whox" privilege.
1806
1807 2005-02-21  Michael Poole <mdpoole@troilus.org>
1808
1809         * include/channel.h (ShowChannel): Remove PRIV_LIST_CHAN check
1810         from here, so /whois does not show secret global channels.
1811
1812         * ircd/m_list.c (param_parse): Require PRIV_LIST_CHAN to use
1813         "/list s".
1814         (m_list): Allow opers with PRIV_LIST_CHAN to see secret channels.
1815
1816 2005-02-21  Perry Lorier <isomer@undernet.org>
1817
1818         * ircd/s_stats.c: Hide the hub IP's.  They're kinda important.
1819
1820 2005-02-20  Perry Lorier <isomer@undernet.org>
1821
1822         * ircd/ircd_parser.y: Moved some parse errors from log_write()'s to
1823         parse_error()'s so that ./ircd -k will display them.  Also clarified
1824         the warning about oper blocks.
1825
1826 2005-02-20  Perry Lorier <isomer@undernet.org>
1827
1828         * tools/convert-conf.py: A multitude of changes to deal with parsing
1829         mistakes, generate a newer config file, better error handling,
1830         being smarter about what config elements you generate etc.
1831         
1832 2005-02-20  Perry Lorier <isomer@undernet.org>
1833
1834         * ircd/engine_epoll.c: Change a size_t to socklen_t to match
1835         getsockopt prototype, so it compiles without warning on amd64
1836
1837 2005-02-19  Michael Poole <mdpoole@troilus.org>
1838
1839         * ircd/ircd_parser.y (clientblock): Parse IP address before
1840         allocating ConfItem; if the parse fails, generate an error.
1841
1842         * ircd/s_err.c (RPL_STATSCLINE): Add format field to prefix IPv6
1843         addresses starting with ':'.
1844         (RPL_STATSILINE): Likewise.
1845         (RPL_STATSOLINE): Add format field for username.
1846
1847         * ircd/s_stats.c (stats_configured_links): Pass the appropriate
1848         argument for the RPL_STATSxLINE changes.
1849         Change RPL_STATSILINE to use * instead of <NULL> when IP or host
1850         is null.
1851
1852 2005-02-18  Michael Poole <mdpoole@troilus.org>
1853
1854         * ircd/IPcheck.c (ip_registry_find): Use canonical form of IP
1855         address to look up and compare against hash entries.
1856
1857         * ircd/channel.c (apply_ban): Do not free a succesful BAN_DEL ban.
1858
1859         * ircd/ircd_parser.y (clientblock): Stash IP string in aconf->name.
1860         (clienthost): Split hosts that contain '@' into username and host.
1861         (clientip): Split IPs that contain '@' into username and IP.
1862         (killreason): Add missing ~ to mask off DENY_FLAGS_FILE.
1863
1864         * ircd/m_silence.c (forward_silences): When we reject a silence,
1865         splice it out of the ban list.  Warn the user if he is local.
1866
1867         * ircd/s_bsd.c (connect_inet): Set IP TOS for outbound server
1868         connections.
1869
1870         * ircd/s_stats.c (stats_configured_links): Display correct field
1871         when listing CONF_UWORLD entries.
1872
1873 2005-02-09  Michael Poole <mdpoole@troilus.org>
1874
1875         * configure.in (YACC): Only warn if we cannot get a version number
1876         from $YACC.
1877
1878         * configure: Regenerate.
1879
1880         * ircd/ircd_res.c (check_resolver_timeout): Try another way to
1881         avoid timer_chg() on a non-queued/active timer.
1882
1883         * ircd/ircd_string.c (ircd_aton): Set part_start to handle input
1884         strings like "::127.0.0.1".
1885
1886         * ircd/test/ircd_in_addr_t.c (test_addrs): Add a test for that.
1887
1888 2005-02-02  Michael Poole <mdpoole@troilus.org>
1889
1890         * Makefile.in (install): Do not create ${prefix}/include since it
1891         is no longer used.
1892
1893         * ircd/Makefile.in (install-*): Remove commented-out code to touch
1894         and chown MPATH and RPATH.
1895
1896         * ircd/gline.c (gline_find): Allow searching for host-based
1897         G-lines by plain hostname (not *@host), thus preventing "GLINE
1898         test ..." from inserting duplicate G-lines.
1899
1900         * ircd/motd.c (motd_create): Null out new Motd's hostmask when
1901         appropriate, avoiding an uninitialized or stale pointer.
1902
1903 2005-01-26  Michael Poole <mdpoole@troilus.org>
1904
1905         * include/ircd_alloc.h (DoMallocZero): Parenthesize macro
1906         arguments, fixing operator precedence problems.
1907         (DoFree): Make debug version also overwrite p.
1908
1909         * include/memdebug.h (fda_get_byte_count, fda_get_block_count):
1910         Declare functions used outside memdebug.c.
1911
1912         * ircd/Makefile.in (UMKPASSWD_SRC): Add memdebug.c.
1913
1914         * ircd/ircd_alloc.c (DoMalloc, DoMallocZero, DoRealloc): Do not
1915         use these if using the memdebug version.
1916
1917         * ircd/memdebug.c: #include "send.h" and <string.h> to get
1918         declarations for certain functions.
1919
1920         * ircd/umkpasswd.c (CurrentTime): Define in case of memdebug.
1921         (sendto_opmask_butone): Likewise.
1922
1923 2005-01-25  Michael Poole <mdpoole@troilus.org>
1924
1925         * configure.in: Fix typos and thinkos in previous commut.
1926
1927         * configure: Regenerate.
1928
1929         * doc/example.conf: Change class name in Connect block to be
1930         consistent with earlier Class block.
1931
1932         * ircd/ircd.c (try_connections): Consider Connect blocks with hold
1933         time of 0.  Fix Links() vs MaxLinks() comparison to reflect ref
1934         count starting at 1.
1935
1936         * ircd/ircd_parser.y (cruleblock, iauthblock): Clear unused
1937         variables after use.
1938
1939 2005-01-24  Michael Poole <mdpoole@troilus.org>
1940
1941         * configure.in: Make sure that $LEX and $YACC are reasonable and
1942         actually run.
1943
1944         * configure: Regenerate.
1945
1946         * ircd/ircd_res.c (check_resolver_timeout): Use correct macro to
1947         test whether the timer is already pending.
1948
1949 2005-01-23  Michael Poole <mdpoole@troilus.org>
1950
1951         * doc/example.conf (Kill): Fix typo in realname Kill block
1952
1953         * include/client.h (infousermodes): Fix typo in comment.
1954
1955         * ircd/ircd.c (parse_command_line): -k implies BOOT_TTY.
1956         (main): Move daemon_init() before event_init() to work around BSD
1957         lameness.
1958
1959 2005-01-23  Michael Poole <mdpoole@troilus.org>
1960
1961         * ircd/test/Makefile.in: Add missing "install" target.  Make
1962         compatible with BSD make (which has no $^ and no $(CPPFLAGS) in
1963         its default .c.o rule).
1964
1965 2005-01-21  Michael Poole <mdpoole@troilus.org>
1966
1967         * ircd/engine_kqueue.c: Move <sys/types.h> earlier to fix build on
1968         FreeBSD 5.x (which needs it for <sys/event.h>).
1969
1970         * ircd/fileio.c (fbopen): Replace BSDism S_IREAD, S_IWRITE with
1971         portable equivalents.
1972
1973         * ircd/ircd_log.c (log_open): Likewise.
1974
1975         * ircd/os_generic.c (_XOPEN_SOURCE): Increase to 600 (SuSv3?) so
1976         that IPv6 definitions become visible on FreeBSD 5.3.
1977
1978         * ircd/s_auth.c: Remove apparently unused <sys/file.h> because
1979         it fails to compile on FreeBSD 5.3.
1980
1981 2005-01-22  Perry Lorier <isomer@undernet.org>
1982
1983         * ircd/ircd_parser.y: Fix missing ;
1984
1985 2005-01-19  Michael Poole <mdpoole@troilus.org>
1986
1987         * ircd/m_invite.c (m_invite, ms_invite): Include timestamp in
1988         outbound INVITE messages.  On incoming INVITEs, ignore if the
1989         timestamp is too recent or if the timestamp is missing and the
1990         peer server is in burst.
1991
1992 2005-01-15  Michael Poole <mdpoole@troilus.org>
1993
1994         * RELEASE.NOTES: Mention CIDR support for Client, Operator, bans
1995         and silences.  Mention net.rider kick change.
1996
1997         * doc/example.conf (Class): Add documentation for restart and
1998         local_opmode privileges.  Fix name of local_jupe privilege.
1999
2000         * ircd/ircd_lexer.l: Recognize local_opmode privilege.
2001
2002 2005-01-14  Michael Poole <mdpoole@troilus.org>
2003
2004         * RELEASE.NOTES: Further updates (mention Pseudo blocks, clarify
2005         CAP comment, mention named /stats, list config heteromorphisms.
2006
2007         * doc/readme.features: Document HIS_STATS_a, HIS_STATS_L,
2008         HIS_STATS_R, LOCAL_CHANNELS, TOPIC_BURST.
2009
2010         * ircd/channel.c (mode_parse_apass): Change old mention of +u mode
2011         to say +U.
2012
2013 2005-01-13  Michael Poole <mdpoole@troilus.org>
2014
2015         * RELEASE.NOTES: Update for 2.10.12.
2016
2017 2005-01-08  Michael Poole <mdpoole@troilus.org>
2018
2019         * ircd/channel.c (@page zombie): Add synopsis to explain what
2020         zombies are supposed to do.
2021
2022         * doc/example.conf (Features): Transfer recommended LOG features
2023         from 2.10.11 example.conf.
2024
2025 2005-01-03  Michael Poole <mdpoole@troilus.org>
2026
2027         * ircd/ircd.c (try_connections): Test Connect hold time before
2028         updating it (spotted by Kev).
2029
2030 2005-01-03  Michael Poole <mdpoole@troilus.org>
2031
2032         * Makefile.in: Add ircd/test as a subdirectory.
2033
2034         * ircd/.cvsignore: Ignore umkpasswd binary.
2035
2036         * ircd/Makefile.in: Update dependencies.
2037
2038         * ircd/test/.cvsignore: New file.
2039
2040         * ircd/test/Makefile.in: Use ${} instead of $().  Add build,
2041         depend, distclean targets to integrate with rest of build system.
2042
2043 2005-01-03  Michael Poole <mdpoole@troilus.org>
2044
2045         * ircd/IPcheck.c (ip_registry_check_remote): Do not count clones
2046         that have an invalid IP address.
2047
2048         * ircd/ircd.c (try_connections): Update Connect hold time before
2049         skipping it, to prevent infinite loops.
2050
2051 2005-01-03  Kevin L Mitchell  <klmitch@mit.edu>
2052
2053         * ircd/s_user.c (is_silenced): is_silenced() would core if sptr
2054         was a server; fixed to skip servers
2055
2056 2004-12-28  Michael Poole <mdpoole@troilus.org>
2057
2058         * include/s_bsd.h (VirtualHost): Replace with separate variables
2059         for IPv4 and IPv6 virtual hosts.
2060
2061         * include/uping.h (uping_echo): Remove declaration.
2062
2063         * ircd/ircd_auth.c (iauth_reconnect): Select VirtualHost_v4 or
2064         VirtualHost_v6 based on iauth server address family.
2065
2066         * ircd/ircd_lexer.l: Do not recognize RESOLVER token.
2067
2068         * ircd/ircd_parser.y (ResolverAddr): Remove declaration.
2069         (RESOLVER): Remove definition.
2070         (generalresolver): Remove.
2071         (generalvhost): Assign address to either VirtualHost_v4 or
2072         VirtualHost_v6, depending on format.
2073
2074         * ircd/ircd_res.c (res_socket): Replace with separate variables
2075         for IPv4 and IPv6 resolver sockets.
2076         (ResolverAddr): Remove definition.
2077         (restart_resolver): Attempt to set up both IPv4 and IPv6 sockets.
2078         (send_res_msg): Select outbound FD based on resolver address type.
2079         (res_readreply): Recognize either inbound socket FD.
2080
2081         * ircd/os_generic.c (sockaddr_from_irc): Require irc != NULL.
2082         (os_socket): Require local != NULL.
2083
2084         * ircd/s_bsd.c (VirtualHost): Replace with separate variables
2085         for IPv4 and IPv6 virtual hosts.
2086         (connect_inet): Select virtual host based on destination address.
2087
2088         * ircd/uping.c (UPingFIleDescriptor): Remove.
2089         (upingSock): Split into separate IPv4 and IPv6 variables.
2090         (uping_echo_callback): Incorporate uping_echo() body here, so the
2091         proper socket FD can be used.
2092         (uping_init): Attempt to set up both v4 and v6 UPING sockets.
2093         (uping_server): Create uping socket with appropriate local address.
2094
2095         * doc/example.conf (General): Update example config file to
2096         reflect removal of Resolver setting and support for separate IPv4
2097         and IPv6 VHost settings.
2098
2099 2004-12-28  Michael Poole <mdpoole@troilus.org>
2100
2101         * ircd/sys.h (BITS_ZERO_ON_*, HAVE_RELIABLE_SIGNALS, DOCURSES,
2102         DOTERMCAP, IRC_UID, IRC_GID, LIMIT_FMT, FALSE, TRUE): Remove
2103         unused macros.
2104
2105         * ircd/ircd_auth.c, ircd/listener.c, ircd/s_auth.c, ircd/s_bsd.c,
2106         ircd/s_conf.c, ircd/uping.c, ircd/whocmds.c: Remove obsolete
2107         #include <arpa/inet.h>.
2108
2109 2004-12-28  Michael Poole <mdpoole@troilus.org>
2110
2111         * ircd/match.c: Remove obsolete #include <arpa/inet.h>.
2112         (ipmask_parse_ipv4): We already parse the dotted quads from the
2113         input string, so use them instead of inet_addr() to populate
2114         out->s_addr.
2115
2116         * ircd/gline.c: Remove obsolete #includes <arpa/inet.h>, "sys.h".
2117         (do_gline): Pass SHOW_IP instead of TRUE as argument to
2118         get_client_name().
2119
2120         * ircd/ircd.c (try_connections): Revise to use fewer temporary
2121         variables.
2122
2123 2004-12-28  Michael Poole <mdpoole@troilus.org>
2124
2125         * include/res.h: Implement irc_in_addr_* as macros.
2126
2127         * ircd/ircd_res.c: Remove the function bodies.
2128
2129         * ircd/ircd_string.c (irc_in_addr_is_ipv4): Remove body.
2130         (ircd_ntoa_r): Do not append extra ':' when unparsing 0::.
2131         (ircd_aton): Accept IPv6 addresses with all eight segments
2132         specified (e.g. 0:0:0:0:0:0:0:0).  Correctly parse addresses
2133         with IPv4 bits at the end (e.g. ::FFFF:127.0.0.1).
2134
2135         * ircd/test/ircd_in_addr_t.c, ircd/test/test_stub.c: New files.
2136
2137         * ircd/test/Makefile: Convert to Makefile.in for proper VPATH
2138         support.  Add test_stub.c and ircd_in_addr_t.c references.
2139
2140         * configure.in: Generate ircd/test/Makefile as an output file.
2141
2142         * configure: Update.
2143
2144 2004-12-18  Michael Poole <mdpoole@troilus.org>
2145
2146         * include/client.h: Move unreg, privs, capab and active fields
2147         from struct Client to struct Connection since that is how they
2148         are really associated.  Adjust macros to match.
2149         (SetPriv, ClrPriv): New macros.
2150
2151         * ircd/client.c (client_set_privs): Exit earlier for remote
2152         clients.  Adjust macro use to correspond.
2153
2154         * ircd/m_server.c (mr_server): Grant all privileges except
2155         PRIV_SET to peer servers.
2156
2157 2004-12-18  Michael Poole <mdpoole@troilus.org>
2158
2159         * ircd/s_user.c (hide_hostmask): Add a missing "break;" to fix bug
2160         #1087461.
2161
2162 2004-12-18  Michael Poole <mdpoole@troilus.org>
2163
2164         * ircd/engine_kqueue.c (engine_loop): Remove an assertion that the
2165         socket's FD is the same after processing as it was before; local
2166         clients apparently have s_fd() == -1 after close.
2167
2168 2004-12-18  Kevin L Mitchell  <klmitch@mit.edu>
2169
2170         * ircd/s_user.c: make absolutely certain register_user() is never
2171         called with cli_unreg non-zero; transition set_nick_name() over to
2172         the new way of determining whether client is ready for
2173         register_user()
2174
2175         * ircd/s_err.c: add ERR_UNKNOWNCAPCMD for reporting failure to
2176         understand a given CAP subcommand
2177
2178         * ircd/parse.c: add "CAP" command
2179
2180         * ircd/m_user.c (m_user): transition over to new way of
2181         determining whether client is ready for register_user()
2182
2183         * ircd/m_pong.c (mr_pong): transition over to new way of
2184         determining whether client is ready for register_user()
2185
2186         * ircd/m_cap.c: implementation of the IRC capabilities draft
2187
2188         * ircd/list.c (make_client): initialize cli_unreg element of
2189         client structure
2190
2191         * ircd/ircd_string.c: correct old bugs in ircd_strn?cmp()
2192         functions that were never found because cross-case ordering has
2193         not been needed until now
2194
2195         * ircd/Makefile.in: add m_cap.c to list of .c files
2196
2197         * include/numeric.h (ERR_UNKNOWNCAPCMD): define new error reply to
2198         indicate an unknown CAP subcommand
2199
2200         * include/msg.h: add "CAP" command
2201
2202         * include/handlers.h: add m_cap() to list of handlers
2203
2204         * include/client.h: add support for client capabilities; rototill
2205         the registration mechanism to dovetail well with the capability
2206         system--i.e., allow the capability system to suspend registration
2207         if the user issues one of the CAP commands
2208
2209         * include/capab.h: header file to define client capabilities
2210
2211 2004-12-17  Michael Poole <mdpoole@troilus.org>
2212
2213         * ircd/channel.h (apply_ban): Add new flag to indicate whether
2214         newban should be free()'d after it is used.
2215
2216         * ircd/channel.c (apply_ban): Likewise.  Also set BAN_DEL flag
2217         when setting BAN_OVERLAPPED, and free newban when BAN_DEL.
2218         (mode_parse_ban): Delete buggy shortcut when channel banlist is
2219         empty.
2220         (mode_process_bans): Always give ownership of ban->banstr to the
2221         mode buffer, avoiding a memory leak.
2222
2223         * ircd/m_silence.c (apply_silence): Pass new parameter to
2224         apply_ban.
2225
2226 2004-12-17  Michael Poole <mdpoole@troilus.org>
2227
2228         * ircd/channel.c (sub1_from_channel): Immediately destroy
2229         non-Apass channels when oplevels are enabled; otherwise, they can
2230         stay opless for a considerable period.
2231         (mode_parse_ban): Initialize banstr to NULL so that set_ban_mask()
2232         does not try to free() an invalid pointer.
2233
2234         * ircd/ircd_parser.y (uworldblock): Put UWorld server name into
2235         aconf->host, not aconf->name.
2236
2237         * ircd/m_server.c (mr_server, ms_server): Attach CONF_UWORLD items
2238         by host here..
2239
2240         * ircd/s_conf.c (conf_check_server): .. rather than by name here.
2241         (attach_conf_uworld): New function to attach CONF_UWORLD items.
2242         (rehash): Use attach_conf_uworld() instead of attaching by name.
2243
2244 2004-12-15  Michael Poole <mdpoole@troilus.org>
2245
2246         * ircd/m_topic.c (do_settopic): Allow +k services to set topics on
2247         channels they are not joined.
2248
2249 2004-12-15  Michael Poole <mdpoole@troilus.org>
2250
2251         * ircd/IPcheck.c (IPTargetEntry): Make count unsigned to squash
2252         warning.
2253         (ip_registry_canonicalize): New function to convert an IP address
2254         into a canonical form for clone checks.
2255         (ip_registry_hash): Update to reflect canonical form.
2256         (ip_registry_find): Use ip_registry_canonicalize().
2257         (ip_registry_check_local, ip_registry_check_remote): Likewise.
2258
2259         * ircd/numnicks.c (iptobase64): Map 6to4 addresses to IPv4 when
2260         sending them to a non-IPv6 server.
2261
2262 2004-02-17  Michael Poole <mdpoole@troilus.org>
2263
2264         * ircd/s_user.c (hide_hostmask): Preserve user's visibility in a
2265         +D channel when they hide their hostmask.
2266
2267 2004-12-15  Michael Poole <dmpoole@troilus.org>
2268
2269         * doc/example.conf: Remove the example Server blocks since they
2270         are no longer used (were merged into Connect).
2271
2272         * ircd/ircd_res.c (restart_resolver): Fix typo in previous commit.
2273
2274         * ircd/m_server.c (check_loop_and_lh): Use a different argument to
2275         test whether an introduced server is directly connected or not.
2276
2277 2004-12-14  Michael Poole <mdpoole@troilus.org>
2278
2279         * include/client.h (FLAG_IPV6): New value for enum Flag.
2280         (IsIPv6, SetIPv6): Accessor macros for it.
2281
2282         * include/numnicks.h (iptobase64): Add flag indicating whether to
2283         use full IPv6 addresses or fake them in an IPv4-compatible way.
2284
2285         * ircd/numnicks.c (iptobase64): Use the new flag.
2286
2287         * include/send.h (sendcmdto_flag_serv_butone): New function to
2288         send different lines to servers based on flags (like FLAG_IPV6).
2289
2290         * ircd/send.c (sendcmdto_flag_serv_butone): Implement it.
2291
2292         * ircd/s_bsd.c (completed_connection): Advertise IPv6 support in
2293         our server flags.
2294
2295         * ircd/s_serv.c (server_estab): Likewise.  Also make sure we send
2296         compatible IP addresses for the new server.
2297
2298         * ircd/s_user.c (register_user): Only send full IPv6 addresses to
2299         links that have FLAG_IPV6 set.
2300
2301 2004-12-13  Michael Poole <mdpoole@troilus.org>
2302
2303         * doc/example.conf: Update General block comment to mention
2304         new RESOLVER option and to explain IPv6 support.
2305
2306         * ircd/ircd_lexer.l: Recognize RESOLVER token.
2307
2308         * ircd/ircd_parser.y: Declare RESOLVER token and use it in an
2309         alternative for generalitem.
2310
2311         * ircd/ircd_res.c: Define global ResolverAddr variable.  If it is
2312         valid, use it instead of VirtualHost in restart_resolver().
2313
2314 2004-12-13  Michael Poole <mdpoole@troilus.org>
2315
2316         * doc/example.conf: Update configuration to move Client block
2317         comment after sample Class blocks, and update entries in it.
2318
2319         * ircd/ircd_lexer.y: Recognize IP and USERNAME tokens.
2320
2321         * ircd/ircd_parser.y: Add ip and username global variables and IP
2322         and USERNAME tokens.  Add clientip and clientusername alternatives
2323         for clientitem, and update clientblock to correspond.
2324
2325         * ircd/ircd_res.c (delete_resolver_queries): Do not try to walk
2326         the request_list before request_list is initialized.
2327         (cres_mem): Likewise.
2328
2329         * ircd/os_generic.c (sockaddr_from_irc): Improve guessing of
2330         proper address family.
2331
2332         * ircd/s_conf.c (attach_iline): Allow aconf->host == NULL, which
2333         means DNS reply is optional.  If aconf->addrbits >= 0, test it.
2334
2335         * tools/crypter: Delete.
2336
2337 2004-12-11  Kevin L Mitchell  <klmitch@mit.edu>
2338
2339         * ircd/*.c: use new assert() in ircd_log.h in preference to system
2340         assert()
2341
2342         * ircd/umkpasswd.c: use new assert in ircd_log.h; add necessary
2343         glue so that umkpasswd will successfully compile and link
2344
2345         * ircd/test/ircd_chattr_t.c: comment out include of assert.h since
2346         there are no calls to assert()
2347
2348         * ircd/ircd_log.c: add sentinel (log_inassert) to prevent assert()
2349         from looping should there be an assertion failure somewhere in the
2350         logging subsystem
2351
2352         * include/ircd_log.h: custom implementation of assert() that calls
2353         log_write()
2354
2355 2004-11-21  Michael Poole <mdpoole@troilus.org>
2356
2357         * ircd/channel.c (mode_parse_upass): Allow forced mode changes to
2358         be done by non-channel-managers, fixing a crash from OPMODE.
2359         (mode_parse_apass): Likewise.
2360
2361 2004-11-20  Michael Poole <mdpoole@troilus.org>
2362
2363         * ircd/m_create.c (ms_create): Complain if a user tries to CREATE
2364         a channel they are already in, but do not add them again.
2365
2366 2004-11-09  Michael Poole <mdpoole@troilus.org>
2367
2368         * include/res.h (init_resolver): Delete, and initialize lazily.
2369
2370         * ircd/ircd.c (main): Do not call init_resolver().
2371
2372         * ircd/ircd_res.c (restart_resolver): Use default VirtualHost for
2373         local resolver socket address.
2374         (init_resolver): Delete.
2375         (make_request): Call restart_resolver() if necessary.
2376         (query_name): Use ircrandom() instead of rand().
2377
2378         * ircd/os_generic.c (sockaddr_from_irc): Convert last argument to
2379         a file descriptor that indicates the socket family to use.
2380         (os_sendto_nonb,os_socket,os_connect_nonb): Update to match.
2381
2382 2004-11-09  Michael Poole <mdpoole@troilus.org>
2383
2384         * ircd/engine_epoll.c (engine_delete): Do not attempt to remove a
2385         socket from epoll on delete, since the kernel does that for us.
2386
2387 2004-11-07  Michael Poole <mdpoole@troilus.org>
2388
2389         * ircd/m_server.c (m_server, ms_server): Assign timestamp before
2390         it might be used in exit_new_server().
2391
2392 2004-11-07  Michael Poole <mdpoole@troilus.org>
2393
2394         * aclocal.m4, config.h.in, configure, ircd/Makefile.in: Regenerate
2395         to reflect the changes since these files' last rebuild.
2396
2397 2004-11-07  Michael Poole <mdpoole@troilus.org>
2398
2399         * include/ircd_crypt.h (ircd_crypt): This should return char*, not
2400         const char*, since it does not own the returned pointer.
2401
2402         * ircd/ircd_crypt.c (ircd_crypt): Change return type.
2403
2404         * ircd/ircd_crypt_smd5.c (irc_crypt_smd5): Make passwd a static
2405         field since it is returned but this function must own the buffer.
2406
2407         * ircd/m_oper.c (oper_password_match): Free the string returned by
2408         ircd_crypt().
2409
2410         * ircd/engine_epoll.c (engine_loop): Fix a memory leak.
2411
2412 2004-11-07  Michael Poole <mdpoole@troilus.org>
2413
2414         * acinclude.m4: Look for a 64-bit integer type.
2415
2416         * configure.in: Look for inttypes.h, since some systems have that
2417         but not stdint.h (and define 64-bit integers therein).
2418
2419         * include/client.h: Delete con_sendK, con_receiveK.  Make
2420         con_sendB and con_receiveB 64 bits wide.
2421
2422         * include/s_misc.h: Delete is_cks, is_ckr, is_sks, is_skr.
2423         Convert the other byte counters and the connected time counters to
2424         64 bits wide.
2425
2426         * ircd/ircd_snprintf.c (doprintf): Unconditionalize the
2427         HAVE_LONG_LONG bits, and use the 64-bit integer types from above.
2428
2429         * ircd/packet.c (update_bytes_received): Remove use of
2430         cli_receiveK().
2431
2432         * ircd/s_bsd.c (deliver_it): Likewise.
2433         (close_connection): Likewise.
2434
2435         * ircd/s_misc.c (tstats): Likewise.  Update format strings to use
2436         %Lu for 64-bit integer parameters.
2437
2438         * ircd/s_stats (stats_links): Convert cli_sendK() and
2439         cli_receiveK() use shifted versions of the byte counters, and
2440         update format strings to use %Lu for 64-bit integer parameters.
2441
2442 2004-11-07  Michael Poole <mdpoole@troilus.org>
2443
2444         * include/s_user.h (add_silence): Delete.
2445         (del_silence): Delete.
2446
2447         * include/struct.h (struct User): Convert silence list to struct Ban.
2448
2449         * ircd/m_silence.c (apply_silence, forward_silences): New functions.
2450         (m_silence): Use forward_silences() instead of add_silence().
2451         (ms_silence): Likewise.
2452
2453         * ircd/s_err.c (replyTable): Update RPL_SILELIST.
2454
2455         * ircd/s_misc.c (exit_one_client): Update to new silence list type.
2456
2457         * ircd/s_user.c (is_silenced): Use find_ban() to search for
2458         silences.  If one is found, send it plus any silence exceptions.
2459         (del_silence): Delete.
2460         (add_silence): Delete.
2461
2462 2004-11-07  Michael Poole <mdpoole@troilus.org>
2463
2464         * include/channel.h: Remove declarations for undefined functions
2465         cancel_mode(), add_token_to_sendbuf(), IsMember().  Delete
2466         add_banid(), next_removed_overlapped_ban().  Add BAN_EXCEPTION
2467         flag and new functions find_ban(), apply_ban().
2468
2469         * ircd/channel.c (PartFmt*, next_ban, prev_ban, removed_bans_list,
2470         LocalChanOperMode): Remove unused variable definitions.
2471         (make_nick_user_host): Delete.
2472         (add_banid): Delete.
2473         (next_removed_overlapped_ban): Delete.
2474         (find_ban): New function, which knows about exceptions.
2475         (is_banned): Use find_ban() and only work on a struct Membership.
2476         (bmatch): New function, which knows about CIDR bans.
2477         (apply_ban): New function to replace add_banid().
2478         (mode_parse_ban): Use apply_ban().
2479
2480 2004-10-28  Michael Poole <mdpoole@troilus.org>
2481
2482         * configure.in (AC_PREREQ): Depend on autoconf 2.50 since we use
2483         new macros like AC_LINK_IFELSE and AC_LANG_PROGRAM.
2484
2485 2004-10-22  Michael Poole <mdpoole@troilus.org>
2486
2487         * ircd/m_invite.c (m_invite, ms_invite): Fix INVITE forwarding
2488         with announcements enabled (do not "announce" to the recipient,
2489         and unconditionally send to the recipient).
2490
2491         * ircd/send.c (sendcmdto_channel_servers_butone): Properly skip
2492         the "from" client and implement SKIP_NONOPS and SKIP_NONVOICES.
2493
2494 2004-10-21  Michael Poole <mdpoole@troilus.org>
2495
2496         * include/channel.h (Ban): Add fields address, nu_len, addrbits to
2497         support netmask-based bans.
2498
2499         * ircd/channel.c (set_ban_mask): New function to parse a ban as
2500         either netmask-based or not.
2501         (make_ban): Use set_ban_mask().
2502         (make_nick_user_ip): Becomes unused; remove it.
2503         (is_banned): Rewrite to match only once against the nick!user part
2504         of a ban, and compare addresses if BAN_IPMASK is set.
2505         (mode_parse_ban): Use set_ban_mask().
2506
2507 2004-10-21  Michael Poole <mdpoole@troilus.org>
2508
2509         * ircd/s_conf.c (attach_iline): Test resolved host names against
2510         aconf->host, not the (NULL) aconf->name.
2511
2512 2004-10-19  Michael Poole <mdpoole@troilus.org>
2513
2514         * include/channel.h: Move ban flags out of channel flags and
2515         rename to reflect this.
2516
2517         * ircd/channel.c: Update ban constant names.
2518
2519         * ircd/m_burst.c: Likewise.
2520
2521 2004-10-18  Michael Poole <mdpoole@troilus.org>
2522
2523         * include/list.h (SLink): Remove ban elements from here...
2524
2525         * include/channel.h (Ban): And move to the new struct Ban.
2526         (Channel): Update banlist field to match.
2527         (next_removed_overlapped_ban): Update return type to match.
2528         (make_ban, free_ban): New functions.
2529
2530         * ircd/channel.c (next_ban, prev_ban, removed_bans_list): Update
2531         list types.
2532         (free_bans): New variable to hold unused Ban elements.
2533         (make_ban, free_ban): New functions.
2534         (destruct_channel, add_banid, next_removed_overlapped_ban): Update
2535         to use struct Ban.
2536         (is_banned, send_channel_modes, send_ban_list): Likewise.
2537         (ParseState, mode_parse_ban, mode_process_bans): Likewise.
2538         (mode_parse): Likewise.
2539
2540         * ircd/m_burst.c (ms_burst): Update to use struct Ban.
2541
2542         * ircd/m_clearmode.c (do_clearmode): Update to use struct Ban.
2543
2544         * ircd/s_debug.c (count_memory): Update to use struct Ban.
2545
2546 2004-10-18  Kevin L Mitchell  <klmitch@mit.edu>
2547
2548         * ircd/gline.c (gline_find): unless we're looking for an exact
2549         match, we should call match() on hostnames, not ircd_strcmp()
2550
2551 2004-10-17  Michael Poole <mdpoole@troilus.org>
2552
2553         * include/s_conf.h (ConfItem): Add new field username.  Replace
2554         unused field bits with addrbits.
2555         (find_conf_exact): Replace user and host arguments with cptr.
2556         (find_conf_name, read_tlines, find_restrict): Remove declaration
2557         for undefined functions.
2558         (conf_parse_userhost): New function.
2559
2560         * ircd/m_oper.c (m_oper): Update calls to find_conf_exact(): both
2561         resolved hostname and IP are matched in one pass now.
2562
2563         * ircd/s_bsd.c (close_connection): Update call to find_conf_exact().
2564
2565         * ircd/s_conf.c (conf_parse_userhost): New function.
2566         (check_limit_and_attach): Use correct ConfItem field to determine
2567         maximum connections per IP.
2568         (attach_iline): Replace user@host matching with shorter, clearer
2569         matching against username and host/IP fields.
2570         (find_conf_exact): Likewise.
2571
2572         * ircd/ircd_parser.y: Replace assignment to aconf->host for
2573         CONF_CLIENT and CONF_OPERATOR with calls the CIDR-aware
2574         conf_parse_userhost().  This means CONF_CLIENT ConfItems no longer
2575         use the name field or the IP token.  Remove the latter.
2576
2577         * ircd/ircd_lexer.l: Remove unused token IP.
2578
2579 2004-10-17  Michael Poole <mdpoole@troilus.org>
2580
2581         * ircd/crule.c (crule_via): Simplify the lookup for the directly
2582         connected server name.
2583
2584 2004-10-16  Michael Poole <mdpoole@troilus.org>
2585
2586         * ircd/class.c: Make find_class() return NULL for unknown classes,
2587         rather than returning the start of connClassList.
2588
2589         * ircd/match.c (parse_ipmask): Translate IPv4 masks as
2590         IPv4-compatible addresses.
2591         (check_ipmask): Fix comparison of IP masks.
2592
2593         * ircd/motd.h, ircd/motd.c: Add a new MOTD type, MOTD_IPMASK, that
2594         uses CIDR style masks in the hostname field of a Motd block.
2595
2596 2004-10-16  Michael Poole <mdpoole@troilus.org>
2597
2598         * ircd/numeric.h: Remove the unused RPL_STATMEM and
2599         RPL_STATMEMTOT.  Move the RPL_BOUNCE comment to its current
2600         value (the former RPL_STATMEM).
2601
2602         * ircd/s_err.c: Remove format strings for RPL_STATMEM and
2603         RPL_STATMEMTOT.
2604
2605 2004-10-16  Michael Poole <mdpoole@troilus.org>
2606
2607         * ircd/m_server.c: Look up server configuration by name of our
2608         directly connected peer rather than the server being introduced.
2609
2610 2004-10-13  Michael Poole <mdpoole@troilus.org>
2611
2612         * include/channel.h: Delete MODE_LISTED and is_listed().  Replace
2613         ListingArgs.chptr with ListingArgs.bucket.  Move declaration of
2614         list_next_channels() to..
2615
2616         * include/hash.h: here, and drop the "nr" argument.
2617
2618         * ircd/channel.c: Remove redundant scan of local clients for
2619         channels being listed.  Delete list_next_channels() function.
2620
2621         * ircd/hash.c: Add list_next_channels() here, revising to not use
2622         MODE_LISTED and to use ListingArgs.bucket instead of chptr.  Also
2623         decide when to stop sending RPL_LISTs based on a half-full sendq.
2624
2625         * ircd/m_burst.c, ircd/s_misc.c: Delete mention of MODE_LISTED.
2626
2627         * ircd/m_list.c: Delete mention of MODE_LISTED.  Unconditionally
2628         call list_next_channels(sptr).
2629
2630         * ircd/s_bsd.c: Remove the "nr" argument to list_next_channels().
2631
2632         * ircd/Makefile.in: Update dependencies (for hash.c).
2633
2634 2004-10-13  Michael Poole <mdpoole@troilus.org>
2635
2636         * ircd/ircd_parser.y: Consistently zero out global variables after
2637         they are used (prevents double frees and other problems).
2638
2639 2004-10-12  Michael Poole <mdpoole@troilus.org>
2640
2641         * include/client.h: Rename FLAGSET_ISSET, _SET, _CLEAR to FlagHas,
2642         Set, Clr respectively.  Get rid of FLAG_CHKACCESS and FLAG_LOCAL.
2643         Delete con_fd (get from con_socket) and con_port.  Move sentalong
2644         from send.c to struct Connection, and cli_lasttime and cli_since
2645         from struct Client to struct Connection.  Update cli_*() macros to
2646         use con_*(cli_connect(cli)).
2647
2648         * ircd/client.c: Replace PrivSet() with FlagSet(), PrivClr() with
2649         FlagClr(), PrivHas() with FlagHas().
2650
2651         * ircd/ircd_parser.y: Likewise.
2652
2653         * ircd/list.c: Remove assignment to cli_local() since it is now a
2654         calculated value.
2655
2656         * ircd/s_bsd.c: Remove uses of cli_port().
2657
2658         * ircd/s_conf.c: Remove uses of ClearAccess().
2659
2660         * ircd/send.c: Delete sentalong array and replace with references
2661         to con_sentalong().
2662
2663 2004-10-12  Michael Poole <mdpoole@troilus.org>
2664
2665         * doc/example.conf: Update example config to reflect the changes
2666         made in the remainder of this patch.
2667
2668         * include/list.h: Make make_conf() take a type argument.
2669
2670         * include/s_conf.h: Delete CONF_LEAF and CONF_HUB.  Add "maximum"
2671         and "hub_limit" to ConfItem to compensate.
2672
2673         * ircd/ircd_lexer.l: Recognize MAXHOPS token.
2674
2675         * ircd/ircd_parser.y: Get rid of aconf global variable and add
2676         hub_limit global variable.  Add MAXHOPS token, and productions
2677         inside connectblock to recognize it and hub masks.  Allow maxlinks
2678         field in a Client block, rather than overloading password field.
2679         Convert serverblock to uworldblock and remove extraneous fields.
2680
2681         * ircd/m_server.c: Make check_loop_and_lh() look up ConfItem and
2682         calculate LHcptr and active_lh_line.  Merge some duplicated code
2683         so handling active_lh_line cases is clearer.
2684
2685         * ircd/s_conf.c: Make make_conf() take a type argument.  Delete
2686         CONF_LEAF and CONF_HUB.  Do not overwrite server name with what
2687         is specified in the config file.
2688
2689         * ircd/s_err.c: Remove the unused RPL_STATSNLINE and
2690         RPL_STATSHLINE.  Remove useless parameters and format fields from
2691         RPL_STATSCLINE, RPL_STATSILINE, RPL_STATSLLINE, RPL_STATSOLINE and
2692         RPL_STATSULINE.
2693
2694         * ircd/s_serv.c: Delete CONF_LEAF and CONF_HUB.
2695
2696         * ircd/s_stats.c: Get rid of report_array and make
2697         stats_configured_links() directly use RPL_STATSxLINE (adding the
2698         new fields for Server and Client blocks).  Remove /stats h, since
2699         that has no meaning.
2700
2701 2004-10-12  Michael Poole <mdpoole@troilus.org>
2702
2703         * ircd/m_burst.c: Mask off channel modes in a wiped-out channel by
2704         default rather than by listing which should be wiped out.
2705
2706 2004-10-09  Michael Poole <mdpoole@troilus.org>
2707
2708         * ircd/m_server.c: Forward port checks for leaf and hub config
2709         rules, and reorganize mr_server() and ms_server() by moving out
2710         common code.  Add doxygen comments for the file.
2711
2712 2004-10-09  Michael Poole <mdpoole@troilus.org>
2713
2714         * ircd/hash.c: Fix thinko in hash function: It is not indexed
2715         simply by character value, so we cannot just remap the values
2716         by case.
2717
2718 2004-10-05  Michael Poole <mdpoole@troilus.org>
2719
2720         * ircd/hash.c: Replace the old hash function with one based on
2721         randomized CRC-32.  The new one avoids a big table from the old
2722         function.
2723
2724 2004-10-05  Michael Poole <mdpoole@troilus.org>
2725
2726         * ircd/random.c: Convert to use ircd_md5 interface and hopefully
2727         keep more internal random state.
2728
2729 2004-10-05  Michael Poole <mdpoole@troilus.org>
2730
2731         * include/ircd_md5.h, ircd/ircd_md5.c, ircd_crypt_smd5.c,
2732         ircd/umkpasswd.c: Get rid of the GoodMD5xxx/BrokenMD5xxx
2733         prefixes.
2734
2735 2004-10-05  Michael Poole <mdpoole@troilus.org>
2736
2737         * adns, lib/adns: Remove unused adns library.
2738
2739 2004-10-05  Michael Poole <mdpoole@troilus.org>, hikari <hikari@undernet.org>, Perry Lorier <isomer@undernet.org>
2740
2741         * include/*.h, ircd/*.c: Convert comments to Doxygen-compatible
2742         format, and add new comments where needed.
2743
2744         * Doxyfile: New file to tell Doxygen how to run.
2745
2746 2004-09-21  Michael Poole <mdpoole@troilus.org>
2747
2748         * ircd/s_auth.c (HeaderMessages): Make the compiler, not the
2749         programmer, generate magic numbers.
2750         (AuthIncompleteList): Remove.
2751         (AuthPollList): Remove.
2752
2753 2004-09-19  Michael Poole <mdpoole@troilus.org>
2754
2755         * acinclude.m4: Clean up AC_DEFINE()s so we no longer need
2756         acconfig.h.
2757
2758         * acconfig.h: Remove since it is now redundant.
2759
2760         * aclocal.m4, config.h.in, configure: Regenerate.
2761
2762 2004-09-19  hikari <hikari@undernet.org>
2763
2764         * configure.in: Fixed configure script rules to fail if (f)lex or yacc/bison 
2765         aren't found as they're essential for compilation.  Regenerated files with 
2766         autreconf.
2767                 
2768 2004-09-18  Michael Poole <mdpoole@troilus.org>
2769
2770         * doc/example.conf: Add NETWORK feature example.  Fix typos in
2771         eaxmples for HANGONGOODLINK and IRCD_RES_TIMEOUT.
2772
2773         * include.class.h: Make max_links and ref_count unsigned ints.
2774         Make ping_freq and conn_freq unsigned short. (No more negative
2775         numbers in /stats y.)
2776
2777         * ircd/ircd.c: Report configuration file name for "ircd -k".
2778
2779 2004-09-18  hikari <hikari@undernet.org>
2780
2781         * ircd/Makefile.in: Fixed a missing internal build dependency.
2782         
2783 2004-09-16  Michael Poole <mdpoole@troilus.org>
2784
2785         * INSTALL: Fix name of example.conf and mention its installed
2786         location.
2787
2788         * include/supported.h (FEATURESVALUES2): Fix a reference to
2789         channel mode +u that escaped earlier rename attempts.
2790
2791         * ircd/ircd_auth.c (iauth_connect): Assign port number after
2792         zeroing out the destination address.
2793         Add some additional debug statements to help follow operations.
2794
2795         * ircd/ircd_parser.y (iauthblock): Do not require "name" to be set.
2796
2797 2004-09-11  Bas Steendijk <steendijk@xs4all.nl>
2798
2799         * include/channel.h, include/supported.h, ircd/channel.c,
2800         ircd/s_err.c: Use +U instead of +u for user keys.
2801
2802 2004-09-13  Michael Poole <mdpoole@troilus.org>
2803
2804         * doc/example.conf: Remove sample VIRTUAL_HOST setting.
2805
2806         * doc/readme.features: Remove VIRTUAL_HOST documentation, and
2807         update NODNS documentation to match current behavior.
2808
2809         * include/s_conf.h: Remove now-unused vhost_address field and
2810         set_virtual_host() function.
2811
2812         * include/ircd_features.h, ircd/ircd_features.c, ircd/s_debug.c:
2813         Remove VIRTUAL_HOST.
2814
2815         * ircd/ircd_auth.c, ircd/s_bsd.c: Use VirtualHost as local address
2816         if we do not have a more specific alternate.
2817
2818         * ircd/ircd_parser.y: Check for sanity in General blocks (from old
2819         conf_add_local()) and assign vhost directly to VirtualHost.
2820
2821         * ircd/ircd_res.c (irc_in_addr_valid): Fix thinko; obviously any
2822         value will be either != 0 or != 0xffff.
2823
2824         * ircd/os_generic.c: Use AF_INET instead of AF_INET6 when the
2825         local addresses are specified as IPv4 addresses.
2826
2827         * ircd/s_conf.c: Remove unused conf_add_local() and
2828         set_virtual_host().
2829
2830 2004-09-13  Michael Poole <mdpoole@troilus.org>
2831
2832         * ircd/listener.c (add_listener): Consolidate duplicated code, and
2833         make sure listener->server is set before calling inetport() on it.
2834
2835 2004-09-12  Michael Poole <mdpoole@troilus.org>
2836
2837         * include/channel.c (mode_parse_upass, mode_parse_apass): Only let
2838         services (not normal opers) force a change of +A or +u.
2839
2840 2004-09-11  Michael Poole <mdpoole@troilus.org>
2841
2842         * include/s_stats.h: Add sd_name to struct StatDesc.  Stop
2843         publishing the statsinfo and statsmap arrays; replace them with
2844         stats_find().  Change argument list of StatFunc() to work with
2845         names.
2846
2847         * ircd/m_stats.c: Use stats_find() instead of statsmap[].  Use the
2848         full argument instead of just the first character in reports.
2849
2850         * ircd/s_stats.c: Adapt individual stats handler functions to new
2851         argument list.  Add long names to statsinfo[].  Add new functions
2852         stats_cmp(), stats_search(), stats_find().  Sort statsinfo[] in
2853         stats_init().
2854
2855         * ircd/s_err.c: Change ENDOFSTATS to display a string rather than
2856         a single character.
2857
2858         * ircd/s_user.c: Send an error to the user when a message loses
2859         its target in transit.
2860
2861         * include/class.h include/gline.h include/ircd_features.h
2862         include/listener.h include/motd.h include/msgq.h include/res.h
2863         include/s_debug.h include/s_misc.h include/userload.h ircd/class.c
2864         ircd/gline.c ircd/ircd_features.c ircd/ircd_res.c ircd/listener.c
2865         ircd/motd.c ircd/msgq.c ircd/s_debug.c ircd/s_misc.c
2866         ircd/userload.c: Adjust stats handlers to new argument list.
2867
2868 2004-09-11  Michael Poole <mdpoole@troilus.org>
2869
2870         * include/numeric.h, ircd/s_err.c: Remove RPL_TRACEPING, and
2871         replace with RPL_TRACEEND.
2872
2873         * ircd/s_trace.c: Move all the duplicated code in m*_trace() to
2874         do_trace().  Implement RPL_TRACEEND, per RFE#830291.
2875
2876 2003-06-20  Alexander Maassen <outsider@key2peace.org>
2877
2878         * ircd/m_topic.c : Don't allow banned users to set a topic in a
2879         channel.
2880
2881 2004-09-11  Kevin L Mitchell  <klmitch@mit.edu>
2882
2883         * config.h.in, tools/Makefile.crypt: Remove wrong pathname from
2884         comment in header.
2885
2886         * ircd/m_clearmode.c, ircd/m_opmode.c: Fix wrong pathname in
2887         header comment.
2888
2889         * ircd/m_away.c, ircd/m_kill.c, ircd/m_notice.c, ircd/m_ping.c,
2890         ircd/m_pong.c, ircd/m_privmsg.c, ircd/m_quit.c, ircd/m_topic.c,
2891         ircd/m_version.c: Remove "template" moniker from comments.
2892
2893         * ircd/test/ircd_chattr.0.dat (IsChannelPrefix): Drop + from
2894         channel prefix list.
2895
2896 2004-09-11  Michael Poole <mdpoole@troilus.org>
2897
2898         * doc/example.conf: Add examples for FEAT_HIS_* features.
2899
2900 2003-06-08 Matthias Crauwels <ultimate_@wol.be>
2901         [Feature renamed to FEAT_HIS_WHOIS_LOCALCHAN by Michael Poole.]
2902
2903         * include/ircd_features.h: new feature FEAT_HIS_LOCAL_CHAN_WHOIS
2904
2905         * ircd/ircd_features.c: new feature FEAT_HIS_LOCAL_CHAN_WHOIS
2906
2907         * ircd/m_whois.c: hide local channels in local WHOIS, this breaks HIS
2908
2909         * doc/readme.features: documented FEAT_HIS_LOCAL_CHAN_WHOIS
2910
2911         * doc/ircd.conf.sample: default value for FEAT_HIS_LOCAL_CHAN_WHOIS
2912
2913 2004-09-11  Michael Poole <mdpoole@troilus.org>
2914
2915         * ircd/ircd_relay.c (server_relay_channel_message,
2916         server_relay_channel_notice): Do not allow other servers to send
2917         or relay to local channels.
2918
2919         * ircd/m_wallchops (ms_wallchops): Likewise.
2920
2921         * ircd/m_wallvoices (ms_wallvoices): Likewise.
2922
2923 2004-09-11  Kevin L Mitchell  <klmitch@mit.edu>
2924
2925         * ircd/gline.c (gline_add): fix GLINE logging (Bug #750927)
2926
2927         * ircd/channel.c: removing limits shouldn't gobble an argument;
2928         this was a subtle interaction issue with modebuf...fixed by adding
2929         MODE_LIMIT to modebuf_flush_int() and short-circuiting
2930         modebuf_mode_uint() to add MODE_LIMIT to mbuf->mb_rem in the
2931         removal case.  Note that this is not proof against the sequence,
2932         "modebuf_mode_uint(mbuf, MODE_ADD | MODE_LIMIT, 10);
2933         modebuf_mode_uint(mbuf, MODE_DEL | MODE_LIMIT, 10);"
2934         (Bug #916138)
2935
2936 2004-09-11  Michael Poole <mdpoole@troilus.org>
2937
2938         * include/supported.h: Kev pointed out I misinterpreted the
2939         meaning of CHANMODES; fix this.  Also define CHANNELLEN and
2940         STATUSMSG from the ISUPPORT draft.
2941
2942 2004-09-10  Michael Poole <mdpoole@troilus.org>
2943
2944         * include/supported.h (FEATURESVALUES2): Include A,u, in CHANMODES
2945         when oplevels are enabled.
2946
2947 2004-09-10  Michael Poole <mdpoole@troilus.org>
2948
2949         * ircd/channel.c (send_channel_modes): Only send oplevels for
2950         channels that actually use them -- for -A channels, send chanops
2951         as :o even if OPLEVELS is enabled.
2952
2953         * ircd/ircd.c: Fix -k (chkconf mode) and show in usage help.
2954
2955         * ircd/numnicks.c (base64toip): Fill in the right number of 0
2956         words when we see _ in a base64-encoded IPv6 address.
2957
2958 2004-09-10  Michael Poole <mdpoole@troilus.org>
2959
2960         * ircd/ircd.c: Add -k as a chkconf-like option to exit after
2961         reading the configuration file.
2962
2963         * ircd/chkconf.c: Remove as unused.
2964
2965         * ircd/Makefile.in: Remove last mentions of chkconf from Makefile.
2966
2967 2004-09-10  Michael Poole <mdpoole@troilus.org>
2968
2969         * doc/example.conf: Remove examples for unused features (TIMESEC,
2970         CRYPT_OPER_PASSWORD) and add for new feature (ANNOUNCE_INVITES).
2971
2972         * doc/readme.features: Remove documentation for unused features
2973         (TIMESEC, CRYPT_OPER_PASSWORD, oper/locop privileges,
2974         HIS_DESYNCS), update defaults for SOCKSENDBUF and SOCKRECVBUF, and
2975         add documentation for ANNOUNCE_INVITES.
2976
2977         * include/ircd_features.h: Remove unused features (TIMESEC,
2978         CRYPT_OPER_PASSWORD, LIST_CHAN, HIS_DESYNCS).
2979
2980         * include/ircd_features.c: Likewise.
2981
2982         * ircd/ircd_res.c: Actually use FEAT_IRCD_RES_RETRIES and
2983         FEAT_IRCD_RES_TIMEOUT where appropriate.
2984
2985         * ircd/s_debug.c: Do not display setting of unused (and now
2986         non-existent) FEAT_CRYPT_OPER_PASSWORD.
2987
2988 2004-09-10  Michael Poole <mdpoole@troilus.org>
2989
2990         * ircd/os_generic.c (sockaddr_from_irc): Fix IPv4 implementation
2991         to use the correct address family and IP offset.
2992
2993 2004-09-10  Michael Poole <mdpoole@troilus.org>
2994
2995         * include/s_conf.h (struct ConfItem): Add origin and origin_name
2996         fields.
2997
2998         * ircd/ircd_parser.y: Add new global variable "origin."  Add a new
2999         "connectionvhost" production that accepts vhost = "IP" inside a
3000         Connect block and assigns the IP to origin_name.
3001
3002         * ircd/s_bsd (connect_inet): If aconf has a valid origin, use it
3003         as the local address.  Otherwise, fall back to the old logic (if
3004         VIRTUAL_HOST="TRUE", use the virtual host setting).
3005
3006         * ircd/s_conf.c (lookup_confhost): If the ConfItem has an
3007         origin_name, try to parse it as an IP address.
3008
3009 2004-04-17  Isomer <isomer@undernet.org>
3010         * ircd/parse.c: Don't rate limit /gline messages
3011
3012 2004-09-10  Michael Poole <mdpoole@troilus.org>
3013
3014         * ircd/ircd_parser.y: Replace references to yylval.whatever with
3015         references to the appropriate term.  This fixes bugs like
3016         "1 hour 30 minutes" being misrecognized as 30 seconds.
3017
3018 2004-09-10  Michael Poole <mdpoole@troilus.org>
3019
3020         * ircd/ircd_features.c (features): Change default values for
3021         SOCKSENDBUF and SOCKRECVBUF to SERVER_TCP_WINDOW, so that users
3022         need not specify them in ircd.conf.
3023
3024 2004-09-10  Michael Poole <mdpoole@troilus.org>
3025
3026         * ircd/ircd_parser.y (serverblock): Server blocks should default
3027         to CONF_LEAF status.
3028
3029         * doc/example.conf: Update example to reflect this.
3030
3031 2004-09-10  Michael Poole <mdpoole@troilus.org>
3032
3033         * ircd/parse.c (msg_tree_parse): Reject commands that contain
3034         non-alphabetic characters.
3035
3036 2004-09-09  Michael Poole <mdpoole@troilus.org>
3037
3038         * config.h.in: Remove duplicated and unused macro definitions.
3039
3040 2004-08-24  Michael Poole <mdpoole@troilus.org>
3041
3042         * ircd/client.h: Properly parenthesize "flag" argument to
3043         FLAGSET_INDEX() and FLAGSET_MASK() macros.
3044
3045 2004-08-22  Michael Poole <mdpoole@troilus.org>
3046
3047         * ircd/channel.c (send_channel_modes): If oplevels are disabled,
3048         send 'o' for chanops instead of the member's oplevel.
3049
3050 2004-08-22  Michael Poole <mdpoole@troilus.org>
3051
3052         * ircd/s_conf.c: find_conf_byip() should use irc_in_addr_cmp()
3053         instead of memcmp().  (Fixes IPv4 servers linking to an IPv6
3054         server.)
3055
3056 2004-08-22  Alex Badea  <decampos@users.sourceforge.net>
3057
3058         * include/ircd_defs.h: increased SOCKIPLEN to fit ipv6 addresses
3059
3060 2004-08-19  Michael Poole <mdpoole@troilus.org>
3061
3062         * include/res.h: Remove unused function gethost_byname_type().
3063
3064         * ircd/ircd_res.c: Likewise, and clean up some small functions
3065         only used once (remove_dlink(), timeout_resolver()).  Use rand()
3066         for random request IDs instead of the deprecated *rand48().  Make
3067         resolver timeout event fire only when needed instead of once a
3068         second.
3069
3070 2004-08-17  Michael Poole <mdpoole@troilus.org>
3071
3072         IPv6 support, with lots of code and design borrowed from a patch
3073         by Alex Badea.
3074
3075         * config.h.in: Add place to #define IPV6 support.
3076
3077         * configure.in: Check for struct sockaddr_in6, and use that as
3078         the default choice for IPv6 support.
3079
3080         * configure: Regenerate.
3081
3082         * include/IPcheck.h, include/client.h, include/gline.h,
3083         include/ircd_string.h, include/listener.h, include/match.h,
3084         include/res.h, include/s_bsd.h: Convert from struct in_addr (from
3085         <netinet/in.h>) to struct irc_in_addr (from "res.h").
3086
3087         * include/ircd_osdep.h, include/s_conf.h, include/uping.h: Convert
3088         from struct sockaddr_in (from <netinet/in.h>) to struct
3089         irc_sockaddr (from "res.h").  Add new functions os_socket(),
3090         os_accept(), os_sendto_nonb() to help abstract away actual
3091         sockaddr types.
3092
3093         * include/ircd_chattr.h, ircd/table_gen.c: Define new bit to mark
3094         characters valid in IPv6 addresses.
3095
3096         * include/numnicks.h, ircd/numnicks.c: New functions iptobase64()
3097         and base64toip() to convert from base64 to struct irc_in_addr.
3098
3099         * ircd/IPcheck.c, ircd/channel.c, ircd/m_nick.c, ircd/m_oper.c,
3100         ircd/m_userip.c, ircd/m_who.c, ircd/m_whois.c, ircd/s_misc.c,
3101         ircd/s_serv.c, ircd/s_user.c, ircd/whocmds.c: Use struct
3102         irc_in_addr instead of unsigned int or struct in_addr.
3103
3104         * ircd/gline.c: Use new more-generic ipmask functions.
3105
3106         * ircd/ircd.c: Use struct irc_sockaddr instead of separate port
3107         fields.
3108
3109         * ircd/ircd_reslib.c: Use struct irc_sockaddr and ircd_aton()
3110         instead of irc_ssaddr and irc_getaddrinfo().
3111
3112         * ircd/ircd_string.c: Implement new functions: IPv6-capable
3113         ircd_ntoa_r(), ircd_aton_ip4(), ircd_aton().
3114
3115         * ircd/match.c: Delete IPv4-only matchcompIP().  Replace with
3116         IPv6-capable ipmask_parse() and ipmask_check().
3117
3118         * ircd/numnicks.c: Implement new functions: iptobase64() and
3119         base64toip().
3120
3121         * ircd/os_generic: Convert external parameters to be struct
3122         irc_addrinfo.  When using IPv6 support, sockaddr_in6 is native.
3123         Implement new functions os_sendto_nonb(), os_socket() and
3124         os_accept().
3125
3126         * ircd/ircd_auth.c, ircd/ircd_parser.y, ircd/ircd_res.c,
3127         ircd/listener.c, ircd/m_connect.c, ircd/s_auth.c, ircd/s_bsd.c,
3128         ircd/s_conf.c, ircd/s_stats.c, ircd/uping.c: Use struct
3129         irc_sockaddr instead of separate in_addr and port fields and new
3130         OS support functions.
3131
3132         * include/ircd_addrinfo.h, ircd/ircd_getaddrinfo.c,
3133         ircd/ircd_getnameinfo.c: Remove, since these functions are no
3134         longer used.
3135
3136         * ircd/os_bsd.c, ircd/os_linux.c, ircd/os_openbsd.c,
3137         ircd/os_solaris.c, ircd/res_adns.c, ircd/res_libresolv.c: Remove,
3138         since these are unused and not compatible with IPv6 support.
3139
3140         * ircd/Makefile.in: Remove references to ircd_getXxxxinfo.c.
3141         Regenerate dependencies.
3142
3143 2004-08-17  Michael Poole <mdpoole@troilus.org>
3144
3145         * ircd/ircd_lexer.l: Change tokenizer to reduce number of lexer
3146         states and be case-insensitive again.
3147
3148 2004-08-15  Michael Poole <mdpoole@troilus.org>
3149
3150         * aclocal.m4: Check for uintNN_t instead of u_intNN_t, since the
3151         former is from C99 (and the latter is absent on Solaris).
3152
3153         * configure.in: Remove check for inttypes.h (which is a C99 format
3154         string header); replace with check for stdint.h.  Add checks for
3155         sys/param.h and sys/socket.h.  Check for socklen_t being defined
3156         (OS X does not set it).  Run program tests for lex and yacc, and
3157         use them rather than assuming flex and bison.  Remove OSDEP_C and
3158         mention to adns.  Remove check for res_mkquery().
3159
3160         * config.h.in: Update u_intNN_t #undef lines.  Add #undef
3161         socklen_t so configure test can set it.
3162
3163         * configure: Regenerate.
3164
3165         * include/ircd_addrinfo.h: #include headers needed for netdb.h and
3166         to define struct addrinfo and uintNN_t.
3167
3168         * include/ircd_reslib.h: Replace u_intNN_t with uintNN_t.
3169
3170         * include/res.h: #include "ircd_addrinfo.h" to get proper type
3171         definitions.  #define INADDR_NONE if it is not defined (as on
3172         Solaris).
3173
3174         * ircd/Makefile.in: Replace LEX and YACC definitions.  Remove
3175         OSDEP_C and OSDEP_SRC; always compile os_generic.c.  Remove adns
3176         directory from CPPFLAGS.  Regenerate dependencies.
3177
3178         * ircd/client.c: Return when no propagation set for oper, to
3179         squash warning about use of "defaults" before it is set.
3180
3181         * ircd/engine_epoll.c: #include correct C99 integer header.
3182
3183         * ircd/engine_poll.c: Last argument to getsockopt() should be of
3184         socklen_t, not size_t; fix.
3185
3186         * ircd/engine_select.c: Squash warning about bzero().
3187
3188         * ircd/ircd_auth.c: OS X does not define in_addr_t, so replace it
3189         with uint32_t.  We need <stdint.h> for that, so include it.
3190
3191         * ircd/ircd_getnameinfo.c, ircd/memdebug.c: Replace u_int32_t with
3192         uint32_t.
3193
3194         * ircd/ircd_lexer.l: Replace flex-isms with portable syntax.
3195         There is no portable way to do %option, so remove that.  lex on
3196         Solaris needs several of its internal tables to be bigger, so
3197         increase those sizes.
3198
3199         * ircd/ircd_parser.y: Remove the second declarations of two
3200         tokens, since standard yacc warns about changing precedence.
3201
3202         * ircd/os_generic.c: Make this compile on common OSes (Linux,
3203         Solaris, OS X, FreeBSD, OpenBSD).
3204
3205         * ircd/table_gen.c: Make arguments to isprint() all unsigned char
3206         to squash warnings on Solaris that array index is "char."
3207
3208         * ircd/umkpasswd.c: Remove #include <libgen.h> since it is not
3209         portable, and replace basename() with an equivalent.
3210
3211         * ircd/uping.c: Typecast printf arguments for 64-bit OSes.
3212
3213 2004-07-27  Michael Poole <mdpoole@troilus.org>
3214
3215         * ircd/m_burst.c: Add new netride_modes() function to check
3216         which modes could be used in a net.ride.  Use this instead
3217         of the old check for just +i or +k.
3218         (Based on patches by beware and pomac.)
3219
3220 2004-07-25  Michael Poole <mdpoole@troilus.org>
3221
3222         * ircd/ircd_parser.y: Remove redundant semicolon; it causes
3223         errors on some versions of yacc.
3224
3225 2004-07-21  Michael Poole <mdpoole@troilus.org>
3226
3227         * include/client.h, ircd/ircd_auth.c, ircd/ircd_crypt_smd5.c,
3228         ircd/ircd_reslib.c: Fix warnings from gcc -pedantic.
3229
3230 2004-07-21  Michael Poole <mdpoole@troilus.org>
3231
3232         New DNS resolver code, courtesy of Dianora and the rest of the
3233         Hybrid team.  (Bugs are of course my fault.)
3234
3235         * configure.in, Makefile.in, ircd/Makefile.in: Remove adns and
3236         libresolv from the build process.  Update dependencies.
3237
3238         * configure: Regenerate.
3239
3240         * include/client.h: Change connection's DNS reply type.
3241
3242         * include/ircd_features.h, ircd/ircd_features.c: New HIS_STATS_a.
3243
3244         * include/numeric.h, ircd/s_err.c, ircd/s_stats.c: Add new
3245         RPL_STATSALINE and /stats a to list DNS servers.
3246
3247         * include/ircd_addrinfo.h, include/ircd_reslib.h, include/res.h,
3248         ircd/ircd_getaddrinfo.c, ircd/ircd_getnameinfo.c, ircd/ircd_res.c,
3249         ircd/ircd_reslib.c: New resolver files.
3250
3251         * ircd/ircd_auth.c, ircd/s_auth.c, ircd/s_bsd.c, ircd/s_conf.c:
3252         Update to new resolver callback interface and to only deal with
3253         one IP and one name per DNS reply.
3254
3255         * ircd/parse.c: Remove /DNS command, since new resolver does not
3256         track those statistics.
3257
3258 2004-07-20  Michael Poole <mdpoole@troilus.org>
3259
3260         * doc/readme.features: Change references to O:, Y:, etc lines into
3261         references to the appropriate block types.
3262
3263 2004-07-01  Michael Poole <mdpoole@troilus.org>
3264
3265         * include/fileio.h: Elaborate on "works for any file descriptor."
3266
3267         * include/iauth.h: Remove unused file.
3268
3269 2004-07-01  Michael Poole <mdpoole@troilus.org>
3270
3271         * include/map.h, ircd/map.c: Remove unused code.
3272
3273         * ircd/m_links.c, ircd/m_map.c, ircd/s_misc.c: Remove includes of
3274         map.h and a call to map_update().
3275
3276         * ircd/Makefile.in: Remove map.c and regenerate dependencies.
3277
3278         * ircd/ircd_parser.y: Recognize Diane Bruce as a copyright holder
3279         for the new config parser.
3280
3281         * ircd/match.c: Remove pointless pointer dereference (Reed points
3282         out that this generates a warning with old gcc).
3283
3284         * ircd/s_user.c: Display connection class in CONNEXIT connection
3285         notice as a string rather than an integer.
3286
3287         * tools/ringlog.c, tools/ringlog.pl: At Kevin's request, remove
3288         lines (falsely) identifying ringlog as related to IRC; the files
3289         are general purpose.
3290
3291         * configure.in, include/ircd_snprintf.h: Add checks for
3292         va_copy()-like alternatives and use them if va_copy() is missing.
3293
3294         * configure, config.h.in: Regenerate.
3295
3296 2004-02-01  beware <steendijk@xs4all.nl>
3297
3298         * ircd/channel.c: Check bans that look like IP bans against user's
3299         hostname just in case they have a host like 1234.domain.tld.
3300
3301 2003-12-18  Timothy Grant Vogelsang <net@astrolink.org>
3302
3303         * ircd/ircd_log.c, ircd/send.c: va_list is not a scalar type
3304
3305 2004-04-02  Gavin Grieve <hektik@dimebox.net>
3306
3307         * ircd/ircd_parser.y: Fix rehash warnings for servername and
3308         numeric so they only warn if changed in the config file.
3309
3310 2004-06-30  Michael Poole <mdpoole@troilus.org>
3311
3312         * doc/readme.iauth, include/ircd_auth.h, ircd/ircd_auth.c: New
3313         files.
3314
3315         * doc/example.conf: Illustrate IAUTH configuration.
3316
3317         * include/client.h: Add fields to record IAUTH status.
3318
3319         * ircd/Makefile.in: Add ircd_auth.c to Makefile.
3320
3321         * ircd/ircd_lexer.l, ircd/ircd_parser.y: Add new IAUTH section.
3322
3323         * ircd/s_conf.c: Notify IAUTH code when reloading a configuration
3324         so that an obsolete connection can be abandoned.
3325
3326         * ircd/s_misc.c: Report client exits via IAUTH.
3327
3328         * ircd/s_user.c: If IAUTH is active and a connecting user has not
3329         been checked against it, interrogate the IAUTH server.
3330
3331 2004-06-25  Michael Poole <mdpoole@troilus.org>
3332
3333         * configure.in: Check for crypt.h as well.
3334
3335         * configure: Regenerate.
3336
3337         * ircd/ircd_crypt_native.c: Move XOPEN defines earlier so they
3338         affect the first includes of system headers.  Include crypt.h if
3339         it is available.
3340
3341         * ircd/umkpasswd.c: Quash a gcc warning.
3342         
3343 2004-06-23  Michael Poole <mdpoole@troilus.org>
3344
3345         * doc/Authors: Add contributors to ircu2.10.11 and myself.
3346
3347         * ircd/gline.c: Fix buglet in my forward port of Alex Badea's fix.
3348
3349         * configure.in: Add missing check for inttypes.h; remove obsolete
3350         display of Head-in-sand, add display of epoll() engine.
3351
3352         * INSTALL, INSTALL_FR, doc/readme.cvs: Update descriptions of how
3353         to use SourceForge's CVS server, from the u2.10.11 branch.
3354
3355 2003-11-09 beware <steendijk@xs4all.nl>
3356
3357         * ircd/s_user.c: move assigning a numeric to a local client from
3358         when nick is set, to when connection becomes client, to not waste
3359         numerics.
3360
3361 2004-06-08  Kevin L Mitchell  <klmitch@mit.edu>
3362
3363         * ircd/parse.c: don't let rank-and-file users escape HIS
3364         limitations with /jupe...
3365
3366 2004-06-18  Alex Badea  <decampos@users.sourceforge.net>
3367
3368         * ircd/gline.c (gline_lookup): only return a gline if it's
3369         active
3370
3371         * ircd/s_conf.c (find_kill): don't check for active gline,
3372         since gline_lookup does now
3373
3374 2002-11-11  hikari <shadow@undernet.org>
3375         * ircd/ircd.c: added call to irc_crypt_init() - someone hurry up and 
3376         modularise :P
3377
3378         * ircd/ircd_xopen.c: removed, superseded by new crypto system.
3379
3380         * ircd/ircd_crypt.c: wrote scary ircd_crypt() interface function,
3381         wrote ircd_crypt_mech_register() function, various other bits 
3382         designed to create a near-pluggable crypto system for ircu.  currently
3383         this code also loads the various mechanisms i've written code for.
3384
3385         * ircd/ircd_crypt_smd5.c: imported the crypt_md5 function from 
3386         elsewhere, manipulated to suit ircu, returns a salted MD5 password.
3387
3388         * ircd/ircd_crypt_native.c: replaces the old ircd_xopen.c file,
3389         generate a crypted password using the systems native crypt() function.
3390
3391         * ircd/ircd_crypt_plain.c: plain text crypt mechanism, should really
3392         only be used for testing purposes.
3393
3394         * ircd/ircd_md5.c: main gubbins of the MD5 hashing code, lifted from
3395         elsewhere, ircuified.
3396
3397         * ircd/umkpasswd.c: mkpasswd program for ircu.
3398
3399         * include/ircd_xopen.h: removed, superseded by new crypto system.
3400
3401         * include/ircd_crypt.h: external definitions for the new ircd_crypt()
3402         function and definition of the ircd_crypt_mech structure for containing
3403         crypto mechanism data.
3404
3405         * include/ircd_crypt_smd5.h: sundary definitions for the salted MD5
3406         mechanism.
3407
3408         * include/ircd_crypt_native.h: sundary definitions for the native 
3409         crypt() mechanism.
3410
3411         * include/ircd_crypt_plain.h: sundary definitions for the plain text
3412         mechanism.
3413
3414         * include/umkpasswd.h: fluff for umkpasswd.
3415
3416 2003-03-11  Landon Fuller (landonf) <landonf@sf.net>
3417
3418         * configure.in: allow ircu to build on OS X.
3419
3420 2004-05-24  Michael Poole <mdpoole@troilus.org>
3421
3422         * ircd/m_invite.c (m_invite): Include channel name in invitation
3423         announcements.
3424         (ms_invite): Likewise, and also fix a use-before-assignment bug in
3425         them.
3426
3427 2004-05-18  Michael Poole <mdpoole@troilus.org>
3428
3429         Announce invitations to other channel operators.
3430
3431         * include/ircd_features.h, ircd/ircd_features.c
3432         (ANNOUNCE_INVITES): Add new boolean feature, default off.
3433
3434         * include/numeric.h, ircd/s_err.c (RPL_ISSUEDINVITE): Add new
3435         reply.
3436
3437         * include/send.h, ircd/send.c (sendcmdto_channel_butserv_butone):
3438         Add 'skip' parameter that is needed elsewhere.
3439         (sendcmdto_channel_servers_butone): New function.
3440
3441         * ircd/channel.c, ircd/m_burst.c, ircd/m_kick.c, ircd/m_topic.c,
3442         ircd/s_user.c: Add argument for 'skip' to calls to s_c_b_b.
3443
3444         * ircd/m_invite.c (m_invite, ms_invite): If ANNOUNCE_INVITES, send
3445         the INVITE message to all interested servers, and send a numeric
3446         to all local chanops.
3447
3448 2004-05-18  Michael Poole <mdpoole@troilus.org>
3449
3450         * ircd/res_adns.c (res_ourserver): Remove unused function.
3451         (validate_name): Likewise.
3452
3453 2004-05-17  Michael Poole <mdpoole@troilus.org>
3454
3455         * include/ircd_features.h, ircd/ircd_features.c, ircd/s_debug.c:
3456         Rip out feature settings related to oper privileges.
3457
3458         * include/client.h: Comment a few unexplained privileges.
3459
3460         * ircd/ircd_lexer.l: Rename privilege keywords to match their
3461         names in code and /PRIVS output.  Add support for two "new"
3462         privileges (FORCE_OPMODE, FORCE_LOCAL_OPMODE).
3463
3464         * include/class.h, ircd/client.c, ircd/ircd_parser.y,
3465         ircd/m_oper.c: Replace the removed feature settings with
3466         per-connection class operator privileges.
3467
3468         * doc/example.conf: Document the change.
3469
3470         * ircd/ircd_parser.y (portblock): Fix slight memory leak.
3471
3472 2004-05-16  Michael Poole <mdpoole@troilus.org>
3473
3474         * doc/example.conf: Make this show the new NICKLEN default.
3475
3476 2004-05-14  Kevin L Mitchell  <klmitch@mit.edu>
3477
3478         * ircd/ircd_features.c: per CFV-0243, NICKLEN default is increased
3479         to 12
3480
3481 2004-05-14  Kevin L Mitchell  <klmitch@mit.edu>
3482
3483         * ircd/s_user.c: process account creation timestamp if present in
3484         user mode portion of a N protocol message; add account creation
3485         timestamp to outgoing N protocol messages if that timestamp is
3486         non-zero
3487
3488         * ircd/m_account.c: process account creation timestamp if present
3489         in AC protocol message
3490
3491         * include/struct.h: add account creation timestamp
3492
3493 2004-05-16  Michael Poole <mdpoole@troilus.org>
3494
3495         * doc/example.conf: Document operator privilege settings.
3496
3497 2004-05-16  Michael Poole <mdpoole@troilus.org>
3498
3499         Get rid of CONF_LOCOP; use PRIV_PROPAGATE instead.
3500
3501         * ircd/ircd_parser.y (invert): New variable.
3502         (operlocal): Remove production.
3503         (operpriv): Use "invert" variable.
3504         (privtype): Add LOCAL alternative production.
3505
3506         * ircd/m_oper.c (m_oper): Remove references to CONF_LOCOP; replace
3507         with CONF_OPERATOR or PRIV_PROPAGATE checks, as appropriate.
3508
3509         * ircd/s_conf.c (AuthorizationCheckResult, find_conf_exact):
3510         Likewise.
3511
3512         * ircd/s_stats.c (report_array, statsinfo): Likewise.
3513
3514         * ircd/s_user.c (set_user_mode): Likewise.
3515
3516 2004-05-15  Michael Poole <mdpoole@troilus.org>
3517
3518         * patches/diffs/astralnet.diff, patches/diffs/nocfv.diff: Remove
3519         patches obsoleted by F: lines.
3520
3521         * patches/diffs/topicburst.diff: Remove patch that was integrated
3522         into the main code.
3523
3524 2004-05-15  Isomer <isomer@undernet.org>
3525
3526         [Original ChangeLog date: 2003-11-05 -MDP]
3527
3528         * ircd/m_whois.c: On remote whois, show +s local channels with a *
3529         prefix to opers.
3530
3531 2004-05-15  Michael Poole <mdpoole@troilus.org>
3532
3533         * include/gline.h, ircd/gline.c, ircd/s_err.c: Forward port a lot
3534         of gline-related fixes from 2.10.11.  Things that work are due to
3535         Kev, Isomer, Spike, hikari, and probably others; CVS makes it hard
3536         to figure out who did what.  Any mistakes are mine.
3537
3538 2004-05-15  Isomer <isomer@undernet.org>
3539
3540         [Original ChangeLog date: 2003-11-05 -MDP]
3541
3542         * ircd/s_misc.c, ircd/s_user.c: added numnick to SNO_CONNEXIT
3543         messages (so you can match EXIT's to CONN's)
3544
3545 2004-05-15  Reed Loden <reed@reedloden.com>
3546
3547         [Original ChangeLog date: 2003-05-01 -MDP]
3548
3549         * ircd/s_err.c: Added network to text and edited 001 a bit.
3550
3551         * ircd/s_user.c: Send network with 001.
3552
3553 2004-05-15  Michael Poole <mdpoole@troilus.org>
3554
3555         * ircd/s_user.c (add_target): Move free target invite check...
3556
3557         * ircd/s_user.c (check_target_limit): to here, matching 2.10.11's
3558         behavior.
3559
3560 2004-05-15  Isomer <isomer@undernet.org>
3561
3562         [Original ChangeLog date: 2003-11-23 -MDP]
3563
3564         * ircd/s_user.c: Don't credit users with an extra attempt if they
3565         are klined/glined, throttle them!
3566
3567 2004-05-15  Jeekay <jeekay@netgamers.org>
3568
3569         [Original ChangeLog date: 2003-04-24 -MDP]
3570
3571         * ircd/s_user.c: Altered (K-lined) to depend on find_kill type
3572
3573 2004-05-15  splidge <splidge@quakenet.org>
3574
3575         [Original ChangeLog date: 2003-09-03 -MDP]
3576
3577         * ircd/s_user.c: Made hide_hostmask() not show bogus joins for
3578         channels where the user is a zombie.
3579
3580 2004-05-15  beware <steendijk@xs4all.nl>
3581
3582         [Original ChangeLog date: 2003-10-25 -MDP]
3583         
3584         * ircd/m_whois.c: Fixed /whois comma separated list with wildcards
3585         cpu hog bug
3586
3587 2004-05-15  Michael Poole <mdpoole@troilus.org>
3588
3589         * ircd/s_conf.c (rehash): Call clear_quarantines on rehash since
3590         2.10.11 does.  Show ident and IP for clients being killed by new
3591         G-lines and K-lines.
3592
3593 2004-05-15  hikari <shadow@undernet.org>
3594
3595         [Original ChangeLog date: 2003-06-27 -MDP]
3596         
3597         * ircd/ircd.c: After thought, update the next check time based on
3598         when an unregistered client should expire.
3599
3600 2004-05-15   hikari <shadow@undernet.org>
3601
3602         [Original ChangeLog date: 2003-06-22 -MDP]
3603
3604         * ircd/ircd.c: Fixed check_pings() - shouldn't be any problem with
3605         clients not being able to connect anymore.
3606
3607 2004-05-15  Michael Poole <mdpoole@troilus.org>
3608
3609         * ircd/channel.c (can_join): Revert to using IsInvited() rather
3610         than walking the list directly.
3611         (modebuf_flush_int): Fix errant HEAD_IN_SAND_SNOTICES check to
3612         use feature_bool(FEAT_HIS_SNOTICES) instead.
3613
3614 2004-05-15  Kevin L Mitchell  <klmitch@mit.edu>
3615
3616         [Original ChangeLog date: 2004-01-31 -MDP]
3617
3618         * ircd/channel.c (mode_parse_key): don't allow , in keys!
3619
3620 2003-04-12  David Mansell (splidge) <splidge@sf.net>
3621
3622         [Original ChangeLog date: 2003-04-14 -MDP]
3623
3624         * ircd/channel.c: When keys and limits conflict on burst, the key
3625         which is first alphabetically or the limit which is lower will be 
3626         used by both servers. This matches pre-2.10.11 behaviour.  
3627         Closes: (#713930)
3628
3629 2004-05-15  David Mansell <splidge@quakenet.org>
3630
3631         [Original ChangeLog date: 2002-12-28 -MDP]
3632
3633         * ircd/channel.c (mode_parse_limit): don't allow -l when no limit is
3634         set, don't allow -l with negative parameter (or unsigned >2^31).
3635  
3636 2004-05-15  David Mansell <splidge@quakenet.org>
3637
3638         [Original ChangeLog date: 2002-12-31 -MDP]
3639
3640         * ircd/m_burst.c (ms_burst): when kicking net riders, clear
3641         invites too.
3642
3643 2004-05-15  Isomer <isomer@undernet.org>
3644
3645         [Original ChangeLog date: 2003-11-04 -MDP]
3646
3647         * ircd/s_serv.c: Burst glines/jupes early
3648
3649 2004-05-15  volta <volta2@gmx.de>
3650
3651         [Original ChangeLog date: 2003-04-26 -MDP]
3652
3653          * ircd/m_userip.c, ircd/m_userhost.c: Small fix, that
3654          allows users to see their own ip & hostname. (Should solve
3655          all problems with dcc)
3656
3657 2004-05-15  Kevin L Mitchell  <klmitch@mit.edu>
3658
3659         [Original ChangeLog date: 2003-06-13 -MDP]
3660
3661         * ircd/m_settime.c: it's supposed to be %ld, not %l
3662
3663 2004-05-15  Isomer <isomer@undernet.org>
3664
3665         [Original ChangeLog date: 2004-03-20 -MDP]
3666
3667         * ircd/m_invite.c: Disallow invites to non existant channels
3668
3669 2004-05-15  David Mansell <splidge@quakenet.org>
3670
3671         [Original ChangeLog date: 2003-04-26 -MDP]
3672
3673         * ircd/m_invite.c: let +k users invite into channels they aren't on.
3674
3675 2004-05-15  hikari <shadow@undernet.org>
3676
3677         [Original ChangeLog date: 2003-07-13 -MDP]
3678         
3679         * ircd/IPcheck.c: Fixed (another) overflow problem in
3680         ip_registry_check_local()
3681
3682         [Original ChangeLog date: 2003-06-29 -MDP]
3683
3684         * ircd/IPcheck.c: Fixed overflow problem in
3685         ip_registry_connect_fail()
3686
3687 2004-05-15 Isomer <isomer@undernet.org>
3688
3689         [Original ChangeLog date: 2003-05-02 -MDP]
3690         
3691         * ircd/IPcheck.c: Added assert()'s to check for underflow
3692
3693 2004-05-15  Kevin L Mitchell  <klmitch@mit.edu>
3694
3695         [Original ChangeLog date: 2003-11-22 -MDP]
3696
3697         * tools/wrapper.c: commit uid on chroot fix from ubra
3698
3699         * ircd/version.c.SH: fix generation generation
3700
3701 2004-05-15  Isomer <isomer@undernet.org>
3702
3703         [Original ChangeLog date: 2003-11-23 -MDP]
3704         
3705         * ircd/os_*.c, ircd/ircd_features.c: Default changing window sizes
3706         to off.  if an admin is smart enough to understand these features
3707         they can enable them manually.
3708
3709 2004-05-15  splidge  <splidge@quakenet.org>
3710
3711         [Original ChangeLog date: 2003-03-26 -MDP]
3712
3713         * ircd/include/ircd_features.h, include/ircd_osdep.h,
3714           ircd/ircd_features.c, ircd/listener.c, ircd/os_bsd.c, 
3715           ircd/os_generic.c, ircd/os_linux.c, ircd/os_openbsd.c
3716           ircd/os_solaris.c, ircd/s_bsd.c: Patch to allow socket bufs to be 
3717           altered via F: lines
3718
3719 2004-05-15  Isomer <isomer@undernet.org>
3720
3721         [Original ChangeLog date: 2003-11-18 -MDP]
3722
3723         * ircd/s_auth.c, ircd/res_libresolv.c, ircd/res_adns.c: Clean up
3724         the preregistration subsystem allowing customisation of timers,
3725         make the dns resolver stats oper only, and make it much more clear
3726         what all the numbers are.
3727
3728 2004-05-15  Spike <spike@undernet.org>
3729
3730         [Original ChangeLog date: 2003-11-23 -MDP]
3731
3732         * ircd/IPcheck.c: Make IPcheck constants configurable
3733
3734 2004-05-14  Kevin L Mitchell  <klmitch@mit.edu>
3735
3736         [Original ChangeLog date: 2003-11-22 -MDP]
3737
3738         * ircd/m_nick.c (m_nick): truncate the nickname to the minimum of
3739         the maximum allowed length (NICKLEN) or the allowed nickname
3740         length specified as the NICKLEN feature
3741
3742         * ircd/ircd_features.c: declare NICKLEN and set its default value
3743         to 9
3744
3745         * include/supported.h: add MAXNICKLEN to ISUPPORT and do a little
3746         rearranging...
3747
3748         * include/ircd_features.h: add NICKLEN feature
3749
3750         * include/ircd_defs.h (NICKLEN): raise max NICKLEN to 15
3751
3752         * doc/readme.features: document new NICKLEN feature
3753
3754         * doc/example.conf: list new NICKLEN F-line
3755
3756 2004-05-14  Matthias Crauwels <ultimate_@wol.be>
3757
3758         [Original ChangeLog date: 2003-06-08 -MDP]
3759         
3760         * ircd/gline.c: fixed the counting bug in gline_memory_count
3761  
3762         * ircd/jupe.c: fixed the counting bug in jupe_memory_count
3763
3764 2004-05-14  Michael Poole <mdpoole@troilus.org>
3765
3766         * ircd/m_mode.c (ms_mode): Do not always try to call
3767         set_user_mode() when parv[1] is a channel name.
3768
3769 2004-05-10  Michael Poole <mdpoole@troilus.org>
3770
3771         Implement a per-connection-class default usermode option.
3772
3773         * doc/example.conf: Illustrate how to use the option.
3774
3775         * include/class.h (struct ConnectionClass): New "default_umode"
3776         field.
3777         (ConfUmode): New macro.
3778
3779         * include/client.h (client_get_default_umode): New function.
3780
3781         * ircd/client.c (client_get_default_umode): Implement it.
3782
3783         * ircd/ircd_lexer.l (usermode): New token.
3784
3785         * ircd/ircd_parser.y (classblock, etc): New syntax.
3786
3787         * ircd/s_user.c (register_user): Set default user modes for user.
3788         This sends the new mode to the user, so the explicit send later
3789         is no longer necessary.
3790
3791 2004-05-10  Michael Poole <mdpoole@troilus.org>
3792
3793         Forward port of asuka-topicburst.patch from Quakenet's "Asuka"
3794         patch set.
3795
3796         * include/ircd_features.h (FEAT_TOPIC_BURST): Add new feature.
3797
3798         * ircd/channel.c (send_channel_modes): If F:TOPIC_BURST:TRUE,
3799         also send a TOPIC to the peer.
3800
3801         * ircd/ircd_features.c (FEAT_TOPIC_BURST): Add new boolean
3802         feature, defaulting to FALSE.
3803
3804         * ircd/m_topic.c (do_settopic): Add argument for topic timestamp,
3805         and allow F:HIS_BANWHO to hide the originator of the topic.
3806         (ms_topic): Parse optional timestamp arguments to TOPIC, and use
3807         them to decide whether to ignore the topic.
3808
3809 2004-05-10  Michael Poole <mdpoole@troilus.org>
3810
3811         Forward port of delayed-join.patch from Quakenet's "Asuka" patch
3812         set (which was a port of code I wrote for the other ircu).
3813
3814         * include/channel.h (CHFL_DELAYED): New membership flag.
3815         (MODE_DELJOINS, MODE_WASDELJOINS): New channel modes.
3816         (infochanmodes): Add +D to list of supported channel modes.
3817         (IsDelayedJoin, SetDelayedJoin, ClearDelayedJoin): New macros.
3818         (member_can_send_to_channel, client_can_send_to_channel): Add
3819         "reveal" parameter to indicate whether a request should cause
3820         a join-delayed user to become visible.
3821         (RevealDelayedJoin, CheckDelayedJoins): New functions.
3822
3823         * include/numeric.h (RPL_DELNAMREPLY): New numeric.
3824         
3825         * include/s_user.h (NAMES_DEL): New flag for do_names().
3826
3827         * include/supported.h (FEATURESVALUES2): Add +D to list of
3828         supported channel modes.
3829
3830         * ircd/channel.c (remove_member_from_channel,
3831         member_can_send_to_channel, client_can_send_to_channel,
3832         joinbuf_join): Handle join-delayed users.
3833         (channel_modes, modebuf_flush_int, modebuf_mode, modebuf_flush,
3834         modebuf_extract, mode_process_clients, mode_parse_mode,
3835         mode_parse): Handle delayed-join channels.
3836         (RevealDelayedJoin, CheckDelayedJoins): New functions.
3837
3838         * ircd/ircd_relay.c (relay_channel_message, relay_channel_notice,
3839         server_relay_channel_message, server_relay_channel_notice): Add
3840         argument for "reveal" parameter to client_can_send_to_channel().
3841
3842         * ircd/m_burst.c (ms_burst): Support MODE_DELJOINS channels.
3843
3844         * ircd/m_clearmode.c (do_clearmode): Support clearing mode +D.
3845
3846         * ircd/m_join.c (join0): Pass the CHFL_DELAYED flag when parting a
3847         channel with JOIN 0.
3848
3849         * ircd/m_kick.c (m_kick): For join-delayed members, only send the
3850         KICK to the kicker and kickee.  Then check whether +d can be
3851         removed.
3852
3853         * ircd/m_names.c (do_names): Show join-delayed users if and only
3854         if the NAMES_DEL flag is given.  If NAMES_DEL is given, also use
3855         RPL_DELNAMREPLY instead of RPL_NAMREPLY.
3856         (m_names): If NAMES -D, pass NAMES_DEL to do_names().
3857
3858         * ircd/m_part.c (m_part, ms_part): Add "reveal" argument for
3859         member_can_send_to_channel().  Set CHFL_DELAYED join in joinbuf if
3860         the user is join-delayed.
3861
3862         * ircd/m_quit.c (m_quit): Handle join-delayed users and new
3863         argument for member_can_send_to_channel().
3864
3865         * ircd/m_topic.c (do_settopic): If a join-delayed channel member
3866         changes the topic, reveal the member.
3867
3868         * ircd/m_wallchops.c (m_wallchops, ms_wallchops): Add argument for
3869         "reveal" parameter to client_can_send_to_channel().
3870
3871         * ircd/m_wallvoices.c (m_wallvoices, ms_wallvoices): Likewise.
3872
3873         * ircd/m_who.c (m_who): Skip join-delayed members where we skip
3874         zombies.
3875
3876         * ircd/m_whois.c (do_whois): Use '<' as a prefix for join-delayed
3877         users.  Use slightly more efficient macros rather than function
3878         calls to test for ops and voice.
3879
3880         * ircd/s_err.c (RPL_DELNAMREPLY): New numeric response string.
3881
3882         * ircd/s_user.c (hide_hostmask): For users with no modes in a
3883         join-delayed channel, do not send JOIN to other members after the
3884         QUIT :Registered.
3885
3886         * ircd/send.c (sendcmdto_common_channels_butone): Skip
3887         join-delayed users where we skip zombies.
3888         
3889 2004-05-10  Michael Poole <mdpoole@troilus.org>
3890
3891         * ircd/ircd_events.c: Actually reference and try to use the epoll
3892         event engine.  Omitted from yesterday's commit.
3893
3894 2004-05-09  Michael Poole <mdpoole@troilus.org>
3895
3896         Forward port of Paul "Zoot" Chang's pseudo-command.patch and
3897         pseudo-support.patch.
3898
3899         * doc/example.conf: Illustrate how to use the feature.
3900
3901         * include/handlers.h (m_pseudo): Declare new handler function.
3902
3903         * include/ircd_features.h (HIS_STATS_R): Add a feature to control
3904         user visibility of the pseudo-commands.
3905
3906         * include/msg.h: Add flag and field for the extra information used
3907         to select a pseudo-command's target.
3908
3909         * include/numeric.h (RPL_STATSRLINE, ERR_SERVICESDOWN): Add
3910         definitions.
3911
3912         * include/parse.h (register_mapping, unregister_mapping): Declare.
3913
3914         * include/s_conf.h (struct nick_host, struct s_map,
3915         GlobalServiceMapList): Define.
3916
3917         * ircd/Makefile.in: Add m_pseudo.c to IRCD_SRC.  Add generated
3918         files to "make depend" dependency list.  Update dependencies.
3919
3920         * ircd/ircd_features.c (HIS_STATS_R): Define feature type and
3921         default value.
3922
3923         * ircd/ircd_lexer.l (pseudo, prepend): Recognize new tokens.
3924
3925         * ircd/ircd_parser.y: Support "Pseudo" configuration blocks.
3926
3927         * ircd/parse.c (msgtab): Add initializer for field "extra" to all
3928         commands.
3929         (msg_tree_insert, msg_tree_remove, register_mapping,
3930         unregister_mapping): New functions.
3931         (parse_client): Implement MFLG_EXTRA extra argument passing.
3932
3933         * ircd/s_conf.c (GlobalServiceMapList): New variable.
3934
3935         * ircd/s_err.c (RPL_STATRLINE, ERR_SERVICESDOWN): Add format
3936         strings for new numeric responses.
3937
3938         * ircd/s_stats.c (stats_mapping): New function.
3939         (statsinfo): Add entry for /stats R and make old /stats r entry
3940         case-sensitive.
3941         
3942 2004-05-09  Michael Poole <mdpoole@troilus.org>
3943
3944         * ircd/ircd_parser.y (parse_error): Convert to being a wrapper for
3945         yyerror() so that configuration errors all go to the same place.
3946
3947         * ircd/s_conf.c: New variables conf_error and conf_already_read.
3948         conf_error is cleared by read_configuration_file() and set by
3949         yyerror(); conf_already_read is set by read_configuration_file()
3950         and never cleared.  Make yyerror() display error to stderr before
3951         conf_already_read is set.  Make configuration errors a fatal
3952         condition in init_conf().
3953
3954 2004-05-09  Michael Poole <mdpoole@troilus.org>
3955
3956         * ircd/Makefile.in: Pass the source directory as an argument to
3957         version.c.SH so it knows where to find the source files for an
3958         out-of-srcdir build.
3959
3960         * ircd/version.c.SH: Use that information.
3961
3962 2004-05-09  Michael Poole <mdpoole@troilus.org>
3963
3964         * Makefile.in: Ensure ${prefix}/include exists, since the adns
3965         install puts files in that directory.  (The adns Makefile does
3966         not use configure's ${includedir}.)
3967
3968 2004-05-09  Michael Poole <mdpoole@troilus.org>
3969
3970         * doc/readme.features: The logic for F:AUTOHIDE was removed, but
3971         not its documentation.  Fix that omission.
3972
3973         * include/ircd_features.h, ircd/ircd_features.c: Remove the unused
3974         definitions for FEATURE_AUTOHIDE.
3975
3976 2004-05-09  Michael Poole <mdpoole@troilus.org>
3977
3978         * doc/readme.who: Document the support for account matching and
3979         display in the WHO command.
3980
3981 2004-05-09  Michael Poole <mdpoole@troilus.org>
3982
3983         * ircd/ircd.c (main): Move check_pid() call until after we read
3984         the configuration file so that F:PPATH works correctly.
3985
3986 2004-05-09  Michael Poole <mdpoole@troilus.org>
3987
3988         * ircd/match.c (match): Use ToLower() instead of tolower() for
3989         character comparisons.
3990
3991 2004-05-09  Michael Poole <mdpoole@troilus.org>
3992
3993         * ircd/s_user.c (register_user): Initialize "flag" (user's old
3994         modes) passed to send_umode() so that the real set of modes are
3995         sent to the user.
3996         
3997 2004-05-09  Michael Poole <mdpoole@troilus.org>
3998
3999         * ircd/m_server.c (ms_server): Apply +h/+s flags only to the new
4000         server, not to a hub between us and the new server.
4001
4002         * ircd/ircd_relay.c (relay_directed_message): Check FLAG_SERVICE
4003         on target server rather than FLAG_CHSERV (so that directed
4004         messages work at all).
4005
4006 2004-05-09  Michael Poole <mdpoole@troilus.org>
4007
4008         * configure.in: Add checks for epoll_* system call family.
4009
4010         * configure: Regenerate.
4011
4012         * ircd/engine_epoll.c: New file; forward ported from 2.10.11
4013         branch.
4014
4015 2004-05-09  Michael Poole <mdpoole@troilus.org>
4016
4017         * include/ircd_alloc.h: Add definitions for MyRealloc, since they
4018         are needed by kqueue and epoll event engines; kill #if 0'd block.
4019
4020         * include/memdebug.h: Declare dbg_realloc() helper function.
4021
4022         * ircd/ircd_alloc.c: Implement DoRealloc() helper function.
4023
4024         * ircd/memdebug.c: Implement dbg_realloc() helper function.
4025
4026 2004-05-09  Michael Poole <mdpoole@troilus.org>
4027
4028         * ircd/channel.c (find_no_nickchange_channel): Disallow nick
4029         changes on a moderated channel with neither ops nor voice.
4030
4031         * ircd/s_err.c: Update ERR_BANNICKCHANGE message to match.
4032
4033 2004-01-20  Perry Lorier <isomer@undernet.org>
4034
4035         * ircd/ircd_parser.y: Fixed parser to work with a more modern bison
4036
4037 2004-01-21 Gavin Grieve <hektik@dimebox.net>
4038
4039         * ircd/channel.c, include/channel.h: bring forward the IsUserParting()
4040           code to resolve the multiple part messages bug written by Entrope.
4041
4042 2003-08-12 Timothy Vogelsang <net@astrolink.org>
4043
4044         * ircd/match.c: (match) rewrote function based on existing
4045           code from the hybrid ircd -- death to goto
4046
4047 2003-07-07  Bas Steendijk <steendijk@xs4all.nl>
4048
4049         * ircd/s_user.c: invalidate ban cache for user on host hiding/account
4050
4051 2003-07-04  Bas Steendijk <steendijk@xs4all.nl>
4052
4053         * include/client.h, ircd/m_userhost.c, ircd/m_userip.c, ircd/m_who.c,
4054         ircd/m_whois.c, ircd/whocmds.c: the same code, for "can user A see user
4055         B is an oper", appeared in a lot of places. made it a define SeeOper.
4056
4057 2003-07-04  Bas Steendijk  <steendijk@xs4all.nl>
4058         * ircd/s_user.c: umode_str (user modes in N token) internal flags var
4059         was not initialized to the user's flags, returned a string with
4060         random modes set.
4061
4062 2003-07-01  Bas Steendijk  <steendijk@xs4all.nl>
4063
4064         * ircd/m_names.c: length counter being incremented one too many
4065         for each nick, resulting names reply messages are about 50 chars
4066         shorter than possible. fixed.
4067
4068 2003-06-29  Bas Steendijk  <steendijk@xs4all.nl>
4069
4070         * ircd/channel.c: don't ever send mode changes for local channels to
4071         servers.
4072
4073 2003-06-27  Bas Steendijk  <steendijk@xs4all.nl>
4074
4075         * include/channel.h, include/client.h, ircd/s_user.c, ircd/s_err.c:
4076         moved the supported channel/user mode strings of the 004 reply from
4077         s_err.c to the header files where the channels/user modes are
4078         defined, and show or hide +Au based on OPLEVELS setting.
4079
4080 2003-06-25  Bas Steendijk  <steendijk@xs4all.nl>
4081
4082         * ircd/m_burst.c: Clear topic set by netrider on burst.
4083
4084 2003-08-05 Diane Bruce  <db@db.net>
4085
4086         * ircd/parse.c: Fixed the typo the fix of the typo created
4087
4088 2003-08-01 Diane Bruce  <db@db.net>
4089
4090         * ircd/parse.c: Fixed typo
4091
4092 2003-06-22  Diane Bruce  <db@db.net>
4093
4094         * ircd/parse.c: Completely rewritten June 2, 2003 - Dianora
4095
4096 2003-06-22  Bas Steendijk  <steendijk@xs4all.nl>
4097
4098         * include/ircd_features.h, include/supported.h, ircd/ircd_features.c,
4099         ircd/ircd_features.c, ircu2.10/ircd/m_join.c, doc/example.conf: 
4100         Make ability to create local channels a feature which can be disabled.
4101
4102 2003-06-22  Bas Steendijk  <steendijk@xs4all.nl>
4103
4104         * include/ircd_features.h, ircd/channel.c, ircd/ircd_features.c,
4105         ircd/m_kick.c, doc/example.conf: Added OPLEVELS feature, which
4106         makes it possible to disable the +Au/oplevels functions.
4107
4108 2003-06-17  Alex Badea  <vampire@p16.pub.ro>
4109
4110         * ircd/res_adns.c: included sys/types.h, for non-Linux
4111         headers
4112
4113 2003-03-06  Kevin L. Mitchell  <klmitch@mit.edu>
4114
4115         * libs/dbprim: database primitives library, including
4116         flexible linked lists, auto-resizing hash tables, and sparse
4117         matrices.  Has a test suite for everything but portions of
4118         the sparse matrix routines (I'm lazy; someone help me write
4119         them!).  Documentation generated by doxygen--feel free to
4120         critique, suggest phrasing improvements, etc.
4121
4122 2003-01-22  Kevin L. Mitchell  <klmitch@mit.edu>
4123         * libs: put third-party libraries in this subdirectory.
4124         Started by copying adns into it--will fix the rest and remove
4125         the top-level copy later.
4126
4127 2003-01-14  Andrew Miller <a1kmm@mware.virtualave.net>
4128         * ircd/m_settime.c: Fixed a minor format string issue.
4129         
4130 2003-01-12  Thomas Helvey <tom.helvey@cox.net>
4131         * adns/src/check.c, adns/src/transmit.c, ircd/m_opmode.c,
4132         ircd/motd.c, ircd/s_user.c: Cleanup warnings, fix precedence
4133         bugs in transmit.c and m_opmode.c.
4134
4135 2003-01-12  Thomas Helvey <tom.helvey@cox.net>
4136         * include/class.h, include/ircd_string.h, ircd/class.c,
4137         ircd/gline.c, ircd_string.c: Fix undefined order
4138         of evaluation bug in gline.c, add general purpose hasher for
4139         conf entries. 
4140
4141 2003-01-11  Thomas Helvey <tom.helvey@cox.net>
4142         * include/channel.h, include/ircd_alloc.h, ircd/channel.c,
4143         ircd/client.c, ircd/gline.c, ircd/ircd_alloc.c,
4144         ircd/ircd_events.c, ircd/ircd_log.c, ircd/ircd_parser.y,
4145         ircd/ircd_snprintf.c, ircd/listener.c, ircd/m_nick.c,
4146         ircd/m_opmode.c, ircd/m_whois.c, ircd/motd.c,
4147         ircd/s_auth.c, ircd/s_bsd.c, ircd/uping.c: Server compiles
4148         with g++ again, type safety, const correctness fixes,
4149         remove C++ keywords again :/
4150
4151 2003-01-11  Thomas Helvey <tom.helvey@cox.net>
4152         * ircd/client.c, ircd/ircd_feature.c: Bugfix, the feature
4153         table data was in a different order than the feature data
4154         structure, which resulted in a wild index being used in
4155         feature_bool. The feature_bool function didn't check it's
4156         index before indexing the features array resulting in
4157         a core dump on /oper.
4158
4159 2003-01-10  Thomas Helvey <tom.helvey@cox.net>
4160         * include/client.h, include/res.h, include/s_bsd.h,
4161         ircd/ircd.c, ircd/list.c ircd/m_connect.c, ircd/res_adns.c,
4162         ircd/res_libresolv.c, ircd/s_auth.c, ircd/s_bsd.c, ircd/s_conf.c:
4163         Remove resolver cache wart, change hostent representation, cleanup
4164         resolver clients.
4165
4166 2003-01-10  Thomas Helvey <tom.helvey@cox.net>
4167         * ircd/map.c, ircd/Makefile.in, include/map.h: Remove 
4168         HEAD_IN_SAND macros to get server to build, rebuild dependencies.
4169
4170 2003-01-08  Fredrik Soderblom <froo@quakenet.org>
4171         * ircd/s_err.c, ircd/s_user.c (hide_hostmask): Simplify
4172         RPL_HOSTHIDDEN and the use of it.
4173
4174 2003-01-07  Kevin L Mitchell  <klmitch@mit.edu>
4175
4176         * BUGS: removed from distribution
4177
4178         * ChangeLog.07: moved into doc/history
4179
4180         * ChangeLog.10: moved into doc/history
4181
4182         * INSTALL: pulled up from u2.10.11.04
4183
4184         * README: pulled up from u2.10.11.04
4185
4186         * README.FreeBSD: pulled up from u2.10.11.04
4187
4188         * README.Solaris: pulled up from u2.10.11.04
4189
4190         * RELEASE.NOTES: add sysctl note from u2.10.11.04
4191
4192         * TODO: removed from distribution
4193
4194         * configure.in: add extra check for res_mkquery; remove
4195         --disable-headinsand since it no longer has any effect; pull up
4196         "Enable" vs. "Disable" changes from u2.10.11.04
4197
4198         * doc/readme.asll: pulled up from u2.10.11.04
4199
4200         * doc/readme.features: pull up missing documentation, including a
4201         couple of corrections
4202
4203         * doc/readme.log: correct text to read FACILITY instead of SYSLOG
4204         in the documentation for configuring syslog facility
4205
4206         * include/channel.h: declare IsInvited()
4207
4208         * include/handlers.h: do some minor reorderings
4209
4210         * include/ircd_defs.h: remove deprecated NETWORK and URL_CLIENTS
4211         #define's
4212
4213         * include/ircd_policy.h: removed from the distribution
4214
4215         * include/jupe.h: declare jupe_memory_count()
4216
4217         * include/msgq.h: remove MsgCounts structure
4218
4219         * include/numeric.h: add a blank line after RPL_STATSQLINE; add
4220         RPL_HOSTHIDDEN
4221
4222         * include/s_stats.h: include ircd_features.h for definition of the
4223         enum; remove extraneous declarations
4224
4225         * ircd/Makefile.in: add LDFLAGS to table_gen
4226
4227         * ircd/engine_poll.c: remove commented-out assertion
4228
4229         * ircd/ircd.c: include s_stats.h and call stats_init()
4230
4231         * ircd/ircd_features.c: feature names have to be case-sensitive
4232         because of some of the HIS features
4233
4234         * ircd/ircd_relay.c: reorder includes
4235
4236         * ircd/m_account.c: include string.h for strlen()
4237
4238         * ircd/m_clearmode.c: remove extraneous clean_channelname(); make
4239         sure to refer to chname, not parv[1]
4240
4241         * ircd/m_create.c: remove the broken code that squits servers that
4242         are >5 minutes fast; fix "badop || CHFL_CHANOP" bug that caused op
4243         desyncs
4244
4245         * ircd/m_gline.c: if it's a server, force the gline; don't
4246         gline_find() before determining if the oper had the privilege
4247
4248         * ircd/m_kick.c: kicks by servers should appear to be from the
4249         local server thanks to HIS
4250
4251         * ircd/m_lusers.c: needs ircd_features.h, not ircd_policy.h
4252
4253         * ircd/m_map.c: needs ircd_features.h, not ircd_policy.h
4254
4255         * ircd/m_nick.c: added an assertion and some explanatory comments
4256         pulled up from u2.10.11.04
4257
4258         * ircd/m_opmode.c: no longer requiring oper to be on the channel;
4259         search for quarantines before allowing ops
4260
4261         * ircd/m_privmsg.c: one character typo that probably means nothing
4262
4263         * ircd/m_settime.c: add back comments I left in the code
4264
4265         * ircd/m_squit.c: remove protocol_violation() notices
4266
4267         * ircd/m_userhost.c: return realhost if user is an oper
4268
4269         * ircd/m_wallvoices.c: only m_wallvoices() should add a +
4270
4271         * ircd/m_who.c: add handling for the 'a' field
4272
4273         * ircd/m_whois.c: correct a typo of FEAT_HIS_SERVERNAME for
4274         FEAT_HIS_SERVERINFO
4275
4276         * ircd/s_bsd.c: close file descriptors 0, 1, and 2; pull up some
4277         ancient bug fixes from the u2.10.11 branch
4278
4279         * ircd/s_debug.c: include gline.h, jupe.h, motd.h, and s_stats.h;
4280         call motd_memory_count(), gline_memory_count(), and
4281         jupe_memory_count() when reporting memory usage; add back a
4282         comment regarding "DBuf caveats"
4283
4284         * ircd/s_err.c: add RPL_STATSQLINE, RPL_HOSTHIDDEN, and pull up
4285         change to ERR_NOPRIVILEGES wording
4286
4287         * ircd/s_misc.c: include ircd_features.h and not ircd_policy.h
4288
4289         * ircd/s_stats.c: count from 0 and not 1 when initializing the
4290         stats
4291
4292         * ircd/s_user.c: comment out assertion; remove extraneous
4293         definition of FLAGS_HOST_HIDDEN; add in hikari's "your host is now
4294         hidden" reply; don't detach oper confs unless sptr is not an oper
4295
4296         * ircd/table_gen.c: pull up change to NTL_CHPFX (removing +);
4297         change channel name character range to be from '\041' (!) to
4298         UCHAR_MAX
4299
4300         * ircd/whocmds.c: pull up fix to /who idle time from u2.10.11.04
4301
4302         * tools/linesync/linesync.conf: pull up from u2.10.11.04
4303
4304         * tools/linesync/linesync.sh: pull up from u2.10.11.04
4305
4306 2003-01-07 Andrew Miller <a1kmm@mware.virtualave.net>
4307         * almost everything: Forward ported numerous changes from .11 to .12
4308         
4309 2002-07-05 Andrew Miller <a1kmm@mware.virtualave.net>
4310         * ircd/packet.c(connect_dopacket): Pass the job on to server_dopacket
4311         when they become a server.
4312         * ircd/s_bsd.c(read_packet): Check they are now a server *after* the
4313         packet is sent.
4314         * ircd/class.c(make_class): Fixed an assert to be more useful.
4315         
4316 2002-07-05 Andrew Miller <a1kmm@mware.virtualave.net>
4317         * ircd/packet.c
4318         * ircd/packet.h: (connect_dopacket): Made a dopacket function for
4319         connecting links which sends the messages through the correct message
4320         handler.
4321         * ircd/s_bsd.c(read_packet): Put packets through the correct handler
4322         for connecting links. Properly handle unknown links becoming
4323         connecting or servers.
4324
4325 2002-07-01 Andrew Miller <a1kmm@mware.virtualave.net>
4326         * include/ircd_alloc.h (MyFree): Accept NULL pointers to do nothing
4327         with, this is used quite a lot.
4328         * ircd/class.c (make_class): Initialise the ref_count to 1 so that
4329         we don't leak.
4330         * ircd/class.c (add_class): When updating a class, free the old name
4331         first to prevent leakage.
4332         * ircd/class.c (class_delete_marked): Decrement the ref_count for the
4333         class after it is removed from the linked list.
4334         * ircd/ircd_parser.y: Changed a free to MyFree().
4335         * ircd/ircd_parser.y: Removed a few debugging messages.
4336
4337 2002-07-01 Andrew Miller <a1kmm@mware.virtualave.net>
4338         * s_bsd.c (read_packet): Our daily addition to the list of entities to
4339         treat as servers - Connecting servers.
4340         
4341 2002-07-01 Andrew Miller <a1kmm@mware.virtualave.net>
4342         * doc/debug_memleak_gc.patch,
4343         * include/ircd_ircd_alloc.h,
4344         * include/memdebug.h,
4345         * configure.in,
4346         * ircd/Makefile.in,
4347         * ircd/memdebug.c: added a Boehm's gc based leak detector to find leaks
4348         and notify the operators.
4349         
4350 2002-06-29  Andrew Miller <a1kmm@mware.virtualave.net>
4351
4352         * ircd/s_bsd.c (read_packet): don't make handshaking servers go through
4353         the dbufs.
4354         
4355 2002-06-18  Andrew Miller <a1kmm@mware.virtualave.net>
4356
4357         * ircd/s_bsd.c (read_packet): don't allow unregistered clients to flood
4358         the server.
4359         
4360 2002-06-18  Alex Badea  <vampire@p16.pub.ro>
4361
4362         * ircd/m_burst.c (ms_burst): kick local members if the channel
4363         has a larger local TS and it's +i or +k remotely (anti net.ride)
4364
4365         * ircd/ircd_parser.y: fixed a bug that broke IP-based C:lines
4366
4367         * ircd/s_err.c: connection classes are now strings (RPL_STATSCLINE)
4368
4369         * include/s_conf.h: externalized lookup_confhost
4370
4371         * adns/Makefile.in: compilation-outside-source-tree fix
4372
4373 2002-06-17  Alex Badea  <vampire@p16.pub.ro>
4374
4375         * adns/*: added a slightly hacked copy of adns
4376
4377         * configure.in: added a --disable-adns switch if you want
4378         to use the old libresolv res.c
4379
4380         * configure: ran autoconf
4381
4382         * ircd/res_libresolv.c: renamed from res.c
4383
4384         * ircd/res_adns.c: added adns resolver
4385
4386 2002-06-17  Alex Badea  <vampire@p16.pub.ro>
4387
4388         * ircd/ircd_parser.y: fixed 'Connect' block processing so now
4389         you can actually connect to other servers
4390
4391 2002-06-04  Alex Badea  <vampire@p16.pub.ro>
4392
4393         * ircd/m_stats.c (report_servers_verbose): oops, fixed it so
4394         it displays all servers, not just local connects
4395
4396 2002-05-30  Jean-Edouard Babin  <Jeb@jeb.com.fr>
4397
4398         * ircd/m_server.c (mr_server): fixed core bug on insufficient
4399         arguments
4400
4401 2002-05-26  Jeekay  <jeekay@irc.planetarion.com>
4402         
4403         * ircd/m_join.c (HasControlChars): fixed unsigned vs signed
4404
4405 2002-05-26  Jeekay  <jeekay@irc.planetarion.com>
4406  
4407         * ircd/m_join.c (m_join,HasControlChars): check if a channel
4408         name has any control chars (<=32) in it before allowing a
4409         local user to join.
4410  
4411 2002-21-05 Andrew Miller <a1kmm@mware.virtualave.net>
4412         * ircd/ircd_relay.c: stop an information leak about the
4413         the network topography from relayed messages.
4414
4415 2002-04-19  Alex Badea  <vampire@p16.pub.ro>
4416
4417         * ircd/m_who.c (m_who): disallow non-opers to /who server.name
4418
4419 2002-04-18  Alex Badea  <vampire@p16.pub.ro>
4420
4421         * ircd/s_err.c (RPL_STATSILINE): connection classes are now
4422         strings
4423
4424 2002-04-17  beware <steendijk@tomaatnet.nl>
4425
4426         * m_whois.c (m_whois): disallow remote queries for non-existent
4427         local users when originated by a non-oper
4428
4429 2002-04-16  Alex Badea  <vampire@p16.pub.ro>
4430
4431         * ircd/s_user.c (hunt_server_cmd): also send a "no such server"
4432         reply if the servername contains a '*' and it doesn't exist
4433
4434         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
4435
4436 2002-04-16  beware <steendijk@tomaatnet.nl>
4437
4438         * ircd/m_whois.c: the previous patch broke whois, fixed it
4439         another way
4440
4441         * ircd/m_admin.c: cleaned up m_admin too while we're here,
4442         hunt_server_cmd can do all the work for us
4443
4444 2002-04-15  Alex Badea  <vampire@p16.pub.ro>
4445
4446         * ircd/m_stats.c: added verbose server reporting (/stats v
4447         or /stats V for machine-readable format) (bugzilla bug 52)
4448
4449         * include/numeric.h: added RPL_STATSVERBOSE 236
4450
4451         * ircd/s_err.c: added RPL_STATSVERBOSE
4452
4453         * ircd/s_stats.c: added help for stats 'v'
4454
4455 2002-04-15  Alex Badea  <vampire@p16.pub.ro>
4456
4457         * ircd/class.c (get_client_class): fixed typo which caused
4458         /trace (and perhaps motd) to core
4459
4460 2002-04-15  beware <steendijk@tomaatnet.nl>
4461
4462         * ircd/m_whois.c: Fixed /whois servermask nomatch bug
4463         where normal users could use the function to discover servers,
4464         also the NOSUCHSERVER check code was missing.
4465
4466 2002-04-14  Alex Badea  <vampire@p16.pub.ro>
4467
4468         * ircd/ircd_parser.y: fixed cli_info(&me) not being set
4469         from 'description' conf
4470
4471 2002-04-13  Stephane Thiell <mbuna@undernet.org>
4472
4473         * ircd/m_whois.c: removed FindUser() in ms_whois to fix
4474         remote whois relaying.
4475
4476         * ircd/class.c: removed unused (and duplicated) code
4477         get_client_ping().
4478         
4479         * include/class.h: removed unused function prototype.
4480         
4481         * config.guess: upgraded with latest
4482         
4483         * config.sub: upgraded with latest
4484
4485 2002-04-12  Alex Badea  <vampire@p16.pub.ro>
4486
4487         * ircd-patch: report which files failed the dry run (so the
4488         user may force the patch if the rejects are in less-than-vital
4489         files, such as ChangeLog or documentation)
4490
4491 2002-04-12  Alex Badea  <vampire@p16.pub.ro>
4492
4493         * ircd/m_invite.c: don't propagate invites for local channels
4494
4495         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
4496
4497 2002-04-10 Joseph Bongaarts <foxxe@wtfs.net>
4498
4499         * ircd/ircd.c: The last fix broke autoconnects completely.
4500         Fixed it another way.
4501         
4502 2002-04-09  Brian Cline  <clineb@cs.winthrop.edu>
4503
4504         * ircd/ircd.c (try_connections): To avoid problems with infinite event
4505         loops, don't try connecting to servers whose connect frequency is 0.
4506         
4507 2002-04-10  Alex Badea  <vampire@p16.pub.ro>
4508
4509         * ircd/ircd_parser.y: fixed a "features" block parse bug
4510
4511         * tools/convert-conf.py: added a configuration file converter
4512         from 2.10.11 to 2.10.12 format
4513
4514         * ircd-patch: added GPL information to top of file
4515
4516 2002-04-09  Alex Badea  <vampire@p16.pub.ro>
4517
4518         * configure.in: added a human-readable report of configured
4519         options at the end of the configure process
4520
4521         * configure: regenerated with autoconf
4522
4523 2002-04-08  Gavin Grieve  <ggrieve@ihug.co.nz>
4524
4525         * include/supported.h: change CHARSET to CASEMAPPING after
4526         discussions as to what would be the preferred name.
4527
4528 2002-04-05 Andrew Miller <a1kmm@mware.virtualave.net>
4529         * ircd/s_conf.c, ircd_parser.y, ircd_lexer.l: Add privilege
4530         specification.
4531         * Fix a minor parser bug that meant rehash didn't always
4532         work correctly.
4533
4534 2002-04-03  Alex Badea  <vampire@p16.pub.ro>
4535
4536         * include/channel.h: fix compiler warnings (paratheses around &&)
4537
4538         * ircd/channel.c (modebuf_extract): fix compiler warnings
4539         (uninitialized variables)
4540
4541         * ircd/Makefile.in: make ircd properly compile outside the
4542         source tree
4543
4544 2002-04-03  Alex Badea  <vampire@p16.pub.ro>
4545
4546         * include/s_user.h: added a sptr parameter to InfoFormatter
4547         function type
4548
4549         * ircd/m_who.c: don't match IPs for clients which have a hidden host,
4550         except when the inquiring user is an oper
4551
4552         * ircd/whocmds.c: show the fake IP from FEAT_HIDDEN_IP if the
4553         target has a hidden host, but show real IP to opers
4554
4555         * ircd/m_userip.c (userip_formatter): add sptr parameter; show the
4556         fake IP from FEAT_HIDDEN_IP if the target has a hidden host, but
4557         show real IP to opers
4558
4559         * ircd/m_userhost.c (userhost_formatter): add (unused) sptr parameter
4560
4561         * ircd/s_user.c (send_user_info): pass sptr to the formatting function
4562
4563         * include/ircd_features.h: new feature FEAT_HIDDEN_IP (stores which
4564         fake IP to show for clients with a hidden host)
4565
4566         * ircd/ircd_features.c: new feature FEAT_HIDDEN_IP
4567
4568         * doc/example.conf: default value for FEAT_HIDDEN_IP
4569
4570         * doc/readme.features: documented FEAT_HIDDEN_IP
4571
4572 2002-04-03 Andrew Miller <a1kmm@mware.virtualave.net>
4573         * doc/example.conf: Cleaned up some comments that ended up in
4574           strange places due to problems in the merge process.
4575         * ircd/m_nick.c: Cleaned up ms_nick, and fixed a bug that
4576           probably dates back to Jarkko code.
4577
4578 2002-04-02  Kevin L Mitchell  <klmitch@mit.edu>
4579
4580         * ircd/m_kill.c: let ms_kill() and mo_kill() seperate the message
4581         from the path before calling do_kill(); add a msg argument to
4582         do_kill() and use it in preference to comment; remove all that old
4583         code that fiddled with the buf and the comment
4584
4585         * ircd/ircd_log.c (log_write_kill): add a seperate msg argument
4586
4587         * include/ircd_log.h: add a seperate msg argument to
4588         log_write_kill()
4589
4590         * ircd/ircd.c: display event engine and MAXCONNECTIONS information
4591  
4592 2002-04-02  Alex Badea <vampire@p16.pub.ro>
4593
4594         * ircd-patch: Automatically generate a version string from patches
4595
4596 2002-04-02  Alex Badea <vampire@p16.pub.ro>
4597         
4598         * ircd-patch: Test before doing anything dangerous, provide -f to
4599                 to it anyway.  exit levels for easy scripting.
4600
4601 2002-04-01  Kevin L Mitchell  <klmitch@mit.edu>
4602
4603         * ircd/channel.c (joinbuf_join): don't add a channel to the list
4604         in the joinbuf unless when we flush it, we empty the list
4605
4606 2002-04-02 Andrew Miller <a1kmm@mware.virtualave.net>
4607         * ircd/ircd_parser.y: Added ircd parser, lexer, to replace the
4608           old configuration file format.
4609         * ircd/ircd_lexer.l
4610         * ircd/s_conf.c
4611         * doc/example.conf
4612
4613 2002-03-23 Bert Faes <bert.faes@pandora.be>
4614
4615         * s_misc.c made /trace reply always show the username
4616         
4617 2002-03-28  Kevin L Mitchell  <klmitch@mit.edu>
4618
4619         * configure.in: use AC_CHECK_FUNCS to define HAVE_* macros; test
4620         for setrlimit, getrusage, and times
4621
4622         * configure: rerun auto-conf
4623
4624         * config.h.in: rerun autoheader
4625
4626 2002-03-27  Kevin L Mitchell  <klmitch@mit.edu>
4627
4628         * ircd/m_burst.c (ms_burst): use MODEBUF_DEST_NOKEY to suppress
4629         sending of the key to the channel
4630
4631         * ircd/channel.c (modebuf_flush_int): when processing keys, only
4632         include the actual key in the mode sent to the channel if
4633         MODEBUF_DEST_NOKEY is not set
4634
4635         * include/channel.h: needed more bits for MODEBUF_DEST_*,
4636         especially when adding MODEBUF_DEST_NOKEY to force keys in the
4637         BURST to be reported as "*" to the channel
4638
4639         * ircd/m_oper.c (m_oper): clear the new oper's sendq so it gets
4640         inherited from the class associated with the O-line
4641
4642 2002-03-25  Kevin L Mitchell  <klmitch@mit.edu>
4643
4644         * ircd/s_user.c (set_nick_name): invalidate all ban valid caching
4645         when a user changes his nickname so we can catch if he now matches
4646         a ban
4647
4648 2002-03-20 Reed Loden <reed@redmagnet.com>
4649         * doc/example.conf: Added OPER_LIST_CHAN and LOCOP_LIST_CHAN.
4650
4651         * doc/readme.features: Added OPER_LIST_CHAN and LOCOP_LIST_CHAN.
4652
4653 2002-03-20 LordLuke <lordluke@undernet.org>
4654         * ircd/client.c: Add LOCOP_LIST_CHAN feature.
4655
4656         * ircd/ircd_features.h: Add LOCOP_LIST_CHAN feature.
4657
4658 2002-03-19 Joseph Bongaarts <foxxe@wtfs.net>
4659
4660         * ircd/m_links.c: Make /links behave like /map for head_in_sand.
4661         cleaned up excess code.
4662
4663         * ircd/map.c: Added map_dump_links_head_in_sand() Made changes in
4664         map_add() and map_update() for links changes.
4665
4666         * include/map.h: Added info and prot to struct Map
4667
4668         * include/ircd_defs.h: Added MAP_CACHE_TIME for length of time
4669         servers are cached in MapList
4670
4671         * ircd/s_misc.c: changed #ifdef for map_update()
4672
4673         * ircd/m_server.c: changed #ifdef for map_update()
4674
4675         * include/ircd_policy.h: added NO_HEAD_IN_SAND for easier removal of
4676         hiding features.
4677
4678         * configure.in: add --disable-headinsand
4679
4680         * configure: Ran autoconf
4681
4682         * ircd/m_stats.c: Fixed a bug in /stats i and made /stats i show 
4683         connect limits
4684
4685         * ircd/s_stats.c: Made /stats i report connect limits
4686
4687         * ircd/s_err.c: Modified RPL_STATSILINE to use %s instead of 
4688         "*" for the password field.
4689         
4690 2002-03-19 LordLuke <lordluke@undernet.org>
4691
4692         * include/channel.h: Allow opers to view +s channels in /list
4693
4694         * include/client.h: Add "PRIV_LIST_CHAN" oper privilege
4695
4696         * include/ircd_features.h: added "LIST_CHAN" feature
4697
4698         * ircd/channel.c: Allow opers to view +s channels in /list
4699
4700         * ircd/client.c: Add "PRIV_LIST_CHAN"
4701
4702         * ircd/ircd_features.c: Add "LIST_CHAN" feature
4703
4704 2002-03-13 Joseph Bongaarts <foxxe@wtfs.net>
4705
4706         * ircd/m_kill.c: Last of the last of the bug fixes (Thanks Spike).
4707         Must be more careful when forward porting by hand...
4708         
4709 2002-03-13  Carlo Wood  <run@alinoe.com>
4710
4711         * include/channel.h: CHFL_CHANNEL_MANAGER, new local
4712         channel flag set when someone creates a channel or joins
4713         using the Apass.  IsChannelManager(), SetChannelManager():
4714         macros to manipulate new channel flag.
4715         channel_modes: Added new argument to avoid calling
4716         find_member_link more often than needed.
4717
4718         * include/numeric.h: RPL_APASSWARN, ERR_NOTLOWEROPLEVEL,
4719         ERR_NOTMANAGER, ERR_CHANSECURED, ERR_UPASSSET,
4720         ERR_UPASSNOTSET: new numeric replies.
4721
4722         * ircd/channel.c: is_level0_op: removed.
4723         member_can_send_to_channel: disallow channel manager
4724         to talk.  channel_modes: show upass to level0 ops.
4725         mode_parse_upass: Only the channel manager is allowed
4726         to change the upass.  Only allow to set upass when apass
4727         is also set.  mode_parse_apass: Don't allow to change the
4728         Apass if the channel is older than 48 hours.  Only allow
4729         to remove the apass when upass is not set.  Send clear
4730         warnings regarding the importance of apass.
4731         mode_process_clients: Don't change the oplevel of an opped
4732         member in a channel where upass is not set.
4733
4734         * ircd/destruct_event.c: exec_expired_destruct_events:
4735         Bug fix: send DESTRUCT message when destructing a channel.
4736
4737         * ircd/m_destruct.c: ms_destruct: Bug fix: use self as
4738         prefix for DESTRUCT message.
4739
4740         * ircd/m_join.c: m_join: Handle apass and upass.
4741
4742         * ircd/m_kick.c: m_kick: Don't allow to kick member with
4743         a higher or equal op-level.
4744
4745         * ircd/m_mode.c: m_mode: Now pass member to channel_modes.
4746         ms_mode: Allow server to do modes on channels with apass
4747         set.
4748
4749         * ircd/s_err.c: RPL_APASSWARN, ERR_NOTLOWEROPLEVEL,
4750         ERR_NOTMANAGER, ERR_CHANSECURED, ERR_UPASSSET,
4751         ERR_UPASSNOTSET: new numeric replies.
4752
4753
4754 2002-03-10 Joseph Bongaarts <foxxe@wtfs.net>
4755
4756         * ircd/m_kill.c: Last of the bug fixes for do_kill()
4757
4758         * ircd/list.c: Don't remove clients from the linked list
4759         that aren't actually in the list.
4760         
4761 2002-03-08  Carlo Wood  <run@alinoe.com>
4762         * include/channel.h: Added CHFL_BURST_ALREADY_OPPED
4763         and CHFL_BURST_ALREADY_VOICED.
4764
4765         * ircd/m_burst.c: Allow BURST outside net-burst
4766         and take into account that users are already joined
4767         to the channel in that case.
4768
4769         * ircd/m_destruct.c: Implementation of DESTRUCT
4770         handling code.
4771
4772         * ircd/m_join.c: Set the channel creationtime to
4773         the timestamp of a message when that timestamp is
4774         smaller.
4775 2002-02-27 Reed Loden <reed@redmagnet.com>
4776        * tools/crypter: Updated some variables, added another notice,
4777        added CVS Id tag, and updated Perl location.
4778
4779        * tools/ringlog.c: Added IRC - Internet Relay Chat, 
4780        tools/ringlog.c
4781
4782        * tools/ringlog.pl: Added IRC - Internet Relay Chat, 
4783        tools/ringlog.pl
4784
4785        * tools/wrapper.c: Added IRC - Internet Relay Chat, 
4786        tools/wrapper.c
4787
4788        * tools/mkpasswd.c: Added CVS Id tag
4789
4790        * tools/sums: Updated to comply with sums being moved to tools/
4791        and added CVS Id tag
4792
4793        * tools/README: Updated location of file and partly rewrote to fit 
4794        u2.10.11's Features
4795
4796        * tools/Makefile.crypt: Updated location of file and added CVS Id 
4797        tag
4798
4799        * acconfig.h: Updated location of file
4800
4801        * config.h.in: Updated location of file
4802
4803        * tools/Bounce/bounce.conf: Added CVS Id tag
4804
4805        * tools/Bounce/Bounce.cpp: Updated location of file
4806
4807        * tools/Bounce/Bounce.h: Updated location of file
4808
4809        * tools/hashtoy: Added CVS Id Tag
4810
4811 2002-02-27  Carlo Wood  <run@alinoe.com>
4812
4813         * /ircd/ircd.c: check_pings: First check if a PING was sent at all.
4814
4815 2002-03-01  Carlo Wood  <run@alinoe.com>
4816
4817         * include/channel.h: struct Channel: new attribute destruct_event.
4818         Prototype for destruct_channel().
4819
4820         * include/destruct_event.h: new header file for destruct_event.c.
4821
4822         * ircd/Makefile.in: New source file: destruct_event.c.
4823
4824         * ircd/channel.c: sub1_from_channel: Don't destruct channel
4825         immedeately but instead schedule it for destruction after
4826         some time when a channel becomes empty (and clear invite
4827         only and limit in that case).
4828         destruct_channel: new function, was previously the destructing
4829         part of sub1_from_channel.
4830         add_user_to_channel: remove destruction request if any.
4831
4832         * ircd/destruct_event.c: New file.  Implementation of functions
4833         schedule_destruct_event_1m, schedule_destruct_event_48h,
4834         remove_destruct_event and exec_expired_destruct_events.
4835
4836         * ircd/ircd.c: destruct_event_timer: new timer.
4837         main: use destruct_event_timer to call exec_expired_destruct_events
4838         once per minute.
4839
4840         * ircd/m_endburst.c: ms_end_of_burst: Don't complain about empty
4841         channels.  Schedule new empty channels for destruction.
4842
4843         * ircd/m_join.c: m_join: Destruct just-created channel immedeately.
4844
4845 2002-03-01  Carlo Wood  <run@alinoe.com>
4846         * ircd/s_misc.c: exit_client: Only call map_update()
4847         for servers.
4848
4849 2002-02-28  Carlo Wood  <run@alinoe.com>
4850         * include/channel.h: New attribute 'oplevel' in struct Membership.
4851         Added defines MAXOPLEVELDIGITS and MAXOPLEVEL.
4852         New macros:  OpLevel(member): returns op-level of member and
4853         SetOpLevel(member, value): sets op-level of member.
4854         Prototype of add_user_to_channel: add oplevel to parameters.
4855         Prototype of mode_parse: add member to to parameters.
4856
4857         * include/numeric.h: added ERR_NOTLOWEROPLEVEL.
4858
4859         * ircd/s_err.c: idem.
4860
4861         * ircd/channel.c: Removed unmatched '{' braces from comments
4862         (confuses vi).  add_user_to_channel: oplevel is passed to function
4863         and added in the created MemberShip structure.  send_channel_modes:
4864         Generate the nick:mode list of the BURST msg in the new style (with
4865         op-levels).  DONE_UPASS/DONE_APASS: fixed typo in comment.  struct
4866         ParseState: New attribute: member.  mode_process_clients: Disallow
4867         deopping someone with an equal or higher op-level, take care of
4868         inheritance of op-level.  mode_parse: member is passed to function      
4869         and added in the created ParseState structure.  joinbuf_join: pass 0
4870         as oplevel to add_user_to_channel as needed initialization of oplevel
4871         in struct MemberShip.
4872
4873         * ircd/m_burst.c: ms_burst: Implementation of op-levels in the
4874         decoding of a BURST message and passing on a BURST message.
4875         Renamed default_mode to current_mode.
4876
4877         * ircd/m_mode.c: m_mode/ms_mode: pass on `member' to mode_parse.
4878
4879         * ircd/m_opmode.c: ms_opmode/mo_opmode: pass on NULL as member
4880         to mode_parse (causes opped member to get op-level 0).                  
4881
4882 2002-02-25  Carlo Wood  <run@alinoe.com>
4883         * include/channel.h: Added two new strings to struct Mode,
4884         upass and apass, both with maximum length PASSLEN (a new
4885         define in this file).  Two new mode defines MODE_UPASS and
4886         MODE_APASS.
4887
4888         * ircd/channel.c: is_level0_op: Added as dummy function.
4889         channel_modes/modebuf_flush_int/modebuf_extract/mode_parse:
4890         Added support for MODE_APASS (+A) and MODE_UPASS (+u).
4891         mode_parse_upass: New function to parse mode +u.
4892         mode_parse_apass: New function to parse mode +A.
4893
4894         * ircd/s_err.c: Added 'A' and 'u' to mode list (RPL_MYINFO).            
4895
4896 2002-02-25  Carlo Wood  <carlo@alinoe.com>
4897
4898         * ircd/m_server.c: remove unused variables
4899
4900 2002-02-25 Joseph Bongaarts <foxxe@wtfs.net>
4901
4902         * ircd/m_map.c: Modified to show a useful output to non-opered
4903           clients when HEAD_IN_SAND_MAP is defined. Servers are added to
4904           the list when first seen (after receiving SERVER) and that list
4905           is sent to clients. Servers are excluded from the list if they are
4906           hubs, services, or have been missing for more than 1 week.
4907         
4908         * ircd/map.c: Created file for map_* functions
4909
4910         * include/map.h: Created file for map_* functions
4911
4912         * ircd/m_server.c: Added calls to map_update()
4913
4914         * ircd/s_misc.c: Added call to map_update()
4915
4916         * ircd/parse.c: Changed to use m_map() and mo_map()
4917         
4918 2002-02-22 Reed Loden <reed@redmagnet.com>
4919
4920        * ircd/m_connect.c: Removed an extra : in remote connect message.
4921
4922 2002-02-19 Joseph Bongaarts <foxxe@wtfs.net>
4923
4924         * ircd/whocmds.c: Local opers should also be able to
4925         see servernames in /who
4926
4927         * ircd/gline.c: Fix core bug in gline_find()
4928
4929         * ircd/m_kill.c: Bug fix for HIS_KILLWHO
4930
4931 2002-02-19 John Buttery <john@io.com>
4932
4933         * ircd/ircd.c: Updated "No such file" error message.
4934         
4935 2002-02-18 Joseph Bongaarts <foxxe@wtfs.net>
4936
4937         * ircd/m_kill.c: Changed m_kill() to do_kill() because its not
4938         a message handler, and some general cleanups and bug fixes. 
4939
4940         * include/ircd_policy.h: Added HEAD_IN_SAND_KILLWHO for hiding
4941         kill source.
4942         
4943 2002-02-16  Tim Vogelsang <net@astrolink.org>
4944
4945         * ircd/m_kill.c: added a new static function, m_kill, which
4946         performs the actual kill.
4947         
4948 2002-02-14 Joseph Bongaarts <foxxe@wtfs.net>
4949
4950         * Added support for LIST STOP
4951         
4952 2002-02-13 Joseph Bongaarts <foxxe@wtfs.net>
4953
4954         * Merged changes from u2_10_11 to main branch.
4955         
4956 2002-02-08  Tim Vogelsang  <net@astrolink.org>
4957
4958        * ircd/m_quit.c: don't prefix user quits with "Quit:" unless a
4959        reason is supplied.
4960
4961 2002-02-06  Kevin L Mitchell  <klmitch@mit.edu>
4962
4963         * ircd/s_auth.c (read_auth_reply): left out an = in an
4964         assertion--shouldn't have had any impact, though
4965
4966         * ircd/Makefile.in: add a hook for using ringlog; run make depend
4967
4968         * tools/ringlog.c: for the heck of it, add a comment including
4969         rules for /etc/magic
4970
4971 2002-02-05  Kevin L Mitchell  <klmitch@mit.edu>
4972
4973         * tools/ringlog.pl: perl script to take output from ringlog and
4974         pass it to addr2line to get function, file, and line number
4975         information
4976
4977         * tools/ringlog.c: program/object to help in building function
4978         trace information
4979
4980 2002-02-04  Alex Badea  <vampire@p16.pub.ro>
4981
4982         * include/ircd_features.h: added new feature MOTD_BANNER
4983
4984         * ircd/ircd_features.c: added new feature MOTD_BANNER
4985
4986         * ircd/motd.c (motd_signon): send a one-line banner from
4987         FEAT_MOTD_BANNER if it's not NULL and FEAT_NODEFAULTMOTD
4988         is set
4989
4990         * doc/example.conf: default value for MOTD_BANNER feature
4991
4992         * doc/readme.features: documented the MOTD_BANNER feature
4993
4994 2002-02-04  Kevin L Mitchell  <klmitch@mit.edu>
4995
4996         * ircd/s_debug.c (debug_serveropts): remove deprecated CHROOTDIR
4997         check; added character 'A' to the server options string to
4998         indicate when assertion checking is enabled
4999
5000 2002-02-03  Kevin L Mitchell  <klmitch@mit.edu>
5001
5002         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
5003
5004         * ircd/engine_kqueue.c (set_or_clear): don't generate an ET_ERROR
5005         event if the errno is EBADF, since the caller probably already
5006         knows about it and just hasn't gotten around to processing it yet
5007
5008         * ircd/ircd_events.c: set the GEN_ERROR flag if an ET_ERROR event
5009         is generated; don't process socket_events() or socket_state() if
5010         an error occurred; add GEN_ERROR to list of flags in gen_flags()
5011
5012         * include/ircd_events.h: define new GEN_ERROR flag; add a macro to
5013         clear it
5014
5015 2002-02-01  Kevin L Mitchell  <klmitch@mit.edu>
5016
5017         * ircd/channel.c: change make_nick_user_{ip,host} to not use a
5018         static buffer--instead, a buffer of the right size (NUH_BUFSIZE or
5019         NUI_BUFSIZE--I confess they're not well-named) is allocated by the
5020         caller
5021
5022 2002-02-02  Alex Badea  <vampire@p16.pub.ro>
5023
5024         * include/client.h: added user flag FLAGS_HIDDENHOST
5025
5026         * include/ircd_features.h: added FEAT_HOST_HIDING and
5027         FEAT_HIDDEN_HOST
5028
5029         * include/numeric.h: defined numeric 338 (RPL_WHOISACTUALLY)
5030         to report real hostnames and IPs to opers
5031
5032         * include/s_user.h: exported hide_hostmask()
5033
5034         * include/send.h: changed sendcmdto_channel_butserv to
5035         sendcmdto_channel_butserv_butone; ditto for
5036         sendcmdto_common_channels
5037
5038         * include/struct.h: added realhost to struct User
5039
5040         * include/whowas.h: added realhost to struct Whowas
5041
5042         * ircd/channel.c: match bans against both real and hidden
5043         hostmasks; moved some calls to use sendcmdto_*_butone
5044
5045         * ircd/gline.c: match glines agains real host
5046
5047         * ircd/ircd_features.c: added FEAT_HOST_HIDING and
5048         FEAT_HIDDEN_HOST
5049
5050         * ircd/m_account.c: call hide_hostmask() for possibly
5051         hiding the user's host
5052
5053         * ircd/m_burst.c: moved some calls to use sendcmdto_*_butone
5054
5055         * ircd/m_topic.c: moved some calls to use sendcmdto_*_butone
5056
5057         * ircd/m_userip.c: report IP 127.0.0.1 if the user has a hidden
5058         host
5059
5060         * ircd/m_who.c: match real hosts, if the query comes from an oper
5061
5062         * ircd/m_whois.c: report real hostname and IP to opers
5063
5064         * ircd/m_whowas.c: report real hostname to opers
5065
5066         * ircd/s_err.c: added user mode 'x' to the list of supported user
5067         modes in RPL_MYINFO (004); added RPL_WHOISACTUALLY for reporting
5068         real hostnames to opers
5069
5070         * ircd/s_misc.c: moved some calls to use sendcmdto_*_butone
5071
5072         * ircd/s_serv.c: send real hostname to servers
5073
5074         * ircd/s_user.c: send real hostname to servers; added processing
5075         of usermode 'x'; added hide_hostmask() which actually does the work
5076         of hiding a user's host; moved some calls to use sendcmdto_*_butone
5077
5078         * ircd/send.c: changed sendcmdto_channel_butserv to
5079         sendcmdto_channel_butserv_butone; ditto for
5080         sendcmdto_common_channels
5081
5082         * ircd/whocmds.c: extra letter 'x' in WHO reply if the user has
5083         it's host hidden
5084
5085         * ircd/whowas.c: if needed, store a user's real host so we can
5086         report it to opers later
5087
5088         * doc/readme.features: documented HOST_HIDING and HIDDEN_HOST
5089         features
5090
5091         * doc/example.conf: default values for HOST_HIDING and
5092         HIDDEN_HOST features
5093
5094 2002-02-01  Tim Vogelsang  <net@astrolink.org>
5095
5096         * ircd/send.c (sendwallto_group_butone): don't sent wallops to
5097         ordinary users
5098
5099 2002-01-28  Kevin L Mitchell  <klmitch@mit.edu>
5100
5101         * ircd/jupe.c (jupe_activate): remove a bogus assertion
5102
5103         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
5104
5105         * ircd/s_err.c: added new channel mode 'r' to list of supported
5106         channel modes in RPL_MYINFO (004); migrated RPL_USERIP to use
5107         numeric 340 instead of 307; add ERR_NEEDREGGEDNICK (477) for
5108         informing users why they can't join a +r channel
5109
5110         * ircd/m_clearmode.c (do_clearmode): add support for MODE_REGONLY
5111         (+r) to do_clearmode(); note that it is *not* being added to the
5112         default clearmode mask!
5113
5114         * ircd/channel.c: don't allow non-+r users to send messages to +r
5115         channels from off the channel; add support for MODE_REGONLY (+r)
5116         to channel_modes(); don't allow non-+r users to join +r channels
5117         without an invite; add support for MODE_REGONLY to the modebuf_*()
5118         family of functions (changes in modebuf_flush_int(),
5119         modebuf_mode(), and modebuf_extract()); add support for
5120         MODE_REGONLY to mode_parse()
5121
5122         * include/supported.h (FEATURESVALUES2): added the new channel
5123         mode 'r' to the list of supported channel modes
5124
5125         * include/numeric.h: move RPL_USERIP to 340 to avoid the 307
5126         conflict; add ERR_NEEDREGGEDNICK (477) for the new +r channels
5127
5128         * include/channel.h: remove unused MODE_SENDTS; add new
5129         MODE_REGONLY
5130
5131         * ircd/s_bsd.c (read_packet): remove call to timer_verify()
5132
5133         * ircd/list.c: remove calls to timer_verify() from
5134         alloc_connection() and dealloc_connection()
5135
5136         * ircd/ircd_events.c: turn off timer_verify(); remove calls to it
5137         from timer_run()
5138
5139 2002-01-27  Kevin L Mitchell  <klmitch@mit.edu>
5140
5141         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
5142
5143         * ircd/ircd_events.c (timer_run): why did I ever use a next
5144         pointer when the algorithm guarantees that the head pointer will
5145         always be the next pointer?
5146
5147 2002-01-26  Kevin L Mitchell  <klmitch@mit.edu>
5148
5149         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
5150
5151         * ircd/s_bsd.c (read_packet): call timer_verify() after adding the
5152         client process timer to catch any list corruption
5153
5154         * ircd/list.c: surround alloc_connection() and
5155         dealloc_connection() with calls to timer_verify()
5156
5157         * ircd/ircd_events.c: add sledgehammer known as timer_verify() to
5158         verify the timer list's structure; call it around timer_run()
5159
5160 2002-01-22  Kevin L Mitchell  <klmitch@mit.edu>
5161
5162         * ircd/send.c (sendcmdto_common_channels): don't send message to a
5163         channel that the source is a zombie on
5164
5165 2002-01-13  Kevin L Mitchell  <klmitch@mit.edu>
5166
5167         * ircd/ircd_events.c (timer_enqueue): one more assertion--make
5168         sure a timer has the ACTIVE flag set before enqueueing the timer
5169
5170         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
5171
5172         * ircd/list.c (dealloc_connection): assert that the process timer
5173         has been removed from the timer queue before dealloc_connection()
5174         is called
5175
5176 2002-01-12  Kevin L Mitchell  <klmitch@mit.edu>
5177
5178         * ircd/res.c: don't accept T_A when we're looking for T_PTR
5179
5180         * ircd/channel.c (modebuf_flush_int): nuke the code that would
5181         send a HACK DESYNCH notice on a HACK(2)--it would be far too
5182         chatty
5183
5184         * ircd/m_away.c (user_set_away): use AWAYLEN instead of TOPICLEN
5185
5186         * include/supported.h: add AWAYLEN to the list of supported
5187         features
5188
5189         * include/ircd_defs.h: add AWAYLEN to specify the maximum length
5190         of an away message
5191
5192         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
5193
5194         * ircd/m_mode.c (m_mode): pass extra parameter to channel_modes()
5195
5196         * ircd/channel.c: pass a buflen parameter to channel_modes() for
5197         pbuf--we were using sizeof(pbuf), which would always be
5198         sizeof(char*) before; change send_channel_modes() to pass extra
5199         parameter to channel_modes()
5200
5201         * include/channel.h: pass a buflen parameter to channel_modes()
5202         for pbuf
5203
5204         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
5205
5206         * ircd/uping.c (uping_start): initialize some timers
5207
5208         * ircd/s_bsd.c (read_packet): use new t_onqueue() macro to figure
5209         out when we need to re-add the process timer
5210
5211         * ircd/s_auth.c (make_auth_request): initialize a timer
5212
5213         * ircd/res.c (init_resolver): initialize some timers
5214
5215         * ircd/list.c (alloc_connection): initialize the client process
5216         timer
5217
5218         * ircd/ircd_events.c: add a function, timer_init(), to initialize
5219         a struct Timer; recast timer_add() to catch when adding a marked
5220         timer and not re-enqueue it--but mark it for re-enqueuing; update
5221         timer_del() to turn off the GEN_READD flag and to ignore reference
5222         counts when destroying the timer--we're using GEN_MARKED as an
5223         ersatz referance count; changed timer_run() to work with the new
5224         way of doing things; add GEN_ACTIVE and GEN_READD to gen_flags()'s
5225         map[]
5226
5227         * ircd/ircd.c: initialize some timers
5228
5229         * ircd/engine_select.c (engine_loop): initialize a timer
5230
5231         * ircd/engine_poll.c (engine_loop): initialize a timer
5232
5233         * ircd/engine_kqueue.c (engine_loop): initialize a timer
5234
5235         * ircd/engine_devpoll.c (engine_loop): initialize a timer
5236
5237         * ircd/IPcheck.c (IPcheck_init): initialize a timer
5238
5239         * include/ircd_events.h: add GEN_READD flag for timers to indicate
5240         that a timer must be readded; add t_onqueue() macro to check to
5241         see if a timer is on the queue (this is a hack, though); added
5242         timer_init() to initialize a struct Timer--we're no longer doing
5243         the initialization in timer_add()
5244
5245 2002-01-11  Kevin L Mitchell  <klmitch@mit.edu>
5246
5247         * ircd/engine_devpoll.c (engine_loop): relocate an assertion to
5248         prevent a core bug *in* the assertion
5249
5250         * doc/readme.features: document new POLLS_PER_LOOP feature; change
5251         documentation to reflect that OPER_SET now defaults to FALSE
5252
5253         * doc/p10.html: documented the new ACCOUNT stuff
5254
5255         * doc/example.conf: document new POLLS_PER_LOOP default; change
5256         default for OPER_SET
5257
5258         * RELEASE.NOTES: changed documentation to reflect the fact that
5259         assertions are now enabled by default and do not cause memory
5260         leaks
5261
5262         * ircd/res.c (make_cache): removed a bogus assertion we probably
5263         never caught because assertions haven't been enabled on production
5264         servers for any length of time before
5265
5266         * ircd/engine_devpoll.c (engine_loop): ditto for POLLS_PER_DEVPOLL
5267
5268         * ircd/engine_kqueue.c (engine_loop): stupid me forgot one
5269         instance of POLLS_PER_KQUEUE
5270
5271         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
5272
5273         * ircd/s_bsd.c (client_timer_callback): only clear the
5274         FREEFLAG_TIMER flag when the timer is being destroyed
5275
5276         * ircd/ircd_features.c: create a new feature, POLLS_PER_LOOP, and
5277         default it to 200; turn OPER_SET off by default
5278
5279         * ircd/engine_kqueue.c: dynamically allocate and reallocate the
5280         array of events to obtain from the kernel
5281
5282         * ircd/engine_devpoll.c: dynamically allocate and reallocate the
5283         array of events to obtain from the kernel
5284
5285         * include/ircd_features.h: add a new feature for tuning how many
5286         events to get from the kernel, for engines that support that
5287
5288         * ircd/Makefile.in: re-run make depend to correct dependancies
5289
5290         * ircd/m_who.c: remove unneeded inclusion of list.h
5291
5292         * ircd/ircd_events.c: remove unneeded inclusion of list.h
5293
5294         * ircd/whocmds.c (do_who): hide server name in /who unless
5295         requester is an operator; simplify hop count insertion
5296
5297         * ircd/s_misc.c (exit_one_client): make sure client's snomask is
5298         cleared
5299
5300         * ircd/parse.c: use mo_version and mo_admin when opers do /version
5301         or /admin
5302
5303         * ircd/m_whowas.c (m_whowas): use HEAD_IN_SAND_SERVERNAME instead
5304         of the static string "*.undernet.org"
5305
5306         * ircd/m_version.c: only let ordinary users get version
5307         information for the server they are on
5308
5309         * ircd/m_admin.c: only let ordinary users get admin information
5310         for the server they are on
5311
5312         * ircd/channel.c (client_can_send_to_channel): check is_banned()
5313         before letting the client speak on a channel s/he is not on
5314
5315         * include/supported.h: add NETWORK to feature list
5316
5317         * include/handlers.h: declare mo_admin() and mo_version()
5318
5319 2002-01-10  Kevin L Mitchell  <klmitch@mit.edu>
5320
5321         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
5322
5323         * ircd/s_debug.c (count_memory): conditionalize on MDEBUG instead
5324         of !NDEBUG
5325
5326         * ircd/m_stats.c: conditionalize /stats M on MDEBUG instead of
5327         !NDEBUG
5328
5329         * ircd/ircd_alloc.c: conditionalize on MDEBUG instead of on
5330         !NDEBUG
5331
5332         * ircd/fda.c: conditionalize on MDEBUG instead of on !NDEBUG
5333
5334         * ircd/Makefile.in: run make depend on chkconf.c as well
5335
5336         * include/ircd_alloc.h: instead of conditionalizing on !NDEBUG,
5337         conditionalize on MDEBUG
5338
5339         * include/fda.h: instead of conditionalizing on !NDEBUG,
5340         conditionalize on MDEBUG
5341
5342         * configure: rebuild configure script
5343
5344         * configure.in: enable assertion checking by default, since we
5345         have now decoupled memory debugging from the NDEBUG macro
5346
5347         * ircd/s_user.c (set_nick_name): remove calls to
5348         verify_client_list()
5349
5350         * ircd/s_misc.c (exit_one_client): remove calls to
5351         verify_client_list()
5352
5353         * ircd/s_conf.c (rehash): remove calls to verify_client_list()
5354
5355         * ircd/m_who.c (m_who): remove calls to verify_client_list()
5356
5357         * ircd/list.c: remove calls to verify_client_list(); keep
5358         verify_client_list() around just in case we ever need it again,
5359         but never compile it in
5360
5361         * ircd/ircd_events.c (event_execute): remove calls to
5362         verify_client_list()
5363
5364         * ircd/client.c (client_get_ping): remove calls to
5365         verify_client_list()
5366
5367         * include/list.h (send_listinfo): remove temporary debugging
5368         function verify_client_list()
5369
5370         * ircd/uping.c: don't die if the event type is ET_ERROR in socket
5371         callback functions
5372
5373         * ircd/res.c (res_callback): don't die if the event type is
5374         ET_ERROR
5375
5376         * ircd/listener.c (accept_connection): don't die if the event type
5377         is ET_ERROR
5378
5379 2002-01-09  Kevin L Mitchell  <klmitch@mit.edu>
5380
5381         * ircd/s_user.c (set_nick_name): bracket call to
5382         add_client_to_list() with calls to verify_client_list()
5383
5384         * include/patchlevel.h (PATCHLEVEL): bump patchlevel (again)
5385
5386         * ircd/list.c (verify_client_list): add a probabilistic loop
5387         detector: for every client added, there is a 2% probability that
5388         it will be used to replace the value of sentinel; if at any time,
5389         sentinel is found again, we know we're in a loop
5390
5391         * ircd/ircd_events.c (event_execute): add verify_client_list()
5392         calls wrapping event_execute; at the very least, I'll figure out
5393         what event the corruption occurred in
5394
5395         * ircd/list.c: moved verify_client_list() to try to keep it from
5396         being inlined
5397
5398         * ircd/Makefile.in (version.c): version.c wasn't dependant on
5399         version.h and patchlevel.h, like it was supposed to be
5400
5401         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
5402
5403         * ircd/s_auth.c (destroy_auth_request): overload send_reports
5404         argument to also indicate whether or not to call
5405         release_auth_client() and thereby enter the client into the linked
5406         list
5407
5408         * ircd/engine_devpoll.c (engine_loop): remove bogus assertion
5409
5410         * include/patchlevel.h (PATCHLEVEL): bump patchlevel
5411
5412         * ircd/list.c (free_client): verify that destroy_auth_request()
5413         didn't automagically re-add us to the list; we might have to think
5414         about this interaction more carefully, actually
5415
5416         * ircd/s_auth.c (auth_kill_client): zero the auth pointer before
5417         calling free_client(); otherwise, free_client() will try to free
5418         the auth by calling destroy_auth_request(), which will call
5419         add_client_to_list()
5420
5421         * ircd/s_misc.c (exit_one_client): liberally sprinkle calls to
5422         verify_client_list() around to catch any corruption that might
5423         occur here
5424
5425         * ircd/s_conf.c (rehash): liberally sprinkle calls to
5426         verify_client_list() here, since this is about the only routine I
5427         can think of that could cause the "core on kill -HUP" bug
5428
5429         * ircd/m_who.c: sprinkle calls to verify_client_list() around
5430         liberally, since we've seen crashes here; temporarily include the
5431         otherwise unneeded list.h header
5432
5433         * ircd/list.c: sprinkle calls to verify_client_list() around quite
5434         liberally; add debugging asserts to list manipulation functions to
5435         catch strange settings for next and prev pointers; define
5436         verify_client_list(), which walks the client list and verifies
5437         that everything is as it's supposed to be
5438
5439         * ircd/client.c: wrap client_get_ping with calls to
5440         verify_client_list() to see if that's where we're dying
5441
5442         * include/patchlevel.h (PATCHLEVEL): bump to 03
5443
5444         * include/list.h: declare verify_client_list() if DEBUGMODE
5445         enabled; otherwise, define it to be empty
5446
5447 2002-01-08  Kevin L Mitchell  <klmitch@mit.edu>
5448
5449         * ircd/m_quit.c (m_quit): remove an unused variable
5450
5451         * include/patchlevel.h (PATCHLEVEL): bump PATCHLEVEL to 2
5452
5453         * ircd/s_user.c: when building the user mode to send to the user,
5454         don't include +r; add an extra set of parens to squelch a warning
5455
5456         * ircd/m_quit.c (m_quit): use exit_client_msg()
5457
5458         * include/patchlevel.h (PATCHLEVEL): bump patch level, so we can
5459         keep track of who's running what version
5460
5461         * ircd/m_squit.c (ms_squit): remove debugging calls to
5462         protocol_violation()
5463
5464         * Makefile.in: change MAKEFILES to IRCD_MAKEFILES to work around a
5465         new gmake "feature" (pull-up from trunk)
5466
5467         * ircd/m_quit.c (m_quit): prefix user quits with "Quit:" (pull-up
5468         from trunk)
5469
5470 2002-01-07  Kevin L Mitchell  <klmitch@mit.edu>
5471
5472         * ircd/s_user.c: add FLAGS_ACCOUNT, represented as 'r', to the
5473         list of user modes; process account name as part of user mode in
5474         NICK decoding (set_nick_name()); add account name to usermode when
5475         building the usermode to incorporate in outgoing NICK messages
5476
5477         * ircd/s_err.c: add RPL_WHOISACCOUNT for reporting what account a
5478         user is logged in to
5479
5480         * ircd/parse.c: define the new ACCOUNT command, usable only by
5481         servers and ignored by everything else
5482
5483         * ircd/m_whois.c: report what account name is associated with a
5484         user, if any
5485
5486         * ircd/m_account.c: implement the ACCOUNT command
5487
5488         * ircd/Makefile.in: add m_account.c to the list of sources; ran
5489         make depend
5490
5491         * include/struct.h: add an account field to struct User
5492
5493         * include/numeric.h: add a reply, RPL_WHOISACCOUNT, for reporting
5494         what username a user is logged in under
5495
5496         * include/msg.h: add ACCOUNT command and token (AC)
5497
5498         * include/ircd_defs.h: define ACCOUNTLEN to be 12--this matches
5499         the maximum length of a username for X
5500
5501         * include/handlers.h: add declaration for ms_account()
5502
5503         * include/client.h: add FLAGS_ACCOUNT to flag when a user account
5504         name has been set; added FLAGS_ACCOUNT to SEND_UMODES; added
5505         IsAccount() and SetAccount() to manipulate the flag
5506
5507         * ircd/m_squit.c (ms_squit): if we call FindNServer() on a server
5508         name like "Amsterdam2.NL.EU.undernet.org", we get the struct
5509         Client for the server with numeric "Am", which happens to be
5510         stockholm!  To fix this, we look up the full name *first*; if that
5511         doesn't get it, *then* we look up by numeric.
5512
5513 2001-12-24  Perry Lorier <isomer@coders.net>
5514         * ircd/m_server.c: cleanups, maybe this will make the bug easier
5515         to find.
5516
5517         * ircd/m_stats.c: display maximum number of connects in an I:
5518
5519 2001-11-22  Perry Lorier  <isomer@coders.net>
5520         * ircd/m_squit.c: Bug fix in squit
5521
5522 2001-11-03  Greg Sikorski <gte@atomicrevs.demon.co.uk>
5523         * ircd/parse.c, include/handlers.h: Give remote whois the correct
5524         handler.
5525         
5526 2001-11-01  Kevin L Mitchell  <klmitch@mit.edu>
5527
5528         * ircd/send.c: some minor white-space fiddling; recast selector
5529         test in sendwallto_group_butone() to remove a warning regarding
5530         putting & within parentheses
5531
5532         * ircd/m_create.c (ms_create): use time_t instead of int as a
5533         declaration for rate
5534
5535         * ircd/ircd_reply.c (protocol_violation): it's supposed to be
5536         WALL_DESYNCH, not CMD_DESYNCH, if I understand things right--no
5537         wonder we weren't seeing any protocol violations!
5538
5539         * include/send.h: include time.h for time_t; move WALL_* closer to
5540         the function they're used in; some white-space fiddling; add
5541         declaration of sendto_opmask_butone_ratelimited()
5542
5543         * ircd/m_squit.c (ms_squit): add protocol_violation() calls in the
5544         cases where we ignore a squit, so we aren't taken by surprise, at
5545         least...
5546
5547         * ircd/m_create.c (ms_create): Display origin server, not origin
5548         user
5549
5550         * ircd/m_create.c (ms_create): Fix "Timestamp drift" server notice
5551
5552 2001-10-31  Perry Lorier  <isomer@coders.net>
5553         * include/m_ping.c: Forward port ping bug
5554
5555 2001-10-31  Perry Lorier  <isomer@coders.net>
5556         * include/patchlevel.h: We're beta now
5557
5558 2001-10-31  Perry Lorier  <isomer@coders.net>
5559         * ircd/s_user.c: fixed hunt_server
5560
5561 2001-09-21  Perry Lorier  <isomer@coders.net>
5562         * ircd/send.c and various: replace sendcmdto_flag_butone with
5563         sendwallto_group_butone
5564
5565 2001-09-21  Vampire-  <unknown>
5566         * ircd/ircd_string.c: unique_name_vector round II.
5567
5568 2001-09-21  mbuna  <mbuna@undernet.org>
5569         * configure.in: Add support for darwin
5570
5571 2001-09-21  Perry Lorier  <isomer@coders.net>
5572         * ircd/s_user.c I'm stupid, s/acptr/from/, Hektik pointed it out
5573
5574 2001-09-20  Perry Lorier  <isomer@coders.net>
5575
5576         * Pullups from 2.10.10.pl16
5577         * Added some warnings, and the concept of rate limited snotices
5578
5579 2001-08-31  Kevin L Mitchell  <klmitch@mit.edu>
5580
5581         * ircd/channel.c: use "%u" to format limit arguments; use
5582         strtoul() to process limit arguments in a /mode command--note:
5583         most clients seem to truncate the integer, probably because
5584         they're using atoi, and perhaps signed ints
5585
5586 2001-08-17  Kevin L Mitchell  <klmitch@mit.edu>
5587
5588         * ircd/numnicks.c: include stdlib.h for exit()
5589
5590         * ircd/ircd_log.c: include stdlib.h for exit()
5591
5592         * ircd/ircd_events.c: include stdlib.h for exit()
5593
5594         * ircd/s_stats.c: remove description of /stats v, since it's gone
5595
5596         * ircd/m_wallops.c (mo_wallops): add "*" to the beginning of
5597         /wallops to distinguish wallops from wallusers
5598
5599         * ircd/m_error.c (mr_error): ignore ERROR from clients that aren't
5600         in the "handshake" or "connecting" states--I think the latter will
5601         never happen, but...
5602
5603         * doc/Authors: apply delete's Authors patch
5604
5605         * RELEASE.NOTES: rewrite RELEASE.NOTES, basing it a little on
5606         Braden's version
5607
5608         * README: rewrite README
5609
5610 2001-07-31  Kevin L. Mitchell  <klmitch@mit.edu>
5611
5612         * ircd/s_serv.c (server_estab): remove unused variable split
5613
5614         * ircd/parse.c: add mr_error to the parse table
5615
5616         * ircd/m_error.c (mr_error): add mr_error() to handle ERRORs from
5617         unregistered connections--if IsUserPort() is true, the ERROR is
5618         ignored, otherwise, the message is saved
5619
5620 2001-07-28  Kevin L. Mitchell  <klmitch@mit.edu>
5621
5622         * ircd/m_kill.c (ms_kill): another minor typo *sigh*
5623
5624         * ircd/s_user.c (send_supported): oops, minor typo...
5625
5626         * ircd/s_user.c: implement send_supported() to send two ISUPPORT
5627         messages containing our feature buffers; make register_user() use
5628         send_supported()
5629
5630         * ircd/s_misc.c (exit_client): make sure not to give away a remote
5631         server in the ERROR message sent to the client; if the killer is a
5632         server, we substitute our name in its place
5633
5634         * ircd/m_version.c (m_version): use send_supported() to send the
5635         ISUPPORT values to the user
5636
5637         * ircd/m_nick.c: shave nick collision kills here a bit, too, for
5638         the same reasons as for m_kill.c
5639
5640         * ircd/m_kill.c: shave kills a bit so that the results look
5641         exactly the same no matter where you are; if we didn't do this, it
5642         would be possible to map the network by looking at the differences
5643         between kills originating under various circumstances
5644
5645         * include/supported.h: split the features into two, so as to not
5646         bust the parameter count when sending the features list
5647
5648         * include/s_user.h: declare new send_supported() function to send
5649         the ISUPPORT information
5650
5651 2001-07-27  Kevin L. Mitchell  <klmitch@mit.edu>
5652
5653         * ircd/s_bsd.c: disable IP (*not* TCP) options to prevent
5654         source-routed spoofing attacks; this is only available under
5655         u2.10.11, so don't even bother, since no one but testers are using
5656         the source base
5657
5658 2001-07-25  Kevin L. Mitchell  <klmitch@mit.edu>
5659
5660         * include/ircd_policy.h: enable HEAD_IN_SAND_REMOTE by default
5661
5662         * ircd/s_err.c: put in a . for reporting link version on /trace,
5663         to match what /version does
5664
5665 2001-07-21  Kevin L. Mitchell  <klmitch@mit.edu>
5666
5667         * ircd/s_misc.c (exit_client): servers don't understand what the
5668         numeric nick ERROR is supposed to mean, so they ignore error
5669         messages, resulting in not knowing why we were rejected; use
5670         sendcmdto_one for servers and sendrawto_one for clients
5671
5672 2001-07-17  Kevin L. Mitchell  <klmitch@mit.edu>
5673
5674         * ircd/m_burst.c (ms_burst): in the case of a modeless channel and
5675         a nick collide, a bare BURST may be propagated; adjust the
5676         enforced parameter count to accept the bare BURST
5677
5678 2001-07-12  Kevin L. Mitchell  <klmitch@mit.edu>
5679
5680         * ircd/s_bsd.c: mark a client as having been IP checked
5681
5682         * ircd/IPcheck.c (ip_registry_check_remote): remove unneeded
5683         second call to SetIPChecked()
5684
5685 2001-07-11  Kevin L. Mitchell  <klmitch@mit.edu>
5686
5687         * ircd/engine_poll.c: deal with POLLHUP properly (hopefully)
5688
5689         * ircd/engine_devpoll.c: deal with POLLHUP properly (hopefully)
5690
5691 2001-07-09  Kevin L. Mitchell  <klmitch@mit.edu>
5692
5693         * ircd/os_bsd.c (os_get_rusage): move buf into the two ifdef'd
5694         sections so that if neither is used, the declaration of buf will
5695         not elicit an "unused variable" warning under NetBSD
5696
5697         * ircd/m_map.c: include string.h to declare strcpy (fix warnings
5698         on alpha)
5699
5700         * ircd/m_away.c: include string.h to declare strcpy/strlen (fix
5701         warnings on alpha)
5702
5703         * ircd/ircd_log.c: include string.h to declare strcpy/strlen (fix
5704         warnings on alpha)
5705
5706         * ircd/client.c: include string.h to declare memset (fix warnings
5707         on alpha)
5708
5709         * ircd/channel.c: remove unused functions next_overlapped_ban,
5710         del_banid, and is_deopped (fix warnings under -O1)
5711
5712         * ircd/IPcheck.c: include string.h to declare memset/memcpy (fix
5713         warnings on alpha)
5714
5715 2001-06-29  Kevin L. Mitchell  <klmitch@mit.edu>
5716
5717         * ircd/s_user.c (set_user_mode): clear the snomask if the user
5718         isn't supposed to receive server notices anymore
5719
5720         * ircd/ircd_features.c: change CONFIG_OPERCMDS to default to FALSE
5721
5722         * configure.in: use AC_MSG_CHECKING/AC_MSG_RESULT when checking
5723         installation prefix; default devpoll and kqueue to on (they get
5724         turned off if the required headers aren't present)
5725
5726         * ircd/whocmds.c (do_who): use ircd_snprintf() instead of
5727         sprintf_irc(); it's a bit hackish, but it'll do for now
5728
5729         * ircd/support.c: remove unused #include
5730
5731         * ircd/send.c: remove unused #include
5732
5733         * ircd/s_user.c: use ircd_snprintf() instead of sprintf_irc()
5734
5735         * ircd/s_serv.c: remove unused #include
5736
5737         * ircd/s_misc.c: use ircd_snprintf() and friends instead of
5738         sprintf_irc() and friends
5739
5740         * ircd/s_err.c: moved atoi_tab[] from ircd/sprintf_irc.c to
5741         ircd/s_err.c, which is the only other file to refer to it
5742
5743         * ircd/s_conf.c (conf_add_deny): use ircd_snprintf() instead of
5744         sprintf_irc()
5745
5746         * ircd/s_bsd.c (connect_server): use ircd_snprintf() instead of
5747         sprintf_irc()
5748
5749         * ircd/s_auth.c: use ircd_snprintf() instead of sprintf_irc()
5750
5751         * ircd/res.c: use ircd_snprintf() instead of sprintf_irc()
5752
5753         * ircd/m_version.c: use ircd_snprintf() instead of sprintf_irc()
5754
5755         * ircd/m_kill.c: use ircd_snprintf() instead of sprintf_irc()
5756
5757         * ircd/listener.c: use ircd_snprintf() instead of sprintf_irc()
5758
5759         * ircd/gline.c: use ircd_snprintf() instead of sprintf_irc()
5760
5761         * ircd/channel.c: don't include sprintf_irc.h; use ircd_snprintf()
5762         instead of sprintf_irc()
5763
5764         * ircd/Makefile.in: remove sprintf_irc.c from sources list; run
5765         make depend
5766
5767         * include/ircd_string.h: remove declaration of sprintf_irc() (what
5768         was it doing here anyway?)
5769
5770         * include/sprintf_irc.h: removed unneeded source file
5771
5772         * ircd/sprintf_irc.c: removed unneeded source file
5773
5774         * ircd/s_debug.c (count_memory): remove some dead code
5775
5776         * ircd/s_auth.c: remove some dead code
5777
5778         * ircd/res.c (update_list): remove some dead code
5779
5780         * ircd/m_whowas.c: remove some dead code
5781
5782         * ircd/m_whois.c: remove some dead code
5783
5784         * ircd/m_who.c: remove some dead code
5785
5786         * ircd/m_wallusers.c: remove some dead code
5787
5788         * ircd/m_wallops.c: remove some dead code
5789
5790         * ircd/m_wallchops.c: remove some dead code
5791
5792         * ircd/m_version.c: remove some dead code
5793
5794         * ircd/m_userip.c: remove some dead code
5795
5796         * ircd/m_userhost.c: remove some dead code
5797
5798         * ircd/m_uping.c: remove some dead code
5799
5800         * ircd/m_trace.c: remove some dead code
5801
5802         * ircd/m_topic.c: remove some dead code
5803
5804         * ircd/m_tmpl.c: remove some dead code
5805
5806         * ircd/m_time.c: remove some dead code
5807
5808         * ircd/m_squit.c: remove some dead code
5809
5810         * ircd/m_silence.c: remove some dead code
5811
5812         * ircd/m_settime.c: remove some dead code
5813
5814         * ircd/m_set.c: remove some dead code
5815
5816         * ircd/m_server.c: remove some dead code
5817
5818         * ircd/m_rpong.c: remove some dead code
5819
5820         * ircd/m_rping.c: remove some dead code
5821
5822         * ircd/m_restart.c: remove some dead code
5823
5824         * ircd/m_reset.c: remove some dead code
5825
5826         * ircd/m_rehash.c: remove some dead code
5827
5828         * ircd/m_quit.c: remove some dead code
5829
5830         * ircd/m_proto.c: remove some dead code
5831
5832         * ircd/m_privs.c: remove some dead code
5833
5834         * ircd/m_privmsg.c: remove some dead code
5835
5836         * ircd/m_pong.c: remove some dead code
5837
5838         * ircd/m_ping.c: remove some dead code
5839
5840         * ircd/m_pass.c: remove some dead code
5841
5842         * ircd/m_part.c: remove some dead code
5843
5844         * ircd/m_opmode.c: remove some dead code
5845
5846         * ircd/m_oper.c: remove some dead code
5847
5848         * ircd/m_notice.c: remove some dead code
5849
5850         * ircd/m_nick.c: remove some dead code
5851
5852         * ircd/m_map.c: remove some dead code
5853
5854         * ircd/m_lusers.c: remove some dead code
5855
5856         * ircd/m_list.c: remove some dead code
5857
5858         * ircd/m_links.c: remove some dead code
5859
5860         * ircd/m_kill.c: remove some dead code
5861
5862         * ircd/m_kick.c: remove some dead code
5863
5864         * ircd/m_jupe.c: remove some dead code
5865
5866         * ircd/m_join.c: remove some dead code
5867
5868         * ircd/m_ison.c: remove some dead code
5869
5870         * ircd/m_invite.c: remove some dead code
5871
5872         * ircd/m_info.c: remove some dead code
5873
5874         * ircd/m_help.c: remove some dead code
5875
5876         * ircd/m_gline.c: remove some dead code
5877
5878         * ircd/m_get.c: remove some dead code
5879
5880         * ircd/m_error.c: remove some dead code
5881
5882         * ircd/m_endburst.c: remove some dead code
5883
5884         * ircd/m_die.c: remove some dead code
5885
5886         * ircd/m_desynch.c: remove some dead code
5887
5888         * ircd/m_destruct.c: remove some dead code
5889
5890         * ircd/m_defaults.c: remove some dead code
5891
5892         * ircd/m_create.c: remove some dead code, along with an #if 1
5893
5894         * ircd/m_cprivmsg.c: remove some dead code
5895
5896         * ircd/m_connect.c: remove some dead code
5897
5898         * ircd/m_close.c: remove some dead code
5899
5900         * ircd/m_clearmode.c: remove some dead code
5901
5902         * ircd/m_burst.c: remove some dead code
5903
5904         * ircd/m_away.c: remove some dead code
5905
5906         * ircd/m_admin.c: remove some dead code
5907
5908         * ircd/listener.c (accept_connection): remove some dead code
5909
5910         * ircd/ircd_reply.c (need_more_params): remove some dead code
5911
5912         * ircd/channel.c (add_banid): remove some dead code
5913
5914         * include/support.h: remove some dead code
5915
5916         * include/querycmds.h: remove some dead code
5917
5918         * doc/readme.chroot: document how to do chroot operation
5919
5920 2001-06-28  Kevin L. Mitchell  <klmitch@mit.edu>
5921
5922         * ircd/Makefile.in: tune for VPATH builds/installs; add a rule to
5923         force bin directory to be created if necessary prior to
5924         installation; run make depend
5925
5926         * doc/Makefile.in (install): tune for VPATH installs by cd'ing to
5927         the ${srcdir}
5928
5929         * Makefile.in: tune to detect Makefile.in changes in
5930         subdirectories and to create installation directory indicated by
5931         ${prefix}
5932
5933         * ircd/whocmds.c (count_users): routine to count the number of
5934         users matching a given user@host mask
5935
5936         * ircd/s_err.c: add error messages for ERR_LONGMASK,
5937         ERR_TOOMANYUSERS, and ERR_MASKTOOWIDE
5938
5939         * ircd/m_gline.c: look for and advance past '!' flag on G-lines
5940         from operators; only set GLINE_OPERFORCE flag if oper has the
5941         PRIV_WIDE_GLINE privilege
5942
5943         * ircd/ircd_features.c: add GLINEMAXUSERCOUNT, which is the
5944         maximum number of users a G-line can impact before it has to be
5945         forced; OPER_WIDE_GLINE, to allow operators to use ! to force a
5946         wide G-line to be set; and LOCOP_WIDE_GLINE, to allow local
5947         operators to use ! to force a wide G-line to be set
5948
5949         * ircd/gline.c: make make_gline() be called with separate user and
5950         host arguments, and not call canon_userhost() directly; implement
5951         gline_checkmask() to verify that a host mask is acceptable; move
5952         BADCHAN check up in gline_add(), and check passed-in mask under
5953         certain circumstances for acceptability; fix call to
5954         sendto_opmask_butone() to handle separation of userhost into user
5955         and host in gline_add(); update call to make_gline()
5956
5957         * ircd/client.c: use FEAT_OPER_WIDE_GLINE and
5958         FEAT_LOCOP_WIDE_GLINE to set PRIV_WIDE_GLINE for an operator; add
5959         PRIV_WIDE_GLINE to privtab[] for client_report_privs()
5960
5961         * include/whocmds.h (count_users): declare routine to count users
5962         matching a given user@host mask
5963
5964         * include/numeric.h: added three new error returns: ERR_LONGMASK
5965         -- mask can't be formatted into a buffer; ERR_TOOMANYUSERS -- too
5966         many users would be impacted by the mask; ERR_MASKTOOWIDE -- mask
5967         contains wildcards in the wrong places
5968
5969         * include/ircd_features.h: add FEAT_GLINEMAXUSERCOUNT,
5970         FEAT_OPER_WIDE_GLINE, and FEAT_LOCOP_WIDE_GLINE
5971
5972         * include/gline.h (GLINE_OPERFORCE): provides a way for m_gline()
5973         to signal to gline_add() that the operator attempted to force the
5974         G-line to be set
5975
5976         * include/client.h (PRIV_WIDE_GLINE): new privilege for operators
5977
5978         * doc/readme.gline: update to document new "!" prefix to a G-line
5979         user@host mask
5980
5981         * doc/readme.features: document GLINEMAXUSERCOUNT,
5982         OPER_WIDE_GLINE, and LOCOP_WIDE_GLINE
5983
5984         * doc/example.conf: update to mention new features along with
5985         their defaults
5986
5987 2001-06-27  Kevin L. Mitchell  <klmitch@mit.edu>
5988
5989         * doc/example.conf: updated example.conf from Braden
5990         <dbtem@yahoo.com>
5991
5992         * include/supported.h: forward-port from pl15
5993
5994 2001-06-25  Kevin L. Mitchell  <klmitch@mit.edu>
5995
5996         * ircd/whocmds.c: include ircd_policy.h and implement
5997         HEAD_IN_SAND_WHO_OPCOUNT--forward-port from pl15
5998
5999         * ircd/m_whois.c: forward-port of the idle-time hiding code from
6000         pl15; this also required passing parc into do_whois(), which also
6001         meant passing parc into do_wilds()--*sigh*
6002
6003         * include/ircd_policy.h: add a couple more HEAD_IN_SAND
6004         #define's--WHOIS_IDLETIME and WHO_HOPCOUNT
6005
6006 2001-06-22  Kevin L. Mitchell  <klmitch@mit.edu>
6007
6008         * tools/wrapper.c: add a wrapper program that can be used to
6009         adjust file descriptor limits and root directories; program must
6010         be run as root--NOT SETUID!--and given appropriate -u arguments
6011
6012         * doc/readme.log: documentation of how to configure logging
6013
6014         * doc/readme.features: documentation of each feature (except for
6015         logging)
6016
6017 2001-06-21  Kevin L. Mitchell  <klmitch@mit.edu>
6018
6019         * Makefile.in (config): add a deprecation notice with a pointer to
6020         tools/transition
6021
6022         * tools/transition: shell script to convert old compile-time
6023         options into new compile-time options and appropriate F-lines
6024
6025         * tools/mkchroot: shell-script to prepare the chroot area by
6026         copying over all the necessary libraries so they can be found
6027
6028 2001-06-20  Kevin L. Mitchell  <klmitch@mit.edu>
6029
6030         * INSTALL: partial update of INSTALL for u2.10.11 release...
6031
6032 2001-06-14  Kevin L. Mitchell  <klmitch@mit.edu>
6033
6034         * ircd/table_gen.c (makeTables): finally got tired of the
6035         "overflow in implicit conversion" warning, so just got rid of it
6036         by explicitly casting UCHAR_MAX to a (default) char; diffs show no
6037         differences in the tables generated
6038
6039 2001-06-11  Kevin L. Mitchell  <klmitch@mit.edu>
6040
6041         * ircd/send.c (sendcmdto_match_butone): don't let the server crash
6042         if a client is in the STAT_CONNECTING status
6043
6044 2001-06-10  Kevin L. Mitchell  <klmitch@mit.edu>
6045
6046         * ircd/send.c: remove unused vsendcmdto_one(), consolidating it
6047         into sendcmdto_one(); define new sendcmdto_prio_one(), which
6048         places the message into the priority queue
6049
6050         * ircd/s_user.c (hunt_server_prio_cmd): definition of
6051         hunt_server_prio_cmd(), which simply calls sendcmdto_prio_one()
6052         instead of sendcmdto_one()
6053
6054         * ircd/m_settime.c: use sendcmdto_prio_one() and
6055         hunt_server_prio_cmd() to send SETTIME
6056
6057         * ircd/m_server.c: use sendcmdto_prio_one() to send SETTIME
6058
6059         * include/send.h: removed declaration for unused vsendcmdto_one();
6060         added a declaration for sendcmdto_prio_one()
6061
6062         * include/s_user.h: declare hunt_server_prio_cmd(), which calls
6063         sendcmdto_prio_one()
6064
6065         * ircd/send.c (sendcmdto_flag_butone): oops; /wallops should be
6066         put in the server's priority queue, too...
6067
6068         * ircd/ircd.c: don't check LPATH for accessibility at all
6069
6070 2001-06-08  Kevin L. Mitchell  <klmitch@mit.edu>
6071
6072         * ircd/s_serv.c (server_estab): send a +h flag in our SERVER
6073         command if we're configured as a hub; send individual server flags
6074         in SERVER commands
6075
6076         * ircd/s_bsd.c (completed_connection): send a +h flag in our
6077         SERVER command if we're configured as a hub
6078
6079         * ircd/m_server.c: implement parv[7] as a mode-like string; +h
6080         sets the FLAGS_HUB flag for a server; +s sets the FLAGS_SERVICE
6081         flag for a server; +hs sets both flags; also modify CMD_SERVER
6082         format string to send the flags
6083
6084         * include/client.h: define two new flags, FLAGS_HUB and
6085         FLAGS_SERVICE to mark services and hubs as such; define testing
6086         macros, setting macros
6087
6088         * ircd/s_user.c: remove deprecated struct Gline* argument to
6089         register_user(); remove GLINE rebroadcast; do not send GLINE
6090         acknowledgement parameter to NICK; do not look for GLINE
6091         acknowledgement parameter to NICK while parsing
6092
6093         * ircd/s_serv.c (server_estab): remove deprecated struct Jupe*
6094         argument to server_estab(); do not send JUPE/GLINE acknowledgement
6095         parameters for SERVER or NICK
6096
6097         * ircd/m_user.c (m_user): remove deprecated argument to
6098         register_user()
6099
6100         * ircd/m_server.c: remove deprecated argument to server_estab();
6101         remove documentation comment regarding JUPE acknowledgement
6102         parameter to SERVER; remove JUPE rebroadcast
6103
6104         * ircd/m_pong.c (mr_pong): remove deprecated argument to
6105         register_user()
6106
6107         * ircd/m_nick.c: remove documentation comment regarding GLINE
6108         acknowledgement parameter to NICK
6109
6110         * ircd/jupe.c: use user's real name in JUPE server notices if
6111         HEAD_IN_SAND_SNOTICES is defined
6112
6113         * ircd/ircd.c: remove deprecated chroot() code; remove deprecated
6114         setuid code; correct ancient DEBUG vs DEBUGMODE typo
6115
6116         * ircd/gline.c: use user's real name in GLINE server notices if
6117         HEAD_IN_SAND_SNOTICES is defined
6118
6119         * ircd/channel.c (modebuf_flush_int): make apparent source be
6120         local server, not oper's server; use user's real name in hack
6121         notices and DESYNC notices if HEAD_IN_SAND_SNOTICES is defined
6122
6123         * include/s_user.h: remove struct Gline pre-declaration; remove
6124         deprecated struct Gline argument from register_user()
6125
6126         * include/s_serv.h: remove struct Jupe pre-declaration; remove
6127         deprecated struct Jupe argument from server_estab()
6128
6129 2001-06-07  Kevin L. Mitchell  <klmitch@mit.edu>
6130
6131         * ircd/s_stats.c (hunt_stats): forward-port from pl15 of all the
6132         changes required to control remote stats
6133
6134         * ircd/s_numeric.c (do_numeric): rewrite numeric origins if
6135         recipient is not an operator and HEAD_IN_SAND_REWRITE is defined
6136         [forward-port from pl15]
6137
6138         * ircd/m_whowas.c (m_whowas): report server name only if requester
6139         is an operator [forward-port from pl15]
6140
6141         * ircd/m_whois.c (do_whois): /whois <mynick> now correctly reports
6142         my server; if HEAD_IN_SAND_REMOTE is 1, ignore the middle argument
6143         and obtain the report from the user's server [forward-port from
6144         pl15]
6145
6146         * ircd/m_who.c: add missing include for ircd_policy.h
6147         [forward-port from pl15]
6148
6149         * ircd/m_version.c (m_version): require oper access for remote
6150         /version if HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
6151
6152         * ircd/m_time.c (m_time): require oper access for remote /time if
6153         HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
6154
6155         * ircd/m_stats.c: pass extra argument to hunt_stats(); correct
6156         missing semicolon [forward-port from pl15]
6157
6158         * ircd/m_nick.c (ms_nick): hide the origin of certain collision
6159         kills [forward-port from pl15]
6160
6161         * ircd/m_motd.c (m_motd): require oper access for remote /motd if
6162         HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
6163
6164         * ircd/m_lusers.c (m_lusers): require oper access for remote
6165         /lusers if HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
6166
6167         * ircd/m_burst.c (ms_burst): server-added bans are stored using
6168         local server name, to hide remote server names; modes also are to
6169         originate from the local server [forward-port from pl15]
6170
6171         * ircd/m_admin.c (m_admin): require oper access for remote /admin
6172         if HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
6173
6174         * ircd/channel.c (add_banid): if a server is adding a ban, use my
6175         server name to hide the remote server's name [forward-port from
6176         pl15]
6177
6178         * ircd/Makefile.in: ran make depend
6179
6180         * include/s_stats.h: hunt_stats() has to have an extra argument to
6181         support the forward-port from pl15
6182
6183         * include/ircd_policy.h: #define HEAD_IN_SAND_STATS_P; add
6184         HEAD_IN_SAND_{BANWHO,REWRITE,REMOTE} [forward-port from pl15]
6185
6186         * ircd/engine_poll.c (engine_loop): remove bogus assert that I
6187         forgot to check in the events branch
6188
6189 2001-06-06  Kevin L. Mitchell  <klmitch@mit.edu>
6190
6191         * ircd/res.c (init_resolver): don't start DNS expires with a 0
6192         relative timeout--if the server starts slow, timeouts could be
6193         messy...there's probably a better solution, but this'll do for now
6194
6195         * ircd/os_solaris.c: _XOPEN_SOURCE doesn't get along with Solaris
6196         headers very well; include stropts.h; define an os_set_tos()
6197
6198         * ircd/os_generic.c (os_set_tos): added an os_set_tos() for
6199         os_generic.c
6200
6201         * ircd/ircd.c: if there are no C-lines, we don't want to have a
6202         timer that expires at the absolute time of 0--it kinda blocks all
6203         the other timers!
6204
6205         * ircd/engine_devpoll.c: some includes for open(); declare errcode
6206         and codesize in engine_loop()
6207
6208         * ircd/list.c (free_client): remove bogus check on timer active
6209         flag
6210
6211         * ircd/s_auth.c: pull out destruction code in
6212         auth_timeout_request() into an externally-visible
6213         destroy_auth_request(); manage cli_auth pointer in client
6214         structure; use it for an extra assertion check
6215
6216         * ircd/list.c: include s_auth.h for destroy_auth_request(); add
6217         debugging notices to show flow when deallocating
6218         connections/clients; call destroy_auth_request() when free'ing a
6219         client that has an auth outstanding; don't free the connection if
6220         the process timer is unmarked but still active
6221
6222         * ircd/ircd_events.c: set GEN_ACTIVE when initializing a generator
6223         and reset it before calling the event handler for an ET_DESTROY
6224         event
6225
6226         * include/s_auth.h (destroy_auth_request): declare
6227         destroy_auth_request(), which can be used to destroy an
6228         outstanding auth request if a client socket goes away before the
6229         auth exchange is completed
6230
6231         * include/ircd_events.h: add an active flag to keep track of
6232         whether or not particular generators are active, for the
6233         convenience of functions using the API
6234
6235         * include/client.h: add a pointer for auth requests to struct
6236         Connection so we can kill outstanding auth requests if a client
6237         socket closes unexpectedly
6238
6239         * ircd/s_bsd.c: cli_connect() could become 0 during the course of
6240         the sock or timer callback; take that into account in the assert
6241
6242         * ircd/list.c: add magic number checking and setting--magic
6243         numbers are zero'd on frees to detect double-frees; add back
6244         setting of cli_from() to 0 to break the back-link from the struct
6245         Connection (duh)
6246
6247         * ircd/ircd.c: set me's magic number correctly
6248
6249         * include/client.h: define magic numbers and accessor/verifier
6250         macros
6251
6252         * ircd/list.c: assert that dealloc_client() is called with
6253         cli_connect(cptr) == 0; set cli_connect(cptr) to 0 before calling
6254         dealloc_client(); don't mess with cli_from(cptr)
6255
6256         * ircd/s_bsd.c: only attempt to dealloc a connection if the
6257         associated client has already been destroyed, or at least delinked
6258
6259 2001-06-05  Kevin L. Mitchell  <klmitch@mit.edu>
6260
6261         * ircd/list.c (free_client): only try to delete the socket when
6262         the fd hasn't already been closed, avoiding a double-free
6263
6264         * ircd/list.c (free_connection): make sure the client is really
6265         gone before doing away with the connection
6266
6267         * ircd/s_bsd.c: record that socket has been added in con_freeflag
6268         field; queue a socket_del() as soon as the socket is close()'d;
6269         use con_freeflag & FREEFLAG_TIMER instead of con_timer; clear
6270         FREEFLAG_SOCKET on ET_DESTROY event in client_sock_callback(),
6271         then dealloc the connection if safe; mark socket as dead when
6272         there's a read error or EOF; clear FREEFLAG_TIMER flag upon entry
6273         to client_timer_callback(); dealloc connection if safe upon
6274         ET_DESTROY event in client_timer_callback()
6275
6276         * ircd/list.c: use con_freeflag instead of con_timer; only dealloc
6277         the connection if both socket and timer have been destroyed;
6278         destroy both socket and timer explicitly and carefully
6279
6280         * include/client.h: replace the con_timer field with a
6281         con_freeflag field, to indicate what still needs freeing; define
6282         the freeflags
6283
6284         * ircd/engine_select.c (engine_loop): duh...sockList[i] could
6285         become 0
6286
6287         * ircd/engine_devpoll.c (engine_loop): duh...sockList[i] could
6288         become 0
6289
6290         * ircd/s_bsd.c: add some extra assertions to try to track down a
6291         corruption problem
6292
6293         * ircd/engine_select.c (engine_loop): add an extra assert to try
6294         to track down a corruption problem
6295
6296         * ircd/engine_poll.c (engine_loop): add an extra assert to try to
6297         track down a corruption problem
6298
6299         * ircd/engine_kqueue.c (engine_loop): add an extra assert to try
6300         to track down a corruption problem
6301
6302         * ircd/engine_devpoll.c (engine_loop): skip slots that have become
6303         empty during processing; add an extra assert to try to track down
6304         a corruption problem
6305
6306         * ircd/engine_kqueue.c (engine_delete): make sure to zero deleted
6307         entries
6308
6309 2001-06-04  Kevin L. Mitchell  <klmitch@mit.edu>
6310
6311         * ircd/s_bsd.c (client_sock_callback): client is no longer
6312         blocked, so we must mark it as unblocked
6313
6314         * ircd/engine_select.c: add Debug() calls galore; add handling for
6315         SS_NOTSOCK; use a dummy sock variable to keep things from
6316         disappearing on us; correct timeout calculation; update nfds for
6317         efficiency
6318
6319         * ircd/engine_poll.c: use new debugging level (DEBUG_ENGINE);
6320         remove a spurious "if (sock)" which will always be true; update
6321         nfds for efficiency
6322
6323         * ircd/engine_kqueue.c: add Debug() calls galore; add handling for
6324         SS_NOTSOCK (just in case); correct timeout calculation
6325
6326         * ircd/engine_devpoll.c: add Debug() calls galore; add handling
6327         for SS_NOTSOCK; correct timeout calculation; add EAGAIN handling
6328
6329         * include/s_debug.h (DEBUG_ENGINE): add new debugging level;
6330         pretty-indent numbers
6331
6332         * ircd/engine_poll.c (engine_loop): break out SS_NOTSOCK
6333         case--it's not a socket; the check for writability is most likely
6334         not needed, but present for completeness
6335
6336 2001-05-24  Kevin L. Mitchell  <klmitch@mit.edu>
6337
6338         * ircd/s_bsd.c: add Debug messages; call read_packet() even if the
6339         no newline flag is set; call read_packet() when the timer expires,
6340         regardless of what's in the buffer--read_packet() should be able
6341         to deal properly
6342
6343         * ircd/IPcheck.c (ip_registry_connect_succeeded): correct a NOTICE
6344         sent to clients to include the client nickname (duh)
6345
6346         * ircd/ircd_events.c: don't destroy a timer if it's already marked
6347         for destruction; replace a missing ! in socket_del()
6348
6349         * ircd/engine_poll.c (engine_loop): reference a temporary variable
6350         so we don't have to worry about sockList[i] going away
6351
6352         * ircd/s_bsd.c (client_sock_callback): add Debug messages
6353
6354         * ircd/s_auth.c: add Debug messages all over the place
6355
6356         * ircd/ircd_events.c: add and edit some Debug messages; add a list
6357         of routines to convert some of the enums and flags from numbers
6358         into human-readable strings for the Debug messages
6359
6360         * ircd/engine_poll.c: hack some Debug messages to use the new name
6361         conversion routines in ircd_events.c; add an extra assert for a
6362         condition that shouldn't ever happen; apparently recv() can return
6363         EAGAIN when poll() returns readable--I wonder why...
6364
6365         * include/ircd_events.h: declare some helper routines under
6366         DEBUGMODE
6367
6368 2001-05-23  Kevin L. Mitchell  <klmitch@mit.edu>
6369
6370         * ircd/s_bsd.c (client_sock_callback): add an extra assertion
6371         check
6372
6373         * ircd/s_auth.c: add more Debug messages
6374
6375         * ircd/list.c (make_client): add an extra assertion check
6376
6377         * ircd/ircd_events.c (socket_events): don't call the engine events
6378         changer if we haven't actually made any changes to the event mask
6379
6380         * ircd/uping.c: add some Debug messages
6381
6382         * ircd/s_stats.c: document new /STATS e
6383
6384         * ircd/s_err.c: add RPL_STATSENGINE to report the engine name
6385
6386         * ircd/s_bsd.c: remove static client_timer variable; in
6387         read_packet(), if there's still data in the client's recvQ after
6388         parsing, add a 2 second timer (con_proc); fix the ET_DESTROY case
6389         of client_sock_callback to handle destroying the timer properly;
6390         rewrote client_timer_callback from scratch to be called on an
6391         individual client
6392
6393         * ircd/m_stats.c: add /STATS e to report the engine name
6394
6395         * ircd/list.c: deal with con_timer field in struct Connection
6396         properly; correct a core-level bug in remove_client_from_list--if
6397         the client is the only one in the list, we try to update
6398         GlobalClientList's cli_prev pointer--not good
6399
6400         * ircd/ircd.c: remove call to init_client_timer()
6401
6402         * ircd/engine_poll.c: made Debug messages more uniform by
6403         prepending "poll:" to them all; corrected an off-by-one error that
6404         caused poll_count to be 1 less than the actual count and removed
6405         my work-around; added Debug messages to indicate which socket is
6406         being checked and what the results are
6407
6408         * ircd/Makefile.in: ran a make depend
6409
6410         * include/s_bsd.h: remove init_client_timer(), since we're doing
6411         it differently now
6412
6413         * include/numeric.h (RPL_STATSENGINE): a stats reply to report the
6414         engine name
6415
6416         * include/ircd_policy.h (HEAD_IN_SAND_STATS_E): turn off /stats e
6417         reports for non-opers
6418
6419         * include/client.h: add con_timer and con_proc fields to struct
6420         Connection and define accessor macros--con_timer marks that
6421         con_proc contains a valid timer, and con_proc is used to pace user
6422         data
6423
6424         * ircd/s_bsd.c (close_connection): let free_client() destroy the
6425         socket
6426
6427         * ircd/s_auth.c (start_auth): add a Debug call to indicate when
6428         auth has begun on a client
6429
6430         * ircd/ircd_events.c: ensure that event_execute() is called with a
6431         non-NULL event; modify event_add() macro to properly zero list
6432         bits; modify gen_dequeue() to not try to clip it out of a list
6433         it's already been clipped out of; change signal socket
6434         initialization to use state SS_NOTSOCK; permit timeout values of
6435         0 in add_timer(); add many Debug calls; change socket_del() and
6436         timer_del() to always set the GEN_DESTROY flag; use GEN_MARKED in
6437         timer_run() instead of GEN_DESTROY so that event_generate() will
6438         pass on the events; remove the switch and replace with a simpler
6439         if-then-else tree in timer_run(); don't allow destroyed sockets to
6440         be destroyed again, nor their states or event masks to be changed
6441
6442         * ircd/ircd.c: initialize "running" to 1
6443
6444         * ircd/engine_poll.c: deal with SS_NOTSOCK "sockets"; add Debug
6445         messages all over the place; fix a counting problem in
6446         engine_add(); turn wait into a signed integer and set it to -1
6447         only if timer_next() returns 0; adjust wait time to be relative;
6448         don't call gen_ref_dec() if socket disappeared while we were
6449         processing it
6450
6451         * include/ircd_events.h: the pipe for signals is not a socket, so
6452         we must mark it as such--added SS_NOTSOCK for that special socket;
6453         events won't be generated if GEN_DESTROY is on, so add GEN_MARKED
6454         for the benefit of timer_run()
6455
6456         * configure.in: add --enable-pedantic and --enable-warnings to
6457         turn on (and off) -Wall -pedantic in CFLAGS
6458
6459 2001-05-21  Kevin L. Mitchell  <klmitch@mit.edu>
6460
6461         * ircd/s_conf.c: change "s_addr" element accesses to "address"
6462         element accesses
6463
6464         * include/s_conf.h: on some systems, "s_addr" is a macro; use
6465         "address" instead
6466
6467 2001-05-18  Kevin L. Mitchell  <klmitch@mit.edu>
6468
6469         * ircd/engine_kqueue.c: include ircd_alloc.h; set_or_clear returns
6470         void in this file; add a missing semi-colon; declare errcode,
6471         codesize
6472
6473         * ircd/uping.c (uping_sender_callback): it's pptr, not uping
6474
6475         * ircd/s_user.c (register_user): comment out spurious reference to
6476         nextping
6477
6478         * ircd/s_serv.c (server_estab): comment out spurious reference to
6479         nextping
6480
6481         * ircd/s_conf.c (read_configuration_file): comment out spurious
6482         reference to nextping and nextconnect
6483
6484         * ircd/s_bsd.c: comment out some spurious references to formerly
6485         global (now non-existant) variables; correct a couple of typos
6486
6487         * ircd/s_auth.c: pre-declare some functions referenced in the
6488         callback; correct a typo
6489
6490         * ircd/res.c (start_resolver): pass errno value of ENFILE
6491
6492         * ircd/listener.c (accept_connection): you know your API is messed
6493         up when...variables that shouldn't have been global crop up in
6494         other files
6495
6496         * ircd/list.c (free_client): substitution of == for =
6497
6498         * ircd/ircd_signal.c: include assert.h for assertion checking;
6499         check ev_data() to find out what signal generated event
6500
6501         * ircd/ircd_events.c: some references to the variable "timer"
6502         should have been references to the variable "ptr"
6503
6504         * ircd/engine_select.c: it's struct fd_set, not struct fdset;
6505         ev_timer(ev) is already a timer pointer; declare codesize as a
6506         size_t to correct signedness issue; use timer_next(), not
6507         time_next()
6508
6509         * ircd/engine_poll.c: ev_timer(ev) is already a timer pointer;
6510         select fd out of struct pollfd in assertion checking; declare
6511         errcode and codesize; use timer_next(), not time_next()
6512
6513         * ircd/engine_kqueue.c: ev_timer(ev) is already a timer pointer;
6514         use function timer_next(), not time_next()
6515
6516         * ircd/engine_devpoll.c: ev_timer(ev) is already a timer pointer;
6517         use function timer_next(), not time_next()
6518
6519         * ircd/Makefile.in (IRCD_SRC): add ircd_events.c to the list of
6520         compiled sources; do make depend
6521
6522         * include/list.h: pre-declare struct Connection
6523
6524         * include/ircd_events.h (gen_ref_inc): cast to the right structure
6525         name
6526
6527         * include/s_auth.h: duh; missing */
6528
6529 2001-05-10  Kevin L. Mitchell  <klmitch@mit.edu>
6530
6531         * ircd/send.c: update write events status after sending data or
6532         accumulating data to be sent
6533
6534         * ircd/m_list.c (m_list): update write events status after
6535         canceling a running /list
6536
6537         * ircd/channel.c (list_next_channels): update write events status
6538         after listing a few channels
6539
6540         * ircd/s_bsd.c: extensive changes to update to new events model;
6541         remove on_write_unblocked() and the two implementations of
6542         read_message(), which have been deprecated by this change
6543
6544         * ircd/s_auth.c: set the socket events we're interested in for
6545         clients; simplify some logic that does the connect_nonb followed
6546         by the socket_add
6547
6548         * ircd/list.c: define free_connection() to free a connection
6549         that's become freeable once the struct Socket has been
6550         deallocated; fix up free_client() to take this new behavior into
6551         account
6552
6553         * ircd/ircd.c: call init_client_timer()
6554
6555         * include/s_bsd.h: declare new REGISTER_ERROR_MESSAGE when unable
6556         to register connect-in-progress with events system; declare
6557         init_client_timer() (HACK!) to preserve rate-limiting behavior
6558
6559         * include/list.h: declare new free_connection()
6560
6561         * include/client.h: add a struct Socket to struct Connection
6562
6563 2001-05-09  Kevin L. Mitchell  <klmitch@mit.edu>
6564
6565         * ircd/ircd_signal.c: massage the handlers for SIGHUP, SIGINT, and
6566         SIGTERM into event callbacks; perform the actions in the
6567         callbacks, since they're not called in the context of the signal;
6568         set up the signal callbacks in the event engine
6569
6570         * ircd/ircd_events.c (signal_callback): we're supposed to look for
6571         a specific signal; don't generate an event if there is no signal
6572         structure for it
6573
6574         * ircd/ircd.c: nuke nextconnect and nextping and replace them with
6575         connect_timer and ping_timer; massage try_connections() and
6576         check_pings() into timer callbacks that re-add themselves at the
6577         right time; remove ircd.c's "event_loop()"; initialize the event
6578         system and the connect_timer and ping_timer
6579
6580         * ircd/uping.c: correct a couple more typos
6581
6582         * ircd/s_auth.c: rework to use new events system
6583
6584         * ircd/os_solaris.c (os_connect_nonb): update to new interface
6585
6586         * ircd/os_openbsd.c (os_connect_nonb): update to new interface
6587
6588         * ircd/os_linux.c (os_connect_nonb): update to new interface
6589
6590         * ircd/os_generic.c (os_connect_nonb): update to new interface
6591
6592         * ircd/os_bsd.c (os_connect_nonb): update to new interface
6593
6594         * include/s_auth.h: remove deprecated members of struct
6595         AuthRequest, replacing them with struct Socket and struct Timer
6596         structures; add flags to indicate when these structures have been
6597         released by the event system; remove the deprecated
6598         timeout_auth_queries()
6599
6600         * include/ircd_osdep.h (os_connect_nonb): connect could complete
6601         immediately, so change the interface to handle that possibility
6602
6603         * ircd/uping.c (uping_server): noticed and corrected a typo
6604
6605         * ircd/listener.c: set up to use ircd_event's struct Socket by
6606         adding an socket_add() call to inetport(), replacing
6607         free_listener() with socket_del() in close_listener(), and
6608         reworking accept_connection to be called as the callback
6609
6610         * ircd/ircd.c: add a call to IPcheck_init()
6611
6612         * ircd/IPcheck.c: remove IPcheck_expire(); rework
6613         ip_registry_expire() to be called from a timer; write
6614         IPcheck_init() to set up the expiration timer (hard-coded for a
6615         60-second expiration time)
6616
6617         * include/listener.h: add a struct Socket to the struct Listener;
6618         remove accept_connection()
6619
6620         * include/IPcheck.h: add IPcheck_init(), remove IPcheck_expire()
6621
6622 2001-05-08  Kevin L. Mitchell  <klmitch@mit.edu>
6623
6624         * ircd/ircd_events.c: include config.h; use USE_KQUEUE and
6625         USE_DEVPOLL instead of HAVE_KQUEUE and HAVE_DEVPOLL_H
6626
6627         * ircd/engine_select.c: include config.h; set FD_SETSIZE to
6628         MAXCONNECTIONS, not IRCD_FD_SETSIZE...
6629
6630         * ircd/engine_poll.c: include config.h
6631
6632         * ircd/engine_kqueue.c: include config.h
6633
6634         * ircd/engine_devpoll.c: include config.h
6635
6636         * ircd/Makefile.in: include engine sources in compilation and make
6637         depend steps
6638
6639         * configure.in: add checks for enabling the /dev/poll- and
6640         kqueue-based engines
6641
6642         * acconfig.h: add lines for USE_DEVPOLL and USE_KQUEUE
6643
6644         * ircd/Makefile.in: work in the engine sources
6645
6646 2001-05-07  Kevin L. Mitchell  <klmitch@mit.edu>
6647
6648         * ircd/m_settime.c: include ircd_snprintf.h
6649
6650         * ircd/ircd_relay.c: stomp a couple of gcc warnings suggesting
6651         parens around a construct that had both || and &&
6652
6653         * ircd/chkconf.c: #include "config.h" to get some important
6654         definitions
6655
6656         * ircd/Makefile.in: revamp ircd makefile for new build system
6657
6658         * doc/Makefile.in: revamp doc makefile for new build system
6659
6660         * config/*: Removed old build system files
6661
6662         * stamp-h.in: a stamp file
6663
6664         * install-sh: install-sh for new build system
6665
6666         * configure.in: configure.in for new build system
6667
6668         * configure: configure script for new build system (built by
6669         autoconf)
6670
6671         * config.sub: config.sub for new build system
6672
6673         * config.h.in: config.h.in for new build system (built by
6674         autoheader)
6675
6676         * config.guess: config.guess for new build system
6677
6678         * aclocal.m4: aclocal.m4 for new build system (built by aclocal
6679         1.4)
6680
6681         * acinclude.m4: aclocal.m4 macros for new build system
6682
6683         * acconfig.h: config.h skeleton for new build system
6684
6685         * Makefile.in: modify for new build system
6686
6687 2001-05-01  Kevin L. Mitchell  <klmitch@mit.edu>
6688
6689         * ircd/s_err.c: get rid of the last vestiges of TIME_T_FMT
6690
6691         * ircd/m_settime.c: get rid of the last vestiges of TIME_T_FMT
6692
6693         * ircd/m_server.c: get rid of the last vestiges of TIME_T_FMT
6694
6695 2001-05-01  Perry Lorier       <Isomer@coders.net>
6696         * doc/iauth.doc: Protocol for iauth server. (from hybrid).
6697         * doc/linux-poll.patch: Patch to make Linux under 2.2 not deadlock
6698                 when you have far far too many sockets in use.
6699         * {include,ircd}/iauth.c: A start on iauth support.
6700
6701 2001-05-01  Perry Lorier       <Isomer@coders.net>
6702         * ircd/s_err.c: Suggested wording change.
6703         * ircd/s_user.c: Users aren't target limited against +k users.
6704         * ircd/chkconf.c: Made it compile again, who knows if it works, but
6705                 now I can at least make install
6706         * various: Cleanups on m_*.c files.
6707
6708
6709 2001-04-23  Kevin L. Mitchell  <klmitch@mit.edu>
6710
6711         * ircd/s_misc.c (exit_client): make netsplit server notice say the
6712         right thing
6713
6714         * ircd/m_links.c (m_links_redirect): forward-port RPL_ENDOFLINKS
6715         change to make Khaled happy...
6716
6717         * ircd/m_whois.c (do_whois): pull-up of m_whois() fix
6718         (do_whois): duh...
6719
6720 2001-04-21  Kevin L. Mitchell  <klmitch@mit.edu>
6721
6722         * ircd/msgq.c: finally remove the msgq_integrity() hack, as it's
6723         turned up no more bugs
6724
6725         * ircd/ircd.c: use /* */ comments instead of // comments--all the
6726         world's not gcc :(
6727
6728         * ircd/s_conf.c (conf_add_server): use /* */ comments instead of
6729         // comments--all the world's not gcc :(
6730
6731         * ircd/runmalloc.c: finally garbage-collect unused file
6732
6733         * include/runmalloc.h: finally garbage-collect unused file
6734
6735         * ircd/<multiple files>: addition of '#include "config.h"' before
6736         all other includes in most .c files
6737
6738         * include/<multiple files>: remove includes of config.h, which are
6739         now going into the raw .c files
6740
6741 2001-04-20  Kevin L. Mitchell  <klmitch@mit.edu>
6742
6743         * ircd/m_whois.c (do_whois): display proper server name if the
6744         user is looking up himself
6745
6746         * ircd/m_who.c (m_who): disable match by servername or display of
6747         server names by non-opers
6748
6749         * include/ircd_policy.h: add define for
6750         HEAD_IN_SAND_WHO_SERVERNAME to cover full intent of sub-motion 15
6751         of CFV 165
6752
6753 2001-04-18  Kevin L. Mitchell  <klmitch@mit.edu>
6754
6755         * ircd/s_conf.c: keep the $R in memory so we can see it clearly
6756         when we do a /stats k
6757
6758         * ircd/s_user.c (set_user_mode): pull-up of changes to prevent
6759         users from turning on +s and +g
6760
6761         * ircd/s_misc.c (exit_client): pull-up of changes to turn off
6762         net.split notice
6763
6764         * ircd/parse.c: pull-up of changes to disable /trace, /links, and
6765         /map for users
6766
6767         * ircd/m_whois.c (do_whois): pull-up of server name masking for
6768         /whois
6769
6770         * ircd/m_user.c (m_user): removal of umode and snomask defaulting
6771         functions, pull-up
6772
6773         * ircd/m_stats.c (m_stats): pull-up of stats-disabling stuff
6774
6775         * ircd/m_map.c (m_map_redirect): pull-up of m_map_redirect()
6776
6777         * ircd/m_links.c (m_links_redirect): pull-up of m_links_redirect()
6778
6779         * ircd/channel.c (channel_modes): pull-up of channel key display
6780         as *
6781
6782         * include/ircd_policy.h: pull-up of ircd_policy.h
6783
6784         * include/client.h: pull-up of Set/ClearServNotice()
6785
6786         * ircd/gline.c (do_gline): report client name in G-line message
6787         (pull-up)
6788
6789         * ircd/s_user.c (register_user): pull-up--show IP address in some
6790         server notices dealing only with users; report which connection
6791         class has filled up
6792
6793         * ircd/s_stats.c (report_deny_list): use conf->flags &
6794         DENY_FLAGS_IP insteaf of conf->ip_kill
6795
6796         * ircd/m_stats.c (report_klines): use conf->flags & DENY_FLAGS_IP
6797         insteaf of conf->ip_kill
6798
6799         * ircd/s_conf.c: use flags field in struct DenyConf; pull-up of
6800         K-line by real name
6801
6802         * include/s_conf.h: use a flags field in struct DenyConf; define
6803         DENY_FLAGS_FILE, DENY_FLAGS_IP, and DENY_FLAGS_REALNAME for
6804         pull-up of K-line by real name
6805
6806         * ircd/m_trace.c: pull-up of IP show for user connections
6807
6808         * doc/example.conf: pull-up of the realname K-line documentation
6809
6810         * ircd/ircd.c: forward port of pid file advisory locking mechanism
6811
6812 2001-04-16  Kevin L. Mitchell  <klmitch@mit.edu>
6813
6814         * ircd/send.c (sendcmdto_flag_butone): recast to just broadcast to
6815         all servers, rather than to only servers that have +w/+g/whatever
6816         users on them; among other things, this removes that atrocity
6817         known as sentalong[] from this function
6818
6819         * ircd/m_admin.c: must include ircd.h to declare "me"; must
6820         include hash.h to declare FindUser()
6821
6822         * ircd/m_wallusers.c: implementation of WALLUSERS
6823
6824         * ircd/m_desynch.c (ms_desynch): only send DESYNCHs to opers
6825
6826         * ircd/m_wallops.c: only send WALLOPS to opers
6827
6828         * ircd/parse.c: add WALLUSERS command to parser table
6829
6830         * include/handlers.h: declare wallusers handlers
6831
6832         * include/msg.h: add WALLUSERS command
6833
6834         * ircd/send.c (sendcmdto_flag_butone): if FLAGS_OPER is or'd with
6835         flag, send only to appropriate opers
6836
6837 2001-04-13  Kevin L. Mitchell  <klmitch@mit.edu>
6838
6839         * ircd/uping.c: refit to use the new events interface
6840
6841         * ircd/res.c: refit to use the new events interface
6842
6843         * ircd/ircd_events.c: create timer_chg(), which permits a
6844         (non-periodic) timer's expire time to be modified; change the
6845         logic in timer_run() so that timers that were re-added while the
6846         event was being processed will not be destroyed prematurely
6847
6848         * include/uping.h: include the events header, declare some extra
6849         fields in struct UPing, remove timeout value, and define some
6850         flags for marking which cleanup items have yet to be done
6851
6852         * include/ircd_events.h: add a prototype for timer_chg() to change
6853         the expire time of a running timer
6854
6855 2001-03-13 Joseph Bongaarts <foxxe@wtfs.net>
6856         * ircd/os_openbsd.c: Tweaked the openbsd hack a bit.
6857         
6858 2001-03-07  Joseph Bongaarts  <foxxe@wtfs.net>
6859
6860         * config/configure.in: Add check for OpenBSD
6861
6862         * ircd/os_openbsd.c: Add seperate os dep file for openbsd which
6863         differs from generic BSD, particularly in its handling of
6864         _XOPEN_SOURCE.
6865         
6866 2001-02-12  Kevin L. Mitchell  <klmitch@mit.edu>
6867
6868         * ircd/m_gline.c (ms_gline): propagate a G-line that happened to
6869         have been added by a U-lined server, rather than going through the
6870         activate/deactivate logic; propagate G-line removals by U-lined
6871         servers as well
6872
6873         * ircd/gline.c: rename propagate_gline() to gline_propagate();
6874         make gline_propagate() return an int 0 (convenience return); only
6875         update lastmod in gline_activate() and gline_deactivate() if the
6876         current lastmod is non-zero, since 0 lastmod is our flag of a
6877         U-lined server having added a G-line
6878
6879         * include/gline.h (gline_propagate): exporting the G-line
6880         propagation function
6881
6882         * ircd/m_list.c (m_list): duh; permit explicit channel name
6883         specification only when /list gets two arguments ("Kev
6884         #wasteland") rather than when /list gets more than two
6885         arguments--nice braino
6886
6887 2001-01-29  Thomas Helvey <twhelvey1@home.com>
6888
6889         * ircd/ircd_reply.c (need_more_params): fix bug that allowed
6890         unregistered clients to spam opers with protocol violation
6891         messages. Note: the bugfix may have eliminated some useful
6892         protocol violation messages.
6893         Please send protocol violation messages explicitly from the
6894         functions they are discovered in, you have much better context
6895         for the error there and it helps to document the behavior of the
6896         server. This was also a design bug in that it violated the
6897         "A function should do one thing" heuristic. Patching this one
6898         would have resulted in a continuous spawning of other bugs over
6899         the next 3 years, so I killed it. Check around for stuff this
6900         broke and readd the calls to protocol_violation in the functions
6901         that need to send the message.
6902
6903 2001-01-29  Kevin L. Mitchell  <klmitch@mit.edu>
6904
6905         * ircd/channel.c (mode_parse_ban): stopper a tiny leak--if a ban
6906         already existed, then the logic would (attempt to) skip it, but
6907         would not free the ban string; now the ban string is free'd and
6908         the ban count is decremented, releasing the ban for use
6909
6910         * ircd/s_user.c: make send_umode_out() take a prop argument
6911         instead of testing for the PRIV_PROPAGATE privilege itself; fix
6912         set_umode() to use this new argument, calculating it before
6913         calculating the new privileges for a -o'd user
6914
6915         * ircd/m_oper.c (m_oper): pass the new prop argument to
6916         send_umode_out()
6917
6918         * ircd/channel.c (mode_parse_ban): turn off MODE_ADD bit in bans
6919         that we're not actually going to add because they already exist;
6920         test that particular bit before adding to the linked list
6921
6922         * include/s_user.h: add a prop argument to send_umode_out() to
6923         indicate whether or not to propagate the user mode
6924
6925 2001-01-24  Kevin L. Mitchell  <klmitch@mit.edu>
6926
6927         * ircd/msgq.c: ircd_vsnprintf() returns the number of bytes that
6928         it would have written; upper-bound the number to prevent overflows
6929         by proxy; also, tune buffer size given to ircd_vsnprintf() to take
6930         into account the fact that ircd_vsnprintf() already takes the
6931         terminal \0 into account
6932
6933 2001-01-22  Kevin L. Mitchell  <klmitch@mit.edu>
6934
6935         * ircd/msgq.c: add an incredibly ugly hack to attempt to track
6936         down an apparent buffer overflow; remove msgq_map(), since it's no
6937         longer used anywhere; slight tweaks to prevent off-by-one errors,
6938         but these can't explain the problems we've seen
6939
6940         * include/msgq.h: remove msgq_map(), since it's no longer used
6941         anywhere
6942
6943 2001-01-18  Kevin L. Mitchell  <klmitch@mit.edu>
6944
6945         * ircd/s_user.c (set_nick_name): call client_set_privs() after
6946         parsing user modes
6947
6948 2001-01-17  Kevin L. Mitchell  <klmitch@mit.edu>
6949
6950         * ircd/s_bsd.c (read_message): fix a typo in the select version of
6951         read_message()
6952
6953         * ircd/whowas.c (whowas_free): MyFree() is a macro that expects
6954         its argument to be an lvalue, which means we can't use
6955         whowas_clean()'s handy-dandy "return ww" feature
6956
6957         * ircd/ircd_features.c: default LOCOP_KILL to TRUE--oops...
6958
6959 2001-01-16  Kevin L. Mitchell  <klmitch@mit.edu>
6960
6961         * ircd/ircd_events.c (timer_run): it's possible that the timer got
6962         deleted during the callback processing, so don't go to the bother
6963         of requeuing it if the destroy flag is set
6964
6965         * ircd/engine_select.c: define FD_SETSIZE to be IRCD_FD_SETSIZE
6966         out of config.h if this is a *BSD; include errno.h (oops);
6967         decrement error count after an hour using a timer; use FD_SETSIZE
6968         constant instead of IRCD_FD_SETSIZE constant; fill in event
6969         processing code
6970
6971         * ircd/engine_poll.c: include errno.h (oops); decrement error
6972         count after an hour using a timer; fill in event processing code
6973
6974         * ircd/engine_kqueue.c: include errno.h (oops); decrement error
6975         count after an hour using a timer; assert events filter is either
6976         EVFILT_READ or EVFILT_WRITE; fill in event processing code
6977
6978         * ircd/engine_devpoll.c: include errno.h (oops); decrement error
6979         count after an hour using a timer; fill in event processing code
6980
6981 2001-01-15  Kevin L. Mitchell  <klmitch@mit.edu>
6982
6983         * ircd/client.c: fixed feattab; basically, when I changed features
6984         to use small integers specifying bit positions, instead of the
6985         bits themselves, I forgot to update feattab to not | these
6986         privileges together; also fixed a bug in the antiprivs masking
6987         loop in client_set_privs()--last index wouldn't get parsed
6988
6989 2001-01-11  Kevin L. Mitchell  <klmitch@mit.edu>
6990
6991         * ircd/ircd_events.c: call event_generate() with new data
6992         argument; make it set that field in struct Event; make
6993         socket_add() return the value of the eng_add callback
6994
6995         * ircd/engine_select.c: make engine_add() return a
6996         successful/unsuccessful status; add bounds-checking outside of an
6997         assert; use accessor macros; use log_write(), not the deprecated
6998         ircd_log(); add an assert to engine_loop() to double-check for
6999         data structure corruption
7000
7001         * ircd/engine_poll.c: make engine_add() return a
7002         successful/unsuccessful status; add bounds-checking outside of an
7003         assert; use accessor macros; use log_write(), not the deprecated
7004         ircd_log(); add an assert to engine_loop() to double-check for
7005         data structure corruption
7006
7007         * ircd/engine_kqueue.c: implementation of an engine for kqueue()
7008
7009         * ircd/engine_devpoll.c: implementation of an engine for /dev/poll
7010
7011         * include/ircd_events.h: define some accessor macros; add ev_data
7012         to struct Event for certain important data--errno values, for
7013         instance; make EngineAdd callback tell us if it was successful or
7014         not; add extra argument to event_generate(); make socket_add()
7015         return the status from EngineAdd
7016
7017 2001-01-10  Kevin L. Mitchell  <klmitch@mit.edu>
7018
7019         * ircd/ircd_events.c: pass initializer information about how many
7020         total _filedescriptors_ may be opened at once
7021
7022         * ircd/ircd.c: use exported "running" instead of unexported
7023         thisServer.running
7024
7025         * ircd/engine_select.c: implementation of an event engine based on
7026         select()
7027
7028         * ircd/engine_poll.c: implementation of an event engine based on
7029         poll()
7030
7031         * include/ircd_events.h: pass the engine initializer an integer
7032         specifing how many _filedescriptors_ may be opened at once
7033
7034         * include/ircd.h: running has to be exported for the engine_*
7035         event loops
7036
7037 2001-01-09  Kevin L. Mitchell  <klmitch@mit.edu>
7038
7039         * ircd/ircd_events.c: include some needed headers; add some
7040         comments; make evEngines[] const; bundle sig_sock and sig_fd into
7041         a struct named sigInfo; rework struct evInfo to have a queue of
7042         _generators_, and only when threaded; added a gen_init() function
7043         to centralize generator initialization; fix various compile-time
7044         errors; rework event_add() for new queueing scheme and checked for
7045         compile-time errors; add casts where needed; spell evEngines[]
7046         correctly; make engine_name() return const char*
7047
7048         * include/ircd_events.h: type EventCallBack depends on struct
7049         Event, so pre-declare it; put _event_ queue into generators, and
7050         only when threaded; give engine data a union to store both ints
7051         and pointers; make engine name a const; fix gen_ref_dec() macro;
7052         make engine_name() return a const char*
7053
7054         * ircd/ircd_events.c: gen_dequeue() is now exported, so move it
7055         down with the non-static functions; modify event_execute() to use
7056         the new gen_ref_dec() to simplify code; make sure event_generate()
7057         does not generate new events for generators marked for destruction
7058
7059         * include/ircd_events.h: the engines, at least, may need to modify
7060         reference counts to keep generators from going away while
7061         something still points at them, so add reference counter
7062         manipulators and export gen_dequeue() for them
7063
7064         * ircd/ircd_events.c: set up the list of engines to try; set up
7065         the signal struct Socket; rename netInfo to evInfo; move static
7066         functions near the beginning of the file; do away with
7067         signal_signal() (since we no longer keep a signal count ourselves)
7068         and call event_generate() directly from signal_callback--also
7069         renamed some functions; allow signal_callback() to read up to
7070         SIGS_PER_SOCK at once from the signal pipe; add event_init() to
7071         initialize the entire event system; add event_loop() to call the
7072         engine's event loop; initialize new struct GenHeader member,
7073         gh_engdata; remove timer_next(); add socket_add() function to add
7074         a socket; add socket_del() to mark a socket for deletion; add
7075         socket_state() to transition a socket between states; add
7076         socket_events() to set what events we're interested in on the
7077         socket; add engine_name() to retrieve event engine's name
7078
7079         * include/ircd_events.h: add engine data field to struct
7080         GenHeader; rename SOCK_ACTION_REMOVE to SOCK_ACTION_DEL; add a
7081         note about states vs s_events; remove signal count; fold union
7082         Generator back into struct Event; remove count members from struct
7083         Generators; redefine engine callbacks to not take a struct
7084         Engine*; add explanatory comments to callback definitions; add
7085         some engine callbacks to handle operations; remove struct Engine
7086         flag member--can detect single flag from eng_signal member; add
7087         event_init(), event_loop(), engine_name(), and the socket_*()
7088         functions; make timer_next() a macro to avoid a function call
7089
7090 2001-01-08  Kevin L. Mitchell  <klmitch@mit.edu>
7091
7092         * include/ircd_events.h: rename to ircd_events.h, since it handles
7093         events, not just networking stuff; add signal support; more
7094         structural rearrangement
7095
7096         * ircd/ircd_events.c: rename to ircd_events.c, since it handles
7097         events, not just networking stuff; add signal support; more
7098         structural rearrangement
7099
7100 2001-01-07  Kevin L. Mitchell  <klmitch@mit.edu>
7101
7102         * ircd/ircd_network.c: implement timer API; add reference counts
7103         appropriately
7104
7105         * include/ircd_network.h: firm up some pieces of the interface;
7106         split out members everything has into a separate structure; add
7107         reference counts; add timer API
7108
7109 2001-01-06  Kevin L. Mitchell  <klmitch@mit.edu>
7110
7111         * ircd/ircd_network.c: static data and event manipulation
7112         functions for new event processing system
7113
7114         * include/ircd_network.h: data structures for new event processing
7115         system
7116
7117 2001-01-03  Kevin L. Mitchell  <klmitch@mit.edu>
7118
7119         * ircd/whowas.c: Completely re-did the old allocation scheme by
7120         turning it into a linked list, permitting the
7121         NICKNAMEHISTORYLENGTH feature to be changed on the fly
7122
7123         * ircd/s_debug.c (count_memory): use FEAT_NICKNAMEHISTORYLENGTH
7124         feature instead of old #define
7125
7126         * ircd/ircd_features.c: add NICKNAMEHISTORYLENGTH feature as an
7127         integer feature with a notify callback (whowas_realloc)
7128
7129         * ircd/client.c (client_set_privs): second memset was supposed to
7130         be over antiprivs, not privs; thanks, Chris Behrens
7131         <cbehrens@xo.com> for pointing that out...
7132
7133         * include/whowas.h: new elements for an extra linked list in
7134         struct Whowas; a notify function for feature value changes
7135
7136         * include/ircd_features.h: new feature--FEAT_NICKNAMEHISTORYLENGTH
7137
7138         * config/config-sh.in: NICKNAMEHISTORYLENGTH is now a feature
7139
7140 2001-01-02  Kevin L. Mitchell  <klmitch@mit.edu>
7141
7142         * config/config-sh.in: get rid of DEFAULT_LIST_PARAMETER
7143         compile-time option--now in features subsystem
7144
7145         * ircd/motd.c (motd_init): rework motd_init() to be called as the
7146         notify function for MPATH and RPATH features (should probably
7147         split it up a bit, though...)
7148
7149         * ircd/m_privs.c (mo_privs): if called with no parameters, return
7150         privs of the caller, rather than an error
7151
7152         * ircd/m_list.c: pull usage message into its own function; pull
7153         list parameter processing into its own function that does not
7154         modify the contents of the parameter; add list_set_default() to
7155         set the default list parameter (uses the notify hook); rework
7156         m_list() to make use of these functions; removed dead code
7157
7158         * ircd/ircd_log.c (log_feature_mark): make sure to return 0, since
7159         we have no notify handler
7160
7161         * ircd/ircd_features.c: add notify callback for notification of
7162         value changes; give mark callback an int return value to indicate
7163         whether or not to call the notify callback; fix up feature macros
7164         for new notify callback; add DEFAULT_LIST_PARAM feature; rewrite
7165         string handling in feature_set() to deal with def_str being a null
7166         pointer; wrote feature_init() to set up all defaults appropriately
7167
7168         * ircd/ircd.c (main): call feature_init() instead of
7169         feature_mark(), to avoid calling notify functions while setting up
7170         defaults
7171
7172         * ircd/client.c: updated to deal with new privileges structure
7173
7174         * ircd/class.c: updated so init_class() can be called should one
7175         of PINGFREQUENCY, CONNECTFREQUENCY, MAXIMUM_LINKS, or
7176         DEFAULTMAXSENDQLENGTH be changed
7177
7178         * include/ircd_log.h: log_feature_mark() updated to fit with new
7179         API changes
7180
7181         * include/ircd_features.h: added DEFAULT_LIST_PARAM feature and
7182         feature_init() function (found necessary since adding the notify
7183         stuff and notifying motd.c during start-up...before we defined
7184         RPATH!)
7185
7186         * include/client.h: move privs around to enable addition of more
7187         bits if necessary; based on the FD_* macros
7188
7189         * include/channel.h: declare list_set_default (actually located in
7190         m_list.c *blanche*)
7191
7192         * ircd/s_user.c: retrieve MAXSILES and MAXSILELENGTH (now
7193         AVBANLEN*MAXSILES) from features subsystem
7194
7195         * ircd/s_debug.c (debug_serveropts): CMDLINE_CONFIG doesn't go to
7196         anything anymore
7197
7198         * ircd/s_bsd.c: retrieve HANGONGOODLINK and HANGONRETRYDELAY from
7199         the features subsystem
7200
7201         * ircd/s_auth.c (start_auth): NODNS migrated to the features
7202         subsystem
7203
7204         * ircd/random.c: created random_seed_set() function to set seed
7205         value, along with some stuff to make ircrandom() a little more
7206         random--state preserving, xor of time instead of direct usage,
7207         etc.; it's still a pseudo-random number generator, though, and
7208         hopefully I haven't broken the randomness
7209
7210         * ircd/m_version.c: FEATUREVALUES makes use of feature_int() calls
7211
7212         * ircd/m_join.c: use features interface to retrieve
7213         MAXCHANNELSPERUSER
7214
7215         * ircd/ircd_features.c: add NODISP flag for super-secret features;
7216         add a whole bunch of new features migrated over from make config
7217
7218         * ircd/ircd.c: use features interface to retrieve PINGFREQUENCY,
7219         CONNECTTIMEOUT, and TIMESEC
7220
7221         * ircd/client.c (client_get_ping): use features interface to
7222         retrieve PINGFREQUENCY
7223
7224         * ircd/class.c: use features interface to retrieve PINGFREQUENCY,
7225         CONNECTFREQUENCY, MAXIMUM_LINKS, and DEFAULTMAXSENDQLENGTH
7226
7227         * ircd/chkconf.c (DEFAULTMAXSENDQLENGTH): since it's now in the
7228         features subsystem, we have to add something explicit
7229
7230         * ircd/channel.c: use features interface to retrieve
7231         KILLCHASETIMELIMIT, MAXBANLENGTH, MAXBANS, and MAXCHANNELSPERUSER;
7232         note that MAXBANLENGTH is now calculated dynamically from MAXBANS
7233         and AVBANLEN
7234
7235         * ircd/Makefile.in: run make depend
7236
7237         * include/supported.h (FEATURESVALUES): update to reference
7238         feature settings
7239
7240         * include/random.h: add prototype for random_seed_set
7241
7242         * include/ircd_features.h: add several more features
7243
7244         * include/channel.h: move MAXBANS and MAXBANLENGTH into feature
7245         subsystem
7246
7247         * config/config-sh.in: feature-ized some more stuff
7248
7249         * include/motd.h: some new elements in motd.h for motd.c changes
7250
7251         * ircd/motd.c: motd_cache() now searches a list of already cached
7252         MOTD files; saves us from having duplicate caches in memory if
7253         there are two identical T-lines for two different sites...
7254
7255 2001-01-02  Perry Lorier <isomer@coders.net>
7256         * ircd/motd.c: don't core if the motd isn't found.  Bug found by
7257         Amarande.
7258
7259 2001-01-02  Perry Lorier <isomer@coders.net>
7260         * ircd/s_err.c: Added third param to 004 - the channel modes that tage params.  Used by hybrid/epic.
7261         * ircd/s_channels.c: Added fix for msg'ing a -n+m channel - thanks
7262                 to guppy for noticing, and hektik for providing the fix.
7263         * misc others: Minor cleanups, added more protocol_violations, ripped
7264                 out more P09 stuffs, bit more protocol neg stuff.
7265
7266 2000-12-19  Kevin L. Mitchell  <klmitch@mit.edu>
7267
7268         * ircd/m_ison.c (m_ison): Dianora says that ISON has to end with a
7269         space (*sigh* stupid clients...)
7270
7271         * ircd/s_user.c: make WALLOPS_OPER_ONLY a feature managed through
7272         ircd_features.[ch]
7273
7274         * ircd/s_err.c: get rid of GODMODE conditionals
7275
7276         * ircd/s_debug.c (debug_serveropts): switch to using appropriate
7277         calls into the features subsystem for various serveropts
7278         characters
7279
7280         * ircd/s_conf.c (find_conf_entry): get rid of USEONE conditional
7281
7282         * ircd/s_bsd.c: remove GODMODE conditional; use features subsystem
7283         to get value of VIRTUAL_HOST and CLIENT_FLOOD; remove
7284         NOFLOWCONTROL conditional
7285
7286         * ircd/s_auth.c: use features subsystem to determine value of
7287         KILL_IPMISMATCH
7288
7289         * ircd/parse.c: get rid of NOOPER and GODMODE conditionals; use
7290         features subsystem to determine the setting of IDLE_FROM_MSG
7291
7292         * ircd/numnicks.c: get rid of EXTENDED_NUMERICS conditionals
7293
7294         * ircd/motd.c: get value of NODEFAULTMOTD from features subsystem;
7295         use features subsystem to get motd file names
7296
7297         * ircd/m_settime.c: get value of RELIABLE_CLOCK from features
7298         subsystem
7299
7300         * ircd/m_server.c: get rid of CRYPT_LINK_PASSWORD, since it does
7301         us no good; use features subsystem to figure out if we need to do
7302         HUB-type stuff; make TESTNET debugging sendto_opmask_butone's use
7303         the Debug(()) macro instead; get value of RELIABLE_CLOCK from
7304         features subsystem
7305
7306         * ircd/m_privmsg.c: get IDLE_FROM_MSG from the features subsystem
7307
7308         * ircd/m_oper.c: get CRYPT_OPER_PASSWORD from the features
7309         subsystem
7310
7311         * ircd/m_connect.c: get SERVER_PORT from the features subsystem
7312
7313         * ircd/ircd_log.c (log_set_file): fix a bug that kept log files
7314         from getting marked if they were already set to something...
7315
7316         * ircd/ircd_features.c: add a flag to indicates read-only access;
7317         add several new features that used to be compile-time selected
7318
7319         * ircd/ircd.c: grab pidfile out of feature subsystem; don't check
7320         access to motd files (what the heck?); make sure to initialize the
7321         feature subsystem before trying to write the config file
7322
7323         * ircd/dbuf.c: use feature_int() to retrieve BUFFERPOOL settings;
7324         use feature_bool() to figure out if we're using the FERGUSON
7325         flusher
7326
7327         * ircd/Makefile.in: MPATH and RPATH are now done differently, so
7328         remove the clause that creates empty files of that name; also ran
7329         make depend
7330
7331         * include/sys.h: CLIENT_FLOOD is now a feature; unfortunately,
7332         there is no easy way to bounds-check it at present
7333
7334         * include/querycmds.h: make sure ircd_features.h is included; use
7335         feature_str(FEAT_DOMAINNAME) in calls to match()
7336
7337         * include/ircd_features.h: many new features that used to be
7338         compile-time selected
7339
7340         * config/config-sh.in: add * to DOMAINNAME; try also using first
7341         argument to search in /etc/resolv.conf; removed many compile-time
7342         options that now can be configured through the features system
7343
7344 2000-12-18  Kevin L. Mitchell  <klmitch@mit.edu>
7345
7346         * doc/api/log.txt: how to use the logging API
7347
7348         * doc/api/features.txt: how to use the features API
7349
7350         * doc/api/api.txt: how to write API documentation
7351
7352         * include/ircd_features.h: rearranged a couple of features for
7353         neatness purposes
7354
7355         * ircd/ircd_features.c: cleaned up the macros some; rearranged
7356         some code to all go into the switch; rearranged a couple of
7357         features for neatness purposes
7358
7359 2000-12-16  Greg Sikorski <gte@atomicrevs.demon.co.uk>
7360         * ircd/os_bsd.c: Added os_set_tos for BSD users.
7361
7362 2000-12-16  Kevin L. Mitchell  <klmitch@mit.edu>
7363
7364         * ircd/ircd_features.c: Isomer almost got it right; you need to
7365         use F_I(), since it's an integer value, not a boolean value.  The
7366         asserts in feature_int would catch you out...  Also made the F_*
7367         macros take flags
7368
7369         * ircd/s_err.c: define RPL_PRIVS reply
7370
7371         * ircd/parse.c: put new PRIVS command into command table
7372
7373         * ircd/m_privs.c (mo_privs): message handler to report operator
7374         privileges
7375
7376         * ircd/ircd_features.c: declare new features OPER_SET and
7377         LOCOP_SET; redo boolean testing routine to accept TRUE, YES, and
7378         ON for boolean TRUE, and FALSE, NO, and OFF for boolean FALSE
7379
7380         * ircd/client.c: simplify client_set_privs() with a table that
7381         defines what features to test for; add new client_report_privs()
7382
7383         * ircd/Makefile.in: compile new m_privs.c; run make depend
7384
7385         * include/numeric.h (RPL_PRIVS): new reply numeric for displaying
7386         an operator's privileges
7387
7388         * include/msg.h: define new command: PRIVS
7389
7390         * include/ircd_features.h: create new features OPER_SET and
7391         LOCOP_SET for controlling access to /set
7392
7393         * include/handlers.h (mo_privs): declare message handler for
7394         reporting oper privileges
7395
7396         * include/client.h (client_report_privs): declare function to
7397         report what privileges an oper has
7398
7399         * ircd/m_whois.c (do_whois): fix a bug that caused /whois to
7400         report that a user is an oper if the oper doing the /whois had
7401         PRIV_SEE_OPERS
7402
7403 2000-12-17  Isomer <Isomer@coders.net>
7404         * ircd/listener.c: added support for TOS twiddling as a 'feature'.
7405
7406 2000-12-17  Isomer <Isomer@coders.net>
7407         * ircd/os_linux.c: add TOS stuffs
7408
7409         * ircd/listener.c: add TOS stuffs
7410
7411 2000-12-16  Kevin L. Mitchell  <klmitch@mit.edu>
7412
7413         * ircd/whocmds.c (do_who): use HasPriv to determine whether or not
7414         to indicate a user is an oper
7415
7416         * ircd/s_user.c: clear privileges setting when deopping; don't
7417         propagate +o unless user has PRIV_PROPAGATE privilege
7418
7419         * ircd/s_debug.c (debug_serveropts): created debug_serveropts()
7420         function and replaced how the server option string is generated
7421
7422         * ircd/parse.c: remove conditional on CONFIG_OPERCMDS
7423
7424         * ircd/m_whois.c (do_whois): use HasPriv to determine whether or
7425         not to indicate the user is an operator
7426
7427         * ircd/m_who.c: use HasPriv to determine whether or not a user
7428         should be displayed in the list of opers
7429
7430         * ircd/m_version.c: call debug_serveropts() to get server option
7431         string
7432
7433         * ircd/m_userip.c (userip_formatter): use HasPriv to determine
7434         whether or not to show oper status
7435
7436         * ircd/m_userhost.c (userhost_formatter): use HasPriv to determine
7437         whether or not to show oper status
7438
7439         * ircd/m_restart.c (mo_restart): replace ugly #ifdef conditional
7440         checks with HasPriv check; remove dead code
7441
7442         * ircd/m_rehash.c (mo_rehash): replace ugly #ifdef conditional
7443         checks with HasPriv check
7444
7445         * ircd/m_opmode.c (mo_opmode): use HasPriv to check permissions;
7446         use feature_bool to check if disabled
7447
7448         * ircd/m_oper.c (m_oper): set oper priviliges
7449
7450         * ircd/m_mode.c (m_mode): replace #ifdef conditional with HasPriv
7451         check
7452
7453         * ircd/m_kill.c (mo_kill): use HasPriv checks to determine if we
7454         can kill
7455
7456         * ircd/m_kick.c (m_kick): replace #ifdef conditional with HasPriv
7457         check
7458
7459         * ircd/m_jupe.c (mo_jupe): rework permissions checking structure;
7460         use feature_bool to check if disabled
7461
7462         * ircd/m_join.c (m_join): remove BADCHAN conditional; replace
7463         #ifdef conditional with a HasPriv check
7464
7465         * ircd/m_gline.c (mo_gline): rework permissions checking
7466         structure; use feature_bool to check if any part is disabled
7467
7468         * ircd/m_die.c: replace ugly #ifdef conditionals with HasPriv
7469         check; remove dead code
7470
7471         * ircd/m_clearmode.c: use feature_bool() to detect if we're
7472         disabled; use HasPriv to figure out what we're permitted to do;
7473         only allow clearmode on moded channels
7474
7475         * ircd/ircd_features.c: define various features; use HasPriv to
7476         verify permissions to set/reset
7477
7478         * ircd/gline.c (gline_add): use HasPriv instead of #ifdef
7479         conditionals
7480
7481         * ircd/client.c (client_set_privs): function to set an oper's
7482         privileges
7483
7484         * ircd/channel.c: use HasPriv calls instead of #ifdef conditionals
7485
7486         * include/whocmds.h: deconditionalize several macros and
7487         substitute appropriate calls to HasPriv()
7488
7489         * include/s_debug.h: get rid of global serveropts[]; define new
7490         function debug_serveropts() to build that string on the fly
7491
7492         * include/ircd_features.h: define some features
7493
7494         * include/client.h: add privs member to struct Connection; define
7495         various priviledges
7496
7497         * include/channel.h: no longer using IsOperOnLocalChannel; remove
7498         conditional of MAGIC_OPER_OVERRIDE on OPER_WALK_THROUGH_LMODES
7499
7500         * doc/Configure.help: remove help information for deprecated
7501         options
7502
7503         * config/config-sh.in: remove certain deprecated options having to
7504         do with what opers can and cannot do--first stage in moving
7505         compile-time constants into the .conf
7506
7507 2000-12-16  Isomer <Isomer@coders.net>
7508         * ircd/parse.c: detect if the prefix is missing and try and recover
7509         instead of coring.
7510
7511 2000-12-15  Kevin L. Mitchell  <klmitch@mit.edu>
7512
7513         * ircd/ircd_log.c: found and fixed some bugs in the debug logging
7514         code that would sometimes result in the log file not being
7515         reopened--which meant that a user could connect and get the
7516         logging output--oops
7517
7518         * ircd/Makefile.in: run make depend...
7519
7520         * ircd/s_stats.c: get rid of report_feature_list()
7521
7522         * ircd/s_err.c: add the 'bad value' error message, shift error
7523         messages over somewhat
7524
7525         * ircd/s_debug.c (debug_init): call log_debug_init with the
7526         use_tty flag
7527
7528         * ircd/s_conf.c (read_configuration_file): unmark features before
7529         reading the config file, then reset unmarked features after
7530         reading the config file
7531
7532         * ircd/m_stats.c: use feature_report() instead of
7533         report_feature_list()
7534
7535         * ircd/ircd_log.c: fix log_debug_file (bogus assertion); add
7536         special 'mark' flags and use them; add the stuff needed by the
7537         features API
7538
7539         * ircd/ircd_features.c: rework the features API and add gobs of
7540         comments to try to explain what some of these complex functions
7541         are actually doing
7542
7543         * include/s_stats.h: get rid of report_feature_list(); use
7544         feature_report() instead
7545
7546         * include/numeric.h: added a new error message and shifted old
7547         values over some--this is, after all, an alpha
7548
7549         * include/ircd_log.h: log_debug_init now takes an integer to tell
7550         it if it should be using the tty; added a couple of functions
7551         required by the features API
7552
7553         * include/ircd_features.h: add an enum and some more functions to
7554         flesh out the feature API--it should now be possible to put all
7555         those compile-time constants in the config file!
7556
7557         * ircd/send.c: got the direction of the assert incorrect...
7558
7559         * ircd/send.c: implement the efficiency of flush_connections by
7560         creating a linked list of struct Connection's with queued data;
7561         also get rid of flush_sendq_except and make sure to yank
7562         connections out of the list when their sendQs become empty (notice
7563         the assertion in flush_connections!)
7564
7565         * ircd/s_bsd.c (close_connection): must yank the Connection out of
7566         the sendq list
7567
7568         * ircd/list.c (dealloc_connection): must yank the Connection out
7569         of the sendq list
7570
7571         * ircd/dbuf.c (dbuf_put): call flush_connections instead of the
7572         deprecated flush_sendq_except
7573
7574         * ircd/client.c: define a couple new helper functions for sendq
7575         threading--this will make the flush_connections function in send.c
7576         considerably more efficient by creating a linked list of
7577         Connections that have queued data to send
7578
7579         * include/send.h: remove flush_sendq_except, as it's not used
7580         anymore
7581
7582         * include/client.h: declare a couple new helper functions for the
7583         sendq threading system
7584
7585 2000-12-14  Kevin L. Mitchell  <klmitch@mit.edu>
7586
7587         * ircd/m_ison.c (m_ison): Apply Diane Bruce's patch to make ISON
7588         parse all arguments
7589
7590         * ircd/s_debug.c (count_memory): modify to report for clients and
7591         connections, not local clients and remote clients
7592
7593         * ircd/list.c: fiddle with the client-fiddling functions to take
7594         into account the divorce of struct Connection from struct Client
7595
7596         * ircd/ircd.c: define a struct Connection for me, initialize it,
7597         and link it into the right place (ewww, globals!)
7598
7599         * include/client.h: remove CLIENT_{LOCAL,REMOTE}_SIZE; split
7600         struct Client into struct Client and struct Connection; redefine
7601         local-portion accessor macros to go through struct Client to the
7602         struct Connection; define struct Connection accessor macros
7603
7604 2000-12-13  Kevin L. Mitchell  <klmitch@mit.edu>
7605
7606         * ircd/whowas.c: missed a couple of accesses to a struct Client
7607
7608         * ircd/uping.c: missed a couple of accesses to a struct Client
7609
7610         * ircd/send.c: missed a couple of accesses to a struct Client
7611
7612         * ircd/s_user.c: missed a couple of accesses to a struct Client
7613
7614         * ircd/s_misc.c: missed a couple of accesses to a struct Client
7615
7616         * ircd/s_conf.c: missed a couple of accesses to a struct Client
7617
7618         * ircd/s_bsd.c: missed a couple of accesses to a struct Client
7619
7620         * ircd/s_auth.c: missed a couple of accesses to a struct Client
7621
7622         * ircd/res.c: missed a couple of accesses to a struct Client
7623
7624         * ircd/parse.c: missed a couple of accesses to a struct Client
7625
7626         * ircd/m_whois.c: use new accessor macros for struct Client
7627
7628         * ircd/m_who.c: use new accessor macros for struct Client
7629
7630         * ircd/m_wallchops.c: use new accessor macros for struct Client
7631
7632         * ircd/m_version.c: use new accessor macros for struct Client
7633
7634         * ircd/m_userip.c: use new accessor macros for struct Client
7635
7636         * ircd/m_userhost.c: use new accessor macros for struct Client
7637
7638         * ircd/m_user.c: use new accessor macros for struct Client
7639
7640         * ircd/m_uping.c: use new accessor macros for struct Client
7641
7642         * ircd/m_trace.c: use new accessor macros for struct Client
7643
7644         * ircd/m_topic.c: use new accessor macros for struct Client
7645
7646         * ircd/m_time.c: use new accessor macros for struct Client
7647
7648         * ircd/m_stats.c: use new accessor macros for struct Client
7649
7650         * ircd/m_squit.c: use new accessor macros for struct Client
7651
7652         * ircd/m_silence.c: use new accessor macros for struct Client
7653
7654         * ircd/m_server.c: use new accessor macros for struct Client;
7655         remove dead code
7656
7657         * ircd/m_rpong.c: use new accessor macros for struct Client
7658
7659         * ircd/m_rping.c: use new accessor macros for struct Client
7660
7661         * ircd/m_quit.c: use new accessor macros for struct Client
7662
7663         * ircd/m_privmsg.c: use new accessor macros for struct Client
7664
7665         * ircd/m_pong.c: use new accessor macros for struct Client; remove
7666         dead code
7667
7668         * ircd/m_ping.c: use new accessor macros for struct Client
7669
7670         * ircd/m_pass.c: use new accessor macros for struct Client
7671
7672         * ircd/m_part.c: use new accessor macros for struct Client
7673
7674         * ircd/m_oper.c: use new accessor macros for struct Client
7675
7676         * ircd/m_notice.c: use new accessor macros for struct Client
7677
7678         * ircd/m_nick.c: use new accessor macros for struct Client
7679
7680         * ircd/m_names.c: use new accessor macros for struct Client
7681
7682         * ircd/m_mode.c: use new accessor macros for struct Client
7683
7684         * ircd/m_map.c: use new accessor macros for struct Client
7685
7686         * ircd/m_list.c: use new accessor macros for struct Client
7687
7688         * ircd/m_links.c: use new accessor macros for struct Client;
7689         remove some dead code
7690
7691         * ircd/m_kill.c: use new accessor macros for struct Client; remove
7692         some dead code
7693
7694         * ircd/m_kick.c: use new accessor macros for struct Client
7695
7696         * ircd/m_join.c: use new accessor macros for struct Client; remove
7697         some dead code
7698
7699         * ircd/m_ison.c: use new accessor macros for struct Client
7700
7701         * ircd/m_invite.c: use new accessor macros for struct Client
7702
7703         * ircd/m_info.c: use new accessor macros for struct Client
7704
7705         * ircd/m_gline.c: use new accessor macros for struct Client
7706
7707         * ircd/m_error.c: use new accessor macros for struct Client
7708
7709         * ircd/m_create.c: use new accessor macros for struct Client
7710
7711         * ircd/m_connect.c: use new accessor macros for struct Client;
7712         removed some dead code
7713
7714         * ircd/m_burst.c: use new accessor macros for struct Client
7715
7716         * ircd/m_away.c: use new accessor macros for struct Client
7717
7718         * ircd/m_admin.c: use new accessor macros for struct Client
7719
7720         * ircd/hash.c: missed a couple of accesses to a struct Client
7721
7722         * ircd/gline.c: missed a couple of accesses to a struct Client
7723
7724         * ircd/crule.c: missed a couple of accesses to a struct Client
7725
7726         * ircd/class.c: missed an access to a struct Client
7727
7728         * ircd/channel.c: missed a couple of accesses to a struct Client
7729
7730         * ircd/IPcheck.c: missed an access to a struct Client
7731
7732         * include/querycmds.h: fix a couple of stats macros to use
7733         structure accessor macros
7734
7735         * include/client.h: change structure member names to highlight any
7736         places in the code I've missed
7737
7738 2000-12-12  Kevin L. Mitchell  <klmitch@mit.edu>
7739
7740         * ircd/whowas.c: use new struct Client accessor macros
7741
7742         * ircd/whocmds.c: use new struct Client accessor macros
7743
7744         * ircd/send.c: use new struct Client accessor macros
7745
7746         * ircd/s_user.c: use new struct Client accessor macros; removed
7747         some dead code
7748
7749         * ircd/s_serv.c: use new struct Client accessor macros; removed
7750         some dead code
7751
7752         * ircd/s_numeric.c: use new struct Client accessor macros
7753
7754         * ircd/s_misc.c: use new struct Client accessor macros
7755
7756         * ircd/s_debug.c: use new struct Client accessor macros
7757
7758         * ircd/s_conf.c: use new struct Client accessor macros
7759
7760         * ircd/s_bsd.c: use new struct Client accessor macros
7761
7762         * ircd/s_auth.c: use new struct Client accessor macros
7763
7764         * ircd/parse.c: use new struct Client accessor macros
7765
7766         * ircd/packet.c: use new struct Client accessor macros
7767
7768         * ircd/numnicks.c: use new struct Client accessor macros
7769
7770         * ircd/motd.c: use new struct Client accessor macros
7771
7772         * ircd/listener.c: use new struct Client accessor macros
7773
7774         * ircd/list.c: use new struct Client accessor macros
7775
7776         * ircd/jupe.c: use new struct Client accessor macros
7777
7778         * ircd/ircd_snprintf.c: use new struct Client accessor macros
7779
7780         * ircd/ircd_reply.c: use new struct Client accessor macros
7781
7782         * ircd/ircd_relay.c: use new struct Client accessor macros
7783
7784         * ircd/ircd.c: use new struct Client accessor macros
7785
7786         * ircd/gline.c: catch some instances of me.<stuff> I missed
7787         previously
7788
7789         * ircd/client.c: use cli_ instead of con_
7790
7791         * ircd/class.c: use cli_ instead of con_
7792
7793         * ircd/channel.c: use cli_ instead of con_
7794
7795         * ircd/IPcheck.c: use cli_ instead of con_; catch some instances
7796         of me.<stuff> I missed previously
7797
7798         * include/client.h: use cli_ instead of con_...seemed like a good
7799         idea at the time *shrug*
7800
7801 2000-12-11  Kevin L. Mitchell  <klmitch@mit.edu>
7802
7803         * ircd/hash.c: use struct Client accessor macros
7804
7805         * ircd/gline.c: use struct Client accessor macros
7806
7807         * ircd/crule.c: use struct Client accessor macros
7808
7809         * ircd/client.c: use struct Client accessor macros; remove some
7810         dead code
7811
7812         * ircd/class.c: use struct Client accessor macros
7813
7814         * ircd/channel.c: use struct Client accessor macros; remove some
7815         dead code
7816
7817         * ircd/IPcheck.c: use struct Client accessor macros
7818
7819         * include/numnicks.h: use struct Client accessor macros
7820
7821         * include/client.h: first step to divorcing struct Client and
7822         struct Connection--define accessor macros and use them
7823
7824         * ircd/gline.c: When Uworld removed Uworld-set G-lines, only the
7825         uplink would remove them.  This is because the removal protocol
7826         message wasn't being sent to the uplinks.  This is fixed by fixing
7827         propagate_gline() to send the proper number of arguments depending
7828         on whether or not we're adding or deleting the Uworld gline, and
7829         by having gline_deactivate() make sure to turn off the active bit
7830         and call propagate_gline() if it's a Uworld gline
7831
7832 2000-12-10  Kevin L. Mitchell  <klmitch@mit.edu>
7833
7834         * ircd/os_generic.c: make sure IOV_MAX gets defined, just in case
7835
7836         * ircd/os_bsd.c: apparently BSD doesn't have IOV_MAX defined
7837         anywhere intelligent...
7838
7839 2000-12-09  Kevin L. Mitchell  <klmitch@mit.edu>
7840
7841         * ircd/send.c (send_queued): call deliver_it with appropriate
7842         arguments
7843
7844         * ircd/s_serv.c: reorder a couple of headers--cosmetic
7845
7846         * ircd/s_bsd.c (deliver_it): make deliver_it work with a struct
7847         MsgQ
7848
7849         * ircd/os_solaris.c (os_sendv_nonb): function for calling writev
7850         with appropriate iovec
7851
7852         * ircd/os_linux.c (os_sendv_nonb): function for calling writev
7853         with appropriate iovec
7854
7855         * ircd/os_generic.c (os_sendv_nonb): function for calling writev
7856         with appropriate iovec
7857
7858         * ircd/os_bsd.c (os_sendv_nonb): function for calling writev with
7859         appropriate iovec
7860
7861         * ircd/msgq.c (msgq_mapiov): add a len_p argument for totalling up
7862         exactly how much we're trying to write out to the fd
7863
7864         * include/s_bsd.h: make deliver_it take a struct MsgQ
7865
7866         * include/msgq.h: add a len_p argument to msgq_mapiov to help
7867         detect short writes that indicate possible socket blocking
7868
7869         * include/ircd_osdep.h: declare os_sendv_nonb()
7870
7871         * ircd/channel.c (modebuf_mode): don't add empty modes...
7872
7873 2000-12-08  Kevin L. Mitchell  <klmitch@mit.edu>
7874
7875         * include/send.h: add prio argument to send_buffer to select
7876         between normal and priority queues
7877
7878         * ircd/s_user.c (send_user_info): add prio argument to send_buffer
7879         call
7880
7881         * ircd/m_ison.c (m_ison): add prio argument to send_buffer call
7882
7883         * ircd/ircd_reply.c (send_reply): add prio argument to send_buffer
7884         call
7885
7886         * ircd/channel.c (send_channel_modes): add prio argument to
7887         send_buffer call
7888
7889         * ircd/send.c (send_buffer): add a prio argument to select the
7890         priority queue; update send.c functions to use it
7891
7892         * ircd/msgq.c (msgq_add): remove msgq_prio; fold msgq_link and
7893         msgq_add; add a prio argument to msgq_add to select the priority
7894         queue
7895
7896         * include/msgq.h: remove msgq_prio; add a prio argument to
7897         msgq_add
7898
7899         * ircd/send.c: remove sendbuf; remove GODMODE code; switch to
7900         using msgq functions instead of dbuf functions; remove old, dead
7901         sendto_* functions; redo send_buffer to take a struct MsgBuf;
7902         rework sendcmdto_* functions to make use of the new struct MsgBuf
7903
7904         * ircd/s_user.c: remove hunt_server; restructure send_user_info to
7905         make appropriate use of struct MsgBuf
7906
7907         * ircd/s_debug.c (count_memory): count memory used by the MsgQ
7908         system and report it
7909
7910         * ircd/s_conf.c (read_configuration_file): use
7911         sendto_opmask_butone instead of the now dead sendto_op_mask
7912
7913         * ircd/s_bsd.c: switch to using appropriate MsgQLength and other
7914         calls on sendQ
7915
7916         * ircd/parse.c (parse_server): get rid of a piece of GODMODE code
7917
7918         * ircd/msgq.c: add msgq_append and msgq_bufleft; fix a bug in
7919         msgq_clean
7920
7921         * ircd/m_version.c: fix spelling in comments marking dead code
7922
7923         * ircd/m_userip.c (userip_formatter): restructure to make use of
7924         struct MsgBuf
7925
7926         * ircd/m_userhost.c (userhost_formatter): restructure to make use
7927         of struct MsgBuf
7928
7929         * ircd/m_stats.c: use MsgQLength on a sendQ
7930
7931         * ircd/m_settime.c: use MsgQLength instead of DBufLength on a
7932         sendQ; mark a piece of dead code
7933
7934         * ircd/m_names.c: use send_reply instead of sendto_one
7935
7936         * ircd/m_mode.c: use new mode; remove old dead code
7937
7938         * ircd/m_ison.c (m_ison): restructure to make use of struct MsgBuf
7939
7940         * ircd/m_burst.c: use BUFSIZE instead of IRC_BUFSIZE; remove old
7941         dead code
7942
7943         * ircd/listener.c (accept_connection): use sendto_opmask_butone
7944         instead of sendto_op_mask
7945
7946         * ircd/list.c (free_client): use MsgQClear to clear sendQ
7947
7948         * ircd/ircd_reply.c: remove send_error_to_client; restructure
7949         send_reply to make use of struct MsgBuf
7950
7951         * ircd/dbuf.c (dbuf_put): remove argument to flush_sendq_except,
7952         since its no longer used (at least currently)
7953
7954         * ircd/channel.c: restructure send_channel_modes to make use of
7955         struct MsgBuf; remove set_mode, add_token_to_sendbuf, cancel_mode,
7956         and send_hack_notice; use BUFSIZE instead of IRC_BUFSIZE
7957
7958         * ircd/Makefile.in: add msgq.c to list of sources; run make depend
7959
7960         * ircd/IPcheck.c: use sendcmdto_one instead of sendto_one
7961
7962         * include/send.h: send_buffer now takes a struct MsgBuf * instead
7963         of a char *; flush_sendq_except now takes no arguments, as sendq
7964         flushing currently only happens in dbuf.h and sendQ is a struct
7965         MsgQ; remove prototypes for a lot of old sendto_* functions that
7966         aren't used anymore; remove sendbuf and IRC_BUFSIZE--the former is
7967         no longer needed, and the latter is identical to BUFSIZE in
7968         ircd_defs.h
7969
7970         * include/s_user.h: make InfoFormatter take a struct MsgBuf*
7971         instead of a char *; also make it return void, instead of char *
7972
7973         * include/msgq.h: add msgq_append and msgq_bufleft functions
7974
7975         * include/client.h: use a struct MsgQ instead of a struct DBuf for
7976         sendq
7977
7978         * doc/Configure.help: Remove help for compile-time options that
7979         have gone away
7980
7981         * config/config-sh.in: remove CONFIG_NEWMODE
7982
7983         * ircd/m_server.c (mr_server): don't send server IPs in any server
7984         notices
7985
7986         * ircd/msgq.c (msgq_vmake): add \r\n to messages
7987
7988 2000-12-07  Kevin L. Mitchell  <klmitch@mit.edu>
7989
7990         * include/msgq.h: declare the MsgQ API
7991
7992         * ircd/msgq.c: implementation of new MsgQ system
7993
7994 2000-12-06  Kevin L. Mitchell  <klmitch@mit.edu>
7995
7996         * ircd/ircd_features.c: #include was supposed to be for
7997           ircd_features.h, not features.h--missed when I had to do a
7998           rename because of namespace collision
7999
8000 2000-12-05  Greg Sikorski <gte@atomicrevs.demon.co.uk>
8001         * ircd/m_topic.c: Added missing braces that caused all remote
8002           topics to be ignored.
8003
8004 2000-12-04  Kevin L. Mitchell  <klmitch@mit.edu>
8005
8006         * ircd/m_create.c: I'm tired of the exit_client warning :)
8007         (ms_create): discovered that exit_client() was being called with
8008         too few arguments
8009
8010         * ircd/s_misc.c (exit_client): remove all dependance on
8011         FNAME_USERLOG, since that's now gone; log only to LS_USER
8012
8013         * ircd/s_debug.c: USE_SYSLOG no longer means anything
8014
8015         * ircd/m_oper.c (m_oper): no longer log to LS_OPERLOG--we already
8016         log to LS_OPER
8017
8018         * ircd/m_kill.c: no longer conditionalize on SYSLOG_KILL
8019
8020         * ircd/ircd_log.c: remove LS_OPERLOG, LS_USERLOG
8021
8022         * include/ircd_log.h: remove LS_OPERLOG, LS_USERLOG--they serve
8023         the same purpose as LS_USER and LS_OPER
8024
8025         * config/config-sh.in: remove no longer relevant log config
8026         variables
8027
8028         * ircd/uping.c (uping_init): use log_write instead of ircd_log
8029
8030         * ircd/s_misc.c (exit_client): use log_write instead of ircd_log
8031
8032         * ircd/s_conf.c: use log_write instead of ircd_log
8033
8034         * ircd/s_bsd.c (report_error): use log_write instead of ircd_log
8035
8036         * ircd/s_auth.c (timeout_auth_queries): use log_write instead of
8037         ircd_log
8038
8039         * ircd/res.c (send_res_msg): use log_write instead of ircd_log
8040
8041         * ircd/m_who.c: use log_write instead of write_log; no longer
8042         conditionalize on WPATH; mark dead ircd_log calls
8043
8044         * ircd/m_uping.c: mark dead ircd_log call
8045
8046         * ircd/m_server.c (mr_server): use log_write instead of ircd_log
8047
8048         * ircd/m_restart.c: use log_write instead of ircd_log; mark dead
8049         ircd_log calls
8050
8051         * ircd/m_rehash.c (mo_rehash): use log_write instead of ircd_log
8052
8053         * ircd/m_oper.c: use log_write instead of ircd_log; no longer
8054         conditionalize on FNAME_OPERLOG; mark dead ircd_log calls
8055
8056         * ircd/m_kill.c: mark dead ircd_log calls
8057
8058         * ircd/m_connect.c: use log_write instead of ircd_log; mark dead
8059         ircd_log
8060
8061         * ircd/m_clearmode.c: use log_write instead of write_log; no
8062         longer conditionalize on OPATH
8063
8064         * ircd/jupe.c: use log_write instead of write_log; no longer
8065         conditionalize on JPATH
8066
8067         * ircd/ircd_log.c: add USER subsystem; remove ircd_log() compat
8068         function; fix a couple of bugs
8069
8070         * ircd/ircd_alloc.c: fixed a comment
8071
8072         * ircd/ircd.c: use log_write instead of ircd_log; fold server
8073         notice generation in a couple of cases
8074
8075         * ircd/gline.c: use log_write instead of write_log; no longer
8076         conditionalize on GPATH
8077
8078         * ircd/channel.c (modebuf_flush_int): use log_write instead of
8079         write_log; no longer conditionalize on OPATH
8080
8081         * ircd/Makefile.in: run make depend, since dependencies have
8082         changed
8083
8084         * doc/example.conf: add system USER to documentation
8085
8086         * include/ircd_log.h: add system USER; remove old ircd_log()
8087         declarations
8088
8089 2000-12-04  Isomer <isomer@coders.net>
8090         * ircd/m_names.c: Add NAMES_EON to do_names to say add a
8091         'end_of_names' reply when done.
8092         * ircd/m_join.c: use NAMES_EON as mentioned above
8093
8094 2000-12-01  net  <simms@LUCIDA.QC.CA>
8095
8096         * ircd/motd.c: add a freelist for struct Motds
8097
8098 2000-11-30  Kevin L. Mitchell  <klmitch@mit.edu>
8099
8100         * ircd/s_stats.c (report_feature_list): report features--only
8101         local opers can see logging configuration, since it doesn't really
8102         mean anything to users
8103
8104         * ircd/s_err.c: add reply messages for new feature subsystem
8105
8106         * ircd/s_conf.c: add F lines to .conf
8107
8108         * ircd/parse.c: add the message descriptions for /set, /reset, and
8109         /get
8110
8111         * ircd/m_stats.c: add /stats f
8112
8113         * ircd/m_set.c (mo_set): implement /set
8114
8115         * ircd/m_reset.c (mo_reset): implement /reset
8116
8117         * ircd/m_rehash.c: /rehash m now flushes MOTD cache, and /rehash l
8118         reopens log files (for log file rotation)
8119
8120         * ircd/m_get.c (mo_get): implement /get
8121
8122         * ircd/ircd_log.c: use int instead of void return value; add
8123         log_report_features() and log_canon(); fix a function that
8124         disappears if DEBUGMODE not #define'd
8125
8126         * ircd/ircd_features.c: functions to manipulate feature settings
8127         either from the config file or with the new /set, /reset, and /get
8128         commands
8129
8130         * ircd/Makefile.in: add new .c files, run make depend
8131
8132         * include/s_stats.h: declare report_feature_list() (/stats f
8133         handler)
8134
8135         * include/numeric.h: add RPL_STATSFLINE, RPL_FEATURE,
8136         ERR_NOFEATURE, ERR_BADLOGTYPE, ERR_BADLOGSYS, and ERR_BADLOGVALUE
8137         reply numerics
8138
8139         * include/msg.h: add defines for SET, RESET, and GET
8140
8141         * include/ircd_log.h: add a function to canonicalize subsystem
8142         names; change some void return values to int
8143
8144         * include/ircd_features.h: new features subsystem handles all the
8145         manipulation of special features, like log files
8146
8147         * include/handlers.h: declare new mo_{s,res,g}et message handlers
8148         for fiddling with features run-time
8149
8150         * include/client.h (SNO_DEFAULT): don't set SNO_DEBUG by default;
8151         seemed like a good idea at the time...
8152
8153         * doc/example.conf: document new F lines
8154
8155 2000-11-29  Kevin L. Mitchell  <klmitch@mit.edu>
8156
8157         * ircd/s_debug.c: rewrite debug_init() and vdebug() in terms of
8158         new logging functions, which have special support for the debug
8159         log; added loop detection to vdebug(), so that I can
8160         sendto_opmask_butone() from log_vwrite() without incurring another
8161         call to vdebug()
8162
8163         * ircd/s_conf.c (rehash): call log_reopen() from rehash routine;
8164         this allows log file rotations
8165
8166         * ircd/m_kill.c: call log_write_kill() instead of ircd_log_kill()
8167
8168         * ircd/ircd_log.c: much more work fleshing out the interface;
8169         removed old interface; included backwards-compat ircd_log()
8170         function that logs to subsystem LS_OLDLOG
8171
8172         * ircd/ircd.c: switch to new log_init()/log_close()/log_reopen()
8173         functions
8174
8175         * include/ircd_log.h: include stdarg.h for va_list; move ordering
8176         warning to top of file; fill out LogSys enum; declare new
8177         log_debug_init(), log_vwrite(), log_write_kill(), and
8178         log_[sg]et_*() functions; add flags argument to log_write();
8179         defined flags to inhibit various logging actions
8180
8181         * include/client.h: added support for new SNO_DEBUG, enabled only
8182         if DEBUGMODE is defined
8183
8184 2000-11-28  Kevin L. Mitchell  <klmitch@mit.edu>
8185
8186         * ircd/ircd_log.c: make sure the various LOG_* constants are
8187         defined (probably not needed, since #include <syslog.h> isn't
8188         conditional); various static data needed for the new logging
8189         functions; definitions of new logging functions
8190
8191         * include/ircd_log.h: new LogSys enum, declarations for part of
8192         new logging API
8193
8194         * ircd/motd.c: we were setting type to MOTD_CLASS unconditionally,
8195         which was of course stupid; switched to using switch/case in
8196         initialization in motd_create(); zero the MotdList.other pointer
8197         from motd_clear()
8198
8199         * ircd/ircd.c (main): motd_init() has to come before init_conf(),
8200         or we overwrite init_conf()'s hard work with respect to T-lines
8201
8202 2000-11-27  Kevin L. Mitchell  <klmitch@mit.edu>
8203
8204         * ircd/s_stats.c: comment out report_motd_list and include a
8205         reference to motd_report()
8206
8207         * ircd/s_conf.c: rip out the old MOTD manipulation functions; call
8208         motd_add() from the conf parser; call motd_clear() from the rehash
8209         routine; remove the no longer needed memory clearing and reloading
8210         stuff from the rehash service routine
8211
8212         * ircd/motd.c: loads new API, including static internal functions
8213         to do allocation/deallocation, etc.
8214
8215         * ircd/m_stats.c: use new motd_report() instead of
8216         report_motd_list()
8217
8218         * ircd/m_motd.c: use new syntax for motd_send()
8219
8220         * ircd/ircd.c: use new motd_init() function
8221
8222         * ircd/Makefile.in (SRC): forgot to add motd.c to SRC in
8223         Makefile.(in); also ran make depend
8224
8225         * include/motd.h: don't need config.h, but now do need time.h;
8226         define new structures and constants; redefine old API and define
8227         new functions
8228
8229 2000-11-22  Kevin L. Mitchell  <klmitch@mit.edu>
8230
8231         * ircd/s_user.c (register_user): use motd_signon() instead of
8232         calling m_motd; much cleaner this way
8233
8234         * ircd/motd.c: write the new motd_* stuff to make MOTD handling
8235         less of a crock
8236
8237         * ircd/m_motd.c: rewrite m{,s}_motd to call out to new motd_*
8238         functions
8239
8240         * include/motd.h: define new MOTD API stuff
8241
8242 2000-11-20  Kevin L. Mitchell  <klmitch@mit.edu>
8243
8244         * ircd/ircd_reply.c (protocol_violation): rewrite
8245         protocol_violation so it'll actually work
8246
8247         oh, yeah, use %s -> cptr->name, instead of %c -> cptr, so we get
8248         the client's real name in there.
8249
8250         * ircd/m_motd.c (m_motd): Iso's addition of get_client_class(sptr)
8251         resulted in core dumps if NODEFAULTMOTD is defined, because m_motd
8252         gets called from register_user with a NULL sptr.  This is probably
8253         a design problem, but this bandaid will do for now...
8254
8255 2000-11-19  Isomer <isomer@coders.net>
8256         * ircd/ircd_reply.c: added 'protocol_violation', thus alerting us
8257         to problems in the server<->server protocol.
8258
8259         * ircd/m_connect.c: allow remote connects with a port of '0'
8260         meaning to use the port in the config file.
8261
8262         * ircd/m_create.c: Enable hacking protection, lets see how far we
8263         get.
8264
8265         * ircd/m_error.c: The RFC says never accept ERROR from unreg'd
8266         clients, so we don't any more.
8267
8268         * ircd/m_kill.c: The kill path is now made up of numnicks of servers,
8269         and the user@host is displayed of the victim.
8270
8271         * ircd/m_map.c: reloaded 'dump_map'.
8272
8273         * ircd/m_trace.c: allow per class T:
8274
8275         * ircd/m_stats.c: allow local opers /remote stats anywhere on the 'net.
8276
8277 2000-11-17  Isomer <isomer@coders.net>
8278
8279         * ircd/m_topic.c: Fixed bug where we'd only send to clients topics
8280         that were the *same* instead of different.  Oh the embarrasment!
8281
8282         * ircd/IPcheck.c: Merged net's fix.
8283
8284 2000-11-02  Kevin L. Mitchell  <klmitch@mit.edu>
8285
8286         * ircd/m_whois.c: remove compiler warning by adding a newline to
8287         end of file
8288
8289         * ircd/m_names.c: moved the flags up to s_user.h
8290
8291         * ircd/m_join.c: call do_names instead of m_names; restructure
8292         ms_join to never transmute a JOIN into a CREATE, but use the TS in
8293         the JOIN (if present) to timestamp the channel
8294
8295         * ircd/channel.c: send JOINs individually, instead of grouping
8296         them, so that we can send the channel's creation time
8297
8298         * include/s_user.h: declare do_names()
8299
8300 2000-10-30  Isomer <isomer@coders.net>
8301         * ircd/m_oper.c: Fixed warning
8302
8303 2000-10-30  Isomer <isomer@coders.net>
8304         * ircd/m_oper.c: Fixed over agressive cut and no paste
8305
8306 2000-10-30  Isomer <isomer@coders.net>
8307
8308         * ircd/m_topic.c: Restructured, fixed bug where topics on local
8309         channels are propergated (I forget who pointed this out to me, but
8310         thanks anyway).  Also to save bandwidth don't send the topic to
8311         users if the topic is already the same on the server (but still
8312         propergate to other servers).  X/W's "autotopic" feature must
8313         chew a lot of bandwidth, hopefully this will help reduce this.
8314
8315         * doc/rfc1459.rfc: Updated documentation on /topic.
8316
8317         * ircd/listener.c: snotice warnings about failed accept()'s
8318         potentially warning admins that they're running out of fd's.
8319
8320         * ircd/stats.c, ircd/class.c: Removed /stats v, added number of
8321         people in a class in /stats y
8322
8323         * ircd/m_create.c: Checks for timewarp hacking and squit's
8324         evil servers. (currently disabled)
8325         
8326
8327 2000-10-30  net <simms@lucida.qc.ca>
8328         
8329         * ircd/gline.c: Fixed various bugs Isomer left behind.
8330
8331 2000-10-26  Kevin L. Mitchell  <klmitch@mit.edu>
8332
8333         * ircd/m_join.c (m_join): reply on attempt to join a BADCHANed
8334         channel is now ERR_BANNEDFROMCHAN instead of ERR_BADCHANNAME
8335
8336 2000-10-24  Kevin L. Mitchell  <klmitch@mit.edu>
8337
8338         * ircd/channel.c: ok, now last mode rules; mode +ps will always
8339         result in +s (and won't send a mode if the channel is already +s);
8340         mode +sp will always result in +p; -n+n on a +n channel results in
8341         no mode change; -n+n on a -n channel results in a +n mode change;
8342         etc.
8343
8344 2000-10-23  Kevin L. Mitchell  <klmitch@mit.edu>
8345
8346         * ircd/channel.c: add "add" and "del" elements to ParseState to
8347         avoid not-too-pretty -p+s when +s is sufficient; fix a bug in
8348         mode_parse_limit that caused it to clear all channel modes
8349         prematurely; restructure mode_parse_mode to avoid calling
8350         modebuf_mode too early (ties in with first mentioned change);
8351         better logic for +p/+s mutual exclusivity; initialize "add" and
8352         "del" elements in mode_parse; send simple modes down to
8353         modebuf_mode after the loop in mode_parse
8354
8355 2000-09-28  Greg Sikorski <gte@atomicrevs.demon.co.uk>
8356         * ircd/m_names.c: Fixed a non-lethal logic error that 
8357         triggers an assert() in find_member_link while debugging.
8358         (Spotted by Maniac-).
8359 2000-09-19  Thomas Helvey <helveytw@home.com>
8360         * ircd/s_conf.c: move K:lines to their own list and data
8361         structures, add supporting code.
8362         * ircd/m_stats.c: cleanup stats processing a bit move
8363         kline listing code to a new function, haven't figured
8364         out where it goes yet tho'
8365         * ircd/s_stats.c: added K:line bulk lister
8366         * include/s_conf.h: added new DenyConf struct
8367         * *[ch]: fixeup code that depended on changes
8368
8369 2000-09-17  Thomas Helvey <helveytw@home.com>
8370         * ircd/class.c: encapsulate class list
8371         * include/class.h: clean up classes
8372         * * fixup code that depended on changes
8373
8374 2000-09-17  Thomas Helvey <helveytw@home.com>
8375         * ircd/s_conf.c: add me to local conf
8376         * include/s_conf.h: move CONF_ME macro to chkconf.c
8377         * ircd/s_bsd.c: cleanup initialization, allow virtual host
8378         to be changed by rehash
8379
8380 2000-09-17  Thomas Helvey <helveytw@home.com>
8381         * include/class.h: add missing prototype
8382         * ircd/class.c: make argument to get_conf_class const
8383
8384 2000-09-17  Thomas Helvey <helveytw@home.com>
8385         * ircd/*.c: merged in changes from 2.10.10.pl12, cleanup
8386         merge conflicts.
8387         * ircd/*.h: merged in changes from 2.10.10.pl12, cleanup
8388         merge conflicts
8389
8390 2000-09-16  Thomas Helvey <helveytw@home.com>
8391         * ircd/s_conf.c: add code for server struct
8392         * ircd/client.c: copy of class.c sort of, new file for client
8393         specific operations, will move things here as appropriate,
8394         currently only one function is exported from here.
8395         * ircd/*.c: general logic cleanups, convert negatives to
8396         positives in places.
8397
8398 2000-09-16  Thomas Helvey <helveytw@home.com>
8399         * ircd/s_conf.c: add code for new crule data structs, strip quotes
8400         * ircd/crule.c: clean up scary casting a bit, type safety stuff
8401         * include/s_conf.h: add CRuleConf struct and support, remove
8402         unused constants
8403         * include/crule.h: type safety cleanups
8404         * ircd/*.c: fixup code that depended on stuff I changed
8405
8406 2000-09-15  Thomas Helvey <helveytw@home.com>
8407         * ircd/s_conf.c: start adding code for new conf data structs, changed
8408         listeners, admin line, motd lines, class lines. Move validate_hostent
8409         to resolver. General mayhem.
8410         * include/s_conf.h: new data structs and accessors
8411         * ircd/res.c: move validate_hostent here, rewrite, use regular
8412         expression for validation.
8413         * doc/example.conf: update docs for port
8414
8415 2000-09-14  Thomas Helvey <helveytw@home.com>
8416         * ircd/s_conf.c (conf_init): rewrite conf file parser, start to break
8417         up conf_init into managable chunks.
8418         * ircd/listener.c (set_listener_mask): fix logic bug core dump.
8419         * include/s_conf.h: add new data struct for local info (unwinding the mess).
8420
8421 2000-09-13  Thomas Helvey <helveytw@home.com>
8422         * ircd/list.c: put Clients in free lists, pre-allocate MAXCONNECTIONS
8423         local clients.
8424         * ircd/list.c: put SLinks in free lists
8425         * ircd/channel.c: put Memberships in free lists
8426         * ircd/ircd.c: rearrange initializations a bit in main
8427         Note: With these changes, ircd NEVER frees Clients, SLinks or
8428         Memberships. It will also rarely need to allocate new
8429         ones during net bursts and other disruptions. This should
8430         cut down on memory fragmentation a bit as well.
8431
8432 2000-08-30  Kevin L. Mitchell  <klmitch@mit.edu>
8433
8434         * ircd/m_names.c (do_names): pull-up from do_names fix in
8435         u2.10.10.pl11
8436
8437 2000-07-15  Perry Lorier       <Isomer@coders.net>
8438         * various: IP only k:'s and G:'s now do bit tests instead of two(!) 
8439                  match()'s.  Major Major cpu savings.  Also speed up the
8440                  other case slightly.  As a side effect you can now
8441                  k/Gline *@10.0.0.0/8.  I'll do bans tomorrow, it's nearing
8442                  3am.
8443
8444 2000-07-15  Perry Lorier       <Isomer@coders.net>
8445         * various: Fixed warnings after compiling on an alpha.
8446 2000-07-09  Perry Lorier       <Isomer@coders.net>
8447         * doc/ircd.8: Applied grammitical changes by Liandrin, applied
8448                       changes suggested by various other people.
8449         * ircd/IPcheck.c: More bug fixes.  Current problem appears to be
8450                         that it gets a corrupt entry somehow.
8451 2000-07-09  Greg Sikorski <gte@atomicrevs.demon.co.uk>
8452         * ircd/m_oper.c: Clean up compiler warning.
8453
8454 2000-07-08  Perry Lorier       <Isomer@coders.net>
8455         * doc/ircd.8: Updated the documentation, it was slightly out of date
8456                       being updated around 1989.
8457         * ircd/m_whois.c: Rewrote for clarity, and probably a bit more speed.
8458                           fixed a few minor glitches.
8459         * doc/rfc1459.unet: Updated.
8460         * ircd/IPcheck.c: Fixed more bugs.
8461         * ircd/s_bsd.c: We now keep track of servers we've conected.
8462
8463 2000-07-02  Perry Lorier       <Isomer@coders.net>
8464         * ircd/s_misc.c: Fixed remote IPcheck bug.  Ok, I'm a moron, so sue
8465                         me.  Thanks to Hektik, thanks thanks thanks thanks
8466                         thanks thanks thanks thanks thank thanks thank thanks
8467
8468 2000-07-01  Perry Lorier       <Isomer@coders.net>
8469         * ircd/s_conf.c: "Fixed" the "bug" where people would "evade" K:'s.
8470         * ircd/s_conf.c, include/IPcheck.h: Fixed compile warnings.
8471
8472 2000-06-22  Perry Lorier       <Isomer@coders.net>
8473         * ircd/IPcheck.c: Large chunks redone.
8474         * ircd/s_conf.c: Changes due to IPcheck - ONE nolonger supported,
8475                         single AND double digit limits are allowed now.
8476         * misc other: Changes to IPcheck.
8477
8478 2000-06-30  Perry Lorier       <Isomer@coders.net>
8479         * ircd/ircd.c: Fix command line parameter bugs.
8480
8481 2000-06-30  Perry Lorier       <Isomer@coders.net>
8482         * ircd/m_kill.c: Fixed bug with LOCAL_KILL_ONLY
8483         * ircd/m_nick.c: Tidied things up.
8484
8485 2000-06-12 Joseph Bongaarts <foxxe@trms.com>
8486         * ircd/m_stats.c: Iso forgot mo_stats when he added /stats v
8487         
8488 2000-05-29  Perry Lorier       <Isomer@coders.net>
8489         * ircd/m_stats.c: add /stats v to do only the last part of the /trace
8490         * ircd/IPcheck.c: Cosmetic change, if we meddle with it enough do
8491                         you think it'll get bored and fix itself?
8492
8493 2000-06-09  Greg Sikorski <gte@atomicrevs.demon.co.uk>
8494
8495         * ircd/m_names.c: Clean up compiler warnings.
8496
8497 2000-06-09  Kevin L. Mitchell  <klmitch@mit.edu>
8498
8499         * ircd/channel.c (mode_parse_client): don't send warning if
8500         there's not enough arguments for a +/-o/v; means the habit of
8501         doing "/mode #channel +oooooo bob" doesn't result in a bunch of
8502         error messages
8503
8504 2000-06-04  Greg Sikorski <gte@atomicrevs.demon.co.uk>
8505
8506         * ircd/m_names.c: Re-factor code to remove unneccessary
8507         GlobalChannelList iteration every time someone joins a channel.
8508
8509 2000-06-02  Kevin L. Mitchell  <klmitch@mit.edu>
8510
8511         * ircd/s_user.c: add struct Gline * argument to register_user;
8512         look up global glines and repropagate them if necessary; send
8513         acknowledgement of gline to remote servers when registering users
8514
8515         * ircd/s_serv.c (server_estab): don't send acknowledgement of
8516         local glines to remote servers; do send gline acknowledgement of
8517         bursted users
8518
8519         * ircd/m_user.c (m_user): pass new struct Gline * argument to
8520         register_user
8521
8522         * ircd/m_pong.c: pass new struct Gline * argument to register_user
8523
8524         * ircd/m_nick.c (ms_nick): document protocol change
8525
8526         * ircd/gline.c: support GLINE_LASTMOD
8527
8528         * include/s_user.h: add struct Gline * argument to register_user
8529
8530         * include/gline.h: add GLINE_LASTMOD to look up non-zero lastmods
8531
8532         * ircd/s_conf.c (find_kill): add unsigned int argument to
8533         gline_lookup()
8534
8535         * ircd/gline.c: add GLINE_GLOBAL to lookup or find only global
8536         glines; add unsigned int argument to gline_lookup()
8537
8538         * include/gline.h: add GLINE_GLOBAL flag; add unsigned int
8539         argument to gline_lookup()
8540
8541         * ircd/m_server.c: Resend jupe only when there is no %<lastmod>
8542         parameter, or when it falls out of bounds: see comments prior to
8543         call to jupe_resend(); call server_estab with struct Jupe
8544         parameter, so that we place the appropriate %<lastmod> in the
8545         appropriate place.
8546
8547         * ircd/s_serv.c (server_estab): send %<lastmod> for introduced
8548         server, as well as for servers when we're sending the BURST
8549
8550         * include/s_serv.h: add a struct Jupe * to the arguments for
8551         server_estab() so that we can send the appropriate lastmod
8552         parameter
8553
8554         * ircd/m_gline.c (ms_gline): actually, this should be the
8555         slightest bit more efficient...
8556
8557         * ircd/m_jupe.c (ms_jupe): actually, this should be the slightest
8558         bit more efficient...
8559
8560         * ircd/m_gline.c (ms_gline): inhibit GLINE processing resends
8561         during netburst
8562
8563         * ircd/m_jupe.c (ms_jupe): inhibit JUPE processing resends during
8564         netburst
8565
8566         * ircd/channel.c (joinbuf_join): really remove user from local
8567         channels
8568
8569 2000-05-29  Perry Lorier       <Isomer@coders.net>
8570         * ircd/m_names.c: Removed redundant space. 
8571         * ircd/s_bsd.c: Fixed incorrect syntax on ERROR line.
8572
8573 2000-05-18  Kevin L. Mitchell  <klmitch@mit.edu>
8574
8575         * ircd/m_burst.c (ms_burst): er...that should have been a ",", not
8576         a " "
8577
8578 2000-05-04  Kevin L. Mitchell  <klmitch@mit.edu>
8579
8580         * ircd/channel.c: replace bogus assertions with returns, which is
8581         logically correct; only wipe out limit/key if they were originally
8582         set in the first place; remove user from channel when doing a
8583         PARTALL; only send MODE +o for user CREATEing channel if user is
8584         not MyUser--CREATE will only be used if the channel did not
8585         originally exist, therefore we can assume no one local is on the
8586         channel anyway, and we don't exactly need for the user to see an
8587         explicit +o for themselves
8588
8589         * doc/readme.gline: describe the syntax of the GLINE command
8590
8591         * doc/readme.jupe: update to reflect a couple of changes to JUPE
8592
8593         * ircd/gline.c: don't propagate local changes
8594
8595         * ircd/jupe.c: don't propagate local changes
8596
8597         * ircd/m_gline.c (mo_gline): force local flag when deactivating
8598         glines with 0 lastmod
8599
8600         * ircd/gline.c (gline_deactivate): G-lines with zero lastmod time
8601         are now removed instead of being deactivated
8602
8603         * ircd/m_gline.c (ms_gline): make G-lines of the form "GLINE *
8604         -<mask>" be accepted
8605
8606         * ircd/channel.c (send_channel_modes): deal with one of the last
8607         vestiges of sendbuf
8608
8609         * ircd/m_burst.c (ms_burst): debugged ban processing; removed
8610         debugging hooks
8611
8612         * ircd/channel.c (modebuf_extract): remove debugging
8613         sendto_opmask_butone calls
8614
8615 2000-05-03  Kevin L. Mitchell  <klmitch@mit.edu>
8616
8617         * ircd/channel.c: support a couple of new flags to support using
8618         mode_parse; fix some bugs with 0 struct ModeBuf *; implementation
8619         of modebuf_extract to extract added flags for use by ms_burst
8620
8621         * include/channel.h: a couple of new flags to support using
8622         mode_parse inside ms_burst
8623
8624         * ircd/m_burst.c (ms_burst): brand new implementation of BURST
8625
8626         * ircd/m_endburst.c: add loop to processing of end_of_burst to
8627         free empty channels after the BURST is over.
8628
8629         * ircd/m_server.c: convert to use new send.c functions--I wanted
8630         to rewrite it from scratch, but the logic's pretty complex; I may
8631         still rewrite it, though...
8632
8633 2000-05-02  Thomas Helvey <tomh@inxpress.net>
8634
8635         * ircd/ircd.c: fix broken header include ordering
8636
8637 2000-05-02  Thomas Helvey <tomh@inxpress.net>
8638         
8639         * ircd/IPcheck.c: cleanups for ZenShadow's cleanups
8640         review emailed privately
8641
8642         * include/IPcheck.h: removed unneeded include
8643
8644 2000-05-02  Kevin L. Mitchell  <klmitch@mit.edu>
8645
8646         * ircd/s_user.c (hunt_server): throw in a comment so I know what
8647         the sendto_one is for
8648
8649         * include/querycmds.h (Count_unknownbecomesclient): convert to
8650         sendto_opmask_butone
8651
8652         * ircd/send.c: start removing dead code
8653
8654         * include/send.h: start removing dead code
8655
8656         * ircd/m_rping.c: convert to sendcmdto_one / send_reply /
8657         hunt_server_cmd
8658
8659         * ircd/m_rpong.c: convert to sendcmdto_one / send_reply
8660
8661 2000-05-01  Kevin L. Mitchell  <klmitch@mit.edu>
8662
8663         * ircd/m_stats.c: convert to sendcmdto_one / send_reply
8664
8665         * ircd/m_kick.c: Completely reimplement m_kick
8666
8667         * ircd/channel.c: send_user_joins removed; it was dead code,
8668         anyway...
8669
8670 2000-05-01  Perry Lorier <isomer@coders.net>
8671         * ircd/m_invite.c: Fix for the rest of m_invite.c, and again.
8672         * ircd/channels.c: My fix for the part problem.  Untested, probably
8673                 won't work.  Can't be much worse than the current problem.
8674                 it'll either work or core, take your pick.
8675
8676
8677 2000-04-30  Perry Lorier <isomer@coders.net>
8678         * config/config-sh.in: Fix for CONNEXIT
8679         * ircd/s_{user,misc}.c: Fix for CONNEXIT
8680         * ircd/m_invite.c: Fix for incorrectly numnickified invite.
8681                         (Kev: Want to come talk to me about this?)
8682
8683 2000-04-30  Steven M. Doyle <steven@doyle.net>
8684         * ircd/ircd.c
8685           - general cleanups and readability enhancements
8686           - rewrite of setuid/chroot code.
8687           - server will no longer run as root
8688           - -DPROFIL compile option removed
8689           - Fixed IPcheck API calls
8690  
8691         * config/config-sh.in
8692           - Fixed up chroot compile options
8693           - Added options for debug and profile compiles
8694  
8695         * config/gen.ircd.Makefile
8696           - Support for new debug/profile options
8697  
8698         * ircd/Makefile.in
8699           - Support for new debug/profile options
8700  
8701         * ircd/ircd_signal.c
8702           - Removed -DPROFIL
8703
8704         * include/IPcheck.h
8705           - Removed old API prototypes, added new ones
8706         
8707         * ircd/IPcheck.c
8708           - Readability cleanups (well, I -think-...)
8709           - Changed IPRegistryEntry.last_connect to a time_t.  The previously
8710             used unsigned short was probably causing interesting things after
8711             a client had been connected longer than about 65,535 seconds...
8712           - Removed old API functions.
8713
8714         * ircd/whocmds.c
8715           - Removed IPcheck.h include
8716         
8717         * Additionally modified IPcheck API calls in:
8718           - ircd/m_nick.c
8719           - ircd/m_auth.c
8720           - ircd/s_bsd.c
8721           - ircd/s_conf.c
8722           - ircd/s_misc.c
8723           - ircd/s_serv.c
8724           - ircd/s_user.c
8725         
8726         
8727 2000-04-30  Perry Lorier <isomer@coders.net>
8728         * ircd/s_bsd.c: Sigh. :)
8729         * ircd/m_mode.c: fix for modeless channels by poptix.
8730
8731 2000-04-29  Kevin L. Mitchell  <klmitch@mit.edu>
8732
8733         * ircd/m_join.c: reimplement JOIN in terms of struct JoinBuf
8734
8735         * ircd/channel.c (clean_channelname): make clean_channelname also
8736         truncate long channel names
8737
8738 2000-04-28  Kevin L. Mitchell  <klmitch@mit.edu>
8739
8740         * ircd/m_create.c: reimplement CREATE in terms of struct JoinBuf
8741
8742         * ircd/channel.c: implemented joinbuf_init, joinbuf_join,
8743         joinbuf_flush
8744
8745         * include/channel.h: definitions and declarations for the struct
8746         JoinBuf abstraction
8747
8748 2000-04-29  Perry Lorier <isomer@coders.net>
8749         * ircd/s_bsd.c: Ok, so I thought I compiled and tested this...
8750
8751 2000-04-29  Perry Lorier <isomer@coders.net>
8752         * ircd/s_bsd.c: Add debugging code to IPcheck
8753
8754 2000-04-28  Kevin L. Mitchell  <klmitch@mit.edu>
8755
8756         * include/ircd_reply.h (SND_EXPLICIT): use instead of RPL_EXPLICIT
8757
8758         * ircd/ircd_reply.c (send_reply): use SND_EXPLICIT instead of
8759         RPL_EXPLICIT
8760
8761         * ircd/m_userhost.c (m_userhost): add a dead code comment
8762
8763         * ircd/m_desynch.c: forgot one...
8764
8765         * ircd/m_rehash.c (mo_rehash): er, duplicates :)
8766
8767         * ircd/m_proto.c (proto_send_supported): just change a comment so
8768         it doesn't show up in my scans
8769
8770         * ircd/ircd_reply.c (send_reply): fix a slight bug...
8771
8772         * ircd/s_numeric.c (do_numeric): use new sendcmdto_* functions,
8773         kinda hackish...
8774
8775         * ircd/parse.c (parse_server): argument wrangling to make
8776         processing in do_numeric a little easier to deal with
8777
8778         * ircd/s_serv.c (server_estab): SERVER should come from
8779         acptr->serv->up, not &me
8780
8781         * ircd/m_lusers.c: accidentally left out sptr for a %C
8782
8783         * ircd/send.c: hack to support doing wallchops...
8784
8785         * ircd/m_whowas.c: convert to new send functions
8786
8787         * ircd/m_whois.c: convert to new send functions
8788
8789         * ircd/m_who.c: convert to new send functions
8790
8791         * ircd/m_wallops.c: convert to new send functions
8792
8793         * ircd/m_wallchops.c: convert to new send functions
8794
8795         * ircd/m_version.c: convert to new send functions
8796
8797         * ircd/m_userip.c: convert to new send functions
8798
8799         * ircd/m_userhost.c: convert to new send functions
8800
8801         * ircd/m_uping.c: convert to new send functions
8802
8803         * ircd/m_trace.c: convert to new send functions
8804
8805         * ircd/m_topic.c: convert to new send functions
8806
8807         * ircd/m_time.c: convert to new send functions
8808
8809         * ircd/m_squit.c: convert to new send functions
8810
8811         * ircd/m_silence.c: convert to new send functions
8812
8813         * ircd/m_settime.c: convert to new send functions
8814
8815         * ircd/m_restart.c: convert to new send functions
8816
8817         * ircd/m_rehash.c: convert to new send functions
8818
8819         * ircd/m_privmsg.c: convert to new send functions
8820
8821         * ircd/m_pong.c: convert to new send functions
8822
8823         * ircd/m_ping.c: convert to new send functions
8824
8825         * ircd/m_pass.c: convert to new send functions
8826
8827         * ircd/m_opmode.c: convert to new send functions
8828
8829         * ircd/m_oper.c: convert to new send functions
8830
8831         * ircd/m_notice.c: convert to new send functions
8832
8833         * ircd/m_nick.c: convert to new send functions
8834
8835         * ircd/m_names.c: convert to new send functions
8836
8837         * ircd/m_motd.c: convert to new send functions
8838
8839         * ircd/m_mode.c: convert to new send functions
8840
8841         * ircd/m_map.c: convert to new send functions
8842
8843         * ircd/m_lusers.c: convert to new send functions
8844
8845         * ircd/m_list.c: convert to new send functions
8846
8847         * ircd/m_links.c: convert to new send functions
8848
8849         * ircd/m_kill.c: convert to new send functions
8850
8851         * ircd/m_jupe.c: convert to new send functions
8852
8853         * ircd/m_invite.c: convert to new send functions
8854
8855         * ircd/m_info.c: convert to new send functions
8856
8857         * ircd/m_help.c: convert to new send functions
8858
8859         * ircd/m_gline.c: convert to new send functions
8860
8861         * ircd/m_error.c: convert to new send functions
8862
8863         * ircd/m_endburst.c: convert to new send functions
8864
8865         * ircd/m_die.c: convert to new send functions
8866
8867         * ircd/m_destruct.c: convert to new send functions
8868
8869         * ircd/m_defaults.c: convert to new send functions
8870
8871         * ircd/m_connect.c: convert to new send functions
8872
8873 2000-04-28  Perry Lorier <isomer@coders.net>
8874         * RELEASE.NOTES: Describe a few more undocumented features.
8875         * config/config-sh.in: change the default paths for logging
8876         and the recommended number of channels.
8877         * include/supported.h: Rearrange slightly, added CHANTYPE's
8878
8879 2000-04-27  Kevin L. Mitchell  <klmitch@mit.edu>
8880
8881         * ircd/m_close.c: convert to send_reply
8882
8883         * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
8884
8885         * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
8886
8887         * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
8888
8889         * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
8890         that takes cmd and tok arguments, etc.  NOTE: THIS IMPLEMENTATION
8891         HAS A MAJOR HACK!!!  The whole hunt_server architecture should be
8892         carefully rethought...
8893
8894         * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
8895
8896         * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
8897
8898         * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
8899         numeric nick; therefore, we have to use the server name
8900
8901         * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
8902
8903         * ircd/send.c: fix minor bugs
8904
8905         * ircd/s_user.c (check_target_limit): mark dead code so I filter
8906         it when I grep
8907
8908         * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
8909         when I grep
8910
8911         * ircd/parse.c: mark dead code so I filter it when I grep
8912
8913         * ircd/map.c: mark dead code so I filter it when I grep
8914
8915         * ircd/ircd.c: mark dead code so I filter it when I grep
8916
8917         * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
8918         functions
8919
8920         * ircd/channel.c: mark dead code so I filter it when I grep
8921
8922         * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
8923         hope I'm not stepping on toes...
8924
8925         * ircd/s_conf.c: more sendto_opmask_butone / send_reply
8926         conversions; use ircd_snprintf in a couple of cases to negate the
8927         possibility of buffer overflow
8928
8929 2000-04-26  Kevin L. Mitchell  <klmitch@mit.edu>
8930
8931         * ircd/channel.c: convert as much as possible to new send
8932         semantics
8933
8934         * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
8935         test member->user->from->fd, not from->fd
8936
8937         * ircd/gline.c (gline_add): go ahead and add badchans; we just
8938         won't look for them in m_gline; this way, they always work...
8939
8940         * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
8941
8942         * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
8943         ircd_vsnprintf conversion specifiers
8944
8945         * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
8946         I have my conversion specifiers
8947
8948         * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
8949
8950         * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
8951         local users
8952
8953         * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
8954         little less brain-dead
8955
8956         * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
8957
8958         * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
8959         RPL_STATSDEBUG
8960
8961         * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
8962         RPL_STATSDEBUG
8963
8964         * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
8965         for RPL_STATSDEBUG
8966
8967         * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
8968
8969         * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
8970
8971         * ircd/s_user.c (register_user): use RPL_EXPLICIT for
8972         ERR_INVALIDUSERNAME
8973
8974         * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
8975
8976         * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
8977         a numeric as needing to use an explicit pattern, which will be the
8978         first argument in the variable argument list
8979
8980         * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
8981         non-prefixed nospoof PING
8982
8983         * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
8984         non-prefixed SERVER login
8985
8986         * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
8987         a numeric usage further up)
8988
8989         * include/send.h: declare sendrawto_one
8990
8991         * ircd/send.c (sendrawto_one): new function to use ONLY for
8992         non-prefixed commands, like PING to client, or PASS/SERVER on
8993         server registration
8994
8995 2000-04-25  Kevin L. Mitchell  <klmitch@mit.edu>
8996
8997         * ircd/ircd_snprintf.c (doprintf): implement %H for possible
8998         future expansion (channel numerics?)
8999
9000         * include/ircd_snprintf.h: added documentation to # to explain use
9001         with %C; added documentation for : to explain use with %C; added
9002         documentation for %H for channels
9003
9004         * ircd/whocmds.c: use send_reply
9005
9006         * ircd/userload.c: use sendcmdto_one
9007
9008         * ircd/uping.c: use sendcmdto_one
9009
9010         * ircd/send.c: use new flags to %C format string; ':' prefixes
9011         client name with a colon for local connects, '#' uses
9012         nick!user@host form for local connects
9013
9014         * ircd/s_user.c: use send_reply, sendto_opmask_butone,
9015         sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
9016
9017         * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
9018
9019         * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
9020         sendcmdto_one
9021
9022         * ircd/s_auth.c: use sendto_opmask_butone
9023
9024         * ircd/res.c: use sendcmdto_one
9025
9026         * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
9027         debugging assertions
9028
9029 2000-04-24  Kevin L. Mitchell  <klmitch@mit.edu>
9030
9031         * ircd/support.c: dumpcore is no longer used, so get rid of it
9032
9033         * ircd/parse.c: use send_reply, sendcmdto_one
9034
9035         * ircd/map.c: use send_reply
9036
9037         * ircd/listener.c: use send_reply
9038
9039         * ircd/jupe.c: use sendto_opmask_butone, send_reply
9040
9041         * ircd/ircd_reply.c: use send_reply
9042
9043         * ircd/ircd.c: use sendto_opmask_butone
9044
9045         * ircd/gline.c: use sendto_opmask_butone, send_reply
9046
9047         * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
9048         registered clients; make FLAG_ALT print nick!user@host; make
9049         FLAG_COLON print :blah
9050
9051         * ircd/class.c (report_classes): use send_reply instead of
9052         sendto_one
9053
9054         * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
9055
9056         * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
9057         sendto_one with sendcmdto_one
9058
9059 2000-04-21  Kevin L. Mitchell  <klmitch@mit.edu>
9060
9061         * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
9062         MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
9063         sendcmdto_match_butone
9064
9065         * include/send.h: declare sendcmdto_match_butone
9066
9067 2000-04-20  Kevin L. Mitchell  <klmitch@mit.edu>
9068
9069         * ircd/jupe.c: update to use send_reply()
9070
9071         * ircd/gline.c: update to use send_reply()
9072
9073         * include/ircd_reply.h: declare send_reply
9074
9075         * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
9076         replies; uses ircd_snprintf
9077
9078         * ircd/send.c: added comments to redirect searchers to appropriate
9079         sendcmdto_* function; moved new functions to end of file; added
9080         explanatory comments; reordered arguments; defined new functions
9081         mentioned below
9082
9083         * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
9084
9085         * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
9086
9087         * ircd/jupe.c: reorder arguments to sendcmdto_* functions
9088
9089         * ircd/gline.c: reorder arguments to sendcmdto_* functions
9090
9091         * include/send.h: reorder arguments, add explanatory comments,
9092         declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
9093         and vsendto_opmask_butone
9094
9095 2000-04-19  Kevin L. Mitchell  <klmitch@mit.edu>
9096
9097         * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
9098         vsendto_op_mask that uses '*' instead of the receiving client
9099         nickname
9100
9101         * include/send.h: declare sendcmdto_channel_butone; takes a skip
9102         argument that allows you to skip (or not to skip) deaf users,
9103         users behind bursting servers, and non channel operators
9104
9105 2000-04-17  Kevin L. Mitchell  <klmitch@mit.edu>
9106
9107         * ircd/send.c: new sendcmdto_channel_butserv -- note that old
9108         sendto_channel_butserv has a subtle bug; also wrote
9109         sendcmdto_common_channels.
9110
9111         * include/send.h: declare new sendcmdto_* functions
9112
9113         * ircd/jupe.c: support local deactivations of jupes
9114
9115         * ircd/gline.c: support local deactivations of glines
9116
9117         * include/jupe.h: JUPE_LDEACT allows jupes to be locally
9118         deactivated; if they aren't locally deactivated, then it slaves to
9119         the net-wide activation status; JupeIsRemActive() tests only
9120         whether the jupe is active everywhere else
9121
9122         * include/gline.h: GLINE_LDEACT allows glines to be locally
9123         deactivated; if they aren't locally deactivated, then it slaves to
9124         the net-wide activation status; GlineIsRemActive() tests only
9125         whether the gline is active everywhere else
9126
9127         * ircd/gline.c: detect overlapping G-lines; if an existing, wider
9128         gline expires after the new one will, we drop the new one,
9129         otherwise we add the G-line after that one (so the wide one will
9130         apply first); if the new one contains an existing G-line and if it
9131         will expire after the existing one, we drop the existing one to
9132         save memory
9133
9134         * ircd/m_gline.c (mo_gline): opers could issue remote local
9135         glines when CONFIG_OPERCMDS was off; fixed
9136
9137 2000-04-16  Kevin L. Mitchell  <klmitch@mit.edu>
9138
9139         * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
9140         this is a local JUPE
9141
9142         * ircd/gline.c: add flags argument to gline_activate and
9143         gline_deactivate for future expansion
9144
9145         * ircd/m_gline.c: pass flags to gline_activate and
9146         gline_deactivate
9147
9148         * include/gline.h: add flags argument to gline_activate and
9149         gline_deactivate
9150
9151         * ircd/jupe.c: add flags argument to jupe_activate and
9152         jupe_deactivate for future expansion
9153
9154         * include/jupe.h: add flags argument to jupe_activate and
9155         jupe_deactivate
9156
9157         * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
9158         local, active; pass flags to jupe_activate and jupe_deactivate
9159
9160         * include/gline.h: remove dead code
9161
9162         * ircd/gline.c: make gline expire times relative to CurrentTime,
9163         since that should be monotonically increasing, instead of
9164         TStime(), which can be set backwards, and which can therefore
9165         cause an expire time to increase; make local glines be removed
9166         instead of just deactivated; don't let gline_find() look for
9167         user@host glines if the mask being looked up is a channel mask
9168
9169         * ircd/send.c (vsendcmdto_one): forgot to account for the case
9170         where origin is a server and destination is a user
9171
9172         * ircd/jupe.c: make jupe expire times relative to CurrentTime,
9173         since that should be monotonically increasing, instead of
9174         TStime(), which can be set backwards, and which can therefore
9175         cause an expire time to increase; make local jupes be removed
9176         instead of just deactivated
9177
9178         * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
9179         limit is fine.  any other warnings I should know about?
9180
9181 2000-04-15  Thomas Helvey <tomh@inxpress.net>
9182
9183         * ircd/*.c: const correctness and type safety cleanups to
9184         get code to compile with C++ compiler. Still has
9185         signed/unsigned comparison warnings.
9186
9187 2000-04-15  Greg Sikorski <gte@atomicrevs.demon.co.uk>
9188
9189         * ircd/userload.c: change <sys/time.h> include to <time.h> for
9190           portability.
9191
9192 2000-04-14  Kevin L. Mitchell  <klmitch@mit.edu>
9193
9194         * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
9195         and convert acptr...
9196
9197         * ircd/s_user.c: move gline_lookup function call into
9198         register_user, where it'll have a username to lookup!
9199
9200         * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
9201         functions; also stuff send_error_to_client into return clauses
9202
9203         * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
9204         functions; also use send_error_to_client where that makes sense
9205
9206         * ircd/jupe.c: modify to utilize new sendcmdto_* series of
9207         functions; also use send_error_to_client where that makes sense
9208
9209         * ircd/gline.c: modify to utilize new sendcmdto_* series of
9210         functions; also fix gline_lookup() to deal properly with remote
9211         clients--boy, do struct Client and struct User need to be cleaned
9212         up!
9213
9214         * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
9215         too...
9216
9217         * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
9218         sendcmdto_serv_butone(), all utilizing the %v conversion of
9219         ircd_snprintf()
9220
9221         * include/send.h: define IRC_BUFSIZE, max size of a message;
9222         declare sendcmdto_one(), vsendcmdto_one(), and
9223         sendcmdto_serv_butone()
9224
9225         * include/msg.h: define all the CMD_* constants needed to utilize
9226         the new sendcmdto_* series of functions
9227
9228         * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
9229
9230         * ircd/gline.c: remove old, dead code.
9231
9232         * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
9233         unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
9234         (don't advertise proxies); remove dead code
9235
9236         * ircd/parse.c: oper handler for JUPE only lists jupes unless
9237         CONFIG_OPERCMDS is enabled
9238
9239         * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
9240         CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
9241
9242         * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
9243         always return ERR_DISABLED
9244
9245         * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
9246         enabled, always return ERR_DISABLED
9247
9248         * ircd/s_err.c: add error message to indicate disabled commands
9249
9250         * include/numeric.h (ERR_DISABLED): to indicate disabled commands
9251
9252         * doc/Configure.help: add documentation for CONFIG_OPERCMDS
9253
9254         * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
9255         CONFIG_NEW_MODE to 'y' for now
9256
9257         * ircd/gline.c (gline_list): fix a minor formatting bogon
9258
9259         * BUGS: since I fixed that bug, might as well mark it fixed.
9260
9261         * ircd/m_join.c: look up badchans with GLINE_EXACT
9262
9263         * ircd/m_gline.c: fix parc count problems; look up existing
9264         G-lines with GLINE_EXACT; only set new lastmod when
9265         activating/deactivating existing glines if old lastmod was not 0
9266
9267         * ircd/gline.c: forgot to copy the gline reason over; don't
9268         propagate a gline with 0 lastmod if origin is user; add
9269         GLINE_EXACT to force exact matching of gline mask
9270
9271         * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
9272         flag properly
9273
9274         * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
9275         but gline_lookup() actually takes a client--d'oh.
9276
9277 2000-04-13  Thomas Helvey <tomh@inxpress.net>
9278         * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
9279
9280 2000-04-13  Greg Sikorski <gte@atomicrevs.demon.co.uk>
9281
9282         * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
9283           "/who * x"
9284           "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
9285           (Found by Plexus).
9286
9287         * ircd/whocmds.c: Change idle time calc from socket idle to user
9288           idle.
9289
9290 2000-04-13  Kevin L. Mitchell  <klmitch@mit.edu>
9291
9292         * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
9293         too, for ircd_snprintf.c
9294
9295         * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
9296         comments; mostly descended from the Linux manpage for printf, but
9297         also documenting the extensions.
9298
9299         * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
9300         client; make 'q' be the same as 'L'; remove __inline__; only
9301         define EXTENSION if HAVE_LONG_LONG is defined
9302
9303         * include/handlers.h: declare m_gline()
9304
9305         * ircd/parse.c: gline can be called by users, but it only lists
9306         the glines.
9307
9308         * ircd/s_user.c (set_nick_name): resend gline if a remote server
9309         introduces a glined client
9310
9311         * ircd/s_serv.c (server_estab): burst glines, too
9312
9313         * ircd/gline.c: fix up all the expire times to be offsets;
9314         simplify gline_resend()
9315
9316         * ircd/m_gline.c: begin coding replacements for ms_gline(),
9317         mo_gline(), and m_gline()
9318
9319         * ircd/gline.c (gline_add): allow *@#channel to work correctly;
9320         also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
9321
9322 2000-04-13  Greg Sikorski <gte@atomicrevs.demon.co.uk>
9323
9324         * tools/Bouncer/*: Add comments/documentation/tags.
9325         * tools/Bouncer/*: Add debug defines, make task fork().
9326
9327 2000-04-12  Thomas Helvey <tomh@inxpress.net>
9328         * ircd/s_err.c: Cleanup s_err.c make one table so we
9329         don't have to do anything tricky to get an error string.
9330
9331 2000-04-12  Greg Sikorski <gte@atomicrevs.demon.co.uk>
9332         * Add port bouncer for http (x/w)
9333
9334 2000-04-12  Kevin L. Mitchell  <klmitch@mit.edu>
9335
9336         * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
9337         call to gline_find(); also used GlineReason() instead of direct
9338         reference to structure member
9339
9340         * ircd/m_join.c (m_join): replace bad_channel() calls with calls
9341         to gline_find(name, GLINE_BADCHAN), and also check to see if gline
9342         is active
9343
9344         * ircd/channel.c: nothing seems to be called anywhere...
9345
9346         * ircd/s_err.c: update a couple of replies to dovetail with new
9347         semantics
9348
9349         * ircd/gline.c: begin complete re-implementation of gline.c along
9350         the lines of the final design of jupe.c
9351
9352         * include/gline.h: begin complete re-implementation of gline.c
9353         along the lines of the final design of jupe.c
9354
9355         * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
9356         %s by %s" message...
9357
9358         * ircd/ircd_snprintf.c: my new snprintf()-like functions
9359
9360         * include/ircd_snprintf.h: my new snprintf()-like functions
9361
9362 2000-04-11  Thomas Helvey <tomh@inxpress.net>
9363         * ircd/IPcheck.c: removed old dead code
9364         * ircd/s_user.c (send_user_info): removed non-standard
9365           user not found message for userhost/userip
9366
9367 2000-04-11  Greg Sikorski <gte@atomicrevs.demon.co.uk>
9368
9369         * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
9370         * doc/p10.html: Work on chapter 4.
9371
9372 2000-04-10  Kevin L. Mitchell  <klmitch@mit.edu>
9373
9374         * ircd/channel.c (mode_parse_client): fix coredump on /mode
9375         #foobar +o nosuchnick
9376
9377 2000-04-10  Perry Lorier  <Isomer@coders.net>
9378         * BUGS: Added bug.
9379
9380 2000-04-09  Thomas Helvey <tomh@inxpress.net>
9381         * include/IPcheck.h: fix prototype
9382         * ircd/s_user.c: fix usage of IPcheck_remote_connect
9383         * ircd/IPcheck.c: removed unused args
9384
9385 2000-04-09  Thomas Helvey <tomh@inxpress.net>
9386         * include/IPcheck.h: add proto for IPcheck_expire
9387
9388         * ircd/IPcheck.c: Rewrote
9389
9390         * ircd/ircd.c: Add IPcheck_expire to main message loop
9391
9392         * ircd/s_user.c: Redo target hashing, refactor target code
9393
9394         * include/numeric.h: Cleaned up numerics, added which ones are
9395         in use by other networks and what they are in use for.
9396
9397         * ircd/channel.c: cleaned can_join(), allow anyone through anything
9398         if /invited, simplified the function.  Opers overusing OPEROVERRIDE
9399         will get a message explaining to them not to cheat.
9400
9401         * ircd/m_join.c: cleaned up the various join functions, should be
9402         a lot more efficient.  Still needs work.  Now assumes that s<->s
9403         won't send it a JOIN 0.  Service coders - note this and tread with
9404         care.
9405
9406         * ircd/m_stats.c: added Gte-'s stats doc patch.
9407
9408         * ircd/m_version.c: /version now returns the 005 numeric as well.
9409         as requested by Liandrin.
9410
9411
9412 2000-04-07  Kevin L. Mitchell  <klmitch@mit.edu>
9413
9414         * ircd/m_clearmode.c: add include for support.h for write_log()
9415
9416         * configure: move ircd/crypt/* to tools/*
9417
9418 2000-04-06  Thomas Helvey <tomh@inxpress.net>
9419         * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
9420           set client host to server alias if connection from localhost
9421
9422 2000-04-06  Perry Lorier <isomer@coders.net>
9423         * ircd/ircd.c: Fix core during pinging (oops)
9424         
9425 2000-04-06  Perry Lorier <isomer@coders.net>
9426         * ircd/send.c: fixed wrong ident being sent to channels bug.
9427         * include/numerics.h: Updated some of the numerics from other
9428         networks.  Flagged some as 'unused' by undernet.
9429
9430 2000-03-30  Perry Lorier <isomer@coders.net>
9431         * ircd/ircd.c: Lets see if this helps the ping problem at all.
9432         * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
9433         time for local clients. (as requested), extended who now returns all
9434         the flags (@+!) so you can tell the complete state of a client.
9435
9436 2000-03-30  Thomas Helvey <tomh@inxpress.net>
9437         * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
9438
9439 2000-03-30  Perry Lorier <isomer@coders.net>
9440         * ircd/parse.c: oops, missed opers.
9441
9442 2000-03-30  Perry Lorier <isomer@coders.net>
9443         * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
9444         for so long.  Remember: m_ping MUST be in the parse array. :)
9445
9446 2000-03-30  Perry Lorier <isomer@coders.net>
9447         * ircd/ircd.c: test in check_pings was wrong.  I move that we
9448         disallow cvs commit after 10pm localtime....
9449
9450 2000-03-30  Perry Lorier <isomer@coders.net>
9451         * ircd/m_pong.c: Fix it for servers too.
9452
9453 2000-03-30  Perry Lorier <isomer@coders.net>
9454         * ircd/m_pong.c: Fix ping timeout bugs
9455
9456 2000-03-30  Perry Lorier <isomer@coders.net>
9457         * ircd/channel.c: Bans had CurrentTime in their when field instead
9458         of TStime()
9459
9460 2000-03-31  Thomas Helvey <tomh@ixpress.net>
9461         * ircd/numnicks.c (SetXYYCapacity): fix for extended
9462         numerics.
9463
9464 2000-03-30  Perry Lorier <isomer@coders.net>
9465         * ircd/m_nick.c: send kills both ways so when we add nick change
9466         on collision we don't desync the network.
9467
9468         * ircd/map.c: Fixup the map a bit more.
9469
9470 2000-03-31  Kevin L. Mitchell  <klmitch@mit.edu>
9471
9472         * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
9473
9474         * ircd/m_opmode.c: Log the mode changes to OPATH
9475
9476         * ircd/channel.c (modebuf_flush_int): Log the mode changes to
9477         OPATH
9478
9479         * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
9480         OPATH
9481
9482         * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
9483
9484         * config/config-sh.in: added OPATH for opmode log file
9485
9486         * ircd/m_clearmode.c (do_clearmode): updated uses of
9487         modebuf_mode_string() for the new usage
9488
9489         * ircd/channel.c: added flag MODE_FREE and an int argument to
9490         modebuf_mode_string() to indicate that the string must be free'd;
9491         updated calls to modebuf_mode_string() for the new usage; called
9492         collapse(pretty_mask()) on the ban string and use allocated memory
9493         for it; added ban list length accounting; fixed a number of small
9494         bugs in ban processing
9495
9496         * include/channel.h: added flag MODE_FREE and an int argument to
9497         modebuf_mode_string() to indicate that the string must be free'd
9498
9499         * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
9500         keys and limits that are set
9501
9502 2000-03-30  Perry Lorier <isomer@coders.net>
9503         * ircd/ircd.c: rewrote check_pings() for maintainability
9504         and speed.  Also changed quit msg's so they don't have
9505         redundant nick[host] info in them.
9506
9507         * ircd/send.c: Changed write errors to report what error
9508         occured (if possible).
9509
9510         * ircd/gline.c: added gline comment to the quit.
9511
9512         * ircd/m_server.c: Added suggestions to server quits mentioning
9513         what went wrong so the admin can fix it earlier instead of asking
9514         questions...
9515
9516         * ircd/map.c: Changed m_map() to hide numerics, show a * beside
9517         servers that aren't fully burst yet.  And show '(--s)' for servers
9518         where its not sure.
9519
9520         * doc/example.conf: Fixed wrapped U:
9521
9522 2000-03-30  Kevin L. Mitchell  <klmitch@mit.edu>
9523
9524         * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
9525         mode_parse() (version selectable at compile time)
9526
9527         * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
9528
9529         * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
9530
9531         * config/config-sh.in: add new config option to enable new m_mode
9532         implementation
9533
9534         * doc/Configure.help: add documentation for new config option
9535         CONFIG_NEW_MODE
9536
9537         * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
9538         MODE -v : Not enough parameters
9539
9540         * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
9541         +k and +l even if they weren't set...
9542
9543         * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
9544
9545         * ircd/channel.c: make mode_process_clients() clear the DEOPPED
9546         flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
9547         for; test the 0-th member, not the i-th member, of the client
9548         change state stuff
9549
9550         * ircd/m_clearmode.c (do_clearmode): use the new
9551         mode_invite_clear() function
9552
9553         * ircd/channel.c: cleared up all the compile-time warnings and
9554         errors
9555
9556         * include/channel.h: added declarations for mode_ban_invalidate()
9557         and mode_invite_clear()
9558
9559         * ircd/channel.c: finished mode_parse(), then broke it up into a
9560         dozen or so helper functions to make the code easier to read
9561
9562 2000-03-29  Thomas Helvey <tomh@inxpress.net>
9563         * ircd/ircd.c: refactor server initialization a bit, use
9564         getopt for parsing command line, refactor init_sys, main,
9565         and other bits.
9566
9567         * ircd/s_bsd.c: add functions for initialization to clean
9568         up logic a bit and remove duplicated code.
9569
9570         * include/ircd.h: add struct for server process related
9571         variables.
9572
9573 2000-03-29  Kevin L. Mitchell  <klmitch@mit.edu>
9574
9575         * ircd/channel.c: initial definition of mode_parse(); flags to
9576         prevent doing the same thing multiple times; helper method
9577         send_notoper() to send a "Not oper"/"Not on channel" notice
9578
9579         * include/channel.h: declare mode_parse() and helper flags
9580
9581         * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
9582         sending to match the current action of set_mode() closely enough
9583         that hopefully there won't be major conflicts
9584
9585         * ircd/channel.c (modebuf_flush_int): consolidated the mode string
9586         building logic, reversed the order of the arguments to mode
9587         commands to have '-' preceed '+'
9588
9589 2000-03-29  Thomas Helvey <tomh@inxpress.net>
9590         * ircd/s_bsd.c (add_connection): don't disable socket options
9591         let OS tune itself and allow important performance tweaks to 
9592         work.
9593
9594 2000-03-28  Kevin L. Mitchell  <klmitch@mit.edu>
9595
9596         * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
9597         confused by set_mode, which is doing some really weird logic;
9598         guess what I'm going to rewrite next?  ;)
9599
9600 2000-03-28  Kevin L. Mitchell  <klmitch@emc.com>
9601
9602         * include/channel.h: added MODE_SAVE for the bounds checking stuff
9603         in modebuf_flush
9604
9605         * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
9606         make it do bounds checking on the buffer; all modes are sent only
9607         if the all parameter is 1; modebuf_flush is the exported wrapper
9608
9609         * include/channel.h: add BOUNCE, renumber flags to get a little
9610         more space
9611
9612         * ircd/channel.c (modebuf_flush): don't overload HACK2, add
9613         BOUNCE; send DESYNCH message
9614
9615 2000-03-27  Kevin L. Mitchell  <klmitch@emc.com>
9616
9617         * ircd/m_clearmode.c (do_clearmode): only mark the modes the
9618         channel actually has in effect for deletion
9619
9620         * ircd/channel.c: added explanatory comments to all added
9621         functions; made flushing take place at the correct place even if
9622         the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
9623         to bash some stupid bugs; made modebuf_flush() return if ModeBuf
9624         is empty, fixed the apparent source, removed some bogus string
9625         termination code, properly terminate the mode strings, add support
9626         for HACK2 and HACK3, made limit strings not be sent if the limit
9627         is being removed, changed where '+' and '-' come from in sent
9628         strings, added support for DEOP flag, set up bouncing code for
9629         HACK2
9630
9631         * ircd/Makefile.in: ran make depend
9632
9633         * include/channel.h: added new defines for future functionality,
9634         made modebuf_flush() return int so I can use tail recursion
9635
9636         * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
9637         to make it all compile
9638
9639         * ircd/m_opmode.c: add msg.h to includes...
9640
9641         * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
9642
9643         * ircd/channel.c (modebuf_flush): realized I forgot to
9644         nul-terminate addbuf/rembuf properly...
9645
9646         * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
9647
9648         * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
9649         sendto_serv_butone--blah^2
9650
9651         * ircd/send.c (sendto_serv_butone): stupid comments confused me
9652
9653         * ircd/channel.c (modebuf_flush): if there are no mode changes to
9654         propagate, we're done...
9655
9656         * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
9657         not sendto_all_butone
9658
9659         * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
9660
9661         * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
9662
9663         * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
9664         the list
9665
9666         * ircd/parse.c: added messages for opmode and clearmode
9667
9668         * include/handlers.h: added declarations for mo_opmode(),
9669         ms_opmode(), mo_clearmode(), and ms_clearmode()
9670
9671         * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
9672         TOK_CLEARMODE
9673
9674         * include/channel.h (MODEBUF_DEST_OPMODE): Define the
9675         MODEBUF_DEST_OPMODE flag
9676
9677         * ircd/channel.c (modebuf_flush): added new flag,
9678         MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
9679         to originate from source's server (or source itself, if
9680         IsServer(source)); also causes a server-level MODE to be sent as
9681         OPMODE instead
9682
9683         * include/channel.h: defined MODEBUF_DEST_SERVER,
9684         MODEBUF_DEST_HACK4
9685
9686         * ircd/channel.c: Add another argument to build_string() to handle
9687         numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
9688         servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
9689         to be sent out
9690
9691 2000-03-27  Perry Lorier <isomer@coders.net>
9692
9693         * ircd/s_bsd.c: fixed missing 'u' typo.
9694
9695 2000-03-26  Kevin L. Mitchell  <klmitch@emc.com>
9696
9697         * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
9698         _mode_string(), _mode_client(), _flush(); also implemented a
9699         simple build_string()
9700
9701         * include/channel.h: added definition of ModeBuf, modebuf_*
9702         manipulation functions, and a couple of helper macros
9703