macssh/GUSI
chombier c7e41d1991 CWPro8.3 Update 2002-11-22 16:49:58 +00:00
..
DCon/Headers First Imported. 2001-03-07 09:55:27 +00:00
Examples First Imported. 2001-03-07 09:55:27 +00:00
GUSIConfig First Imported. 2001-03-07 09:55:27 +00:00
doc First Imported. 2001-03-07 09:55:27 +00:00
include pre-carbon cleanup 2002-11-22 16:45:45 +00:00
project CWPro8.3 Update 2002-11-22 16:49:58 +00:00
scripts First Imported. 2001-03-07 09:55:27 +00:00
src fixed kOTProviderWillClose 2002-11-22 16:46:03 +00:00
test GUSI 2.1.6 update 2001-04-10 16:42:25 +00:00
GUSIConfig.mk First Imported. 2001-03-07 09:55:27 +00:00
GUSI_Install.MPW First Imported. 2001-03-07 09:55:27 +00:00
MANIFEST First Imported. 2001-03-07 09:55:27 +00:00
MacDistr GUSI 2.1.9 update 2001-10-06 09:50:37 +00:00
Makefile.mk First Imported. 2001-03-07 09:55:27 +00:00
README GUSI 2.1.9 update 2001-10-06 09:50:37 +00:00
STLport_Install.MPW First Imported. 2001-03-07 09:55:27 +00:00

README

                 GUSI 2 -- A multithreaded POSIX library
INTRODUCTION

GUSI is an extension and partial replacement of the standard C runtime library
supplied with your compiler. The main objective of GUSI is to faciliate the 
porting of software written for UNIX systems by implementing a substantial subset
of the Single Unix Specification library routines:

 - BSD style sockets.
 - Pthreads.
 - Many other POSIX facilities such as diropen().

REQUIREMENTS

To use GUSI, you need one of the following compilers:

 - Metrowerks CodeWarrior Pro 5 or later.
 - SC/SCpp 8.8.4d1c1 or later.
 - MrC/MrCpp 4.1.0a6c1 or later.

GETTING STARTED

If you're new to GUSI, start by reading the manual in :doc:GUSI.pdf. 

If you're using GUSI with the Metrowerks CodeWarrior IDE, also read 
:doc:GUSI_CW_Guide.pdf if you haver any difficulties getting your first GUSI 
project to compile/link.

If you're using GUSI in combination with the MPW shell and/or the MPW compilers,
please run GUSI_Install.MPW. For more details, please consider reading the 
documentation in the doc folder.

To recompile GUSI with the MPW compilers, you need an STL library. I've found
STLport, available at http://www.stlport.org/download.shtml, to work perfectly
for my purposes. To install it, put it anywhere on your disk and run 
STLport_Install.MPW. Current versions of GUSI have been compiled with STLport 3.1.2.

GUSI USER LICENSE

My primary objective in distributing GUSI is to have it used as widely as 
possible, while protecting my moral rights of authorship and limiting my 
exposure to liability.

Copyright (C) 1992-2001 Matthias Neeracher

Permission is granted to anyone to use this software for any purpose on any
computer system, and to redistribute it freely, subject to the following
restrictions:

- The author is not responsible for the consequences of use of this software,
  no matter how awful, even if they arise from defects in it.
- The origin of this software must not be misrepresented, either by explicit
  claim or by omission.
- You are allowed to distributed modified copies of the software, in source
  and binary form, provided they are marked plainly as altered versions, and 
  are not misrepresented as being the original software.

While I am giving GUSI away for free, that does not mean that I don't like 
getting appreciation for it. If you want to do something for me beyond your
obligations outlined above, you can

- Acknowledge the use of GUSI in the about box of your application and/or
  your documentation.
- Send me a CD as described in 
  http://www.iis.ee.ethz.ch/~neeri/macintosh/donations.html

BUGS, QUESTIONS, SUGGESTIONS

Please report any problems you experience with the code or the documentation to
me. I'd also be interested in hearing about your success stories, if you have
any.

GUSI ON WWW

An online version of the GUSI manual and a GUSI FAQ are available at 
http://www.iis.ee.ethz.ch/~neeri/macintosh.html

