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