]> code.citadel.org Git - citadel.git/blob - citadel/ChangeLog
434e652d71ecbac78d85aea43a1a3fa8987a9798
[citadel.git] / citadel / ChangeLog
1 Fri Oct 23 19:34:38 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
2         * setup.c: default node name is now obtained from uname()
3
4 Wed Oct 21 22:24:48 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
5         * Mail rooms now hide their owner-prefix from the client.
6         * proxy.c: added configurability and primitive message expiry
7
8 1998-10-20 Nathan Bryant <bryant@cs.usm.maine.edu>
9         * Makefile.tmpl: fix to build client with old Configure script
10         * configure.in: autologin defaults to enabled if crypt() is available
11         * room_ops.c: fix improper null-termination bug I introduced
12
13 Mon Oct 19 20:52:55 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
14         * Client ability to force display of prompts in Mail rooms, even when
15           the user has prompting turned off (citadel.rc option)
16
17 1998-10-16 Nathan Bryant <bryant@cs.usm.maine.edu>
18         * sysdep.c (cprintf): generate a newline on truncated buffer
19         * room_ops.c: exploitable overrun fixes
20
21 Thu Oct 15 19:27:32 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
22         * msgbase.c: reimplemented cmd_move()
23           room_ops.c: wrote AddMessageToRoom() which is used for both entering
24           and moving messages.
25         * setup.c: system-default message expire policy of "number of
26           messages, 150" is now a default configuration instead of a temp hack
27         * proxy.c: cache dir create now dies on any error except EEXIST
28
29 Wed Oct 14 22:41:16 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
30         * Misc code cleanup
31
32 1998-10-13 Nathan Bryant <bryant@cs.usm.maine.edu>
33         * configure.in: don't check for -lcrypt unless autologin is enabled
34         * file_ops.c: fix another overrun
35
36 Mon Oct 12 15:27:21 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
37         * Killed the "rooms" subdirectory (it isn't used anymore)
38         * dynloader.c: Made dynamically added server commands case-insensitive
39         * import.c is now serv_upgrade.c, a module
40         * Removed most of the "level 9" trace messages no longer needed
41
42 1998-10-12 Nathan Bryant <bryant@cs.usm.maine.edu>
43         * Makefile.in: simplified to use pattern rules; files compiled with
44           -D_REENTRANT go to *.ro to allow the same files to be used with both
45           client and server
46         * tools.c, tools.h: new files; misc routines used by both client and
47           server go here. contains safestrncpy() at the moment.
48         * rooms.c: fix several exploitable buffer overruns
49         * sysdep.c: fix infinite loop when long lines are received from the
50           client; fix exploitable buffer overrun in cprintf()
51         * ipc_c_tcp.c: fix infinite loop on long line from server
52         * serv_upgrade.sh: remove uncnsrd-dependent absolute path
53         * .cvsignore: add *.ro
54
55 Sun Oct 11 23:17:48 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
56         * Built some more of the message expiry infrastructure
57
58 1998-10-11 Nathan Bryant <bryant@cs.usm.maine.edu>
59         * citserver.c: fix two more overruns, one of which was preventing
60           the "From Host" from showing up in the <W>ho listing.
61
62 Sun Oct 11 02:51:55 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
63         * Moved "struct visit" and its associated defs from citadel.h to
64           server.h where they belong
65         * Set up data structures for room policies (expiry, etc.)
66
67 1998-10-10 Nathan Bryant <bryant@cs.usm.maine.edu>
68         * citserver.c: fix overrun which caused segv's on servers with long
69           hostnames.
70
71 Fri Oct  9 18:34:06 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
72         * user_ops.c: added PurgeStaleRelationships() to do processing at
73           session logout time to remove visits for rooms which no longer exist
74         * user_ops.c: implemented NewMailCount()
75
76 1998-10-09 Nathan Bryant <bryant@cs.usm.maine.edu>
77         * serv_chat.c: fix buffer overrun that was resulting in segv's
78         * serv_chat.c: fix another overrun that could cause sessions to hang,
79           and cleaned up some other strncpy()-related stuff. DON'T FORGET TO
80           NULL-TERMINATE DESTINATION BUFFERS AFTER STRNCPY CALLS.
81
82 Fri Oct  9 13:22:37 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
83         * Implemented "lazy mode" traversal - pressing the space bar will do
84           <N>ext messsage, <G>oto next room, or read <N>ew as appropriate.
85         * room_ops.c: modify CtdlRoomAccess() to allow access to mailbox rooms
86           only to their owners.
87
88 Thu Oct  8 17:13:27 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
89         * messages.c, citadel.rc: added the ability to display message numbers
90           in the header when reading messages.  I think this is butt ugly, but
91           some of the DaveCode afficionados seem to like it...
92
93 Thu Oct  8 15:34:45 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
94         * room_ops.c: Added is_noneditable() function to replace all of the
95           duplicated code present in all functions which edit room parameters.
96
97 1998-10-08 Nathan Bryant <bryant@cs.usm.maine.edu>
98         * lots of warning fixes; builds with -std1 on dec unix
99         * aidepost.c, citadel.h, citmail.c, file_ops.c, msgbase.c, netmailer.c,
100           netproc.c, rcit.c, server.h, stats.c, userlist.c: use time_t where
101           needed
102         * control.c, room_ops.c, serv_chat.c, sysdep.c: use memset() instead of
103           bzero()
104         * dynloader.c, dynloader.h, messages.c, server.h, sysdep.c,
105           sysdep_decls.h: function pointer/prototyping fixes
106         * rooms.c: use mkfifo(3) instead of system("mkfifo")
107
108 1998-10-07 Nathan Bryant <bryant@cs.usm.maine.edu>
109         * snprintf.c, snprintf.h: new files
110         * Makefile.in, configure.in, dynloader.c, sysdep.c: support for the
111           above; citserver now builds and runs on Digital Unix 4.0d with the
112           GNU-style configure script. there is a bug with the hostname display
113           in the wholist.
114         * netproc.c: sillyness fix
115         * room_ops.h: prototype delete_room()
116         * client_chat.c, commands.c, serv_chat.c, sysdep.c:
117           use HAVE_SYS_SELECT_H macro
118
119 Mon Oct  5 17:01:32 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
120         * Began fixing the stuff I broke
121
122 Sun Oct  4 23:35:18 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
123         * Did the big migration to the new data structures.  Lots of stuff is
124           now broken.  Basic moving from room to room works, but Mail is
125           broken, and some of the administrative commands are unimplemented.
126
127 1998-10-02 Nathan Bryant <bryant@cs.usm.maine.edu>
128         * configure.in: autologin now defaults to disabled
129
130 Fri Oct  2 00:04:31 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
131         * Finally removed all three usersupp.foo[MAXROOMS] elements, and
132           migrated all the code that used them to use "struct visit" instead.
133
134 Thu Oct  1 23:02:20 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
135         * Rewrote [l][get|put]room() functions to use room names rather than
136           room index numbers.  Temporarily prepended a "n" to these four
137           function names until they are put to use.
138
139 Thu Oct  1 16:27:13 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
140         * Removed a few more references to usersupp.lastseen[]
141
142 1998-10-01 Nathan Bryant <bryant@cs.usm.maine.edu>
143         * .cvsignore: add so_locations (generated by osf1 ld with shared libs)
144         * Makefile.in: restructured variables for greater consistency, use
145           @echo to print out notices during the make process, add so_locations
146           to `cleaner'
147         * configure.in, Makefile.in: configure checks for -rdynamic
148         * ipc_c_tcp.c: fix DEC compiler warning wrt unsigned char
149         * stats.c: add semicolon to placate DREC compiler
150         * user_ops.c: define _POSIX_C_SOURCE, include <limits.h>
151         * configure.in: pass -pthread to DEC compiler, don't check for
152           libpthread[s] on DEC Unix
153
154 1998-09-30 Nathan Bryant <bryant@cs.usm.maine.edu>
155         * Makefile.in: new variable PTHREAD_DEFS for portability
156         * aidepost.c, citadel.c, citmail.c, mailinglist.c, msgform.c,
157           netmailer.c, netpoll.c, netproc.c, rcit.c, readlog.c, setup.c,
158           stats.c, userlist.c, whobbs.c: return type of main() is int
159         * citadel.c, commands.c, messages.c: use time_t properly
160         * citserver.c: include <limits.h>
161         * config.guess, config.sub, install-sh: new files
162         * configure.in: don't use gcc on Digital Unix
163
164 Tue Sep 29 23:17:34 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
165         * room_ops.c: modified usergoto() to look at the new data structures
166           for counting new messages and such.
167
168 1998-09-29 Nathan Bryant <bryant@cs.usm.maine.edu>
169         * user_ops.c: fix compiler warning and potential memory leak,
170           include sysdep.h
171         * configure.in, Makefile.in: only build the server if we find pthreads
172         * Makefile.in: realclean removes config.{cache,log,status}
173
174 Tue Sep 29 13:20:14 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
175         * Removed code from some of the utilities which was still attempting
176           to access the old non-gdbm data store.
177         * housekeeping.c: rewrote check_ref_counts() to do a ForEachRoom()
178           traversal instead of a MAXROOMS loop.
179         * sysdep.c: set up a dummy CitContext record to be used during server
180           startup, during which time there is no real context.
181
182 Mon Sep 28 23:51:51 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
183         * Implemented the function ForEachRoom() to handle all-rooms traversal
184           (this will work with both the old and new paradigms, because both
185           use a GDBM database with one room per record).  Migrated all room
186           list commands to use it.
187
188 Mon Sep 28 22:05:35 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
189         * Implemented the function CtdlRoomAccess() to handle *all* of the
190           user-access-to-rooms functionality.  Migrated all room list commands
191           to use it.  Still need to migrate gotos.
192
193 1998-09-28 Nathan Bryant <bryant@cs.usm.maine.edu>
194         * configure.in, acconfig.h: new files; partially functional GNU
195           autoconf configure script. Run autoheader; autoconf; ./configure
196           --prefix=`pwd` to test.
197         * Makefile.tmpl: new file; this is what Makefile.in used to be. Used by
198           Configure.
199         * Makefile.in: modified to work with autoconf-style configure script
200         * Configure: modified to use Makefile.tmpl and generate autoconf-style
201           macros. Removed procfs detection. Pass -O2 to gcc, -O to other
202           compilers. Removed mknod/mkfifo detection; code should use mkfifo(3).
203         * citmail.c, msgform.c, netproc.c, routines.c, support.c, userlist.c,
204           whobbs.c: use HAVE_STRERROR macro rather than NO_STRERROR
205         * commands.c: use HAVE_TERMIOS_H macro rather than POSIX_TERMIO
206         * netproc.c: remove procfs stuff. simply attempt to kill the target
207           process with signal zero instead; this checks whether the process
208           exists.
209         * setup.c, useradmin.c: use HAVE_CURSES_H macro
210
211 Sun Sep 27 23:41:29 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
212         * BOTH the old and new generation systems are being written to at
213           this point.  Code that reads stuff is still using the old system.
214
215 Sun Sep 27 16:10:49 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
216         * Changed all "generation" variables from char to long, in preparation
217           for removing MAXROOMS.  Generations for new rooms are now timestamps.
218         * Defined "struct visit" to hold user/room relationships.
219         * Removed some #define's from citadel.h that are no longer used.
220
221 Wed Sep 23 13:41:49 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
222         * More changes to support attachments.  They mostly work, but only
223           in fixed-format messages.
224
225 Mon Sep 21 21:19:17 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
226         * msgbase.c: began laying the groundwork to support attachments.
227           Purchased Rogaine(tm) in preparation for expected hair loss.
228
229 1998-09-21 Nathan Bryant <bryant@cs.usm.maine.edu>
230         * msgbase.c: include dynloader.h
231         * citadelapi.h: removed
232         * dynloader.h: prototype CtdlRegisterUserHook()
233
234 Sun Sep 20 18:56:37 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
235         * Added a UserFunctionHook category to implement hooks which perform
236           operations on various users or usernames
237
238 Fri Sep 18 21:14:41 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
239         * citserver.c: removed cmd_extn() and related code
240
241 1998-09-18 Nathan Bryant <bryant@cs.usm.maine.edu>
242         * user_ops.c: include dynloader.h
243         * roomstats.{c,mk}: removed
244         * Configure, Makefile.in: autodependency-related fixes
245
246 Thu Sep 17 22:55:29 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
247         * Various changes to allow "new messages" to work correctly with Mail
248
249 Thu Sep 17 22:21:45 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
250         * server.h, dynloader.c, citserver.c, user_ops.c: reduced the number
251           of hook types by inventing an EventType field to the Session hook.
252         * proxy.c: added pre-fetching
253
254 1998-09-17 Nathan Bryant <bryant@cs.usm.maine.edu>
255         * Makefile.in: add SERV_MODULES and PROXY_TARGETS to `cleaner'
256         * dynloader.[ch], serv_{chat,test}.[ch], sysdep.c: cleaned
257           up the dynamic loader interface as follows:
258           - all the symbol table stuff is gone.
259           - modules are loaded once at server startup and never unloaded.
260           - Added a new function CtdlRegisterProtoHook() to handle the stuff
261             that was being done with the symbol tables.
262           - Dynamic_Module_Init() now returns a pointer to a static struct
263             DLModule_Info; this structure itself has been modified to use char*
264             fields instead of fixed char arrays.
265         * roomstats.c: include <stdarg.h> not <stdargs.h> (is this file still
266           in use?)
267         * Configure, Makefile.in: added autodependency support
268
269 Wed Sep 16 22:25:13 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
270         * Implemented separate structs, lists, and functions for each type
271           of server-side hook available.
272
273 1998-09-16 Nathan Bryant <bryant@cs.usm.maine.edu>
274         * ipc_c_tcp.c: Fixed up some #include/prototyping stuff, call memcpy()
275           instead of bcopy()
276         * hooks.h: removed
277         * sysdep.c, user_ops.c: removed reference to hooks.h
278
279 Wed Sep 16 11:42:42 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
280         * ipc_c_tcp.c: Reversed any changes that have been made to this file,
281           because something was causing abominally slow response time.
282         * proxy.c: added.  This will eventually become a caching, pre-fetching
283           multiuser proxy server for the Citadel protocol.
284
285 1998-09-15 Nathan Bryant <bryant@cs.usm.maine.edu>
286         * Makefile.in: remove support.o from serv_chat.so, add -fPIC to compile
287           flags for serv_chat.o
288         * dynloader.c: include "sysdep_decls.h", use RTLD_NOW not RTLD_LAZY
289         * dynloader.h: prototype CtdlRegisterHook()
290         * .cvsignore: added data
291
292 Mon Sep 14 20:49:08 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
293         * Tried my hand at adding the ability for server extensions to
294           register various types of "hooks" in addition to just adding
295           server commands.  This is probably not final.
296
297 Tue Sep  8 12:11:56 EDT 1998 Brian Costello <btx@calyx.net>
298         * Added support for dynamic server modules.  Reworked serv_chat.c
299           to be such a module.
300
301 Tue Sep  1 23:09:50 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
302         * userpurge.c: rewrote using functions from the server core, rather
303           than the now-defunct external API.  This'll be ready once the module
304           loading code is done.  (I just had to commit _something_ tonight.)
305
306 Mon Aug 31 22:47:58 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
307         * Yanked the citadelapi.c module.  This wasn't working out well.
308         * techdocs/citadelapi.txt - began documenting the new API to be used
309           by modules which will be dynamic linked into the server - most of
310           this API is existing server functions.
311         * Added a ForEachUser() function with callback mechanism, and reworked
312           cmd_list() to use it.
313
314 Sun Aug 30 21:52:43 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
315         * Moved all of the gdbm databases to a separate "data" directory.
316
317 1998-08-26 Nathan Bryant <bryant@cs.usm.maine.edu>
318         * Makefile.in: realclean removes Makefile, fixed `touch citadel.h'
319           problem
320
321 1998-08-25 Nathan Bryant <bryant@cs.usm.maine.edu>
322         * room_ops.c: include time.h
323         * userlist.c, whobbs.c, serv_chat.c, user_ops.c, sysdep.c, stats.c,
324           citadel_decls.h, commands.c, messages.h, routines.h, routines2.h:
325           remove duplicated declarations
326
327 Mon Aug 24 23:45:01 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
328         * setup.c: Removed yesno_s()
329         * citadel.h, room_ops.c: added QRmtime field to struct quickroom,
330           modified whenever a room is modified or posted in.
331         * citadelapi.c: Added CtdlForEachRoom() function
332
333 Mon Aug 24 20:04:04 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
334         * Makefile.in: new target `cleaner' does the same as `realclean' 
335           without removing sysdep.h
336         * proto.h: is bad. eliminate. I've moved the prototypes into several
337           header files, one per .c file
338
339 Mon Aug 24 00:45:55 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
340         * Added a CtdlGotoRoom() function to the CitadelAPI.
341  
342 Sun Aug 23 21:47:00 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
343         * sysoputil is finally dead!  Removed it from the build.
344         * Added userpurge.c server extension (initial implementation)
345
346 Tue Aug 18 00:42:33 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
347         * Makefile.in: `clean' target no longer rm's sysdep.h; new target
348           `realclean' removes everything clean does, plus sysdep.h, plus
349           target binaries.
350         * Configure: add -Wstrict-prototypes to CFLAGS for gcc systems
351         * *.[ch]: protoized. Added several new header files containing
352           prototypes and other external declarations; many duplicated
353           declarations still should be moved to header files. proto.h must die
354           as well, IMHO.
355
356 Mon Aug 17 23:52:13 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
357         * Implemented a bunch of user account related functions in the
358           CitadelAPI library.
359
360 Mon Aug 17 20:01:18 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
361         * Fixed the crash problem.  It wasn't AGUP/ASUP, but rather a buffer
362           overrun in getuser() (thanks, Nathan).  Implemented overrun checks
363           in getuser(), getroom(), and getfloor() to prevent future problems.
364
365 Mon Aug 17 00:06:52 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
366         * Updated citmail.c with the latest stuff from the production system.
367         * Implemented AGUP and ASUP commands, but AGUP crashes the server
368           after its first successful use (user-not-found's don't affect it).
369
370 Thu Aug  6 19:25:01 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
371         * Got the CitadelAPI library to the point where the server can start
372           up an extension, and the extension will connect to the server, do
373           some initialization, call a user-supplied CtdlMain(), and exit.  Also
374           hacked together a _temporary_ form of the new EXTN server command.
375  
376 Wed Aug  5 23:02:22 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
377         * Second attempt at getting the server API started.  Now it runs
378           outside of the server and builds a connection.
379
380 Tue Aug  4 18:33:06 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
381         * Modified the appearance of Internet addresses when they arrive on
382           a Citadel system.
383         * Removed the <E> field from the message format writeup in hack.txt.
384         * Fixed-up citmail.c so that it doesn't try to do database lookups.
385
386 Mon Aug  3 23:01:37 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
387         * Started developing the server-side API.  This is in its very
388           initial stages.  See serverapi.c and techdoc/api.txt
389
390 1998-08-02  Nathan Bryant  <bryant@cs.usm.maine.edu>
391         * Makefile.in: added config_decls.h to dependencies
392
393 Sun Aug  2 21:09:09 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
394         * config_defs.h: renamed to config_decls.h
395         * config.c, sysoputil.c: updated to reflect the above
396
397 Sun Aug  2 18:52:05 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
398         * config_defs.h: new file, contains external declarations from config.c
399         * config.c: moved defs to config_defs.h, use PATH_MAX from <limits.h>
400           for bbs_home_directory
401         * mailinglist.c, support.c: include <string.h>
402         * sysoputil.c: include <string.h>, <limits.h>, "config_defs.h", remove
403           duplicated defs, replace gets() call with fgets()
404         * user_ops.c: define _XOPEN_SOURCE_EXTENDED
405
406 Sat Aug  1 18:32:52 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
407         * ipc_c_tcp.c: fixed order of memcpy parameters after gethostbyname
408
409 Sun Jul 19 17:26:12 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
410         * ChangeLog: reordered; the GNU standard is to add new entries to the
411           top.
412         * .cvsignore: added userlist
413
414 Sun Jul 12 20:58:59 EDT 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
415         * Finished migrating everything to the new data store.
416         * Replaced the binary "calllog" with the ASCII "citadel.log"
417         * Began converting broken utilities that depend on the old data store
418
419 Sat Jul 11 00:20:48 EDT 1998 Nathan Bryant <bryant@cs.usm.maine.edu>
420         * Makefile.in: removed msgstats
421
422 Fri Jul 10 1998 Art Cancro <ajc@uncnsrd.mt-kisco.ny.us>
423         * Initial CVS import