MAILING LIST

There is a mailing list for announcing new releases and discussions about 
how to make GUSI change your life. To subscribe, send a mail:

----------------------------------
To: gusi-request@iis.ee.ethz.ch
Subject: (is ignored)

subscribe
----------------------------------

Mail is now processed by a daemon, so please follow the above format.

	Matthias Neeracher 	
	20875 Valley Green Dr. #50			
	Cupertino, CA 95014
	
	e-Mail: 	<neeracher@mac.com>	
	Fax:   	+1 (408) 514-2605 ext. 0023

KNOWN BUGS

 - MSG_PEEK does not yet work for for native OpenTransport sockets, only for MacTCP 
 	sockets [John Cargill-Ek].
 - hstrerror() is not yet implemented [Darrell Walisser].
 
RELEASE NOTES

Version 2.1.9		22Jul01

 - Fixed st_blksize for files on HFS+ volumes, made st_blksize be expressed in 
 	terms of st_blksize, not as 512 byte blocks [Marcel Riechert, Chris Nandor, 
	MacPerl Bug #424874].
 - Errors in MPW calls would still not be propagated correctly in CW 68K code
 	[Chris Nandor, MacPerl Bug #436537].
 - If STDOUT and STDERR were reidrected to the same file, MPW tools would not 
 	work correctly [Chris Nandor, MacPerl Bug #436506].

Version 2.1.8		02Jul01

 - truncate() was broken [Chris Nandor, MacPerl Bug #436893].
 - errors of MPW calls wouldn't be propagated correctly in MWPPC code 
 	[Chris Nandor, MacPerl Bug #436537].
 - open(..., O_CREAT|O_EXCL) would fail with MPW sockets [Thomas Wegner, MacPerl Bug #425901].
 - S_ISFIFO and S_ISSOCK were broken (a bug apparently inherited straight from BSD).
   [Thomas Wegner, MacPerl Bug #430930].
 
Version 2.1.7		15Apr01

 - Path resolution of absolute paths with embedded aliases was broken.
 - GUSIFSpGetCatInfo returned garbage in the ioNamePtr field [Alan Fry].

Version 2.1.6		08Apr01

 - Fix handling of error codes in select() [Jean-Pierre Stierlin].
 - Paths starting with ::: were mishandled [Chris Nandor, MacPerl Bug #409940].
 - Made minor tweaks to make GUSI work better with Natty (Don't ask yet).
 - Fixed major bugs in relative path generation.
 - MPW tools were unable to open files which were open as windows 
 	[Thomas Wegner, MacPerl Bug #231006]
 - Used delete where delete[] was appropriate [Wade Williams].
 - Fixed handling of network configuration changes [Jean-Pierre Stierlin].
 - Fixed a number of logic bugs related to select() [Michael Johnson, Wade Williams].
 - Clean out fNextListener after accept() [Joe van Tunen].
 - Fixed CW Project to include specific directories rather than {Compiler}.
 
Version 2.1.5		21Jan01

 - Make literate programming tools configurable to some extent [Jack Jansen].
 - Made countless tweaks to scheduling and wakeups [Andreas Grosam, Keith Stattenfield].
 - Prevent inlining of overridable functions [Andreas Grosam].
 - Socket options did not work properly for OT sockets created by accept [Andreas Grosam].
 - pthread_cond_timedwait never returned ETIMEDOUT [Andreas Grosam].
 
Version 2.1.4		22Dec00

 - Using a GUSIFSxxx call before any POSIX calls could cause programs to hang
 	because the default context was not initialized yet.
 - GUSIForeignThreads was unable to open ThreadsLib [Max Horn].
 - GUSI diagnostic messages were sometimes emitted at A5 unsafe times 
 	[Jean-Pierre Stierlin].
 - Added ssh entry in hard coded services table [Jean-Pierre Stierlin].
 
Version 2.1.3		29Oct00

 - More CW 6 fixes, especially for massive problems with time related functions
 	[Richard Wesley].
 - Nonstandard macros defined in sys/cdefs.h conflicted with CW macros [David Willis].
 - PPC sockets were totally broken; they seemed to have slipped entirely through any
   sort of acceptance testing [David Willis].
 - Deal with CW's non-standard signature for fdopen.
 - Include two new tests (GUSIThreadTest, GUSIPPCTest) in interactive test suite.
 - Switched to distributing XML versions of the CW projects for space savings and
 	portability.
 
Version 2.1.2 		16Oct00

 - Fixes for CodeWarrior 6 [Jack Jansen, Jeff Shulman].
 - SC would always use A5 relative addresses, with disastrous consequences in 
 	completion routines [Jean-Pierre Stierlin].
 - The OpenTransport code for dealing with multiple incoming connections had
   severe bugs [Gordon McMillan].
 - Accommodate the fact that CodeWarrior internally uses a different numbering 
 	scheme for SIGINT [Jack Jansen].

Version 2.1.1		05Jun00

 - Some functions were returning references to stack values [Alexandre Parenteau].
 - Fixed a shocking amount of bugs in time(), localtime(), and gmtime() 
 	[Jack Jansen, Alexandre Parenteau].
 - Keep DCon support from crashing under Sfio.
 - Introduced preliminary support for multiple descriptor tables.

Version 2.1.0		29May00

 - Improved formatting of the woven documentation [Peter Teeson].
 - Updated to Universal Headers 3.3.1 [Tom Bayley].
 - Tuned scheduling again [Jack Jansen].
 - Implemented proper linger model, closing sockets immediately (while 
 	actually putting them into a background queue to allow pending data to
	be transmitted) [Rich Cook, Oebele Dijkstra].
 - MacTCP sockets would hang on close with pending data [Jack Jansen].
 - Fixed bugs in lseek for read-only files [Jack Jansen].
 - Failed OpenTransport DNS lookups would return garbage data instead of
   error [Karl Armstrong, Mike Johnson].
 - Repeatedly calling a connect on a nonblocking socket could cause an infinite
 	loop [Mike Johnson].
 - Fixed leak in OT UDP sendto [Tom Bayley].
 - (Hopefully) fixed a problem that could cause select() not to return a 
   ready to read status [Mike Johnson].
 
Version 2.0.6		14Mar00

 - Fixed several race conditions causing hangs in OpenTransport code 
 	[Alexandre Parenteau].
 - Console would get initialized twice [Steven Gillispie].
 - Suffix finding code was broken [Alexandre Parenteau].
 - open(":x:y", O_RDWR) would create x as a file if it didn't exist [Alexandre Parenteau].
 - Temporary name creation would crash horribly [Alexandre Parenteau].
 - rename() was broken [Alexandre Parenteau].
 - Try to enforce alignment of struct and class fields when GUSI headers are
 	included by clients with arbitrary default alignments [Alexandre Parenteau].
 - Custom thread switchers were not getting correctly reinstalled upon destruction
   of a thread [Andre Radke].
 - GUSIFileSpec::Resolve needed to clear fValidInfo [Alexandre Parenteau].
 - Accidentally had reversed the logic for my "fix" of the double destruction of detached
   threads [Stephen Coy].
 - getservbyname would crash if /etc/services did not exist 
 	[Christopher Stern, Alexandre Parenteau].

Version 2.0.5		06Mar00

 - Added a visual manual for first time CodeWarrior GUSI users [Rich Cook].
 - Forgot include guard in inttypes.h
 - Device families did not check that the paths passed to them were device paths
 	[Christopher Stern]
 - Sped up thread switching by a factor of up to 1000 [Jack Jansen].
 - Called InitGraf in one location without checking configuration flag 
   [Alexandre Parenteau].
 - Used a flaky plausibility test for automatic InitGraf.
 - Detached threads were deleted twice [Stephen Coy].
 - Force order of static destructors by closing descriptors before deleting threads
   [Christopher Stern].
 - Checked for nonexistent devices in file calls [Alexandre Parenteau].
 - readdir() would always return an error at the end of the directory, which is against
 	the specification [Alexandre Parenteau].
 - sleep() from the main thread didn't [Darrell Walisser].
 - Renamed CodeWarrior projects to .mcp for cross platform compilability [Chris Brown].
 
Version 2.0.4		16Jan00

 - Updated to CodeWarrior 5.3 compilers (this shouldn't affect any existing CW 5 users 
   negatively, I think. If it does, please alert me.).
 - Some of the macros in pthread.h had PTHREAD_ misspelled as PTHREADS_ [Mike Davis]
 - GUSI's version of rename() was incorrectly mangled, so clients would link with
   the standard rename() [Matthew Nolan].
 - Removing an open file in the temporary items folder would fail [Jack Jansen].

Version 2.0.3		13Dec99

 - Closing a OpenTransport TCP socket with data pending would hang 
   [Oebele Dijkstra, Darrell Walisser].
 - Calling gethostbyname() before any sockets were opened would malfunction.

Version 2.0.2		12Dec99

 - Attempting to set SO_LINGER would crash [Keith Rollin].
 - Passing a null timezone argument to gettimeofday() would misbehave [Christopher Stern].
 - GUSISetThreadSwitcher would get the wrong linkage [Bruno Litman].
 - read() on OpenTransport TCP/IP sockets had wrong results on disconnected sockets
   [Keith Rollin].
 - select() would return a wrong result if any descriptors were ready for both reading 
   and writing [Keith Rollin].
 - Added pause() call.

Version 2.0.1		14Nov99
 
 - select() would sometimes unecessarily poll [David Lawrence].
 - Added GUSIwithPPCSockets, GUSIwithLocalSockets, which I had forgotten
   [Darrell Walisser].
 - GUSI would generate SIGINT for background applications if Command-. was
   pressed in the foreground application [Darrell Walisser].
 - Calling signal() before any sockets were created would crash [Darrell Walisser].
 - gethostname() would garble the name if running with TCP/IP off 
 	[Christopher Stern].
 - stat() would not return an error for nonexistent files [Christopher Stern].
 
Version 2.0			23Oct99

 - Removed the advertising clause from the BSD headers, as UCB no longer
   requires it. Thanks!
 - Included DCon.h in the distribution so GUSI compiles even if you
   don't have DCon. Thanks to Ed Wynne, Phasic Interware, Inc.,
	for his permission to do so. [Steven Gillispie]
	
Version 2.0fc2		14Oct99

 - Open Transport sockets didn't close their connections in an orderly way 
 	[Steven Gillispie].

Version 2.0fc1    25Sep99

 - The number and severity of bug reports has decreased sufficiently to
   convince me to declare final candidate status on GUSI 2. Please report
	all bugs immediately.
 - Added sanity checks on A5 before attempting to call InitGraf [Brian Pink].
 - Renamed the socket option IPPROTO_IP/IP_BROADCAST to its correct name
   SOL_SOCKET/SO_BROADCAST [Chris Brown].

Version 2.0b10 08Sep99
 
 - I found several bugs in GUSI when trying to port the Darwin Streaming Server
   to MacOS.
 - Attempted to deal with threads created outside GUSI (e.g. in PowerPlant)
   [Eli Bishop].
 - File manager sockets would misbehave when switching off read-ahead.
 - Implemented the interface detection ioctl calls for OpenTransport TCP/IP.
 - getsockname would not work on sockets returned fropm accept under 
 	OpenTransport.
 - recvfrom would not correctly return the sorce socket address under 
 	OpenTransport except for a connected datagram socket [Philippe Lang].
 - Nonblocking reads on OpenTransport stream sockets did in fact block.
 - Nonblocking reads on OpenTransport datagram sockets leaked memory.
 - Implemented inet_aton and minimal pthread_condattr and pthread_mutexattr 
   support.
 - Fixed bugs in the documentation [Chris Brown]. Added warning about 
   interaction between GUSIConfig and precompiled headers [Steven Gillispie].
 
Version 2.0b9	02Sep99

 - OpenTransport operations in threads sometimes would hang 
 	[Brian Pink, David Catmull].

Version 2.0b8 	25Aug99

 - Fixed problems with nonblocking connects in MacTCP [Philippe Lang].
 - Open transport sockets needed to have an explicit unbind [Steven Gillispie].
 - Work on literate edition of the source code.

Version 2.0b7	04Aug99

 - Adapted to CodeWarrior Pro 5.
 - Updated documentation.
 - Tried to clarify license and added pointer to donations page.
 
Version 2.0b6	01Aug99 (Happy 708th birthday, Switzerland!)

 - Philippe Lang convinced me to support the SO_ERROR socket option, and while
   I was at it, I supported as many socket options as I reasonably could 
	(mostly on Open Transport).
 - Found out that the member fields of a struct timespec are named tv_xxx, not 
   ts_xxx, thanks to W. Richard Stevens' sample code.
 - Fixed conditional macros in sys/un.h [Michel Rabozee].
 - Calling MSL __close_all() turned out not to have been such a hot idea.

Version 2.0b5	19Jul99

 - Rick Waits correctly pointed out that most of the new files
   promised in b4 were actually missing.
 - Fixed bug in MacTCP UDP code [Philippe Lang].
 - Specified bool support in Example project so it would compile again [Rick Waits].
 
Version 2.0b4	18Jul99

 - Added support for SIOW based programs.
 - Added mkdir/rmdir.
 - Fixed Open Transport nonblocking connects [Philippe Lang].
 - Fixed long standing inability to give new files the right type and
   creator [Chris Jacobson].
 - Add MPW makefile and examples to :Examples [Rick Waits].

Version 2.0b3  30Jun99

 - Added support for Standard C and UNIX 98 style signal handling.
 - Added support for using sfio with SC and MrC.
 - Improved performance of file I/O.
 - Tried to improve documentation for SC and MrC [Rick Waits].
 - Added GUSI_Install.MPW installation script.
 - Eradicated dependences on STL from GUSI headers.

Version 2.0b2  07Jun99

 - Added support for SC[pp] and MrC[pp] compilers. I compiled with SCpp 8.8.4d1c1
   and MrCpp 4.1.0a5c3, and intend to maintain the code for newer, but not older 
	versions of these compilers. Unfortunately, Stdio does not work yet when
	using GUSI with MrCpp due to shared library conflicts. I intend to support
	sfio for SC and MrC in the near future, though.
 - Added back STDIN_FILENO & co. Fixed various bad comments in header guards
   [Chris Jacobson].
 - select for OpenTransport datagram (UDP) sockets was broken [Philippe Lang].
 - Allow recursive locks for mutexes.
 - Added a CodeWarrior project files to simplify rebuilds.
 - Some more work on PPC sockets.
 
Version 2.0b1	14Apr99

 - Added support for broadcast and multicast options [Tom Bayley, Quinn].
 - Rewrote GUSIConfig in C++.
 - Brought documentation up to date.
 - Event handling for AppleEvents was broken [Chris Jacobson].
 - Changed auto-spin default to off, as this feature has less importance in
   GUSI II and can easier be turned on with configuration files.
 - Introduced GUSIContextFactory to add more flexibility to GUSIContext
   creation. Made switching in and out fully virtualized.
 - Massively improved and simplified the handling of race conditions
   in wakeups [George Warner & Quinn]
 - Added support for the DCon debugging console, and also switched to DCon
   for our own debugging output.
 - Added support for the PPC (Program-to-program communications) toolbox.
 - Fixed several bugs in Open Transport support.
 - Removed GUSIwithThreading, which is no longer necessary.
 
Version 2.0a4		22Nov98

 - Since my Mac is getting packed up, a hasty and somewhat incomplete, but
   interesting release.
 - Changed configuration system to explicit configuration files created with
   GUSI_Configurator. This change is not reflected in the examples yet.
 - Added OpenTransport TCP/IP support (finally!)

Version 2.0a3		25Oct98

 - Added MacTCP UDP support, SIOUX support, MSG_PEEK support.
 - Fixed many bugs.
 - Started adapting old test programs in Examples

Version 2.0a2		11Oct98

 - Much more feature complete version: Added most file routines and domain name
   support.
 - Incorporated as much as I could of Michel Rabozee's excellent feedback.

Version 2.0a1     02Aug98

 - A sneak peek to give an impression of the flavor of the new facilities 
   in GUSI2. This version is far from feature complete, lacking most file 
	routines, UDP support, support for AppleTalk, OpenTransport support,
	and support of the domain name resolver.