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