Author: jv <unknown>
[ircu2.10.12-pk.git] / ChangeLog
1 2001-06-29  Kevin L. Mitchell  <klmitch@mit.edu>
2
3         * ircd/s_user.c (set_user_mode): clear the snomask if the user
4         isn't supposed to receive server notices anymore
5
6         * ircd/ircd_features.c: change CONFIG_OPERCMDS to default to FALSE
7
8         * configure.in: use AC_MSG_CHECKING/AC_MSG_RESULT when checking
9         installation prefix; default devpoll and kqueue to on (they get
10         turned off if the required headers aren't present)
11
12         * ircd/whocmds.c (do_who): use ircd_snprintf() instead of
13         sprintf_irc(); it's a bit hackish, but it'll do for now
14
15         * ircd/support.c: remove unused #include
16
17         * ircd/send.c: remove unused #include
18
19         * ircd/s_user.c: use ircd_snprintf() instead of sprintf_irc()
20
21         * ircd/s_serv.c: remove unused #include
22
23         * ircd/s_misc.c: use ircd_snprintf() and friends instead of
24         sprintf_irc() and friends
25
26         * ircd/s_err.c: moved atoi_tab[] from ircd/sprintf_irc.c to
27         ircd/s_err.c, which is the only other file to refer to it
28
29         * ircd/s_conf.c (conf_add_deny): use ircd_snprintf() instead of
30         sprintf_irc()
31
32         * ircd/s_bsd.c (connect_server): use ircd_snprintf() instead of
33         sprintf_irc()
34
35         * ircd/s_auth.c: use ircd_snprintf() instead of sprintf_irc()
36
37         * ircd/res.c: use ircd_snprintf() instead of sprintf_irc()
38
39         * ircd/m_version.c: use ircd_snprintf() instead of sprintf_irc()
40
41         * ircd/m_kill.c: use ircd_snprintf() instead of sprintf_irc()
42
43         * ircd/listener.c: use ircd_snprintf() instead of sprintf_irc()
44
45         * ircd/gline.c: use ircd_snprintf() instead of sprintf_irc()
46
47         * ircd/channel.c: don't include sprintf_irc.h; use ircd_snprintf()
48         instead of sprintf_irc()
49
50         * ircd/Makefile.in: remove sprintf_irc.c from sources list; run
51         make depend
52
53         * include/ircd_string.h: remove declaration of sprintf_irc() (what
54         was it doing here anyway?)
55
56         * include/sprintf_irc.h: removed unneeded source file
57
58         * ircd/sprintf_irc.c: removed unneeded source file
59
60         * ircd/s_debug.c (count_memory): remove some dead code
61
62         * ircd/s_auth.c: remove some dead code
63
64         * ircd/res.c (update_list): remove some dead code
65
66         * ircd/m_whowas.c: remove some dead code
67
68         * ircd/m_whois.c: remove some dead code
69
70         * ircd/m_who.c: remove some dead code
71
72         * ircd/m_wallusers.c: remove some dead code
73
74         * ircd/m_wallops.c: remove some dead code
75
76         * ircd/m_wallchops.c: remove some dead code
77
78         * ircd/m_version.c: remove some dead code
79
80         * ircd/m_userip.c: remove some dead code
81
82         * ircd/m_userhost.c: remove some dead code
83
84         * ircd/m_uping.c: remove some dead code
85
86         * ircd/m_trace.c: remove some dead code
87
88         * ircd/m_topic.c: remove some dead code
89
90         * ircd/m_tmpl.c: remove some dead code
91
92         * ircd/m_time.c: remove some dead code
93
94         * ircd/m_squit.c: remove some dead code
95
96         * ircd/m_silence.c: remove some dead code
97
98         * ircd/m_settime.c: remove some dead code
99
100         * ircd/m_set.c: remove some dead code
101
102         * ircd/m_server.c: remove some dead code
103
104         * ircd/m_rpong.c: remove some dead code
105
106         * ircd/m_rping.c: remove some dead code
107
108         * ircd/m_restart.c: remove some dead code
109
110         * ircd/m_reset.c: remove some dead code
111
112         * ircd/m_rehash.c: remove some dead code
113
114         * ircd/m_quit.c: remove some dead code
115
116         * ircd/m_proto.c: remove some dead code
117
118         * ircd/m_privs.c: remove some dead code
119
120         * ircd/m_privmsg.c: remove some dead code
121
122         * ircd/m_pong.c: remove some dead code
123
124         * ircd/m_ping.c: remove some dead code
125
126         * ircd/m_pass.c: remove some dead code
127
128         * ircd/m_part.c: remove some dead code
129
130         * ircd/m_opmode.c: remove some dead code
131
132         * ircd/m_oper.c: remove some dead code
133
134         * ircd/m_notice.c: remove some dead code
135
136         * ircd/m_nick.c: remove some dead code
137
138         * ircd/m_map.c: remove some dead code
139
140         * ircd/m_lusers.c: remove some dead code
141
142         * ircd/m_list.c: remove some dead code
143
144         * ircd/m_links.c: remove some dead code
145
146         * ircd/m_kill.c: remove some dead code
147
148         * ircd/m_kick.c: remove some dead code
149
150         * ircd/m_jupe.c: remove some dead code
151
152         * ircd/m_join.c: remove some dead code
153
154         * ircd/m_ison.c: remove some dead code
155
156         * ircd/m_invite.c: remove some dead code
157
158         * ircd/m_info.c: remove some dead code
159
160         * ircd/m_help.c: remove some dead code
161
162         * ircd/m_gline.c: remove some dead code
163
164         * ircd/m_get.c: remove some dead code
165
166         * ircd/m_error.c: remove some dead code
167
168         * ircd/m_endburst.c: remove some dead code
169
170         * ircd/m_die.c: remove some dead code
171
172         * ircd/m_desynch.c: remove some dead code
173
174         * ircd/m_destruct.c: remove some dead code
175
176         * ircd/m_defaults.c: remove some dead code
177
178         * ircd/m_create.c: remove some dead code, along with an #if 1
179
180         * ircd/m_cprivmsg.c: remove some dead code
181
182         * ircd/m_connect.c: remove some dead code
183
184         * ircd/m_close.c: remove some dead code
185
186         * ircd/m_clearmode.c: remove some dead code
187
188         * ircd/m_burst.c: remove some dead code
189
190         * ircd/m_away.c: remove some dead code
191
192         * ircd/m_admin.c: remove some dead code
193
194         * ircd/listener.c (accept_connection): remove some dead code
195
196         * ircd/ircd_reply.c (need_more_params): remove some dead code
197
198         * ircd/channel.c (add_banid): remove some dead code
199
200         * include/support.h: remove some dead code
201
202         * include/querycmds.h: remove some dead code
203
204         * doc/readme.chroot: document how to do chroot operation
205
206 2001-06-28  Kevin L. Mitchell  <klmitch@mit.edu>
207
208         * ircd/Makefile.in: tune for VPATH builds/installs; add a rule to
209         force bin directory to be created if necessary prior to
210         installation; run make depend
211
212         * doc/Makefile.in (install): tune for VPATH installs by cd'ing to
213         the ${srcdir}
214
215         * Makefile.in: tune to detect Makefile.in changes in
216         subdirectories and to create installation directory indicated by
217         ${prefix}
218
219         * ircd/whocmds.c (count_users): routine to count the number of
220         users matching a given user@host mask
221
222         * ircd/s_err.c: add error messages for ERR_LONGMASK,
223         ERR_TOOMANYUSERS, and ERR_MASKTOOWIDE
224
225         * ircd/m_gline.c: look for and advance past '!' flag on G-lines
226         from operators; only set GLINE_OPERFORCE flag if oper has the
227         PRIV_WIDE_GLINE privilege
228
229         * ircd/ircd_features.c: add GLINEMAXUSERCOUNT, which is the
230         maximum number of users a G-line can impact before it has to be
231         forced; OPER_WIDE_GLINE, to allow operators to use ! to force a
232         wide G-line to be set; and LOCOP_WIDE_GLINE, to allow local
233         operators to use ! to force a wide G-line to be set
234
235         * ircd/gline.c: make make_gline() be called with separate user and
236         host arguments, and not call canon_userhost() directly; implement
237         gline_checkmask() to verify that a host mask is acceptable; move
238         BADCHAN check up in gline_add(), and check passed-in mask under
239         certain circumstances for acceptability; fix call to
240         sendto_opmask_butone() to handle separation of userhost into user
241         and host in gline_add(); update call to make_gline()
242
243         * ircd/client.c: use FEAT_OPER_WIDE_GLINE and
244         FEAT_LOCOP_WIDE_GLINE to set PRIV_WIDE_GLINE for an operator; add
245         PRIV_WIDE_GLINE to privtab[] for client_report_privs()
246
247         * include/whocmds.h (count_users): declare routine to count users
248         matching a given user@host mask
249
250         * include/numeric.h: added three new error returns: ERR_LONGMASK
251         -- mask can't be formatted into a buffer; ERR_TOOMANYUSERS -- too
252         many users would be impacted by the mask; ERR_MASKTOOWIDE -- mask
253         contains wildcards in the wrong places
254
255         * include/ircd_features.h: add FEAT_GLINEMAXUSERCOUNT,
256         FEAT_OPER_WIDE_GLINE, and FEAT_LOCOP_WIDE_GLINE
257
258         * include/gline.h (GLINE_OPERFORCE): provides a way for m_gline()
259         to signal to gline_add() that the operator attempted to force the
260         G-line to be set
261
262         * include/client.h (PRIV_WIDE_GLINE): new privilege for operators
263
264         * doc/readme.gline: update to document new "!" prefix to a G-line
265         user@host mask
266
267         * doc/readme.features: document GLINEMAXUSERCOUNT,
268         OPER_WIDE_GLINE, and LOCOP_WIDE_GLINE
269
270         * doc/example.conf: update to mention new features along with
271         their defaults
272
273 2001-06-27  Kevin L. Mitchell  <klmitch@mit.edu>
274
275         * doc/example.conf: updated example.conf from Braden
276         <dbtem@yahoo.com>
277
278         * include/supported.h: forward-port from pl15
279
280 2001-06-25  Kevin L. Mitchell  <klmitch@mit.edu>
281
282         * ircd/whocmds.c: include ircd_policy.h and implement
283         HEAD_IN_SAND_WHO_OPCOUNT--forward-port from pl15
284
285         * ircd/m_whois.c: forward-port of the idle-time hiding code from
286         pl15; this also required passing parc into do_whois(), which also
287         meant passing parc into do_wilds()--*sigh*
288
289         * include/ircd_policy.h: add a couple more HEAD_IN_SAND
290         #define's--WHOIS_IDLETIME and WHO_HOPCOUNT
291
292 2001-06-22  Kevin L. Mitchell  <klmitch@mit.edu>
293
294         * tools/wrapper.c: add a wrapper program that can be used to
295         adjust file descriptor limits and root directories; program must
296         be run as root--NOT SETUID!--and given appropriate -u arguments
297
298         * doc/readme.log: documentation of how to configure logging
299
300         * doc/readme.features: documentation of each feature (except for
301         logging)
302
303 2001-06-21  Kevin L. Mitchell  <klmitch@mit.edu>
304
305         * Makefile.in (config): add a deprecation notice with a pointer to
306         tools/transition
307
308         * tools/transition: shell script to convert old compile-time
309         options into new compile-time options and appropriate F-lines
310
311         * tools/mkchroot: shell-script to prepare the chroot area by
312         copying over all the necessary libraries so they can be found
313
314 2001-06-20  Kevin L. Mitchell  <klmitch@mit.edu>
315
316         * INSTALL: partial update of INSTALL for u2.10.11 release...
317
318 2001-06-14  Kevin L. Mitchell  <klmitch@mit.edu>
319
320         * ircd/table_gen.c (makeTables): finally got tired of the
321         "overflow in implicit conversion" warning, so just got rid of it
322         by explicitly casting UCHAR_MAX to a (default) char; diffs show no
323         differences in the tables generated
324
325 2001-06-11  Kevin L. Mitchell  <klmitch@mit.edu>
326
327         * ircd/send.c (sendcmdto_match_butone): don't let the server crash
328         if a client is in the STAT_CONNECTING status
329
330 2001-06-10  Kevin L. Mitchell  <klmitch@mit.edu>
331
332         * ircd/send.c: remove unused vsendcmdto_one(), consolidating it
333         into sendcmdto_one(); define new sendcmdto_prio_one(), which
334         places the message into the priority queue
335
336         * ircd/s_user.c (hunt_server_prio_cmd): definition of
337         hunt_server_prio_cmd(), which simply calls sendcmdto_prio_one()
338         instead of sendcmdto_one()
339
340         * ircd/m_settime.c: use sendcmdto_prio_one() and
341         hunt_server_prio_cmd() to send SETTIME
342
343         * ircd/m_server.c: use sendcmdto_prio_one() to send SETTIME
344
345         * include/send.h: removed declaration for unused vsendcmdto_one();
346         added a declaration for sendcmdto_prio_one()
347
348         * include/s_user.h: declare hunt_server_prio_cmd(), which calls
349         sendcmdto_prio_one()
350
351         * ircd/send.c (sendcmdto_flag_butone): oops; /wallops should be
352         put in the server's priority queue, too...
353
354         * ircd/ircd.c: don't check LPATH for accessibility at all
355
356 2001-06-08  Kevin L. Mitchell  <klmitch@mit.edu>
357
358         * ircd/s_serv.c (server_estab): send a +h flag in our SERVER
359         command if we're configured as a hub; send individual server flags
360         in SERVER commands
361
362         * ircd/s_bsd.c (completed_connection): send a +h flag in our
363         SERVER command if we're configured as a hub
364
365         * ircd/m_server.c: implement parv[7] as a mode-like string; +h
366         sets the FLAGS_HUB flag for a server; +s sets the FLAGS_SERVICE
367         flag for a server; +hs sets both flags; also modify CMD_SERVER
368         format string to send the flags
369
370         * include/client.h: define two new flags, FLAGS_HUB and
371         FLAGS_SERVICE to mark services and hubs as such; define testing
372         macros, setting macros
373
374         * ircd/s_user.c: remove deprecated struct Gline* argument to
375         register_user(); remove GLINE rebroadcast; do not send GLINE
376         acknowledgement parameter to NICK; do not look for GLINE
377         acknowledgement parameter to NICK while parsing
378
379         * ircd/s_serv.c (server_estab): remove deprecated struct Jupe*
380         argument to server_estab(); do not send JUPE/GLINE acknowledgement
381         parameters for SERVER or NICK
382
383         * ircd/m_user.c (m_user): remove deprecated argument to
384         register_user()
385
386         * ircd/m_server.c: remove deprecated argument to server_estab();
387         remove documentation comment regarding JUPE acknowledgement
388         parameter to SERVER; remove JUPE rebroadcast
389
390         * ircd/m_pong.c (mr_pong): remove deprecated argument to
391         register_user()
392
393         * ircd/m_nick.c: remove documentation comment regarding GLINE
394         acknowledgement parameter to NICK
395
396         * ircd/jupe.c: use user's real name in JUPE server notices if
397         HEAD_IN_SAND_SNOTICES is defined
398
399         * ircd/ircd.c: remove deprecated chroot() code; remove deprecated
400         setuid code; correct ancient DEBUG vs DEBUGMODE typo
401
402         * ircd/gline.c: use user's real name in GLINE server notices if
403         HEAD_IN_SAND_SNOTICES is defined
404
405         * ircd/channel.c (modebuf_flush_int): make apparent source be
406         local server, not oper's server; use user's real name in hack
407         notices and DESYNC notices if HEAD_IN_SAND_SNOTICES is defined
408
409         * include/s_user.h: remove struct Gline pre-declaration; remove
410         deprecated struct Gline argument from register_user()
411
412         * include/s_serv.h: remove struct Jupe pre-declaration; remove
413         deprecated struct Jupe argument from server_estab()
414
415 2001-06-07  Kevin L. Mitchell  <klmitch@mit.edu>
416
417         * ircd/s_stats.c (hunt_stats): forward-port from pl15 of all the
418         changes required to control remote stats
419
420         * ircd/s_numeric.c (do_numeric): rewrite numeric origins if
421         recipient is not an operator and HEAD_IN_SAND_REWRITE is defined
422         [forward-port from pl15]
423
424         * ircd/m_whowas.c (m_whowas): report server name only if requester
425         is an operator [forward-port from pl15]
426
427         * ircd/m_whois.c (do_whois): /whois <mynick> now correctly reports
428         my server; if HEAD_IN_SAND_REMOTE is 1, ignore the middle argument
429         and obtain the report from the user's server [forward-port from
430         pl15]
431
432         * ircd/m_who.c: add missing include for ircd_policy.h
433         [forward-port from pl15]
434
435         * ircd/m_version.c (m_version): require oper access for remote
436         /version if HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
437
438         * ircd/m_time.c (m_time): require oper access for remote /time if
439         HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
440
441         * ircd/m_stats.c: pass extra argument to hunt_stats(); correct
442         missing semicolon [forward-port from pl15]
443
444         * ircd/m_nick.c (ms_nick): hide the origin of certain collision
445         kills [forward-port from pl15]
446
447         * ircd/m_motd.c (m_motd): require oper access for remote /motd if
448         HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
449
450         * ircd/m_lusers.c (m_lusers): require oper access for remote
451         /lusers if HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
452
453         * ircd/m_burst.c (ms_burst): server-added bans are stored using
454         local server name, to hide remote server names; modes also are to
455         originate from the local server [forward-port from pl15]
456
457         * ircd/m_admin.c (m_admin): require oper access for remote /admin
458         if HEAD_IN_SAND_REMOTE is 1 [forward-port from pl15]
459
460         * ircd/channel.c (add_banid): if a server is adding a ban, use my
461         server name to hide the remote server's name [forward-port from
462         pl15]
463
464         * ircd/Makefile.in: ran make depend
465
466         * include/s_stats.h: hunt_stats() has to have an extra argument to
467         support the forward-port from pl15
468
469         * include/ircd_policy.h: #define HEAD_IN_SAND_STATS_P; add
470         HEAD_IN_SAND_{BANWHO,REWRITE,REMOTE} [forward-port from pl15]
471
472         * ircd/engine_poll.c (engine_loop): remove bogus assert that I
473         forgot to check in the events branch
474
475 2001-06-06  Kevin L. Mitchell  <klmitch@mit.edu>
476
477         * ircd/res.c (init_resolver): don't start DNS expires with a 0
478         relative timeout--if the server starts slow, timeouts could be
479         messy...there's probably a better solution, but this'll do for now
480
481         * ircd/os_solaris.c: _XOPEN_SOURCE doesn't get along with Solaris
482         headers very well; include stropts.h; define an os_set_tos()
483
484         * ircd/os_generic.c (os_set_tos): added an os_set_tos() for
485         os_generic.c
486
487         * ircd/ircd.c: if there are no C-lines, we don't want to have a
488         timer that expires at the absolute time of 0--it kinda blocks all
489         the other timers!
490
491         * ircd/engine_devpoll.c: some includes for open(); declare errcode
492         and codesize in engine_loop()
493
494         * ircd/list.c (free_client): remove bogus check on timer active
495         flag
496
497         * ircd/s_auth.c: pull out destruction code in
498         auth_timeout_request() into an externally-visible
499         destroy_auth_request(); manage cli_auth pointer in client
500         structure; use it for an extra assertion check
501
502         * ircd/list.c: include s_auth.h for destroy_auth_request(); add
503         debugging notices to show flow when deallocating
504         connections/clients; call destroy_auth_request() when free'ing a
505         client that has an auth outstanding; don't free the connection if
506         the process timer is unmarked but still active
507
508         * ircd/ircd_events.c: set GEN_ACTIVE when initializing a generator
509         and reset it before calling the event handler for an ET_DESTROY
510         event
511
512         * include/s_auth.h (destroy_auth_request): declare
513         destroy_auth_request(), which can be used to destroy an
514         outstanding auth request if a client socket goes away before the
515         auth exchange is completed
516
517         * include/ircd_events.h: add an active flag to keep track of
518         whether or not particular generators are active, for the
519         convenience of functions using the API
520
521         * include/client.h: add a pointer for auth requests to struct
522         Connection so we can kill outstanding auth requests if a client
523         socket closes unexpectedly
524
525         * ircd/s_bsd.c: cli_connect() could become 0 during the course of
526         the sock or timer callback; take that into account in the assert
527
528         * ircd/list.c: add magic number checking and setting--magic
529         numbers are zero'd on frees to detect double-frees; add back
530         setting of cli_from() to 0 to break the back-link from the struct
531         Connection (duh)
532
533         * ircd/ircd.c: set me's magic number correctly
534
535         * include/client.h: define magic numbers and accessor/verifier
536         macros
537
538         * ircd/list.c: assert that dealloc_client() is called with
539         cli_connect(cptr) == 0; set cli_connect(cptr) to 0 before calling
540         dealloc_client(); don't mess with cli_from(cptr)
541
542         * ircd/s_bsd.c: only attempt to dealloc a connection if the
543         associated client has already been destroyed, or at least delinked
544
545 2001-06-05  Kevin L. Mitchell  <klmitch@mit.edu>
546
547         * ircd/list.c (free_client): only try to delete the socket when
548         the fd hasn't already been closed, avoiding a double-free
549
550         * ircd/list.c (free_connection): make sure the client is really
551         gone before doing away with the connection
552
553         * ircd/s_bsd.c: record that socket has been added in con_freeflag
554         field; queue a socket_del() as soon as the socket is close()'d;
555         use con_freeflag & FREEFLAG_TIMER instead of con_timer; clear
556         FREEFLAG_SOCKET on ET_DESTROY event in client_sock_callback(),
557         then dealloc the connection if safe; mark socket as dead when
558         there's a read error or EOF; clear FREEFLAG_TIMER flag upon entry
559         to client_timer_callback(); dealloc connection if safe upon
560         ET_DESTROY event in client_timer_callback()
561
562         * ircd/list.c: use con_freeflag instead of con_timer; only dealloc
563         the connection if both socket and timer have been destroyed;
564         destroy both socket and timer explicitly and carefully
565
566         * include/client.h: replace the con_timer field with a
567         con_freeflag field, to indicate what still needs freeing; define
568         the freeflags
569
570         * ircd/engine_select.c (engine_loop): duh...sockList[i] could
571         become 0
572
573         * ircd/engine_devpoll.c (engine_loop): duh...sockList[i] could
574         become 0
575
576         * ircd/s_bsd.c: add some extra assertions to try to track down a
577         corruption problem
578
579         * ircd/engine_select.c (engine_loop): add an extra assert to try
580         to track down a corruption problem
581
582         * ircd/engine_poll.c (engine_loop): add an extra assert to try to
583         track down a corruption problem
584
585         * ircd/engine_kqueue.c (engine_loop): add an extra assert to try
586         to track down a corruption problem
587
588         * ircd/engine_devpoll.c (engine_loop): skip slots that have become
589         empty during processing; add an extra assert to try to track down
590         a corruption problem
591
592         * ircd/engine_kqueue.c (engine_delete): make sure to zero deleted
593         entries
594
595 2001-06-04  Kevin L. Mitchell  <klmitch@mit.edu>
596
597         * ircd/s_bsd.c (client_sock_callback): client is no longer
598         blocked, so we must mark it as unblocked
599
600         * ircd/engine_select.c: add Debug() calls galore; add handling for
601         SS_NOTSOCK; use a dummy sock variable to keep things from
602         disappearing on us; correct timeout calculation; update nfds for
603         efficiency
604
605         * ircd/engine_poll.c: use new debugging level (DEBUG_ENGINE);
606         remove a spurious "if (sock)" which will always be true; update
607         nfds for efficiency
608
609         * ircd/engine_kqueue.c: add Debug() calls galore; add handling for
610         SS_NOTSOCK (just in case); correct timeout calculation
611
612         * ircd/engine_devpoll.c: add Debug() calls galore; add handling
613         for SS_NOTSOCK; correct timeout calculation; add EAGAIN handling
614
615         * include/s_debug.h (DEBUG_ENGINE): add new debugging level;
616         pretty-indent numbers
617
618         * ircd/engine_poll.c (engine_loop): break out SS_NOTSOCK
619         case--it's not a socket; the check for writability is most likely
620         not needed, but present for completeness
621
622 2001-05-24  Kevin L. Mitchell  <klmitch@mit.edu>
623
624         * ircd/s_bsd.c: add Debug messages; call read_packet() even if the
625         no newline flag is set; call read_packet() when the timer expires,
626         regardless of what's in the buffer--read_packet() should be able
627         to deal properly
628
629         * ircd/IPcheck.c (ip_registry_connect_succeeded): correct a NOTICE
630         sent to clients to include the client nickname (duh)
631
632         * ircd/ircd_events.c: don't destroy a timer if it's already marked
633         for destruction; replace a missing ! in socket_del()
634
635         * ircd/engine_poll.c (engine_loop): reference a temporary variable
636         so we don't have to worry about sockList[i] going away
637
638         * ircd/s_bsd.c (client_sock_callback): add Debug messages
639
640         * ircd/s_auth.c: add Debug messages all over the place
641
642         * ircd/ircd_events.c: add and edit some Debug messages; add a list
643         of routines to convert some of the enums and flags from numbers
644         into human-readable strings for the Debug messages
645
646         * ircd/engine_poll.c: hack some Debug messages to use the new name
647         conversion routines in ircd_events.c; add an extra assert for a
648         condition that shouldn't ever happen; apparently recv() can return
649         EAGAIN when poll() returns readable--I wonder why...
650
651         * include/ircd_events.h: declare some helper routines under
652         DEBUGMODE
653
654 2001-05-23  Kevin L. Mitchell  <klmitch@mit.edu>
655
656         * ircd/s_bsd.c (client_sock_callback): add an extra assertion
657         check
658
659         * ircd/s_auth.c: add more Debug messages
660
661         * ircd/list.c (make_client): add an extra assertion check
662
663         * ircd/ircd_events.c (socket_events): don't call the engine events
664         changer if we haven't actually made any changes to the event mask
665
666         * ircd/uping.c: add some Debug messages
667
668         * ircd/s_stats.c: document new /STATS e
669
670         * ircd/s_err.c: add RPL_STATSENGINE to report the engine name
671
672         * ircd/s_bsd.c: remove static client_timer variable; in
673         read_packet(), if there's still data in the client's recvQ after
674         parsing, add a 2 second timer (con_proc); fix the ET_DESTROY case
675         of client_sock_callback to handle destroying the timer properly;
676         rewrote client_timer_callback from scratch to be called on an
677         individual client
678
679         * ircd/m_stats.c: add /STATS e to report the engine name
680
681         * ircd/list.c: deal with con_timer field in struct Connection
682         properly; correct a core-level bug in remove_client_from_list--if
683         the client is the only one in the list, we try to update
684         GlobalClientList's cli_prev pointer--not good
685
686         * ircd/ircd.c: remove call to init_client_timer()
687
688         * ircd/engine_poll.c: made Debug messages more uniform by
689         prepending "poll:" to them all; corrected an off-by-one error that
690         caused poll_count to be 1 less than the actual count and removed
691         my work-around; added Debug messages to indicate which socket is
692         being checked and what the results are
693
694         * ircd/Makefile.in: ran a make depend
695
696         * include/s_bsd.h: remove init_client_timer(), since we're doing
697         it differently now
698
699         * include/numeric.h (RPL_STATSENGINE): a stats reply to report the
700         engine name
701
702         * include/ircd_policy.h (HEAD_IN_SAND_STATS_E): turn off /stats e
703         reports for non-opers
704
705         * include/client.h: add con_timer and con_proc fields to struct
706         Connection and define accessor macros--con_timer marks that
707         con_proc contains a valid timer, and con_proc is used to pace user
708         data
709
710         * ircd/s_bsd.c (close_connection): let free_client() destroy the
711         socket
712
713         * ircd/s_auth.c (start_auth): add a Debug call to indicate when
714         auth has begun on a client
715
716         * ircd/ircd_events.c: ensure that event_execute() is called with a
717         non-NULL event; modify event_add() macro to properly zero list
718         bits; modify gen_dequeue() to not try to clip it out of a list
719         it's already been clipped out of; change signal socket
720         initialization to use state SS_NOTSOCK; permit timeout values of
721         0 in add_timer(); add many Debug calls; change socket_del() and
722         timer_del() to always set the GEN_DESTROY flag; use GEN_MARKED in
723         timer_run() instead of GEN_DESTROY so that event_generate() will
724         pass on the events; remove the switch and replace with a simpler
725         if-then-else tree in timer_run(); don't allow destroyed sockets to
726         be destroyed again, nor their states or event masks to be changed
727
728         * ircd/ircd.c: initialize "running" to 1
729
730         * ircd/engine_poll.c: deal with SS_NOTSOCK "sockets"; add Debug
731         messages all over the place; fix a counting problem in
732         engine_add(); turn wait into a signed integer and set it to -1
733         only if timer_next() returns 0; adjust wait time to be relative;
734         don't call gen_ref_dec() if socket disappeared while we were
735         processing it
736
737         * include/ircd_events.h: the pipe for signals is not a socket, so
738         we must mark it as such--added SS_NOTSOCK for that special socket;
739         events won't be generated if GEN_DESTROY is on, so add GEN_MARKED
740         for the benefit of timer_run()
741
742         * configure.in: add --enable-pedantic and --enable-warnings to
743         turn on (and off) -Wall -pedantic in CFLAGS
744
745 2001-05-21  Kevin L. Mitchell  <klmitch@mit.edu>
746
747         * ircd/s_conf.c: change "s_addr" element accesses to "address"
748         element accesses
749
750         * include/s_conf.h: on some systems, "s_addr" is a macro; use
751         "address" instead
752
753 2001-05-18  Kevin L. Mitchell  <klmitch@mit.edu>
754
755         * ircd/engine_kqueue.c: include ircd_alloc.h; set_or_clear returns
756         void in this file; add a missing semi-colon; declare errcode,
757         codesize
758
759         * ircd/uping.c (uping_sender_callback): it's pptr, not uping
760
761         * ircd/s_user.c (register_user): comment out spurious reference to
762         nextping
763
764         * ircd/s_serv.c (server_estab): comment out spurious reference to
765         nextping
766
767         * ircd/s_conf.c (read_configuration_file): comment out spurious
768         reference to nextping and nextconnect
769
770         * ircd/s_bsd.c: comment out some spurious references to formerly
771         global (now non-existant) variables; correct a couple of typos
772
773         * ircd/s_auth.c: pre-declare some functions referenced in the
774         callback; correct a typo
775
776         * ircd/res.c (start_resolver): pass errno value of ENFILE
777
778         * ircd/listener.c (accept_connection): you know your API is messed
779         up when...variables that shouldn't have been global crop up in
780         other files
781
782         * ircd/list.c (free_client): substitution of == for =
783
784         * ircd/ircd_signal.c: include assert.h for assertion checking;
785         check ev_data() to find out what signal generated event
786
787         * ircd/ircd_events.c: some references to the variable "timer"
788         should have been references to the variable "ptr"
789
790         * ircd/engine_select.c: it's struct fd_set, not struct fdset;
791         ev_timer(ev) is already a timer pointer; declare codesize as a
792         size_t to correct signedness issue; use timer_next(), not
793         time_next()
794
795         * ircd/engine_poll.c: ev_timer(ev) is already a timer pointer;
796         select fd out of struct pollfd in assertion checking; declare
797         errcode and codesize; use timer_next(), not time_next()
798
799         * ircd/engine_kqueue.c: ev_timer(ev) is already a timer pointer;
800         use function timer_next(), not time_next()
801
802         * ircd/engine_devpoll.c: ev_timer(ev) is already a timer pointer;
803         use function timer_next(), not time_next()
804
805         * ircd/Makefile.in (IRCD_SRC): add ircd_events.c to the list of
806         compiled sources; do make depend
807
808         * include/list.h: pre-declare struct Connection
809
810         * include/ircd_events.h (gen_ref_inc): cast to the right structure
811         name
812
813         * include/s_auth.h: duh; missing */
814
815 2001-05-10  Kevin L. Mitchell  <klmitch@mit.edu>
816
817         * ircd/send.c: update write events status after sending data or
818         accumulating data to be sent
819
820         * ircd/m_list.c (m_list): update write events status after
821         canceling a running /list
822
823         * ircd/channel.c (list_next_channels): update write events status
824         after listing a few channels
825
826         * ircd/s_bsd.c: extensive changes to update to new events model;
827         remove on_write_unblocked() and the two implementations of
828         read_message(), which have been deprecated by this change
829
830         * ircd/s_auth.c: set the socket events we're interested in for
831         clients; simplify some logic that does the connect_nonb followed
832         by the socket_add
833
834         * ircd/list.c: define free_connection() to free a connection
835         that's become freeable once the struct Socket has been
836         deallocated; fix up free_client() to take this new behavior into
837         account
838
839         * ircd/ircd.c: call init_client_timer()
840
841         * include/s_bsd.h: declare new REGISTER_ERROR_MESSAGE when unable
842         to register connect-in-progress with events system; declare
843         init_client_timer() (HACK!) to preserve rate-limiting behavior
844
845         * include/list.h: declare new free_connection()
846
847         * include/client.h: add a struct Socket to struct Connection
848
849 2001-05-09  Kevin L. Mitchell  <klmitch@mit.edu>
850
851         * ircd/ircd_signal.c: massage the handlers for SIGHUP, SIGINT, and
852         SIGTERM into event callbacks; perform the actions in the
853         callbacks, since they're not called in the context of the signal;
854         set up the signal callbacks in the event engine
855
856         * ircd/ircd_events.c (signal_callback): we're supposed to look for
857         a specific signal; don't generate an event if there is no signal
858         structure for it
859
860         * ircd/ircd.c: nuke nextconnect and nextping and replace them with
861         connect_timer and ping_timer; massage try_connections() and
862         check_pings() into timer callbacks that re-add themselves at the
863         right time; remove ircd.c's "event_loop()"; initialize the event
864         system and the connect_timer and ping_timer
865
866         * ircd/uping.c: correct a couple more typos
867
868         * ircd/s_auth.c: rework to use new events system
869
870         * ircd/os_solaris.c (os_connect_nonb): update to new interface
871
872         * ircd/os_openbsd.c (os_connect_nonb): update to new interface
873
874         * ircd/os_linux.c (os_connect_nonb): update to new interface
875
876         * ircd/os_generic.c (os_connect_nonb): update to new interface
877
878         * ircd/os_bsd.c (os_connect_nonb): update to new interface
879
880         * include/s_auth.h: remove deprecated members of struct
881         AuthRequest, replacing them with struct Socket and struct Timer
882         structures; add flags to indicate when these structures have been
883         released by the event system; remove the deprecated
884         timeout_auth_queries()
885
886         * include/ircd_osdep.h (os_connect_nonb): connect could complete
887         immediately, so change the interface to handle that possibility
888
889         * ircd/uping.c (uping_server): noticed and corrected a typo
890
891         * ircd/listener.c: set up to use ircd_event's struct Socket by
892         adding an socket_add() call to inetport(), replacing
893         free_listener() with socket_del() in close_listener(), and
894         reworking accept_connection to be called as the callback
895
896         * ircd/ircd.c: add a call to IPcheck_init()
897
898         * ircd/IPcheck.c: remove IPcheck_expire(); rework
899         ip_registry_expire() to be called from a timer; write
900         IPcheck_init() to set up the expiration timer (hard-coded for a
901         60-second expiration time)
902
903         * include/listener.h: add a struct Socket to the struct Listener;
904         remove accept_connection()
905
906         * include/IPcheck.h: add IPcheck_init(), remove IPcheck_expire()
907
908 2001-05-08  Kevin L. Mitchell  <klmitch@mit.edu>
909
910         * ircd/ircd_events.c: include config.h; use USE_KQUEUE and
911         USE_DEVPOLL instead of HAVE_KQUEUE and HAVE_DEVPOLL_H
912
913         * ircd/engine_select.c: include config.h; set FD_SETSIZE to
914         MAXCONNECTIONS, not IRCD_FD_SETSIZE...
915
916         * ircd/engine_poll.c: include config.h
917
918         * ircd/engine_kqueue.c: include config.h
919
920         * ircd/engine_devpoll.c: include config.h
921
922         * ircd/Makefile.in: include engine sources in compilation and make
923         depend steps
924
925         * configure.in: add checks for enabling the /dev/poll- and
926         kqueue-based engines
927
928         * acconfig.h: add lines for USE_DEVPOLL and USE_KQUEUE
929
930         * ircd/Makefile.in: work in the engine sources
931
932 2001-05-07  Kevin L. Mitchell  <klmitch@mit.edu>
933
934         * ircd/m_settime.c: include ircd_snprintf.h
935
936         * ircd/ircd_relay.c: stomp a couple of gcc warnings suggesting
937         parens around a construct that had both || and &&
938
939         * ircd/chkconf.c: #include "config.h" to get some important
940         definitions
941
942         * ircd/Makefile.in: revamp ircd makefile for new build system
943
944         * doc/Makefile.in: revamp doc makefile for new build system
945
946         * config/*: Removed old build system files
947
948         * stamp-h.in: a stamp file
949
950         * install-sh: install-sh for new build system
951
952         * configure.in: configure.in for new build system
953
954         * configure: configure script for new build system (built by
955         autoconf)
956
957         * config.sub: config.sub for new build system
958
959         * config.h.in: config.h.in for new build system (built by
960         autoheader)
961
962         * config.guess: config.guess for new build system
963
964         * aclocal.m4: aclocal.m4 for new build system (built by aclocal
965         1.4)
966
967         * acinclude.m4: aclocal.m4 macros for new build system
968
969         * acconfig.h: config.h skeleton for new build system
970
971         * Makefile.in: modify for new build system
972
973 2001-05-01  Kevin L. Mitchell  <klmitch@mit.edu>
974
975         * ircd/s_err.c: get rid of the last vestiges of TIME_T_FMT
976
977         * ircd/m_settime.c: get rid of the last vestiges of TIME_T_FMT
978
979         * ircd/m_server.c: get rid of the last vestiges of TIME_T_FMT
980
981 2001-05-01  Perry Lorier       <Isomer@coders.net>
982         * doc/iauth.doc: Protocol for iauth server. (from hybrid).
983         * doc/linux-poll.patch: Patch to make Linux under 2.2 not deadlock
984                 when you have far far too many sockets in use.
985         * {include,ircd}/iauth.c: A start on iauth support.
986
987 2001-05-01  Perry Lorier       <Isomer@coders.net>
988         * ircd/s_err.c: Suggested wording change.
989         * ircd/s_user.c: Users aren't target limited against +k users.
990         * ircd/chkconf.c: Made it compile again, who knows if it works, but
991                 now I can at least make install
992         * various: Cleanups on m_*.c files.
993
994
995 2001-04-23  Kevin L. Mitchell  <klmitch@mit.edu>
996
997         * ircd/s_misc.c (exit_client): make netsplit server notice say the
998         right thing
999
1000         * ircd/m_links.c (m_links_redirect): forward-port RPL_ENDOFLINKS
1001         change to make Khaled happy...
1002
1003         * ircd/m_whois.c (do_whois): pull-up of m_whois() fix
1004         (do_whois): duh...
1005
1006 2001-04-21  Kevin L. Mitchell  <klmitch@mit.edu>
1007
1008         * ircd/msgq.c: finally remove the msgq_integrity() hack, as it's
1009         turned up no more bugs
1010
1011         * ircd/ircd.c: use /* */ comments instead of // comments--all the
1012         world's not gcc :(
1013
1014         * ircd/s_conf.c (conf_add_server): use /* */ comments instead of
1015         // comments--all the world's not gcc :(
1016
1017         * ircd/runmalloc.c: finally garbage-collect unused file
1018
1019         * include/runmalloc.h: finally garbage-collect unused file
1020
1021         * ircd/<multiple files>: addition of '#include "config.h"' before
1022         all other includes in most .c files
1023
1024         * include/<multiple files>: remove includes of config.h, which are
1025         now going into the raw .c files
1026
1027 2001-04-20  Kevin L. Mitchell  <klmitch@mit.edu>
1028
1029         * ircd/m_whois.c (do_whois): display proper server name if the
1030         user is looking up himself
1031
1032         * ircd/m_who.c (m_who): disable match by servername or display of
1033         server names by non-opers
1034
1035         * include/ircd_policy.h: add define for
1036         HEAD_IN_SAND_WHO_SERVERNAME to cover full intent of sub-motion 15
1037         of CFV 165
1038
1039 2001-04-18  Kevin L. Mitchell  <klmitch@mit.edu>
1040
1041         * ircd/s_conf.c: keep the $R in memory so we can see it clearly
1042         when we do a /stats k
1043
1044         * ircd/s_user.c (set_user_mode): pull-up of changes to prevent
1045         users from turning on +s and +g
1046
1047         * ircd/s_misc.c (exit_client): pull-up of changes to turn off
1048         net.split notice
1049
1050         * ircd/parse.c: pull-up of changes to disable /trace, /links, and
1051         /map for users
1052
1053         * ircd/m_whois.c (do_whois): pull-up of server name masking for
1054         /whois
1055
1056         * ircd/m_user.c (m_user): removal of umode and snomask defaulting
1057         functions, pull-up
1058
1059         * ircd/m_stats.c (m_stats): pull-up of stats-disabling stuff
1060
1061         * ircd/m_map.c (m_map_redirect): pull-up of m_map_redirect()
1062
1063         * ircd/m_links.c (m_links_redirect): pull-up of m_links_redirect()
1064
1065         * ircd/channel.c (channel_modes): pull-up of channel key display
1066         as *
1067
1068         * include/ircd_policy.h: pull-up of ircd_policy.h
1069
1070         * include/client.h: pull-up of Set/ClearServNotice()
1071
1072         * ircd/gline.c (do_gline): report client name in G-line message
1073         (pull-up)
1074
1075         * ircd/s_user.c (register_user): pull-up--show IP address in some
1076         server notices dealing only with users; report which connection
1077         class has filled up
1078
1079         * ircd/s_stats.c (report_deny_list): use conf->flags &
1080         DENY_FLAGS_IP insteaf of conf->ip_kill
1081
1082         * ircd/m_stats.c (report_klines): use conf->flags & DENY_FLAGS_IP
1083         insteaf of conf->ip_kill
1084
1085         * ircd/s_conf.c: use flags field in struct DenyConf; pull-up of
1086         K-line by real name
1087
1088         * include/s_conf.h: use a flags field in struct DenyConf; define
1089         DENY_FLAGS_FILE, DENY_FLAGS_IP, and DENY_FLAGS_REALNAME for
1090         pull-up of K-line by real name
1091
1092         * ircd/m_trace.c: pull-up of IP show for user connections
1093
1094         * doc/example.conf: pull-up of the realname K-line documentation
1095
1096         * ircd/ircd.c: forward port of pid file advisory locking mechanism
1097
1098 2001-04-16  Kevin L. Mitchell  <klmitch@mit.edu>
1099
1100         * ircd/send.c (sendcmdto_flag_butone): recast to just broadcast to
1101         all servers, rather than to only servers that have +w/+g/whatever
1102         users on them; among other things, this removes that atrocity
1103         known as sentalong[] from this function
1104
1105         * ircd/m_admin.c: must include ircd.h to declare "me"; must
1106         include hash.h to declare FindUser()
1107
1108         * ircd/m_wallusers.c: implementation of WALLUSERS
1109
1110         * ircd/m_desynch.c (ms_desynch): only send DESYNCHs to opers
1111
1112         * ircd/m_wallops.c: only send WALLOPS to opers
1113
1114         * ircd/parse.c: add WALLUSERS command to parser table
1115
1116         * include/handlers.h: declare wallusers handlers
1117
1118         * include/msg.h: add WALLUSERS command
1119
1120         * ircd/send.c (sendcmdto_flag_butone): if FLAGS_OPER is or'd with
1121         flag, send only to appropriate opers
1122
1123 2001-04-13  Kevin L. Mitchell  <klmitch@mit.edu>
1124
1125         * ircd/uping.c: refit to use the new events interface
1126
1127         * ircd/res.c: refit to use the new events interface
1128
1129         * ircd/ircd_events.c: create timer_chg(), which permits a
1130         (non-periodic) timer's expire time to be modified; change the
1131         logic in timer_run() so that timers that were re-added while the
1132         event was being processed will not be destroyed prematurely
1133
1134         * include/uping.h: include the events header, declare some extra
1135         fields in struct UPing, remove timeout value, and define some
1136         flags for marking which cleanup items have yet to be done
1137
1138         * include/ircd_events.h: add a prototype for timer_chg() to change
1139         the expire time of a running timer
1140
1141 2001-03-13 Joseph Bongaarts <foxxe@wtfs.net>
1142         * ircd/os_openbsd.c: Tweaked the openbsd hack a bit.
1143         
1144 2001-03-07  Joseph Bongaarts  <foxxe@wtfs.net>
1145
1146         * config/configure.in: Add check for OpenBSD
1147
1148         * ircd/os_openbsd.c: Add seperate os dep file for openbsd which
1149         differs from generic BSD, particularly in its handling of
1150         _XOPEN_SOURCE.
1151         
1152 2001-02-12  Kevin L. Mitchell  <klmitch@mit.edu>
1153
1154         * ircd/m_gline.c (ms_gline): propagate a G-line that happened to
1155         have been added by a U-lined server, rather than going through the
1156         activate/deactivate logic; propagate G-line removals by U-lined
1157         servers as well
1158
1159         * ircd/gline.c: rename propagate_gline() to gline_propagate();
1160         make gline_propagate() return an int 0 (convenience return); only
1161         update lastmod in gline_activate() and gline_deactivate() if the
1162         current lastmod is non-zero, since 0 lastmod is our flag of a
1163         U-lined server having added a G-line
1164
1165         * include/gline.h (gline_propagate): exporting the G-line
1166         propagation function
1167
1168         * ircd/m_list.c (m_list): duh; permit explicit channel name
1169         specification only when /list gets two arguments ("Kev
1170         #wasteland") rather than when /list gets more than two
1171         arguments--nice braino
1172
1173 2001-01-29  Thomas Helvey <twhelvey1@home.com>
1174
1175         * ircd/ircd_reply.c (need_more_params): fix bug that allowed
1176         unregistered clients to spam opers with protocol violation
1177         messages. Note: the bugfix may have eliminated some useful
1178         protocol violation messages.
1179         Please send protocol violation messages explicitly from the
1180         functions they are discovered in, you have much better context
1181         for the error there and it helps to document the behavior of the
1182         server. This was also a design bug in that it violated the
1183         "A function should do one thing" heuristic. Patching this one
1184         would have resulted in a continuous spawning of other bugs over
1185         the next 3 years, so I killed it. Check around for stuff this
1186         broke and readd the calls to protocol_violation in the functions
1187         that need to send the message.
1188
1189 2001-01-29  Kevin L. Mitchell  <klmitch@mit.edu>
1190
1191         * ircd/channel.c (mode_parse_ban): stopper a tiny leak--if a ban
1192         already existed, then the logic would (attempt to) skip it, but
1193         would not free the ban string; now the ban string is free'd and
1194         the ban count is decremented, releasing the ban for use
1195
1196         * ircd/s_user.c: make send_umode_out() take a prop argument
1197         instead of testing for the PRIV_PROPAGATE privilege itself; fix
1198         set_umode() to use this new argument, calculating it before
1199         calculating the new privileges for a -o'd user
1200
1201         * ircd/m_oper.c (m_oper): pass the new prop argument to
1202         send_umode_out()
1203
1204         * ircd/channel.c (mode_parse_ban): turn off MODE_ADD bit in bans
1205         that we're not actually going to add because they already exist;
1206         test that particular bit before adding to the linked list
1207
1208         * include/s_user.h: add a prop argument to send_umode_out() to
1209         indicate whether or not to propagate the user mode
1210
1211 2001-01-24  Kevin L. Mitchell  <klmitch@mit.edu>
1212
1213         * ircd/msgq.c: ircd_vsnprintf() returns the number of bytes that
1214         it would have written; upper-bound the number to prevent overflows
1215         by proxy; also, tune buffer size given to ircd_vsnprintf() to take
1216         into account the fact that ircd_vsnprintf() already takes the
1217         terminal \0 into account
1218
1219 2001-01-22  Kevin L. Mitchell  <klmitch@mit.edu>
1220
1221         * ircd/msgq.c: add an incredibly ugly hack to attempt to track
1222         down an apparent buffer overflow; remove msgq_map(), since it's no
1223         longer used anywhere; slight tweaks to prevent off-by-one errors,
1224         but these can't explain the problems we've seen
1225
1226         * include/msgq.h: remove msgq_map(), since it's no longer used
1227         anywhere
1228
1229 2001-01-18  Kevin L. Mitchell  <klmitch@mit.edu>
1230
1231         * ircd/s_user.c (set_nick_name): call client_set_privs() after
1232         parsing user modes
1233
1234 2001-01-17  Kevin L. Mitchell  <klmitch@mit.edu>
1235
1236         * ircd/s_bsd.c (read_message): fix a typo in the select version of
1237         read_message()
1238
1239         * ircd/whowas.c (whowas_free): MyFree() is a macro that expects
1240         its argument to be an lvalue, which means we can't use
1241         whowas_clean()'s handy-dandy "return ww" feature
1242
1243         * ircd/ircd_features.c: default LOCOP_KILL to TRUE--oops...
1244
1245 2001-01-16  Kevin L. Mitchell  <klmitch@mit.edu>
1246
1247         * ircd/ircd_events.c (timer_run): it's possible that the timer got
1248         deleted during the callback processing, so don't go to the bother
1249         of requeuing it if the destroy flag is set
1250
1251         * ircd/engine_select.c: define FD_SETSIZE to be IRCD_FD_SETSIZE
1252         out of config.h if this is a *BSD; include errno.h (oops);
1253         decrement error count after an hour using a timer; use FD_SETSIZE
1254         constant instead of IRCD_FD_SETSIZE constant; fill in event
1255         processing code
1256
1257         * ircd/engine_poll.c: include errno.h (oops); decrement error
1258         count after an hour using a timer; fill in event processing code
1259
1260         * ircd/engine_kqueue.c: include errno.h (oops); decrement error
1261         count after an hour using a timer; assert events filter is either
1262         EVFILT_READ or EVFILT_WRITE; fill in event processing code
1263
1264         * ircd/engine_devpoll.c: include errno.h (oops); decrement error
1265         count after an hour using a timer; fill in event processing code
1266
1267 2001-01-15  Kevin L. Mitchell  <klmitch@mit.edu>
1268
1269         * ircd/client.c: fixed feattab; basically, when I changed features
1270         to use small integers specifying bit positions, instead of the
1271         bits themselves, I forgot to update feattab to not | these
1272         privileges together; also fixed a bug in the antiprivs masking
1273         loop in client_set_privs()--last index wouldn't get parsed
1274
1275 2001-01-11  Kevin L. Mitchell  <klmitch@mit.edu>
1276
1277         * ircd/ircd_events.c: call event_generate() with new data
1278         argument; make it set that field in struct Event; make
1279         socket_add() return the value of the eng_add callback
1280
1281         * ircd/engine_select.c: make engine_add() return a
1282         successful/unsuccessful status; add bounds-checking outside of an
1283         assert; use accessor macros; use log_write(), not the deprecated
1284         ircd_log(); add an assert to engine_loop() to double-check for
1285         data structure corruption
1286
1287         * ircd/engine_poll.c: make engine_add() return a
1288         successful/unsuccessful status; add bounds-checking outside of an
1289         assert; use accessor macros; use log_write(), not the deprecated
1290         ircd_log(); add an assert to engine_loop() to double-check for
1291         data structure corruption
1292
1293         * ircd/engine_kqueue.c: implementation of an engine for kqueue()
1294
1295         * ircd/engine_devpoll.c: implementation of an engine for /dev/poll
1296
1297         * include/ircd_events.h: define some accessor macros; add ev_data
1298         to struct Event for certain important data--errno values, for
1299         instance; make EngineAdd callback tell us if it was successful or
1300         not; add extra argument to event_generate(); make socket_add()
1301         return the status from EngineAdd
1302
1303 2001-01-10  Kevin L. Mitchell  <klmitch@mit.edu>
1304
1305         * ircd/ircd_events.c: pass initializer information about how many
1306         total _filedescriptors_ may be opened at once
1307
1308         * ircd/ircd.c: use exported "running" instead of unexported
1309         thisServer.running
1310
1311         * ircd/engine_select.c: implementation of an event engine based on
1312         select()
1313
1314         * ircd/engine_poll.c: implementation of an event engine based on
1315         poll()
1316
1317         * include/ircd_events.h: pass the engine initializer an integer
1318         specifing how many _filedescriptors_ may be opened at once
1319
1320         * include/ircd.h: running has to be exported for the engine_*
1321         event loops
1322
1323 2001-01-09  Kevin L. Mitchell  <klmitch@mit.edu>
1324
1325         * ircd/ircd_events.c: include some needed headers; add some
1326         comments; make evEngines[] const; bundle sig_sock and sig_fd into
1327         a struct named sigInfo; rework struct evInfo to have a queue of
1328         _generators_, and only when threaded; added a gen_init() function
1329         to centralize generator initialization; fix various compile-time
1330         errors; rework event_add() for new queueing scheme and checked for
1331         compile-time errors; add casts where needed; spell evEngines[]
1332         correctly; make engine_name() return const char*
1333
1334         * include/ircd_events.h: type EventCallBack depends on struct
1335         Event, so pre-declare it; put _event_ queue into generators, and
1336         only when threaded; give engine data a union to store both ints
1337         and pointers; make engine name a const; fix gen_ref_dec() macro;
1338         make engine_name() return a const char*
1339
1340         * ircd/ircd_events.c: gen_dequeue() is now exported, so move it
1341         down with the non-static functions; modify event_execute() to use
1342         the new gen_ref_dec() to simplify code; make sure event_generate()
1343         does not generate new events for generators marked for destruction
1344
1345         * include/ircd_events.h: the engines, at least, may need to modify
1346         reference counts to keep generators from going away while
1347         something still points at them, so add reference counter
1348         manipulators and export gen_dequeue() for them
1349
1350         * ircd/ircd_events.c: set up the list of engines to try; set up
1351         the signal struct Socket; rename netInfo to evInfo; move static
1352         functions near the beginning of the file; do away with
1353         signal_signal() (since we no longer keep a signal count ourselves)
1354         and call event_generate() directly from signal_callback--also
1355         renamed some functions; allow signal_callback() to read up to
1356         SIGS_PER_SOCK at once from the signal pipe; add event_init() to
1357         initialize the entire event system; add event_loop() to call the
1358         engine's event loop; initialize new struct GenHeader member,
1359         gh_engdata; remove timer_next(); add socket_add() function to add
1360         a socket; add socket_del() to mark a socket for deletion; add
1361         socket_state() to transition a socket between states; add
1362         socket_events() to set what events we're interested in on the
1363         socket; add engine_name() to retrieve event engine's name
1364
1365         * include/ircd_events.h: add engine data field to struct
1366         GenHeader; rename SOCK_ACTION_REMOVE to SOCK_ACTION_DEL; add a
1367         note about states vs s_events; remove signal count; fold union
1368         Generator back into struct Event; remove count members from struct
1369         Generators; redefine engine callbacks to not take a struct
1370         Engine*; add explanatory comments to callback definitions; add
1371         some engine callbacks to handle operations; remove struct Engine
1372         flag member--can detect single flag from eng_signal member; add
1373         event_init(), event_loop(), engine_name(), and the socket_*()
1374         functions; make timer_next() a macro to avoid a function call
1375
1376 2001-01-08  Kevin L. Mitchell  <klmitch@mit.edu>
1377
1378         * include/ircd_events.h: rename to ircd_events.h, since it handles
1379         events, not just networking stuff; add signal support; more
1380         structural rearrangement
1381
1382         * ircd/ircd_events.c: rename to ircd_events.c, since it handles
1383         events, not just networking stuff; add signal support; more
1384         structural rearrangement
1385
1386 2001-01-07  Kevin L. Mitchell  <klmitch@mit.edu>
1387
1388         * ircd/ircd_network.c: implement timer API; add reference counts
1389         appropriately
1390
1391         * include/ircd_network.h: firm up some pieces of the interface;
1392         split out members everything has into a separate structure; add
1393         reference counts; add timer API
1394
1395 2001-01-06  Kevin L. Mitchell  <klmitch@mit.edu>
1396
1397         * ircd/ircd_network.c: static data and event manipulation
1398         functions for new event processing system
1399
1400         * include/ircd_network.h: data structures for new event processing
1401         system
1402
1403 2001-01-03  Kevin L. Mitchell  <klmitch@mit.edu>
1404
1405         * ircd/whowas.c: Completely re-did the old allocation scheme by
1406         turning it into a linked list, permitting the
1407         NICKNAMEHISTORYLENGTH feature to be changed on the fly
1408
1409         * ircd/s_debug.c (count_memory): use FEAT_NICKNAMEHISTORYLENGTH
1410         feature instead of old #define
1411
1412         * ircd/ircd_features.c: add NICKNAMEHISTORYLENGTH feature as an
1413         integer feature with a notify callback (whowas_realloc)
1414
1415         * ircd/client.c (client_set_privs): second memset was supposed to
1416         be over antiprivs, not privs; thanks, Chris Behrens
1417         <cbehrens@xo.com> for pointing that out...
1418
1419         * include/whowas.h: new elements for an extra linked list in
1420         struct Whowas; a notify function for feature value changes
1421
1422         * include/ircd_features.h: new feature--FEAT_NICKNAMEHISTORYLENGTH
1423
1424         * config/config-sh.in: NICKNAMEHISTORYLENGTH is now a feature
1425
1426 2001-01-02  Kevin L. Mitchell  <klmitch@mit.edu>
1427
1428         * config/config-sh.in: get rid of DEFAULT_LIST_PARAMETER
1429         compile-time option--now in features subsystem
1430
1431         * ircd/motd.c (motd_init): rework motd_init() to be called as the
1432         notify function for MPATH and RPATH features (should probably
1433         split it up a bit, though...)
1434
1435         * ircd/m_privs.c (mo_privs): if called with no parameters, return
1436         privs of the caller, rather than an error
1437
1438         * ircd/m_list.c: pull usage message into its own function; pull
1439         list parameter processing into its own function that does not
1440         modify the contents of the parameter; add list_set_default() to
1441         set the default list parameter (uses the notify hook); rework
1442         m_list() to make use of these functions; removed dead code
1443
1444         * ircd/ircd_log.c (log_feature_mark): make sure to return 0, since
1445         we have no notify handler
1446
1447         * ircd/ircd_features.c: add notify callback for notification of
1448         value changes; give mark callback an int return value to indicate
1449         whether or not to call the notify callback; fix up feature macros
1450         for new notify callback; add DEFAULT_LIST_PARAM feature; rewrite
1451         string handling in feature_set() to deal with def_str being a null
1452         pointer; wrote feature_init() to set up all defaults appropriately
1453
1454         * ircd/ircd.c (main): call feature_init() instead of
1455         feature_mark(), to avoid calling notify functions while setting up
1456         defaults
1457
1458         * ircd/client.c: updated to deal with new privileges structure
1459
1460         * ircd/class.c: updated so init_class() can be called should one
1461         of PINGFREQUENCY, CONNECTFREQUENCY, MAXIMUM_LINKS, or
1462         DEFAULTMAXSENDQLENGTH be changed
1463
1464         * include/ircd_log.h: log_feature_mark() updated to fit with new
1465         API changes
1466
1467         * include/ircd_features.h: added DEFAULT_LIST_PARAM feature and
1468         feature_init() function (found necessary since adding the notify
1469         stuff and notifying motd.c during start-up...before we defined
1470         RPATH!)
1471
1472         * include/client.h: move privs around to enable addition of more
1473         bits if necessary; based on the FD_* macros
1474
1475         * include/channel.h: declare list_set_default (actually located in
1476         m_list.c *blanche*)
1477
1478         * ircd/s_user.c: retrieve MAXSILES and MAXSILELENGTH (now
1479         AVBANLEN*MAXSILES) from features subsystem
1480
1481         * ircd/s_debug.c (debug_serveropts): CMDLINE_CONFIG doesn't go to
1482         anything anymore
1483
1484         * ircd/s_bsd.c: retrieve HANGONGOODLINK and HANGONRETRYDELAY from
1485         the features subsystem
1486
1487         * ircd/s_auth.c (start_auth): NODNS migrated to the features
1488         subsystem
1489
1490         * ircd/random.c: created random_seed_set() function to set seed
1491         value, along with some stuff to make ircrandom() a little more
1492         random--state preserving, xor of time instead of direct usage,
1493         etc.; it's still a pseudo-random number generator, though, and
1494         hopefully I haven't broken the randomness
1495
1496         * ircd/m_version.c: FEATUREVALUES makes use of feature_int() calls
1497
1498         * ircd/m_join.c: use features interface to retrieve
1499         MAXCHANNELSPERUSER
1500
1501         * ircd/ircd_features.c: add NODISP flag for super-secret features;
1502         add a whole bunch of new features migrated over from make config
1503
1504         * ircd/ircd.c: use features interface to retrieve PINGFREQUENCY,
1505         CONNECTTIMEOUT, and TIMESEC
1506
1507         * ircd/client.c (client_get_ping): use features interface to
1508         retrieve PINGFREQUENCY
1509
1510         * ircd/class.c: use features interface to retrieve PINGFREQUENCY,
1511         CONNECTFREQUENCY, MAXIMUM_LINKS, and DEFAULTMAXSENDQLENGTH
1512
1513         * ircd/chkconf.c (DEFAULTMAXSENDQLENGTH): since it's now in the
1514         features subsystem, we have to add something explicit
1515
1516         * ircd/channel.c: use features interface to retrieve
1517         KILLCHASETIMELIMIT, MAXBANLENGTH, MAXBANS, and MAXCHANNELSPERUSER;
1518         note that MAXBANLENGTH is now calculated dynamically from MAXBANS
1519         and AVBANLEN
1520
1521         * ircd/Makefile.in: run make depend
1522
1523         * include/supported.h (FEATURESVALUES): update to reference
1524         feature settings
1525
1526         * include/random.h: add prototype for random_seed_set
1527
1528         * include/ircd_features.h: add several more features
1529
1530         * include/channel.h: move MAXBANS and MAXBANLENGTH into feature
1531         subsystem
1532
1533         * config/config-sh.in: feature-ized some more stuff
1534
1535         * include/motd.h: some new elements in motd.h for motd.c changes
1536
1537         * ircd/motd.c: motd_cache() now searches a list of already cached
1538         MOTD files; saves us from having duplicate caches in memory if
1539         there are two identical T-lines for two different sites...
1540
1541 2001-01-02  Perry Lorier <isomer@coders.net>
1542         * ircd/motd.c: don't core if the motd isn't found.  Bug found by
1543         Amarande.
1544
1545 2001-01-02  Perry Lorier <isomer@coders.net>
1546         * ircd/s_err.c: Added third param to 004 - the channel modes that tage params.  Used by hybrid/epic.
1547         * ircd/s_channels.c: Added fix for msg'ing a -n+m channel - thanks
1548                 to guppy for noticing, and hektik for providing the fix.
1549         * misc others: Minor cleanups, added more protocol_violations, ripped
1550                 out more P09 stuffs, bit more protocol neg stuff.
1551
1552 2000-12-19  Kevin L. Mitchell  <klmitch@mit.edu>
1553
1554         * ircd/m_ison.c (m_ison): Dianora says that ISON has to end with a
1555         space (*sigh* stupid clients...)
1556
1557         * ircd/s_user.c: make WALLOPS_OPER_ONLY a feature managed through
1558         ircd_features.[ch]
1559
1560         * ircd/s_err.c: get rid of GODMODE conditionals
1561
1562         * ircd/s_debug.c (debug_serveropts): switch to using appropriate
1563         calls into the features subsystem for various serveropts
1564         characters
1565
1566         * ircd/s_conf.c (find_conf_entry): get rid of USEONE conditional
1567
1568         * ircd/s_bsd.c: remove GODMODE conditional; use features subsystem
1569         to get value of VIRTUAL_HOST and CLIENT_FLOOD; remove
1570         NOFLOWCONTROL conditional
1571
1572         * ircd/s_auth.c: use features subsystem to determine value of
1573         KILL_IPMISMATCH
1574
1575         * ircd/parse.c: get rid of NOOPER and GODMODE conditionals; use
1576         features subsystem to determine the setting of IDLE_FROM_MSG
1577
1578         * ircd/numnicks.c: get rid of EXTENDED_NUMERICS conditionals
1579
1580         * ircd/motd.c: get value of NODEFAULTMOTD from features subsystem;
1581         use features subsystem to get motd file names
1582
1583         * ircd/m_settime.c: get value of RELIABLE_CLOCK from features
1584         subsystem
1585
1586         * ircd/m_server.c: get rid of CRYPT_LINK_PASSWORD, since it does
1587         us no good; use features subsystem to figure out if we need to do
1588         HUB-type stuff; make TESTNET debugging sendto_opmask_butone's use
1589         the Debug(()) macro instead; get value of RELIABLE_CLOCK from
1590         features subsystem
1591
1592         * ircd/m_privmsg.c: get IDLE_FROM_MSG from the features subsystem
1593
1594         * ircd/m_oper.c: get CRYPT_OPER_PASSWORD from the features
1595         subsystem
1596
1597         * ircd/m_connect.c: get SERVER_PORT from the features subsystem
1598
1599         * ircd/ircd_log.c (log_set_file): fix a bug that kept log files
1600         from getting marked if they were already set to something...
1601
1602         * ircd/ircd_features.c: add a flag to indicates read-only access;
1603         add several new features that used to be compile-time selected
1604
1605         * ircd/ircd.c: grab pidfile out of feature subsystem; don't check
1606         access to motd files (what the heck?); make sure to initialize the
1607         feature subsystem before trying to write the config file
1608
1609         * ircd/dbuf.c: use feature_int() to retrieve BUFFERPOOL settings;
1610         use feature_bool() to figure out if we're using the FERGUSON
1611         flusher
1612
1613         * ircd/Makefile.in: MPATH and RPATH are now done differently, so
1614         remove the clause that creates empty files of that name; also ran
1615         make depend
1616
1617         * include/sys.h: CLIENT_FLOOD is now a feature; unfortunately,
1618         there is no easy way to bounds-check it at present
1619
1620         * include/querycmds.h: make sure ircd_features.h is included; use
1621         feature_str(FEAT_DOMAINNAME) in calls to match()
1622
1623         * include/ircd_features.h: many new features that used to be
1624         compile-time selected
1625
1626         * config/config-sh.in: add * to DOMAINNAME; try also using first
1627         argument to search in /etc/resolv.conf; removed many compile-time
1628         options that now can be configured through the features system
1629
1630 2000-12-18  Kevin L. Mitchell  <klmitch@mit.edu>
1631
1632         * doc/api/log.txt: how to use the logging API
1633
1634         * doc/api/features.txt: how to use the features API
1635
1636         * doc/api/api.txt: how to write API documentation
1637
1638         * include/ircd_features.h: rearranged a couple of features for
1639         neatness purposes
1640
1641         * ircd/ircd_features.c: cleaned up the macros some; rearranged
1642         some code to all go into the switch; rearranged a couple of
1643         features for neatness purposes
1644
1645 2000-12-16  Greg Sikorski <gte@atomicrevs.demon.co.uk>
1646         * ircd/os_bsd.c: Added os_set_tos for BSD users.
1647
1648 2000-12-16  Kevin L. Mitchell  <klmitch@mit.edu>
1649
1650         * ircd/ircd_features.c: Isomer almost got it right; you need to
1651         use F_I(), since it's an integer value, not a boolean value.  The
1652         asserts in feature_int would catch you out...  Also made the F_*
1653         macros take flags
1654
1655         * ircd/s_err.c: define RPL_PRIVS reply
1656
1657         * ircd/parse.c: put new PRIVS command into command table
1658
1659         * ircd/m_privs.c (mo_privs): message handler to report operator
1660         privileges
1661
1662         * ircd/ircd_features.c: declare new features OPER_SET and
1663         LOCOP_SET; redo boolean testing routine to accept TRUE, YES, and
1664         ON for boolean TRUE, and FALSE, NO, and OFF for boolean FALSE
1665
1666         * ircd/client.c: simplify client_set_privs() with a table that
1667         defines what features to test for; add new client_report_privs()
1668
1669         * ircd/Makefile.in: compile new m_privs.c; run make depend
1670
1671         * include/numeric.h (RPL_PRIVS): new reply numeric for displaying
1672         an operator's privileges
1673
1674         * include/msg.h: define new command: PRIVS
1675
1676         * include/ircd_features.h: create new features OPER_SET and
1677         LOCOP_SET for controlling access to /set
1678
1679         * include/handlers.h (mo_privs): declare message handler for
1680         reporting oper privileges
1681
1682         * include/client.h (client_report_privs): declare function to
1683         report what privileges an oper has
1684
1685         * ircd/m_whois.c (do_whois): fix a bug that caused /whois to
1686         report that a user is an oper if the oper doing the /whois had
1687         PRIV_SEE_OPERS
1688
1689 2000-12-17  Isomer <Isomer@coders.net>
1690         * ircd/listener.c: added support for TOS twiddling as a 'feature'.
1691
1692 2000-12-17  Isomer <Isomer@coders.net>
1693         * ircd/os_linux.c: add TOS stuffs
1694
1695         * ircd/listener.c: add TOS stuffs
1696
1697 2000-12-16  Kevin L. Mitchell  <klmitch@mit.edu>
1698
1699         * ircd/whocmds.c (do_who): use HasPriv to determine whether or not
1700         to indicate a user is an oper
1701
1702         * ircd/s_user.c: clear privileges setting when deopping; don't
1703         propagate +o unless user has PRIV_PROPAGATE privilege
1704
1705         * ircd/s_debug.c (debug_serveropts): created debug_serveropts()
1706         function and replaced how the server option string is generated
1707
1708         * ircd/parse.c: remove conditional on CONFIG_OPERCMDS
1709
1710         * ircd/m_whois.c (do_whois): use HasPriv to determine whether or
1711         not to indicate the user is an operator
1712
1713         * ircd/m_who.c: use HasPriv to determine whether or not a user
1714         should be displayed in the list of opers
1715
1716         * ircd/m_version.c: call debug_serveropts() to get server option
1717         string
1718
1719         * ircd/m_userip.c (userip_formatter): use HasPriv to determine
1720         whether or not to show oper status
1721
1722         * ircd/m_userhost.c (userhost_formatter): use HasPriv to determine
1723         whether or not to show oper status
1724
1725         * ircd/m_restart.c (mo_restart): replace ugly #ifdef conditional
1726         checks with HasPriv check; remove dead code
1727
1728         * ircd/m_rehash.c (mo_rehash): replace ugly #ifdef conditional
1729         checks with HasPriv check
1730
1731         * ircd/m_opmode.c (mo_opmode): use HasPriv to check permissions;
1732         use feature_bool to check if disabled
1733
1734         * ircd/m_oper.c (m_oper): set oper priviliges
1735
1736         * ircd/m_mode.c (m_mode): replace #ifdef conditional with HasPriv
1737         check
1738
1739         * ircd/m_kill.c (mo_kill): use HasPriv checks to determine if we
1740         can kill
1741
1742         * ircd/m_kick.c (m_kick): replace #ifdef conditional with HasPriv
1743         check
1744
1745         * ircd/m_jupe.c (mo_jupe): rework permissions checking structure;
1746         use feature_bool to check if disabled
1747
1748         * ircd/m_join.c (m_join): remove BADCHAN conditional; replace
1749         #ifdef conditional with a HasPriv check
1750
1751         * ircd/m_gline.c (mo_gline): rework permissions checking
1752         structure; use feature_bool to check if any part is disabled
1753
1754         * ircd/m_die.c: replace ugly #ifdef conditionals with HasPriv
1755         check; remove dead code
1756
1757         * ircd/m_clearmode.c: use feature_bool() to detect if we're
1758         disabled; use HasPriv to figure out what we're permitted to do;
1759         only allow clearmode on moded channels
1760
1761         * ircd/ircd_features.c: define various features; use HasPriv to
1762         verify permissions to set/reset
1763
1764         * ircd/gline.c (gline_add): use HasPriv instead of #ifdef
1765         conditionals
1766
1767         * ircd/client.c (client_set_privs): function to set an oper's
1768         privileges
1769
1770         * ircd/channel.c: use HasPriv calls instead of #ifdef conditionals
1771
1772         * include/whocmds.h: deconditionalize several macros and
1773         substitute appropriate calls to HasPriv()
1774
1775         * include/s_debug.h: get rid of global serveropts[]; define new
1776         function debug_serveropts() to build that string on the fly
1777
1778         * include/ircd_features.h: define some features
1779
1780         * include/client.h: add privs member to struct Connection; define
1781         various priviledges
1782
1783         * include/channel.h: no longer using IsOperOnLocalChannel; remove
1784         conditional of MAGIC_OPER_OVERRIDE on OPER_WALK_THROUGH_LMODES
1785
1786         * doc/Configure.help: remove help information for deprecated
1787         options
1788
1789         * config/config-sh.in: remove certain deprecated options having to
1790         do with what opers can and cannot do--first stage in moving
1791         compile-time constants into the .conf
1792
1793 2000-12-16  Isomer <Isomer@coders.net>
1794         * ircd/parse.c: detect if the prefix is missing and try and recover
1795         instead of coring.
1796
1797 2000-12-15  Kevin L. Mitchell  <klmitch@mit.edu>
1798
1799         * ircd/ircd_log.c: found and fixed some bugs in the debug logging
1800         code that would sometimes result in the log file not being
1801         reopened--which meant that a user could connect and get the
1802         logging output--oops
1803
1804         * ircd/Makefile.in: run make depend...
1805
1806         * ircd/s_stats.c: get rid of report_feature_list()
1807
1808         * ircd/s_err.c: add the 'bad value' error message, shift error
1809         messages over somewhat
1810
1811         * ircd/s_debug.c (debug_init): call log_debug_init with the
1812         use_tty flag
1813
1814         * ircd/s_conf.c (read_configuration_file): unmark features before
1815         reading the config file, then reset unmarked features after
1816         reading the config file
1817
1818         * ircd/m_stats.c: use feature_report() instead of
1819         report_feature_list()
1820
1821         * ircd/ircd_log.c: fix log_debug_file (bogus assertion); add
1822         special 'mark' flags and use them; add the stuff needed by the
1823         features API
1824
1825         * ircd/ircd_features.c: rework the features API and add gobs of
1826         comments to try to explain what some of these complex functions
1827         are actually doing
1828
1829         * include/s_stats.h: get rid of report_feature_list(); use
1830         feature_report() instead
1831
1832         * include/numeric.h: added a new error message and shifted old
1833         values over some--this is, after all, an alpha
1834
1835         * include/ircd_log.h: log_debug_init now takes an integer to tell
1836         it if it should be using the tty; added a couple of functions
1837         required by the features API
1838
1839         * include/ircd_features.h: add an enum and some more functions to
1840         flesh out the feature API--it should now be possible to put all
1841         those compile-time constants in the config file!
1842
1843         * ircd/send.c: got the direction of the assert incorrect...
1844
1845         * ircd/send.c: implement the efficiency of flush_connections by
1846         creating a linked list of struct Connection's with queued data;
1847         also get rid of flush_sendq_except and make sure to yank
1848         connections out of the list when their sendQs become empty (notice
1849         the assertion in flush_connections!)
1850
1851         * ircd/s_bsd.c (close_connection): must yank the Connection out of
1852         the sendq list
1853
1854         * ircd/list.c (dealloc_connection): must yank the Connection out
1855         of the sendq list
1856
1857         * ircd/dbuf.c (dbuf_put): call flush_connections instead of the
1858         deprecated flush_sendq_except
1859
1860         * ircd/client.c: define a couple new helper functions for sendq
1861         threading--this will make the flush_connections function in send.c
1862         considerably more efficient by creating a linked list of
1863         Connections that have queued data to send
1864
1865         * include/send.h: remove flush_sendq_except, as it's not used
1866         anymore
1867
1868         * include/client.h: declare a couple new helper functions for the
1869         sendq threading system
1870
1871 2000-12-14  Kevin L. Mitchell  <klmitch@mit.edu>
1872
1873         * ircd/m_ison.c (m_ison): Apply Diane Bruce's patch to make ISON
1874         parse all arguments
1875
1876         * ircd/s_debug.c (count_memory): modify to report for clients and
1877         connections, not local clients and remote clients
1878
1879         * ircd/list.c: fiddle with the client-fiddling functions to take
1880         into account the divorce of struct Connection from struct Client
1881
1882         * ircd/ircd.c: define a struct Connection for me, initialize it,
1883         and link it into the right place (ewww, globals!)
1884
1885         * include/client.h: remove CLIENT_{LOCAL,REMOTE}_SIZE; split
1886         struct Client into struct Client and struct Connection; redefine
1887         local-portion accessor macros to go through struct Client to the
1888         struct Connection; define struct Connection accessor macros
1889
1890 2000-12-13  Kevin L. Mitchell  <klmitch@mit.edu>
1891
1892         * ircd/whowas.c: missed a couple of accesses to a struct Client
1893
1894         * ircd/uping.c: missed a couple of accesses to a struct Client
1895
1896         * ircd/send.c: missed a couple of accesses to a struct Client
1897
1898         * ircd/s_user.c: missed a couple of accesses to a struct Client
1899
1900         * ircd/s_misc.c: missed a couple of accesses to a struct Client
1901
1902         * ircd/s_conf.c: missed a couple of accesses to a struct Client
1903
1904         * ircd/s_bsd.c: missed a couple of accesses to a struct Client
1905
1906         * ircd/s_auth.c: missed a couple of accesses to a struct Client
1907
1908         * ircd/res.c: missed a couple of accesses to a struct Client
1909
1910         * ircd/parse.c: missed a couple of accesses to a struct Client
1911
1912         * ircd/m_whois.c: use new accessor macros for struct Client
1913
1914         * ircd/m_who.c: use new accessor macros for struct Client
1915
1916         * ircd/m_wallchops.c: use new accessor macros for struct Client
1917
1918         * ircd/m_version.c: use new accessor macros for struct Client
1919
1920         * ircd/m_userip.c: use new accessor macros for struct Client
1921
1922         * ircd/m_userhost.c: use new accessor macros for struct Client
1923
1924         * ircd/m_user.c: use new accessor macros for struct Client
1925
1926         * ircd/m_uping.c: use new accessor macros for struct Client
1927
1928         * ircd/m_trace.c: use new accessor macros for struct Client
1929
1930         * ircd/m_topic.c: use new accessor macros for struct Client
1931
1932         * ircd/m_time.c: use new accessor macros for struct Client
1933
1934         * ircd/m_stats.c: use new accessor macros for struct Client
1935
1936         * ircd/m_squit.c: use new accessor macros for struct Client
1937
1938         * ircd/m_silence.c: use new accessor macros for struct Client
1939
1940         * ircd/m_server.c: use new accessor macros for struct Client;
1941         remove dead code
1942
1943         * ircd/m_rpong.c: use new accessor macros for struct Client
1944
1945         * ircd/m_rping.c: use new accessor macros for struct Client
1946
1947         * ircd/m_quit.c: use new accessor macros for struct Client
1948
1949         * ircd/m_privmsg.c: use new accessor macros for struct Client
1950
1951         * ircd/m_pong.c: use new accessor macros for struct Client; remove
1952         dead code
1953
1954         * ircd/m_ping.c: use new accessor macros for struct Client
1955
1956         * ircd/m_pass.c: use new accessor macros for struct Client
1957
1958         * ircd/m_part.c: use new accessor macros for struct Client
1959
1960         * ircd/m_oper.c: use new accessor macros for struct Client
1961
1962         * ircd/m_notice.c: use new accessor macros for struct Client
1963
1964         * ircd/m_nick.c: use new accessor macros for struct Client
1965
1966         * ircd/m_names.c: use new accessor macros for struct Client
1967
1968         * ircd/m_mode.c: use new accessor macros for struct Client
1969
1970         * ircd/m_map.c: use new accessor macros for struct Client
1971
1972         * ircd/m_list.c: use new accessor macros for struct Client
1973
1974         * ircd/m_links.c: use new accessor macros for struct Client;
1975         remove some dead code
1976
1977         * ircd/m_kill.c: use new accessor macros for struct Client; remove
1978         some dead code
1979
1980         * ircd/m_kick.c: use new accessor macros for struct Client
1981
1982         * ircd/m_join.c: use new accessor macros for struct Client; remove
1983         some dead code
1984
1985         * ircd/m_ison.c: use new accessor macros for struct Client
1986
1987         * ircd/m_invite.c: use new accessor macros for struct Client
1988
1989         * ircd/m_info.c: use new accessor macros for struct Client
1990
1991         * ircd/m_gline.c: use new accessor macros for struct Client
1992
1993         * ircd/m_error.c: use new accessor macros for struct Client
1994
1995         * ircd/m_create.c: use new accessor macros for struct Client
1996
1997         * ircd/m_connect.c: use new accessor macros for struct Client;
1998         removed some dead code
1999
2000         * ircd/m_burst.c: use new accessor macros for struct Client
2001
2002         * ircd/m_away.c: use new accessor macros for struct Client
2003
2004         * ircd/m_admin.c: use new accessor macros for struct Client
2005
2006         * ircd/hash.c: missed a couple of accesses to a struct Client
2007
2008         * ircd/gline.c: missed a couple of accesses to a struct Client
2009
2010         * ircd/crule.c: missed a couple of accesses to a struct Client
2011
2012         * ircd/class.c: missed an access to a struct Client
2013
2014         * ircd/channel.c: missed a couple of accesses to a struct Client
2015
2016         * ircd/IPcheck.c: missed an access to a struct Client
2017
2018         * include/querycmds.h: fix a couple of stats macros to use
2019         structure accessor macros
2020
2021         * include/client.h: change structure member names to highlight any
2022         places in the code I've missed
2023
2024 2000-12-12  Kevin L. Mitchell  <klmitch@mit.edu>
2025
2026         * ircd/whowas.c: use new struct Client accessor macros
2027
2028         * ircd/whocmds.c: use new struct Client accessor macros
2029
2030         * ircd/send.c: use new struct Client accessor macros
2031
2032         * ircd/s_user.c: use new struct Client accessor macros; removed
2033         some dead code
2034
2035         * ircd/s_serv.c: use new struct Client accessor macros; removed
2036         some dead code
2037
2038         * ircd/s_numeric.c: use new struct Client accessor macros
2039
2040         * ircd/s_misc.c: use new struct Client accessor macros
2041
2042         * ircd/s_debug.c: use new struct Client accessor macros
2043
2044         * ircd/s_conf.c: use new struct Client accessor macros
2045
2046         * ircd/s_bsd.c: use new struct Client accessor macros
2047
2048         * ircd/s_auth.c: use new struct Client accessor macros
2049
2050         * ircd/parse.c: use new struct Client accessor macros
2051
2052         * ircd/packet.c: use new struct Client accessor macros
2053
2054         * ircd/numnicks.c: use new struct Client accessor macros
2055
2056         * ircd/motd.c: use new struct Client accessor macros
2057
2058         * ircd/listener.c: use new struct Client accessor macros
2059
2060         * ircd/list.c: use new struct Client accessor macros
2061
2062         * ircd/jupe.c: use new struct Client accessor macros
2063
2064         * ircd/ircd_snprintf.c: use new struct Client accessor macros
2065
2066         * ircd/ircd_reply.c: use new struct Client accessor macros
2067
2068         * ircd/ircd_relay.c: use new struct Client accessor macros
2069
2070         * ircd/ircd.c: use new struct Client accessor macros
2071
2072         * ircd/gline.c: catch some instances of me.<stuff> I missed
2073         previously
2074
2075         * ircd/client.c: use cli_ instead of con_
2076
2077         * ircd/class.c: use cli_ instead of con_
2078
2079         * ircd/channel.c: use cli_ instead of con_
2080
2081         * ircd/IPcheck.c: use cli_ instead of con_; catch some instances
2082         of me.<stuff> I missed previously
2083
2084         * include/client.h: use cli_ instead of con_...seemed like a good
2085         idea at the time *shrug*
2086
2087 2000-12-11  Kevin L. Mitchell  <klmitch@mit.edu>
2088
2089         * ircd/hash.c: use struct Client accessor macros
2090
2091         * ircd/gline.c: use struct Client accessor macros
2092
2093         * ircd/crule.c: use struct Client accessor macros
2094
2095         * ircd/client.c: use struct Client accessor macros; remove some
2096         dead code
2097
2098         * ircd/class.c: use struct Client accessor macros
2099
2100         * ircd/channel.c: use struct Client accessor macros; remove some
2101         dead code
2102
2103         * ircd/IPcheck.c: use struct Client accessor macros
2104
2105         * include/numnicks.h: use struct Client accessor macros
2106
2107         * include/client.h: first step to divorcing struct Client and
2108         struct Connection--define accessor macros and use them
2109
2110         * ircd/gline.c: When Uworld removed Uworld-set G-lines, only the
2111         uplink would remove them.  This is because the removal protocol
2112         message wasn't being sent to the uplinks.  This is fixed by fixing
2113         propagate_gline() to send the proper number of arguments depending
2114         on whether or not we're adding or deleting the Uworld gline, and
2115         by having gline_deactivate() make sure to turn off the active bit
2116         and call propagate_gline() if it's a Uworld gline
2117
2118 2000-12-10  Kevin L. Mitchell  <klmitch@mit.edu>
2119
2120         * ircd/os_generic.c: make sure IOV_MAX gets defined, just in case
2121
2122         * ircd/os_bsd.c: apparently BSD doesn't have IOV_MAX defined
2123         anywhere intelligent...
2124
2125 2000-12-09  Kevin L. Mitchell  <klmitch@mit.edu>
2126
2127         * ircd/send.c (send_queued): call deliver_it with appropriate
2128         arguments
2129
2130         * ircd/s_serv.c: reorder a couple of headers--cosmetic
2131
2132         * ircd/s_bsd.c (deliver_it): make deliver_it work with a struct
2133         MsgQ
2134
2135         * ircd/os_solaris.c (os_sendv_nonb): function for calling writev
2136         with appropriate iovec
2137
2138         * ircd/os_linux.c (os_sendv_nonb): function for calling writev
2139         with appropriate iovec
2140
2141         * ircd/os_generic.c (os_sendv_nonb): function for calling writev
2142         with appropriate iovec
2143
2144         * ircd/os_bsd.c (os_sendv_nonb): function for calling writev with
2145         appropriate iovec
2146
2147         * ircd/msgq.c (msgq_mapiov): add a len_p argument for totalling up
2148         exactly how much we're trying to write out to the fd
2149
2150         * include/s_bsd.h: make deliver_it take a struct MsgQ
2151
2152         * include/msgq.h: add a len_p argument to msgq_mapiov to help
2153         detect short writes that indicate possible socket blocking
2154
2155         * include/ircd_osdep.h: declare os_sendv_nonb()
2156
2157         * ircd/channel.c (modebuf_mode): don't add empty modes...
2158
2159 2000-12-08  Kevin L. Mitchell  <klmitch@mit.edu>
2160
2161         * include/send.h: add prio argument to send_buffer to select
2162         between normal and priority queues
2163
2164         * ircd/s_user.c (send_user_info): add prio argument to send_buffer
2165         call
2166
2167         * ircd/m_ison.c (m_ison): add prio argument to send_buffer call
2168
2169         * ircd/ircd_reply.c (send_reply): add prio argument to send_buffer
2170         call
2171
2172         * ircd/channel.c (send_channel_modes): add prio argument to
2173         send_buffer call
2174
2175         * ircd/send.c (send_buffer): add a prio argument to select the
2176         priority queue; update send.c functions to use it
2177
2178         * ircd/msgq.c (msgq_add): remove msgq_prio; fold msgq_link and
2179         msgq_add; add a prio argument to msgq_add to select the priority
2180         queue
2181
2182         * include/msgq.h: remove msgq_prio; add a prio argument to
2183         msgq_add
2184
2185         * ircd/send.c: remove sendbuf; remove GODMODE code; switch to
2186         using msgq functions instead of dbuf functions; remove old, dead
2187         sendto_* functions; redo send_buffer to take a struct MsgBuf;
2188         rework sendcmdto_* functions to make use of the new struct MsgBuf
2189
2190         * ircd/s_user.c: remove hunt_server; restructure send_user_info to
2191         make appropriate use of struct MsgBuf
2192
2193         * ircd/s_debug.c (count_memory): count memory used by the MsgQ
2194         system and report it
2195
2196         * ircd/s_conf.c (read_configuration_file): use
2197         sendto_opmask_butone instead of the now dead sendto_op_mask
2198
2199         * ircd/s_bsd.c: switch to using appropriate MsgQLength and other
2200         calls on sendQ
2201
2202         * ircd/parse.c (parse_server): get rid of a piece of GODMODE code
2203
2204         * ircd/msgq.c: add msgq_append and msgq_bufleft; fix a bug in
2205         msgq_clean
2206
2207         * ircd/m_version.c: fix spelling in comments marking dead code
2208
2209         * ircd/m_userip.c (userip_formatter): restructure to make use of
2210         struct MsgBuf
2211
2212         * ircd/m_userhost.c (userhost_formatter): restructure to make use
2213         of struct MsgBuf
2214
2215         * ircd/m_stats.c: use MsgQLength on a sendQ
2216
2217         * ircd/m_settime.c: use MsgQLength instead of DBufLength on a
2218         sendQ; mark a piece of dead code
2219
2220         * ircd/m_names.c: use send_reply instead of sendto_one
2221
2222         * ircd/m_mode.c: use new mode; remove old dead code
2223
2224         * ircd/m_ison.c (m_ison): restructure to make use of struct MsgBuf
2225
2226         * ircd/m_burst.c: use BUFSIZE instead of IRC_BUFSIZE; remove old
2227         dead code
2228
2229         * ircd/listener.c (accept_connection): use sendto_opmask_butone
2230         instead of sendto_op_mask
2231
2232         * ircd/list.c (free_client): use MsgQClear to clear sendQ
2233
2234         * ircd/ircd_reply.c: remove send_error_to_client; restructure
2235         send_reply to make use of struct MsgBuf
2236
2237         * ircd/dbuf.c (dbuf_put): remove argument to flush_sendq_except,
2238         since its no longer used (at least currently)
2239
2240         * ircd/channel.c: restructure send_channel_modes to make use of
2241         struct MsgBuf; remove set_mode, add_token_to_sendbuf, cancel_mode,
2242         and send_hack_notice; use BUFSIZE instead of IRC_BUFSIZE
2243
2244         * ircd/Makefile.in: add msgq.c to list of sources; run make depend
2245
2246         * ircd/IPcheck.c: use sendcmdto_one instead of sendto_one
2247
2248         * include/send.h: send_buffer now takes a struct MsgBuf * instead
2249         of a char *; flush_sendq_except now takes no arguments, as sendq
2250         flushing currently only happens in dbuf.h and sendQ is a struct
2251         MsgQ; remove prototypes for a lot of old sendto_* functions that
2252         aren't used anymore; remove sendbuf and IRC_BUFSIZE--the former is
2253         no longer needed, and the latter is identical to BUFSIZE in
2254         ircd_defs.h
2255
2256         * include/s_user.h: make InfoFormatter take a struct MsgBuf*
2257         instead of a char *; also make it return void, instead of char *
2258
2259         * include/msgq.h: add msgq_append and msgq_bufleft functions
2260
2261         * include/client.h: use a struct MsgQ instead of a struct DBuf for
2262         sendq
2263
2264         * doc/Configure.help: Remove help for compile-time options that
2265         have gone away
2266
2267         * config/config-sh.in: remove CONFIG_NEWMODE
2268
2269         * ircd/m_server.c (mr_server): don't send server IPs in any server
2270         notices
2271
2272         * ircd/msgq.c (msgq_vmake): add \r\n to messages
2273
2274 2000-12-07  Kevin L. Mitchell  <klmitch@mit.edu>
2275
2276         * include/msgq.h: declare the MsgQ API
2277
2278         * ircd/msgq.c: implementation of new MsgQ system
2279
2280 2000-12-06  Kevin L. Mitchell  <klmitch@mit.edu>
2281
2282         * ircd/ircd_features.c: #include was supposed to be for
2283           ircd_features.h, not features.h--missed when I had to do a
2284           rename because of namespace collision
2285
2286 2000-12-05  Greg Sikorski <gte@atomicrevs.demon.co.uk>
2287         * ircd/m_topic.c: Added missing braces that caused all remote
2288           topics to be ignored.
2289
2290 2000-12-04  Kevin L. Mitchell  <klmitch@mit.edu>
2291
2292         * ircd/m_create.c: I'm tired of the exit_client warning :)
2293         (ms_create): discovered that exit_client() was being called with
2294         too few arguments
2295
2296         * ircd/s_misc.c (exit_client): remove all dependance on
2297         FNAME_USERLOG, since that's now gone; log only to LS_USER
2298
2299         * ircd/s_debug.c: USE_SYSLOG no longer means anything
2300
2301         * ircd/m_oper.c (m_oper): no longer log to LS_OPERLOG--we already
2302         log to LS_OPER
2303
2304         * ircd/m_kill.c: no longer conditionalize on SYSLOG_KILL
2305
2306         * ircd/ircd_log.c: remove LS_OPERLOG, LS_USERLOG
2307
2308         * include/ircd_log.h: remove LS_OPERLOG, LS_USERLOG--they serve
2309         the same purpose as LS_USER and LS_OPER
2310
2311         * config/config-sh.in: remove no longer relevant log config
2312         variables
2313
2314         * ircd/uping.c (uping_init): use log_write instead of ircd_log
2315
2316         * ircd/s_misc.c (exit_client): use log_write instead of ircd_log
2317
2318         * ircd/s_conf.c: use log_write instead of ircd_log
2319
2320         * ircd/s_bsd.c (report_error): use log_write instead of ircd_log
2321
2322         * ircd/s_auth.c (timeout_auth_queries): use log_write instead of
2323         ircd_log
2324
2325         * ircd/res.c (send_res_msg): use log_write instead of ircd_log
2326
2327         * ircd/m_who.c: use log_write instead of write_log; no longer
2328         conditionalize on WPATH; mark dead ircd_log calls
2329
2330         * ircd/m_uping.c: mark dead ircd_log call
2331
2332         * ircd/m_server.c (mr_server): use log_write instead of ircd_log
2333
2334         * ircd/m_restart.c: use log_write instead of ircd_log; mark dead
2335         ircd_log calls
2336
2337         * ircd/m_rehash.c (mo_rehash): use log_write instead of ircd_log
2338
2339         * ircd/m_oper.c: use log_write instead of ircd_log; no longer
2340         conditionalize on FNAME_OPERLOG; mark dead ircd_log calls
2341
2342         * ircd/m_kill.c: mark dead ircd_log calls
2343
2344         * ircd/m_connect.c: use log_write instead of ircd_log; mark dead
2345         ircd_log
2346
2347         * ircd/m_clearmode.c: use log_write instead of write_log; no
2348         longer conditionalize on OPATH
2349
2350         * ircd/jupe.c: use log_write instead of write_log; no longer
2351         conditionalize on JPATH
2352
2353         * ircd/ircd_log.c: add USER subsystem; remove ircd_log() compat
2354         function; fix a couple of bugs
2355
2356         * ircd/ircd_alloc.c: fixed a comment
2357
2358         * ircd/ircd.c: use log_write instead of ircd_log; fold server
2359         notice generation in a couple of cases
2360
2361         * ircd/gline.c: use log_write instead of write_log; no longer
2362         conditionalize on GPATH
2363
2364         * ircd/channel.c (modebuf_flush_int): use log_write instead of
2365         write_log; no longer conditionalize on OPATH
2366
2367         * ircd/Makefile.in: run make depend, since dependencies have
2368         changed
2369
2370         * doc/example.conf: add system USER to documentation
2371
2372         * include/ircd_log.h: add system USER; remove old ircd_log()
2373         declarations
2374
2375 2000-12-04  Isomer <isomer@coders.net>
2376         * ircd/m_names.c: Add NAMES_EON to do_names to say add a
2377         'end_of_names' reply when done.
2378         * ircd/m_join.c: use NAMES_EON as mentioned above
2379
2380 2000-12-01  net  <simms@LUCIDA.QC.CA>
2381
2382         * ircd/motd.c: add a freelist for struct Motds
2383
2384 2000-11-30  Kevin L. Mitchell  <klmitch@mit.edu>
2385
2386         * ircd/s_stats.c (report_feature_list): report features--only
2387         local opers can see logging configuration, since it doesn't really
2388         mean anything to users
2389
2390         * ircd/s_err.c: add reply messages for new feature subsystem
2391
2392         * ircd/s_conf.c: add F lines to .conf
2393
2394         * ircd/parse.c: add the message descriptions for /set, /reset, and
2395         /get
2396
2397         * ircd/m_stats.c: add /stats f
2398
2399         * ircd/m_set.c (mo_set): implement /set
2400
2401         * ircd/m_reset.c (mo_reset): implement /reset
2402
2403         * ircd/m_rehash.c: /rehash m now flushes MOTD cache, and /rehash l
2404         reopens log files (for log file rotation)
2405
2406         * ircd/m_get.c (mo_get): implement /get
2407
2408         * ircd/ircd_log.c: use int instead of void return value; add
2409         log_report_features() and log_canon(); fix a function that
2410         disappears if DEBUGMODE not #define'd
2411
2412         * ircd/ircd_features.c: functions to manipulate feature settings
2413         either from the config file or with the new /set, /reset, and /get
2414         commands
2415
2416         * ircd/Makefile.in: add new .c files, run make depend
2417
2418         * include/s_stats.h: declare report_feature_list() (/stats f
2419         handler)
2420
2421         * include/numeric.h: add RPL_STATSFLINE, RPL_FEATURE,
2422         ERR_NOFEATURE, ERR_BADLOGTYPE, ERR_BADLOGSYS, and ERR_BADLOGVALUE
2423         reply numerics
2424
2425         * include/msg.h: add defines for SET, RESET, and GET
2426
2427         * include/ircd_log.h: add a function to canonicalize subsystem
2428         names; change some void return values to int
2429
2430         * include/ircd_features.h: new features subsystem handles all the
2431         manipulation of special features, like log files
2432
2433         * include/handlers.h: declare new mo_{s,res,g}et message handlers
2434         for fiddling with features run-time
2435
2436         * include/client.h (SNO_DEFAULT): don't set SNO_DEBUG by default;
2437         seemed like a good idea at the time...
2438
2439         * doc/example.conf: document new F lines
2440
2441 2000-11-29  Kevin L. Mitchell  <klmitch@mit.edu>
2442
2443         * ircd/s_debug.c: rewrite debug_init() and vdebug() in terms of
2444         new logging functions, which have special support for the debug
2445         log; added loop detection to vdebug(), so that I can
2446         sendto_opmask_butone() from log_vwrite() without incurring another
2447         call to vdebug()
2448
2449         * ircd/s_conf.c (rehash): call log_reopen() from rehash routine;
2450         this allows log file rotations
2451
2452         * ircd/m_kill.c: call log_write_kill() instead of ircd_log_kill()
2453
2454         * ircd/ircd_log.c: much more work fleshing out the interface;
2455         removed old interface; included backwards-compat ircd_log()
2456         function that logs to subsystem LS_OLDLOG
2457
2458         * ircd/ircd.c: switch to new log_init()/log_close()/log_reopen()
2459         functions
2460
2461         * include/ircd_log.h: include stdarg.h for va_list; move ordering
2462         warning to top of file; fill out LogSys enum; declare new
2463         log_debug_init(), log_vwrite(), log_write_kill(), and
2464         log_[sg]et_*() functions; add flags argument to log_write();
2465         defined flags to inhibit various logging actions
2466
2467         * include/client.h: added support for new SNO_DEBUG, enabled only
2468         if DEBUGMODE is defined
2469
2470 2000-11-28  Kevin L. Mitchell  <klmitch@mit.edu>
2471
2472         * ircd/ircd_log.c: make sure the various LOG_* constants are
2473         defined (probably not needed, since #include <syslog.h> isn't
2474         conditional); various static data needed for the new logging
2475         functions; definitions of new logging functions
2476
2477         * include/ircd_log.h: new LogSys enum, declarations for part of
2478         new logging API
2479
2480         * ircd/motd.c: we were setting type to MOTD_CLASS unconditionally,
2481         which was of course stupid; switched to using switch/case in
2482         initialization in motd_create(); zero the MotdList.other pointer
2483         from motd_clear()
2484
2485         * ircd/ircd.c (main): motd_init() has to come before init_conf(),
2486         or we overwrite init_conf()'s hard work with respect to T-lines
2487
2488 2000-11-27  Kevin L. Mitchell  <klmitch@mit.edu>
2489
2490         * ircd/s_stats.c: comment out report_motd_list and include a
2491         reference to motd_report()
2492
2493         * ircd/s_conf.c: rip out the old MOTD manipulation functions; call
2494         motd_add() from the conf parser; call motd_clear() from the rehash
2495         routine; remove the no longer needed memory clearing and reloading
2496         stuff from the rehash service routine
2497
2498         * ircd/motd.c: loads new API, including static internal functions
2499         to do allocation/deallocation, etc.
2500
2501         * ircd/m_stats.c: use new motd_report() instead of
2502         report_motd_list()
2503
2504         * ircd/m_motd.c: use new syntax for motd_send()
2505
2506         * ircd/ircd.c: use new motd_init() function
2507
2508         * ircd/Makefile.in (SRC): forgot to add motd.c to SRC in
2509         Makefile.(in); also ran make depend
2510
2511         * include/motd.h: don't need config.h, but now do need time.h;
2512         define new structures and constants; redefine old API and define
2513         new functions
2514
2515 2000-11-22  Kevin L. Mitchell  <klmitch@mit.edu>
2516
2517         * ircd/s_user.c (register_user): use motd_signon() instead of
2518         calling m_motd; much cleaner this way
2519
2520         * ircd/motd.c: write the new motd_* stuff to make MOTD handling
2521         less of a crock
2522
2523         * ircd/m_motd.c: rewrite m{,s}_motd to call out to new motd_*
2524         functions
2525
2526         * include/motd.h: define new MOTD API stuff
2527
2528 2000-11-20  Kevin L. Mitchell  <klmitch@mit.edu>
2529
2530         * ircd/ircd_reply.c (protocol_violation): rewrite
2531         protocol_violation so it'll actually work
2532
2533         oh, yeah, use %s -> cptr->name, instead of %c -> cptr, so we get
2534         the client's real name in there.
2535
2536         * ircd/m_motd.c (m_motd): Iso's addition of get_client_class(sptr)
2537         resulted in core dumps if NODEFAULTMOTD is defined, because m_motd
2538         gets called from register_user with a NULL sptr.  This is probably
2539         a design problem, but this bandaid will do for now...
2540
2541 2000-11-19  Isomer <isomer@coders.net>
2542         * ircd/ircd_reply.c: added 'protocol_violation', thus alerting us
2543         to problems in the server<->server protocol.
2544
2545         * ircd/m_connect.c: allow remote connects with a port of '0'
2546         meaning to use the port in the config file.
2547
2548         * ircd/m_create.c: Enable hacking protection, lets see how far we
2549         get.
2550
2551         * ircd/m_error.c: The RFC says never accept ERROR from unreg'd
2552         clients, so we don't any more.
2553
2554         * ircd/m_kill.c: The kill path is now made up of numnicks of servers,
2555         and the user@host is displayed of the victim.
2556
2557         * ircd/m_map.c: reloaded 'dump_map'.
2558
2559         * ircd/m_trace.c: allow per class T:
2560
2561         * ircd/m_stats.c: allow local opers /remote stats anywhere on the 'net.
2562
2563 2000-11-17  Isomer <isomer@coders.net>
2564
2565         * ircd/m_topic.c: Fixed bug where we'd only send to clients topics
2566         that were the *same* instead of different.  Oh the embarrasment!
2567
2568         * ircd/IPcheck.c: Merged net's fix.
2569
2570 2000-11-02  Kevin L. Mitchell  <klmitch@mit.edu>
2571
2572         * ircd/m_whois.c: remove compiler warning by adding a newline to
2573         end of file
2574
2575         * ircd/m_names.c: moved the flags up to s_user.h
2576
2577         * ircd/m_join.c: call do_names instead of m_names; restructure
2578         ms_join to never transmute a JOIN into a CREATE, but use the TS in
2579         the JOIN (if present) to timestamp the channel
2580
2581         * ircd/channel.c: send JOINs individually, instead of grouping
2582         them, so that we can send the channel's creation time
2583
2584         * include/s_user.h: declare do_names()
2585
2586 2000-10-30  Isomer <isomer@coders.net>
2587         * ircd/m_oper.c: Fixed warning
2588
2589 2000-10-30  Isomer <isomer@coders.net>
2590         * ircd/m_oper.c: Fixed over agressive cut and no paste
2591
2592 2000-10-30  Isomer <isomer@coders.net>
2593
2594         * ircd/m_topic.c: Restructured, fixed bug where topics on local
2595         channels are propergated (I forget who pointed this out to me, but
2596         thanks anyway).  Also to save bandwidth don't send the topic to
2597         users if the topic is already the same on the server (but still
2598         propergate to other servers).  X/W's "autotopic" feature must
2599         chew a lot of bandwidth, hopefully this will help reduce this.
2600
2601         * doc/rfc1459.rfc: Updated documentation on /topic.
2602
2603         * ircd/listener.c: snotice warnings about failed accept()'s
2604         potentially warning admins that they're running out of fd's.
2605
2606         * ircd/stats.c, ircd/class.c: Removed /stats v, added number of
2607         people in a class in /stats y
2608
2609         * ircd/m_create.c: Checks for timewarp hacking and squit's
2610         evil servers. (currently disabled)
2611         
2612
2613 2000-10-30  net <simms@lucida.qc.ca>
2614         
2615         * ircd/gline.c: Fixed various bugs Isomer left behind.
2616
2617 2000-10-26  Kevin L. Mitchell  <klmitch@mit.edu>
2618
2619         * ircd/m_join.c (m_join): reply on attempt to join a BADCHANed
2620         channel is now ERR_BANNEDFROMCHAN instead of ERR_BADCHANNAME
2621
2622 2000-10-24  Kevin L. Mitchell  <klmitch@mit.edu>
2623
2624         * ircd/channel.c: ok, now last mode rules; mode +ps will always
2625         result in +s (and won't send a mode if the channel is already +s);
2626         mode +sp will always result in +p; -n+n on a +n channel results in
2627         no mode change; -n+n on a -n channel results in a +n mode change;
2628         etc.
2629
2630 2000-10-23  Kevin L. Mitchell  <klmitch@mit.edu>
2631
2632         * ircd/channel.c: add "add" and "del" elements to ParseState to
2633         avoid not-too-pretty -p+s when +s is sufficient; fix a bug in
2634         mode_parse_limit that caused it to clear all channel modes
2635         prematurely; restructure mode_parse_mode to avoid calling
2636         modebuf_mode too early (ties in with first mentioned change);
2637         better logic for +p/+s mutual exclusivity; initialize "add" and
2638         "del" elements in mode_parse; send simple modes down to
2639         modebuf_mode after the loop in mode_parse
2640
2641 2000-09-28  Greg Sikorski <gte@atomicrevs.demon.co.uk>
2642         * ircd/m_names.c: Fixed a non-lethal logic error that 
2643         triggers an assert() in find_member_link while debugging.
2644         (Spotted by Maniac-).
2645 2000-09-19  Thomas Helvey <helveytw@home.com>
2646         * ircd/s_conf.c: move K:lines to their own list and data
2647         structures, add supporting code.
2648         * ircd/m_stats.c: cleanup stats processing a bit move
2649         kline listing code to a new function, haven't figured
2650         out where it goes yet tho'
2651         * ircd/s_stats.c: added K:line bulk lister
2652         * include/s_conf.h: added new DenyConf struct
2653         * *[ch]: fixeup code that depended on changes
2654
2655 2000-09-17  Thomas Helvey <helveytw@home.com>
2656         * ircd/class.c: encapsulate class list
2657         * include/class.h: clean up classes
2658         * * fixup code that depended on changes
2659
2660 2000-09-17  Thomas Helvey <helveytw@home.com>
2661         * ircd/s_conf.c: add me to local conf
2662         * include/s_conf.h: move CONF_ME macro to chkconf.c
2663         * ircd/s_bsd.c: cleanup initialization, allow virtual host
2664         to be changed by rehash
2665
2666 2000-09-17  Thomas Helvey <helveytw@home.com>
2667         * include/class.h: add missing prototype
2668         * ircd/class.c: make argument to get_conf_class const
2669
2670 2000-09-17  Thomas Helvey <helveytw@home.com>
2671         * ircd/*.c: merged in changes from 2.10.10.pl12, cleanup
2672         merge conflicts.
2673         * ircd/*.h: merged in changes from 2.10.10.pl12, cleanup
2674         merge conflicts
2675
2676 2000-09-16  Thomas Helvey <helveytw@home.com>
2677         * ircd/s_conf.c: add code for server struct
2678         * ircd/client.c: copy of class.c sort of, new file for client
2679         specific operations, will move things here as appropriate,
2680         currently only one function is exported from here.
2681         * ircd/*.c: general logic cleanups, convert negatives to
2682         positives in places.
2683
2684 2000-09-16  Thomas Helvey <helveytw@home.com>
2685         * ircd/s_conf.c: add code for new crule data structs, strip quotes
2686         * ircd/crule.c: clean up scary casting a bit, type safety stuff
2687         * include/s_conf.h: add CRuleConf struct and support, remove
2688         unused constants
2689         * include/crule.h: type safety cleanups
2690         * ircd/*.c: fixup code that depended on stuff I changed
2691
2692 2000-09-15  Thomas Helvey <helveytw@home.com>
2693         * ircd/s_conf.c: start adding code for new conf data structs, changed
2694         listeners, admin line, motd lines, class lines. Move validate_hostent
2695         to resolver. General mayhem.
2696         * include/s_conf.h: new data structs and accessors
2697         * ircd/res.c: move validate_hostent here, rewrite, use regular
2698         expression for validation.
2699         * doc/example.conf: update docs for port
2700
2701 2000-09-14  Thomas Helvey <helveytw@home.com>
2702         * ircd/s_conf.c (conf_init): rewrite conf file parser, start to break
2703         up conf_init into managable chunks.
2704         * ircd/listener.c (set_listener_mask): fix logic bug core dump.
2705         * include/s_conf.h: add new data struct for local info (unwinding the mess).
2706
2707 2000-09-13  Thomas Helvey <helveytw@home.com>
2708         * ircd/list.c: put Clients in free lists, pre-allocate MAXCONNECTIONS
2709         local clients.
2710         * ircd/list.c: put SLinks in free lists
2711         * ircd/channel.c: put Memberships in free lists
2712         * ircd/ircd.c: rearrange initializations a bit in main
2713         Note: With these changes, ircd NEVER frees Clients, SLinks or
2714         Memberships. It will also rarely need to allocate new
2715         ones during net bursts and other disruptions. This should
2716         cut down on memory fragmentation a bit as well.
2717
2718 2000-08-30  Kevin L. Mitchell  <klmitch@mit.edu>
2719
2720         * ircd/m_names.c (do_names): pull-up from do_names fix in
2721         u2.10.10.pl11
2722
2723 2000-07-15  Perry Lorier       <Isomer@coders.net>
2724         * various: IP only k:'s and G:'s now do bit tests instead of two(!) 
2725                  match()'s.  Major Major cpu savings.  Also speed up the
2726                  other case slightly.  As a side effect you can now
2727                  k/Gline *@10.0.0.0/8.  I'll do bans tomorrow, it's nearing
2728                  3am.
2729
2730 2000-07-15  Perry Lorier       <Isomer@coders.net>
2731         * various: Fixed warnings after compiling on an alpha.
2732 2000-07-09  Perry Lorier       <Isomer@coders.net>
2733         * doc/ircd.8: Applied grammitical changes by Liandrin, applied
2734                       changes suggested by various other people.
2735         * ircd/IPcheck.c: More bug fixes.  Current problem appears to be
2736                         that it gets a corrupt entry somehow.
2737 2000-07-09  Greg Sikorski <gte@atomicrevs.demon.co.uk>
2738         * ircd/m_oper.c: Clean up compiler warning.
2739
2740 2000-07-08  Perry Lorier       <Isomer@coders.net>
2741         * doc/ircd.8: Updated the documentation, it was slightly out of date
2742                       being updated around 1989.
2743         * ircd/m_whois.c: Rewrote for clarity, and probably a bit more speed.
2744                           fixed a few minor glitches.
2745         * doc/rfc1459.unet: Updated.
2746         * ircd/IPcheck.c: Fixed more bugs.
2747         * ircd/s_bsd.c: We now keep track of servers we've conected.
2748
2749 2000-07-02  Perry Lorier       <Isomer@coders.net>
2750         * ircd/s_misc.c: Fixed remote IPcheck bug.  Ok, I'm a moron, so sue
2751                         me.  Thanks to Hektik, thanks thanks thanks thanks
2752                         thanks thanks thanks thanks thank thanks thank thanks
2753
2754 2000-07-01  Perry Lorier       <Isomer@coders.net>
2755         * ircd/s_conf.c: "Fixed" the "bug" where people would "evade" K:'s.
2756         * ircd/s_conf.c, include/IPcheck.h: Fixed compile warnings.
2757
2758 2000-06-22  Perry Lorier       <Isomer@coders.net>
2759         * ircd/IPcheck.c: Large chunks redone.
2760         * ircd/s_conf.c: Changes due to IPcheck - ONE nolonger supported,
2761                         single AND double digit limits are allowed now.
2762         * misc other: Changes to IPcheck.
2763
2764 2000-06-30  Perry Lorier       <Isomer@coders.net>
2765         * ircd/ircd.c: Fix command line parameter bugs.
2766
2767 2000-06-30  Perry Lorier       <Isomer@coders.net>
2768         * ircd/m_kill.c: Fixed bug with LOCAL_KILL_ONLY
2769         * ircd/m_nick.c: Tidied things up.
2770
2771 2000-06-12 Joseph Bongaarts <foxxe@trms.com>
2772         * ircd/m_stats.c: Iso forgot mo_stats when he added /stats v
2773         
2774 2000-05-29  Perry Lorier       <Isomer@coders.net>
2775         * ircd/m_stats.c: add /stats v to do only the last part of the /trace
2776         * ircd/IPcheck.c: Cosmetic change, if we meddle with it enough do
2777                         you think it'll get bored and fix itself?
2778
2779 2000-06-09  Greg Sikorski <gte@atomicrevs.demon.co.uk>
2780
2781         * ircd/m_names.c: Clean up compiler warnings.
2782
2783 2000-06-09  Kevin L. Mitchell  <klmitch@mit.edu>
2784
2785         * ircd/channel.c (mode_parse_client): don't send warning if
2786         there's not enough arguments for a +/-o/v; means the habit of
2787         doing "/mode #channel +oooooo bob" doesn't result in a bunch of
2788         error messages
2789
2790 2000-06-04  Greg Sikorski <gte@atomicrevs.demon.co.uk>
2791
2792         * ircd/m_names.c: Re-factor code to remove unneccessary
2793         GlobalChannelList iteration every time someone joins a channel.
2794
2795 2000-06-02  Kevin L. Mitchell  <klmitch@mit.edu>
2796
2797         * ircd/s_user.c: add struct Gline * argument to register_user;
2798         look up global glines and repropagate them if necessary; send
2799         acknowledgement of gline to remote servers when registering users
2800
2801         * ircd/s_serv.c (server_estab): don't send acknowledgement of
2802         local glines to remote servers; do send gline acknowledgement of
2803         bursted users
2804
2805         * ircd/m_user.c (m_user): pass new struct Gline * argument to
2806         register_user
2807
2808         * ircd/m_pong.c: pass new struct Gline * argument to register_user
2809
2810         * ircd/m_nick.c (ms_nick): document protocol change
2811
2812         * ircd/gline.c: support GLINE_LASTMOD
2813
2814         * include/s_user.h: add struct Gline * argument to register_user
2815
2816         * include/gline.h: add GLINE_LASTMOD to look up non-zero lastmods
2817
2818         * ircd/s_conf.c (find_kill): add unsigned int argument to
2819         gline_lookup()
2820
2821         * ircd/gline.c: add GLINE_GLOBAL to lookup or find only global
2822         glines; add unsigned int argument to gline_lookup()
2823
2824         * include/gline.h: add GLINE_GLOBAL flag; add unsigned int
2825         argument to gline_lookup()
2826
2827         * ircd/m_server.c: Resend jupe only when there is no %<lastmod>
2828         parameter, or when it falls out of bounds: see comments prior to
2829         call to jupe_resend(); call server_estab with struct Jupe
2830         parameter, so that we place the appropriate %<lastmod> in the
2831         appropriate place.
2832
2833         * ircd/s_serv.c (server_estab): send %<lastmod> for introduced
2834         server, as well as for servers when we're sending the BURST
2835
2836         * include/s_serv.h: add a struct Jupe * to the arguments for
2837         server_estab() so that we can send the appropriate lastmod
2838         parameter
2839
2840         * ircd/m_gline.c (ms_gline): actually, this should be the
2841         slightest bit more efficient...
2842
2843         * ircd/m_jupe.c (ms_jupe): actually, this should be the slightest
2844         bit more efficient...
2845
2846         * ircd/m_gline.c (ms_gline): inhibit GLINE processing resends
2847         during netburst
2848
2849         * ircd/m_jupe.c (ms_jupe): inhibit JUPE processing resends during
2850         netburst
2851
2852         * ircd/channel.c (joinbuf_join): really remove user from local
2853         channels
2854
2855 2000-05-29  Perry Lorier       <Isomer@coders.net>
2856         * ircd/m_names.c: Removed redundant space. 
2857         * ircd/s_bsd.c: Fixed incorrect syntax on ERROR line.
2858
2859 2000-05-18  Kevin L. Mitchell  <klmitch@mit.edu>
2860
2861         * ircd/m_burst.c (ms_burst): er...that should have been a ",", not
2862         a " "
2863
2864 2000-05-04  Kevin L. Mitchell  <klmitch@mit.edu>
2865
2866         * ircd/channel.c: replace bogus assertions with returns, which is
2867         logically correct; only wipe out limit/key if they were originally
2868         set in the first place; remove user from channel when doing a
2869         PARTALL; only send MODE +o for user CREATEing channel if user is
2870         not MyUser--CREATE will only be used if the channel did not
2871         originally exist, therefore we can assume no one local is on the
2872         channel anyway, and we don't exactly need for the user to see an
2873         explicit +o for themselves
2874
2875         * doc/readme.gline: describe the syntax of the GLINE command
2876
2877         * doc/readme.jupe: update to reflect a couple of changes to JUPE
2878
2879         * ircd/gline.c: don't propagate local changes
2880
2881         * ircd/jupe.c: don't propagate local changes
2882
2883         * ircd/m_gline.c (mo_gline): force local flag when deactivating
2884         glines with 0 lastmod
2885
2886         * ircd/gline.c (gline_deactivate): G-lines with zero lastmod time
2887         are now removed instead of being deactivated
2888
2889         * ircd/m_gline.c (ms_gline): make G-lines of the form "GLINE *
2890         -<mask>" be accepted
2891
2892         * ircd/channel.c (send_channel_modes): deal with one of the last
2893         vestiges of sendbuf
2894
2895         * ircd/m_burst.c (ms_burst): debugged ban processing; removed
2896         debugging hooks
2897
2898         * ircd/channel.c (modebuf_extract): remove debugging
2899         sendto_opmask_butone calls
2900
2901 2000-05-03  Kevin L. Mitchell  <klmitch@mit.edu>
2902
2903         * ircd/channel.c: support a couple of new flags to support using
2904         mode_parse; fix some bugs with 0 struct ModeBuf *; implementation
2905         of modebuf_extract to extract added flags for use by ms_burst
2906
2907         * include/channel.h: a couple of new flags to support using
2908         mode_parse inside ms_burst
2909
2910         * ircd/m_burst.c (ms_burst): brand new implementation of BURST
2911
2912         * ircd/m_endburst.c: add loop to processing of end_of_burst to
2913         free empty channels after the BURST is over.
2914
2915         * ircd/m_server.c: convert to use new send.c functions--I wanted
2916         to rewrite it from scratch, but the logic's pretty complex; I may
2917         still rewrite it, though...
2918
2919 2000-05-02  Thomas Helvey <tomh@inxpress.net>
2920
2921         * ircd/ircd.c: fix broken header include ordering
2922
2923 2000-05-02  Thomas Helvey <tomh@inxpress.net>
2924         
2925         * ircd/IPcheck.c: cleanups for ZenShadow's cleanups
2926         review emailed privately
2927
2928         * include/IPcheck.h: removed unneeded include
2929
2930 2000-05-02  Kevin L. Mitchell  <klmitch@mit.edu>
2931
2932         * ircd/s_user.c (hunt_server): throw in a comment so I know what
2933         the sendto_one is for
2934
2935         * include/querycmds.h (Count_unknownbecomesclient): convert to
2936         sendto_opmask_butone
2937
2938         * ircd/send.c: start removing dead code
2939
2940         * include/send.h: start removing dead code
2941
2942         * ircd/m_rping.c: convert to sendcmdto_one / send_reply /
2943         hunt_server_cmd
2944
2945         * ircd/m_rpong.c: convert to sendcmdto_one / send_reply
2946
2947 2000-05-01  Kevin L. Mitchell  <klmitch@mit.edu>
2948
2949         * ircd/m_stats.c: convert to sendcmdto_one / send_reply
2950
2951         * ircd/m_kick.c: Completely reimplement m_kick
2952
2953         * ircd/channel.c: send_user_joins removed; it was dead code,
2954         anyway...
2955
2956 2000-05-01  Perry Lorier <isomer@coders.net>
2957         * ircd/m_invite.c: Fix for the rest of m_invite.c, and again.
2958         * ircd/channels.c: My fix for the part problem.  Untested, probably
2959                 won't work.  Can't be much worse than the current problem.
2960                 it'll either work or core, take your pick.
2961
2962
2963 2000-04-30  Perry Lorier <isomer@coders.net>
2964         * config/config-sh.in: Fix for CONNEXIT
2965         * ircd/s_{user,misc}.c: Fix for CONNEXIT
2966         * ircd/m_invite.c: Fix for incorrectly numnickified invite.
2967                         (Kev: Want to come talk to me about this?)
2968
2969 2000-04-30  Steven M. Doyle <steven@doyle.net>
2970         * ircd/ircd.c
2971           - general cleanups and readability enhancements
2972           - rewrite of setuid/chroot code.
2973           - server will no longer run as root
2974           - -DPROFIL compile option removed
2975           - Fixed IPcheck API calls
2976  
2977         * config/config-sh.in
2978           - Fixed up chroot compile options
2979           - Added options for debug and profile compiles
2980  
2981         * config/gen.ircd.Makefile
2982           - Support for new debug/profile options
2983  
2984         * ircd/Makefile.in
2985           - Support for new debug/profile options
2986  
2987         * ircd/ircd_signal.c
2988           - Removed -DPROFIL
2989
2990         * include/IPcheck.h
2991           - Removed old API prototypes, added new ones
2992         
2993         * ircd/IPcheck.c
2994           - Readability cleanups (well, I -think-...)
2995           - Changed IPRegistryEntry.last_connect to a time_t.  The previously
2996             used unsigned short was probably causing interesting things after
2997             a client had been connected longer than about 65,535 seconds...
2998           - Removed old API functions.
2999
3000         * ircd/whocmds.c
3001           - Removed IPcheck.h include
3002         
3003         * Additionally modified IPcheck API calls in:
3004           - ircd/m_nick.c
3005           - ircd/m_auth.c
3006           - ircd/s_bsd.c
3007           - ircd/s_conf.c
3008           - ircd/s_misc.c
3009           - ircd/s_serv.c
3010           - ircd/s_user.c
3011         
3012         
3013 2000-04-30  Perry Lorier <isomer@coders.net>
3014         * ircd/s_bsd.c: Sigh. :)
3015         * ircd/m_mode.c: fix for modeless channels by poptix.
3016
3017 2000-04-29  Kevin L. Mitchell  <klmitch@mit.edu>
3018
3019         * ircd/m_join.c: reimplement JOIN in terms of struct JoinBuf
3020
3021         * ircd/channel.c (clean_channelname): make clean_channelname also
3022         truncate long channel names
3023
3024 2000-04-28  Kevin L. Mitchell  <klmitch@mit.edu>
3025
3026         * ircd/m_create.c: reimplement CREATE in terms of struct JoinBuf
3027
3028         * ircd/channel.c: implemented joinbuf_init, joinbuf_join,
3029         joinbuf_flush
3030
3031         * include/channel.h: definitions and declarations for the struct
3032         JoinBuf abstraction
3033
3034 2000-04-29  Perry Lorier <isomer@coders.net>
3035         * ircd/s_bsd.c: Ok, so I thought I compiled and tested this...
3036
3037 2000-04-29  Perry Lorier <isomer@coders.net>
3038         * ircd/s_bsd.c: Add debugging code to IPcheck
3039
3040 2000-04-28  Kevin L. Mitchell  <klmitch@mit.edu>
3041
3042         * include/ircd_reply.h (SND_EXPLICIT): use instead of RPL_EXPLICIT
3043
3044         * ircd/ircd_reply.c (send_reply): use SND_EXPLICIT instead of
3045         RPL_EXPLICIT
3046
3047         * ircd/m_userhost.c (m_userhost): add a dead code comment
3048
3049         * ircd/m_desynch.c: forgot one...
3050
3051         * ircd/m_rehash.c (mo_rehash): er, duplicates :)
3052
3053         * ircd/m_proto.c (proto_send_supported): just change a comment so
3054         it doesn't show up in my scans
3055
3056         * ircd/ircd_reply.c (send_reply): fix a slight bug...
3057
3058         * ircd/s_numeric.c (do_numeric): use new sendcmdto_* functions,
3059         kinda hackish...
3060
3061         * ircd/parse.c (parse_server): argument wrangling to make
3062         processing in do_numeric a little easier to deal with
3063
3064         * ircd/s_serv.c (server_estab): SERVER should come from
3065         acptr->serv->up, not &me
3066
3067         * ircd/m_lusers.c: accidentally left out sptr for a %C
3068
3069         * ircd/send.c: hack to support doing wallchops...
3070
3071         * ircd/m_whowas.c: convert to new send functions
3072
3073         * ircd/m_whois.c: convert to new send functions
3074
3075         * ircd/m_who.c: convert to new send functions
3076
3077         * ircd/m_wallops.c: convert to new send functions
3078
3079         * ircd/m_wallchops.c: convert to new send functions
3080
3081         * ircd/m_version.c: convert to new send functions
3082
3083         * ircd/m_userip.c: convert to new send functions
3084
3085         * ircd/m_userhost.c: convert to new send functions
3086
3087         * ircd/m_uping.c: convert to new send functions
3088
3089         * ircd/m_trace.c: convert to new send functions
3090
3091         * ircd/m_topic.c: convert to new send functions
3092
3093         * ircd/m_time.c: convert to new send functions
3094
3095         * ircd/m_squit.c: convert to new send functions
3096
3097         * ircd/m_silence.c: convert to new send functions
3098
3099         * ircd/m_settime.c: convert to new send functions
3100
3101         * ircd/m_restart.c: convert to new send functions
3102
3103         * ircd/m_rehash.c: convert to new send functions
3104
3105         * ircd/m_privmsg.c: convert to new send functions
3106
3107         * ircd/m_pong.c: convert to new send functions
3108
3109         * ircd/m_ping.c: convert to new send functions
3110
3111         * ircd/m_pass.c: convert to new send functions
3112
3113         * ircd/m_opmode.c: convert to new send functions
3114
3115         * ircd/m_oper.c: convert to new send functions
3116
3117         * ircd/m_notice.c: convert to new send functions
3118
3119         * ircd/m_nick.c: convert to new send functions
3120
3121         * ircd/m_names.c: convert to new send functions
3122
3123         * ircd/m_motd.c: convert to new send functions
3124
3125         * ircd/m_mode.c: convert to new send functions
3126
3127         * ircd/m_map.c: convert to new send functions
3128
3129         * ircd/m_lusers.c: convert to new send functions
3130
3131         * ircd/m_list.c: convert to new send functions
3132
3133         * ircd/m_links.c: convert to new send functions
3134
3135         * ircd/m_kill.c: convert to new send functions
3136
3137         * ircd/m_jupe.c: convert to new send functions
3138
3139         * ircd/m_invite.c: convert to new send functions
3140
3141         * ircd/m_info.c: convert to new send functions
3142
3143         * ircd/m_help.c: convert to new send functions
3144
3145         * ircd/m_gline.c: convert to new send functions
3146
3147         * ircd/m_error.c: convert to new send functions
3148
3149         * ircd/m_endburst.c: convert to new send functions
3150
3151         * ircd/m_die.c: convert to new send functions
3152
3153         * ircd/m_destruct.c: convert to new send functions
3154
3155         * ircd/m_defaults.c: convert to new send functions
3156
3157         * ircd/m_connect.c: convert to new send functions
3158
3159 2000-04-28  Perry Lorier <isomer@coders.net>
3160         * RELEASE.NOTES: Describe a few more undocumented features.
3161         * config/config-sh.in: change the default paths for logging
3162         and the recommended number of channels.
3163         * include/supported.h: Rearrange slightly, added CHANTYPE's
3164
3165 2000-04-27  Kevin L. Mitchell  <klmitch@mit.edu>
3166
3167         * ircd/m_close.c: convert to send_reply
3168
3169         * ircd/m_clearmode.c: convert to send_reply, sendcmdto_serv_butone
3170
3171         * ircd/m_away.c: convert to send_reply and sendcmdto_serv_butone
3172
3173         * ircd/m_admin.c: convert to send_reply and hunt_server_cmd
3174
3175         * ircd/s_user.c (hunt_server_cmd): new hunt_server replacement
3176         that takes cmd and tok arguments, etc.  NOTE: THIS IMPLEMENTATION
3177         HAS A MAJOR HACK!!!  The whole hunt_server architecture should be
3178         carefully rethought...
3179
3180         * ircd/s_stats.c (hunt_stats): use new hunt_server_cmd
3181
3182         * include/s_user.h: hunt_server_cmd -- replacement for hunt_server
3183
3184         * ircd/s_misc.c: *sigh* 2.10.10 doesn't support squitting by
3185         numeric nick; therefore, we have to use the server name
3186
3187         * ircd/m_squit.c (ms_squit): allow to squit by server numeric nick
3188
3189         * ircd/send.c: fix minor bugs
3190
3191         * ircd/s_user.c (check_target_limit): mark dead code so I filter
3192         it when I grep
3193
3194         * ircd/s_serv.c (exit_new_server): mark dead code so I filter it
3195         when I grep
3196
3197         * ircd/parse.c: mark dead code so I filter it when I grep
3198
3199         * ircd/map.c: mark dead code so I filter it when I grep
3200
3201         * ircd/ircd.c: mark dead code so I filter it when I grep
3202
3203         * ircd/ircd_relay.c: convert over to new sendcmdto_*, send_reply
3204         functions
3205
3206         * ircd/channel.c: mark dead code so I filter it when I grep
3207
3208         * ircd/s_stats.c: use send_reply instead of sendto_one w/rpl_str;
3209         hope I'm not stepping on toes...
3210
3211         * ircd/s_conf.c: more sendto_opmask_butone / send_reply
3212         conversions; use ircd_snprintf in a couple of cases to negate the
3213         possibility of buffer overflow
3214
3215 2000-04-26  Kevin L. Mitchell  <klmitch@mit.edu>
3216
3217         * ircd/channel.c: convert as much as possible to new send
3218         semantics
3219
3220         * ircd/send.c (sendcmdto_common_channels): fix a subtle bug --
3221         test member->user->from->fd, not from->fd
3222
3223         * ircd/gline.c (gline_add): go ahead and add badchans; we just
3224         won't look for them in m_gline; this way, they always work...
3225
3226         * ircd/jupe.c: use ircd_vsnprintf conversion specifiers
3227
3228         * ircd/gline.c: since write_log now uses ircd_vsnprintf, use
3229         ircd_vsnprintf conversion specifiers
3230
3231         * ircd/support.c (write_log): use ircd_vsnprintf for write_log, so
3232         I have my conversion specifiers
3233
3234         * ircd/gline.c (do_gline): use send_reply for ERR_YOUREBANNEDCREEP
3235
3236         * ircd/send.c (sendcmdto_flag_butone): explicitly send WALLOPS to
3237         local users
3238
3239         * ircd/s_serv.c (exit_new_server): rewrite exit_new_server to be a
3240         little less brain-dead
3241
3242         * ircd/s_misc.c: use sendcmdto_one, sendrawto_one, and send_reply
3243
3244         * ircd/s_debug.c: use send_reply with RPL_EXPLICIT for
3245         RPL_STATSDEBUG
3246
3247         * ircd/res.c (cres_mem): use send_reply with RPL_EXPLICIT for
3248         RPL_STATSDEBUG
3249
3250         * ircd/list.c (send_listinfo): use send_reply with RPL_EXPLICIT
3251         for RPL_STATSDEBUG
3252
3253         * ircd/m_pong.c: use RPL_EXPLICIT for ERR_BADPING
3254
3255         * ircd/ircd.c: use RPL_EXPLICIT for ERR_BADPING
3256
3257         * ircd/s_user.c (register_user): use RPL_EXPLICIT for
3258         ERR_INVALIDUSERNAME
3259
3260         * ircd/ircd_reply.c (send_reply): support RPL_EXPLICIT
3261
3262         * include/ircd_reply.h (RPL_EXPLICIT): somewhat of a hack to mark
3263         a numeric as needing to use an explicit pattern, which will be the
3264         first argument in the variable argument list
3265
3266         * ircd/s_user.c: use sendrawto_one instead of sendto_one to send
3267         non-prefixed nospoof PING
3268
3269         * ircd/s_bsd.c: use sendrawto_one instead of sendto_one to send
3270         non-prefixed SERVER login
3271
3272         * ircd/ircd.c (check_pings): fix last sendto_one calls (except for
3273         a numeric usage further up)
3274
3275         * include/send.h: declare sendrawto_one
3276
3277         * ircd/send.c (sendrawto_one): new function to use ONLY for
3278         non-prefixed commands, like PING to client, or PASS/SERVER on
3279         server registration
3280
3281 2000-04-25  Kevin L. Mitchell  <klmitch@mit.edu>
3282
3283         * ircd/ircd_snprintf.c (doprintf): implement %H for possible
3284         future expansion (channel numerics?)
3285
3286         * include/ircd_snprintf.h: added documentation to # to explain use
3287         with %C; added documentation for : to explain use with %C; added
3288         documentation for %H for channels
3289
3290         * ircd/whocmds.c: use send_reply
3291
3292         * ircd/userload.c: use sendcmdto_one
3293
3294         * ircd/uping.c: use sendcmdto_one
3295
3296         * ircd/send.c: use new flags to %C format string; ':' prefixes
3297         client name with a colon for local connects, '#' uses
3298         nick!user@host form for local connects
3299
3300         * ircd/s_user.c: use send_reply, sendto_opmask_butone,
3301         sendcmdto_one, sendcmdto_serv_butone, sendcmdto_flag_butone
3302
3303         * ircd/s_serv.c: use sendcmdto_one, sendto_opmask_butone
3304
3305         * ircd/s_bsd.c: use sendto_opmask_butone, send_reply,
3306         sendcmdto_one
3307
3308         * ircd/s_auth.c: use sendto_opmask_butone
3309
3310         * ircd/res.c: use sendcmdto_one
3311
3312         * ircd/ircd_snprintf.c (doprintf): minor bug fixes and some
3313         debugging assertions
3314
3315 2000-04-24  Kevin L. Mitchell  <klmitch@mit.edu>
3316
3317         * ircd/support.c: dumpcore is no longer used, so get rid of it
3318
3319         * ircd/parse.c: use send_reply, sendcmdto_one
3320
3321         * ircd/map.c: use send_reply
3322
3323         * ircd/listener.c: use send_reply
3324
3325         * ircd/jupe.c: use sendto_opmask_butone, send_reply
3326
3327         * ircd/ircd_reply.c: use send_reply
3328
3329         * ircd/ircd.c: use sendto_opmask_butone
3330
3331         * ircd/gline.c: use sendto_opmask_butone, send_reply
3332
3333         * ircd/ircd_snprintf.c (doprintf): make it deal with incompletely
3334         registered clients; make FLAG_ALT print nick!user@host; make
3335         FLAG_COLON print :blah
3336
3337         * ircd/class.c (report_classes): use send_reply instead of
3338         sendto_one
3339
3340         * ircd/hash.c (m_hash): replace sendto_one with sendcmdto_one
3341
3342         * ircd/IPcheck.c (ip_registry_connect_succeeded): replace
3343         sendto_one with sendcmdto_one
3344
3345 2000-04-21  Kevin L. Mitchell  <klmitch@mit.edu>
3346
3347         * ircd/send.c: clean up logic in sendcmdto_channel_butone; use
3348         MyConnect() instead of IsServer() in sendcmdto_flag_butone; define
3349         sendcmdto_match_butone
3350
3351         * include/send.h: declare sendcmdto_match_butone
3352
3353 2000-04-20  Kevin L. Mitchell  <klmitch@mit.edu>
3354
3355         * ircd/jupe.c: update to use send_reply()
3356
3357         * ircd/gline.c: update to use send_reply()
3358
3359         * include/ircd_reply.h: declare send_reply
3360
3361         * ircd/ircd_reply.c (send_reply): send_error_to_client, but for
3362         replies; uses ircd_snprintf
3363
3364         * ircd/send.c: added comments to redirect searchers to appropriate
3365         sendcmdto_* function; moved new functions to end of file; added
3366         explanatory comments; reordered arguments; defined new functions
3367         mentioned below
3368
3369         * ircd/m_jupe.c: reorder arguments to sendcmdto_* functions
3370
3371         * ircd/m_gline.c: reorder arguments to sendcmdto_* functions
3372
3373         * ircd/jupe.c: reorder arguments to sendcmdto_* functions
3374
3375         * ircd/gline.c: reorder arguments to sendcmdto_* functions
3376
3377         * include/send.h: reorder arguments, add explanatory comments,
3378         declare new functions sendcmdto_flag_butone, sendto_opmask_butone,
3379         and vsendto_opmask_butone
3380
3381 2000-04-19  Kevin L. Mitchell  <klmitch@mit.edu>
3382
3383         * ircd/send.c: define sendcmdto_channel_butone, wrote a simplified
3384         vsendto_op_mask that uses '*' instead of the receiving client
3385         nickname
3386
3387         * include/send.h: declare sendcmdto_channel_butone; takes a skip
3388         argument that allows you to skip (or not to skip) deaf users,
3389         users behind bursting servers, and non channel operators
3390
3391 2000-04-17  Kevin L. Mitchell  <klmitch@mit.edu>
3392
3393         * ircd/send.c: new sendcmdto_channel_butserv -- note that old
3394         sendto_channel_butserv has a subtle bug; also wrote
3395         sendcmdto_common_channels.
3396
3397         * include/send.h: declare new sendcmdto_* functions
3398
3399         * ircd/jupe.c: support local deactivations of jupes
3400
3401         * ircd/gline.c: support local deactivations of glines
3402
3403         * include/jupe.h: JUPE_LDEACT allows jupes to be locally
3404         deactivated; if they aren't locally deactivated, then it slaves to
3405         the net-wide activation status; JupeIsRemActive() tests only
3406         whether the jupe is active everywhere else
3407
3408         * include/gline.h: GLINE_LDEACT allows glines to be locally
3409         deactivated; if they aren't locally deactivated, then it slaves to
3410         the net-wide activation status; GlineIsRemActive() tests only
3411         whether the gline is active everywhere else
3412
3413         * ircd/gline.c: detect overlapping G-lines; if an existing, wider
3414         gline expires after the new one will, we drop the new one,
3415         otherwise we add the G-line after that one (so the wide one will
3416         apply first); if the new one contains an existing G-line and if it
3417         will expire after the existing one, we drop the existing one to
3418         save memory
3419
3420         * ircd/m_gline.c (mo_gline): opers could issue remote local
3421         glines when CONFIG_OPERCMDS was off; fixed
3422
3423 2000-04-16  Kevin L. Mitchell  <klmitch@mit.edu>
3424
3425         * ircd/m_jupe.c (mo_jupe): allow target argument to be dropped if
3426         this is a local JUPE
3427
3428         * ircd/gline.c: add flags argument to gline_activate and
3429         gline_deactivate for future expansion
3430
3431         * ircd/m_gline.c: pass flags to gline_activate and
3432         gline_deactivate
3433
3434         * include/gline.h: add flags argument to gline_activate and
3435         gline_deactivate
3436
3437         * ircd/jupe.c: add flags argument to jupe_activate and
3438         jupe_deactivate for future expansion
3439
3440         * include/jupe.h: add flags argument to jupe_activate and
3441         jupe_deactivate
3442
3443         * ircd/m_jupe.c: pass a flags argument to jupe_add instead of
3444         local, active; pass flags to jupe_activate and jupe_deactivate
3445
3446         * include/gline.h: remove dead code
3447
3448         * ircd/gline.c: make gline expire times relative to CurrentTime,
3449         since that should be monotonically increasing, instead of
3450         TStime(), which can be set backwards, and which can therefore
3451         cause an expire time to increase; make local glines be removed
3452         instead of just deactivated; don't let gline_find() look for
3453         user@host glines if the mask being looked up is a channel mask
3454
3455         * ircd/send.c (vsendcmdto_one): forgot to account for the case
3456         where origin is a server and destination is a user
3457
3458         * ircd/jupe.c: make jupe expire times relative to CurrentTime,
3459         since that should be monotonically increasing, instead of
3460         TStime(), which can be set backwards, and which can therefore
3461         cause an expire time to increase; make local jupes be removed
3462         instead of just deactivated
3463
3464         * ircd/ircd_snprintf.c: d'oh, thanks for catching that; short for
3465         limit is fine.  any other warnings I should know about?
3466
3467 2000-04-15  Thomas Helvey <tomh@inxpress.net>
3468
3469         * ircd/*.c: const correctness and type safety cleanups to
3470         get code to compile with C++ compiler. Still has
3471         signed/unsigned comparison warnings.
3472
3473 2000-04-15  Greg Sikorski <gte@atomicrevs.demon.co.uk>
3474
3475         * ircd/userload.c: change <sys/time.h> include to <time.h> for
3476           portability.
3477
3478 2000-04-14  Kevin L. Mitchell  <klmitch@mit.edu>
3479
3480         * ircd/m_gline.c (mo_gline): d'oh, target isn't a numeric; use %C
3481         and convert acptr...
3482
3483         * ircd/s_user.c: move gline_lookup function call into
3484         register_user, where it'll have a username to lookup!
3485
3486         * ircd/m_gline.c: modify to utilize new sendcmdto_* series of
3487         functions; also stuff send_error_to_client into return clauses
3488
3489         * ircd/m_jupe.c: modify to utilize new sendcmdto_* series of
3490         functions; also use send_error_to_client where that makes sense
3491
3492         * ircd/jupe.c: modify to utilize new sendcmdto_* series of
3493         functions; also use send_error_to_client where that makes sense
3494
3495         * ircd/gline.c: modify to utilize new sendcmdto_* series of
3496         functions; also fix gline_lookup() to deal properly with remote
3497         clients--boy, do struct Client and struct User need to be cleaned
3498         up!
3499
3500         * ircd/ircd_snprintf.c (doprintf): a dest of &me is a server,
3501         too...
3502
3503         * ircd/send.c: wrote sendcmdto_one(), vsendcmdto_one(), and
3504         sendcmdto_serv_butone(), all utilizing the %v conversion of
3505         ircd_snprintf()
3506
3507         * include/send.h: define IRC_BUFSIZE, max size of a message;
3508         declare sendcmdto_one(), vsendcmdto_one(), and
3509         sendcmdto_serv_butone()
3510
3511         * include/msg.h: define all the CMD_* constants needed to utilize
3512         the new sendcmdto_* series of functions
3513
3514         * ircd/Makefile.in (SRC): list ircd_snprintf.c; run make depend
3515
3516         * ircd/gline.c: remove old, dead code.
3517
3518         * ircd/m_gline.c (mo_gline): disallow setting of global G-lines
3519         unless CONFIG_OPERCMDS is enabled; disallow listing of all G-lines
3520         (don't advertise proxies); remove dead code
3521
3522         * ircd/parse.c: oper handler for JUPE only lists jupes unless
3523         CONFIG_OPERCMDS is enabled
3524
3525         * ircd/m_jupe.c (mo_jupe): don't compile mo_jupe() if
3526         CONFIG_OPERCMDS is not enabled; we'll disable it in parse.c
3527
3528         * ircd/m_opmode.c (mo_opmode): if CONFIG_OPERCMDS is not enabled,
3529         always return ERR_DISABLED
3530
3531         * ircd/m_clearmode.c (mo_clearmode): if CONFIG_OPERCMDS is not
3532         enabled, always return ERR_DISABLED
3533
3534         * ircd/s_err.c: add error message to indicate disabled commands
3535
3536         * include/numeric.h (ERR_DISABLED): to indicate disabled commands
3537
3538         * doc/Configure.help: add documentation for CONFIG_OPERCMDS
3539
3540         * config/config-sh.in: add CONFIG_OPERCMDS, default both it and
3541         CONFIG_NEW_MODE to 'y' for now
3542
3543         * ircd/gline.c (gline_list): fix a minor formatting bogon
3544
3545         * BUGS: since I fixed that bug, might as well mark it fixed.
3546
3547         * ircd/m_join.c: look up badchans with GLINE_EXACT
3548
3549         * ircd/m_gline.c: fix parc count problems; look up existing
3550         G-lines with GLINE_EXACT; only set new lastmod when
3551         activating/deactivating existing glines if old lastmod was not 0
3552
3553         * ircd/gline.c: forgot to copy the gline reason over; don't
3554         propagate a gline with 0 lastmod if origin is user; add
3555         GLINE_EXACT to force exact matching of gline mask
3556
3557         * ircd/ircd_snprintf.c (doprintf): forgot to deal with the zero
3558         flag properly
3559
3560         * ircd/s_conf.c (find_kill): gline_find() takes a char *userhost,
3561         but gline_lookup() actually takes a client--d'oh.
3562
3563 2000-04-13  Thomas Helvey <tomh@inxpress.net>
3564         * ircd/IPcheck.c: Back port BLMet's bugfix from 2.10.10
3565
3566 2000-04-13  Greg Sikorski <gte@atomicrevs.demon.co.uk>
3567
3568         * ircd/whocmds.c: Don't make idle flag default in /who, to prevent:
3569           "/who * x"
3570           "Gte3 H*iwg Gte@212.49.240.217 :1 :0 I am the one that was."
3571           (Found by Plexus).
3572
3573         * ircd/whocmds.c: Change idle time calc from socket idle to user
3574           idle.
3575
3576 2000-04-13  Kevin L. Mitchell  <klmitch@mit.edu>
3577
3578         * config/aclocal.m4 (unet_CHECK_TYPE_SIZES): check size of void *,
3579         too, for ircd_snprintf.c
3580
3581         * include/ircd_snprintf.h: documentation for ircd_(v)snprintf, in
3582         comments; mostly descended from the Linux manpage for printf, but
3583         also documenting the extensions.
3584
3585         * ircd/ircd_snprintf.c: NULL dest is equivalent to going to a
3586         client; make 'q' be the same as 'L'; remove __inline__; only
3587         define EXTENSION if HAVE_LONG_LONG is defined
3588
3589         * include/handlers.h: declare m_gline()
3590
3591         * ircd/parse.c: gline can be called by users, but it only lists
3592         the glines.
3593
3594         * ircd/s_user.c (set_nick_name): resend gline if a remote server
3595         introduces a glined client
3596
3597         * ircd/s_serv.c (server_estab): burst glines, too
3598
3599         * ircd/gline.c: fix up all the expire times to be offsets;
3600         simplify gline_resend()
3601
3602         * ircd/m_gline.c: begin coding replacements for ms_gline(),
3603         mo_gline(), and m_gline()
3604
3605         * ircd/gline.c (gline_add): allow *@#channel to work correctly;
3606         also, prohibit local BADCHANs if LOCAL_BADCHAN not defined
3607
3608 2000-04-13  Greg Sikorski <gte@atomicrevs.demon.co.uk>
3609
3610         * tools/Bouncer/*: Add comments/documentation/tags.
3611         * tools/Bouncer/*: Add debug defines, make task fork().
3612
3613 2000-04-12  Thomas Helvey <tomh@inxpress.net>
3614         * ircd/s_err.c: Cleanup s_err.c make one table so we
3615         don't have to do anything tricky to get an error string.
3616
3617 2000-04-12  Greg Sikorski <gte@atomicrevs.demon.co.uk>
3618         * Add port bouncer for http (x/w)
3619
3620 2000-04-12  Kevin L. Mitchell  <klmitch@mit.edu>
3621
3622         * ircd/s_conf.c (find_kill): replaced call to find_gline() with a
3623         call to gline_find(); also used GlineReason() instead of direct
3624         reference to structure member
3625
3626         * ircd/m_join.c (m_join): replace bad_channel() calls with calls
3627         to gline_find(name, GLINE_BADCHAN), and also check to see if gline
3628         is active
3629
3630         * ircd/channel.c: nothing seems to be called anywhere...
3631
3632         * ircd/s_err.c: update a couple of replies to dovetail with new
3633         semantics
3634
3635         * ircd/gline.c: begin complete re-implementation of gline.c along
3636         the lines of the final design of jupe.c
3637
3638         * include/gline.h: begin complete re-implementation of gline.c
3639         along the lines of the final design of jupe.c
3640
3641         * ircd/channel.c (mode_process_clients): fix "Deop of +k user on
3642         %s by %s" message...
3643
3644         * ircd/ircd_snprintf.c: my new snprintf()-like functions
3645
3646         * include/ircd_snprintf.h: my new snprintf()-like functions
3647
3648 2000-04-11  Thomas Helvey <tomh@inxpress.net>
3649         * ircd/IPcheck.c: removed old dead code
3650         * ircd/s_user.c (send_user_info): removed non-standard
3651           user not found message for userhost/userip
3652
3653 2000-04-11  Greg Sikorski <gte@atomicrevs.demon.co.uk>
3654
3655         * ircd/s_err.c: Added missing quotes to ERR_DONTCHEAT numeric.
3656         * doc/p10.html: Work on chapter 4.
3657
3658 2000-04-10  Kevin L. Mitchell  <klmitch@mit.edu>
3659
3660         * ircd/channel.c (mode_parse_client): fix coredump on /mode
3661         #foobar +o nosuchnick
3662
3663 2000-04-10  Perry Lorier  <Isomer@coders.net>
3664         * BUGS: Added bug.
3665
3666 2000-04-09  Thomas Helvey <tomh@inxpress.net>
3667         * include/IPcheck.h: fix prototype
3668         * ircd/s_user.c: fix usage of IPcheck_remote_connect
3669         * ircd/IPcheck.c: removed unused args
3670
3671 2000-04-09  Thomas Helvey <tomh@inxpress.net>
3672         * include/IPcheck.h: add proto for IPcheck_expire
3673
3674         * ircd/IPcheck.c: Rewrote
3675
3676         * ircd/ircd.c: Add IPcheck_expire to main message loop
3677
3678         * ircd/s_user.c: Redo target hashing, refactor target code
3679
3680         * include/numeric.h: Cleaned up numerics, added which ones are
3681         in use by other networks and what they are in use for.
3682
3683         * ircd/channel.c: cleaned can_join(), allow anyone through anything
3684         if /invited, simplified the function.  Opers overusing OPEROVERRIDE
3685         will get a message explaining to them not to cheat.
3686
3687         * ircd/m_join.c: cleaned up the various join functions, should be
3688         a lot more efficient.  Still needs work.  Now assumes that s<->s
3689         won't send it a JOIN 0.  Service coders - note this and tread with
3690         care.
3691
3692         * ircd/m_stats.c: added Gte-'s stats doc patch.
3693
3694         * ircd/m_version.c: /version now returns the 005 numeric as well.
3695         as requested by Liandrin.
3696
3697
3698 2000-04-07  Kevin L. Mitchell  <klmitch@mit.edu>
3699
3700         * ircd/m_clearmode.c: add include for support.h for write_log()
3701
3702         * configure: move ircd/crypt/* to tools/*
3703
3704 2000-04-06  Thomas Helvey <tomh@inxpress.net>
3705         * ircd/s_auth.c: Shorten auth connect timeout to 60 seconds
3706           set client host to server alias if connection from localhost
3707
3708 2000-04-06  Perry Lorier <isomer@coders.net>
3709         * ircd/ircd.c: Fix core during pinging (oops)
3710         
3711 2000-04-06  Perry Lorier <isomer@coders.net>
3712         * ircd/send.c: fixed wrong ident being sent to channels bug.
3713         * include/numerics.h: Updated some of the numerics from other
3714         networks.  Flagged some as 'unused' by undernet.
3715
3716 2000-03-30  Perry Lorier <isomer@coders.net>
3717         * ircd/ircd.c: Lets see if this helps the ping problem at all.
3718         * ircd/whocmds.c, /doc/readme.who: Added %l specifier to get idle
3719         time for local clients. (as requested), extended who now returns all
3720         the flags (@+!) so you can tell the complete state of a client.
3721
3722 2000-03-30  Thomas Helvey <tomh@inxpress.net>
3723         * m_rping.c m_rpong.c: add Gte's rping/rpong fixes
3724
3725 2000-03-30  Perry Lorier <isomer@coders.net>
3726         * ircd/parse.c: oops, missed opers.
3727
3728 2000-03-30  Perry Lorier <isomer@coders.net>
3729         * ircd/parse.c: fixed mystifying ping bug thats been plaguing us
3730         for so long.  Remember: m_ping MUST be in the parse array. :)
3731
3732 2000-03-30  Perry Lorier <isomer@coders.net>
3733         * ircd/ircd.c: test in check_pings was wrong.  I move that we
3734         disallow cvs commit after 10pm localtime....
3735
3736 2000-03-30  Perry Lorier <isomer@coders.net>
3737         * ircd/m_pong.c: Fix it for servers too.
3738
3739 2000-03-30  Perry Lorier <isomer@coders.net>
3740         * ircd/m_pong.c: Fix ping timeout bugs
3741
3742 2000-03-30  Perry Lorier <isomer@coders.net>
3743         * ircd/channel.c: Bans had CurrentTime in their when field instead
3744         of TStime()
3745
3746 2000-03-31  Thomas Helvey <tomh@ixpress.net>
3747         * ircd/numnicks.c (SetXYYCapacity): fix for extended
3748         numerics.
3749
3750 2000-03-30  Perry Lorier <isomer@coders.net>
3751         * ircd/m_nick.c: send kills both ways so when we add nick change
3752         on collision we don't desync the network.
3753
3754         * ircd/map.c: Fixup the map a bit more.
3755
3756 2000-03-31  Kevin L. Mitchell  <klmitch@mit.edu>
3757
3758         * ircd/m_clearmode.c (do_clearmode): Log the CLEARMODE to OPATH
3759
3760         * ircd/m_opmode.c: Log the mode changes to OPATH
3761
3762         * ircd/channel.c (modebuf_flush_int): Log the mode changes to
3763         OPATH
3764
3765         * include/channel.h (MODEBUF_DEST_LOG): Log the mode changes to
3766         OPATH
3767
3768         * doc/Configure.help: help text for CONFIG_LOG_OPMODE / OPATH
3769
3770         * config/config-sh.in: added OPATH for opmode log file
3771
3772         * ircd/m_clearmode.c (do_clearmode): updated uses of
3773         modebuf_mode_string() for the new usage
3774
3775         * ircd/channel.c: added flag MODE_FREE and an int argument to
3776         modebuf_mode_string() to indicate that the string must be free'd;
3777         updated calls to modebuf_mode_string() for the new usage; called
3778         collapse(pretty_mask()) on the ban string and use allocated memory
3779         for it; added ban list length accounting; fixed a number of small
3780         bugs in ban processing
3781
3782         * include/channel.h: added flag MODE_FREE and an int argument to
3783         modebuf_mode_string() to indicate that the string must be free'd
3784
3785         * ircd/m_clearmode.c (do_clearmode): made sure clearmode removed
3786         keys and limits that are set
3787
3788 2000-03-30  Perry Lorier <isomer@coders.net>
3789         * ircd/ircd.c: rewrote check_pings() for maintainability
3790         and speed.  Also changed quit msg's so they don't have
3791         redundant nick[host] info in them.
3792
3793         * ircd/send.c: Changed write errors to report what error
3794         occured (if possible).
3795
3796         * ircd/gline.c: added gline comment to the quit.
3797
3798         * ircd/m_server.c: Added suggestions to server quits mentioning
3799         what went wrong so the admin can fix it earlier instead of asking
3800         questions...
3801
3802         * ircd/map.c: Changed m_map() to hide numerics, show a * beside
3803         servers that aren't fully burst yet.  And show '(--s)' for servers
3804         where its not sure.
3805
3806         * doc/example.conf: Fixed wrapped U:
3807
3808 2000-03-30  Kevin L. Mitchell  <klmitch@mit.edu>
3809
3810         * ircd/m_mode.c (ms_mode): implemented a new m_mode in terms of
3811         mode_parse() (version selectable at compile time)
3812
3813         * ircd/m_clearmode.c (mo_clearmode): clean_channelname(parv[1])
3814
3815         * ircd/m_opmode.c (mo_opmode): clean_channelname(parv[1])
3816
3817         * config/config-sh.in: add new config option to enable new m_mode
3818         implementation
3819
3820         * doc/Configure.help: add documentation for new config option
3821         CONFIG_NEW_MODE
3822
3823         * ircd/channel.c (mode_parse_client): /opmode #foobar -o -- 461
3824         MODE -v : Not enough parameters
3825
3826         * ircd/m_clearmode.c (do_clearmode): do_clearmode() would remove
3827         +k and +l even if they weren't set...
3828
3829         * ircd/m_opmode.c: implement the OPMODE command using mode_parse()
3830
3831         * ircd/channel.c: make mode_process_clients() clear the DEOPPED
3832         flag; fix +s+p exclusivity; add MODE_ADD/MODE_DEL to flag list
3833         for; test the 0-th member, not the i-th member, of the client
3834         change state stuff
3835
3836         * ircd/m_clearmode.c (do_clearmode): use the new
3837         mode_invite_clear() function
3838
3839         * ircd/channel.c: cleared up all the compile-time warnings and
3840         errors
3841
3842         * include/channel.h: added declarations for mode_ban_invalidate()
3843         and mode_invite_clear()
3844
3845         * ircd/channel.c: finished mode_parse(), then broke it up into a
3846         dozen or so helper functions to make the code easier to read
3847
3848 2000-03-29  Thomas Helvey <tomh@inxpress.net>
3849         * ircd/ircd.c: refactor server initialization a bit, use
3850         getopt for parsing command line, refactor init_sys, main,
3851         and other bits.
3852
3853         * ircd/s_bsd.c: add functions for initialization to clean
3854         up logic a bit and remove duplicated code.
3855
3856         * include/ircd.h: add struct for server process related
3857         variables.
3858
3859 2000-03-29  Kevin L. Mitchell  <klmitch@mit.edu>
3860
3861         * ircd/channel.c: initial definition of mode_parse(); flags to
3862         prevent doing the same thing multiple times; helper method
3863         send_notoper() to send a "Not oper"/"Not on channel" notice
3864
3865         * include/channel.h: declare mode_parse() and helper flags
3866
3867         * ircd/channel.c (modebuf_flush_int): fiddled with timestamp
3868         sending to match the current action of set_mode() closely enough
3869         that hopefully there won't be major conflicts
3870
3871         * ircd/channel.c (modebuf_flush_int): consolidated the mode string
3872         building logic, reversed the order of the arguments to mode
3873         commands to have '-' preceed '+'
3874
3875 2000-03-29  Thomas Helvey <tomh@inxpress.net>
3876         * ircd/s_bsd.c (add_connection): don't disable socket options
3877         let OS tune itself and allow important performance tweaks to 
3878         work.
3879
3880 2000-03-28  Kevin L. Mitchell  <klmitch@mit.edu>
3881
3882         * ircd/channel.c (modebuf_flush_int): use %d, not %-15d; I got
3883         confused by set_mode, which is doing some really weird logic;
3884         guess what I'm going to rewrite next?  ;)
3885
3886 2000-03-28  Kevin L. Mitchell  <klmitch@emc.com>
3887
3888         * include/channel.h: added MODE_SAVE for the bounds checking stuff
3889         in modebuf_flush
3890
3891         * ircd/channel.c: make modebuf_flush into modebuf_flush_int and
3892         make it do bounds checking on the buffer; all modes are sent only
3893         if the all parameter is 1; modebuf_flush is the exported wrapper
3894
3895         * include/channel.h: add BOUNCE, renumber flags to get a little
3896         more space
3897
3898         * ircd/channel.c (modebuf_flush): don't overload HACK2, add
3899         BOUNCE; send DESYNCH message
3900
3901 2000-03-27  Kevin L. Mitchell  <klmitch@emc.com>
3902
3903         * ircd/m_clearmode.c (do_clearmode): only mark the modes the
3904         channel actually has in effect for deletion
3905
3906         * ircd/channel.c: added explanatory comments to all added
3907         functions; made flushing take place at the correct place even if
3908         the MODEBUF_DEST_DEOP flag is set; rewrote build_string() helper
3909         to bash some stupid bugs; made modebuf_flush() return if ModeBuf
3910         is empty, fixed the apparent source, removed some bogus string
3911         termination code, properly terminate the mode strings, add support
3912         for HACK2 and HACK3, made limit strings not be sent if the limit
3913         is being removed, changed where '+' and '-' come from in sent
3914         strings, added support for DEOP flag, set up bouncing code for
3915         HACK2
3916
3917         * ircd/Makefile.in: ran make depend
3918
3919         * include/channel.h: added new defines for future functionality,
3920         made modebuf_flush() return int so I can use tail recursion
3921
3922         * ircd/m_clearmode.c: add msg.h to includes; other misc cleanups
3923         to make it all compile
3924
3925         * ircd/m_opmode.c: add msg.h to includes...
3926
3927         * ircd/m_clearmode.c: implemented mo_clearchan()/ms_clearchan()
3928
3929         * ircd/channel.c (modebuf_flush): realized I forgot to
3930         nul-terminate addbuf/rembuf properly...
3931
3932         * ircd/m_clearmode.c (do_clearmode): wrote do_clearmode()...
3933
3934         * ircd/channel.c (modebuf_flush): correct sendto_server_butone to
3935         sendto_serv_butone--blah^2
3936
3937         * ircd/send.c (sendto_serv_butone): stupid comments confused me
3938
3939         * ircd/channel.c (modebuf_flush): if there are no mode changes to
3940         propagate, we're done...
3941
3942         * ircd/channel.c (modebuf_flush): duh; it's sendto_server_butone,
3943         not sendto_all_butone
3944
3945         * ircd/m_clearmode.c: define skeleton for m{o,s}_clearmode
3946
3947         * ircd/m_opmode.c: define skeleton for m{o,s}_opmode
3948
3949         * ircd/Makefile.in (SRC): added m_opmode() and m_clearmode() to
3950         the list
3951
3952         * ircd/parse.c: added messages for opmode and clearmode
3953
3954         * include/handlers.h: added declarations for mo_opmode(),
3955         ms_opmode(), mo_clearmode(), and ms_clearmode()
3956
3957         * include/msg.h: define MSG_OPMODE, TOK_OPMODE, MSG_CLEARMODE, and
3958         TOK_CLEARMODE
3959
3960         * include/channel.h (MODEBUF_DEST_OPMODE): Define the
3961         MODEBUF_DEST_OPMODE flag
3962
3963         * ircd/channel.c (modebuf_flush): added new flag,
3964         MODEBUF_DEST_OPMODE; causes channel MODE/HACK(4) notice to appear
3965         to originate from source's server (or source itself, if
3966         IsServer(source)); also causes a server-level MODE to be sent as
3967         OPMODE instead
3968
3969         * include/channel.h: defined MODEBUF_DEST_SERVER,
3970         MODEBUF_DEST_HACK4
3971
3972         * ircd/channel.c: Add another argument to build_string() to handle
3973         numeric nicks; implemented MODEBUF_DEST_SERVER to send MODEs to
3974         servers; implemented MODEBUF_DEST_HACK4 to cause HACK(4) notices
3975         to be sent out
3976
3977 2000-03-27  Perry Lorier <isomer@coders.net>
3978
3979         * ircd/s_bsd.c: fixed missing 'u' typo.
3980
3981 2000-03-26  Kevin L. Mitchell  <klmitch@emc.com>
3982
3983         * ircd/channel.c: implement modebuf_init(), _mode(), _mode_uint(),
3984         _mode_string(), _mode_client(), _flush(); also implemented a
3985         simple build_string()
3986
3987         * include/channel.h: added definition of ModeBuf, modebuf_*
3988         manipulation functions, and a couple of helper macros
3989
3990 2000-03-24 Thomas Helvey <tomh@inxpress.net>
3991   * numicks.c: convert extended numerics to use original mask version
3992   * numnicks.h: ""
3993   * s_user.c:
3994 2000-03-23 Thomas Helvey <tomh@inxpress.net>
3995   * Merge in changes from production
3996 2000-03-22 Thomas Helvey <tomh@inxpress.net>
3997   * numicks.c: Tweak to numnick generator to reduce possibility of duplicates.
3998   * rfc1459.unet: Add Maniac's documentation for /names 0
3999 * Fix misc. jupe bugs that somehow made it into the tree
4000 * Escape /names 0 to mean /names --Maniac
4001 * Don't core when server asks for info --Maniac 
4002 * Add Kev's jupe patch --Bleep
4003 * Add Maniacs squit patch --Bleep
4004 * Merge in u2_10_10_beta07 changes --Bleep
4005 * Merge in u2_10_10_beta06 changes --Bleep
4006 * Start ircu2.10.11 development, beta branch u2_10_10 --Bleep
4007 #-----------------------------------------------------------------------------