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