[comp.lang.c++] C++ Class Library Survey

newsuser@LTH.Se (LTH network news server) (03/13/89)

Here are the results from the C++ Class Library Survey posted about
two weeks ago.  Some interesting comments are available in another
posting.

I must admit I expected more responses, considering the number of
people that apparently work actively with C++.  I hope this survey
will spawn an increased interest in sharing C++ code, and that a
survey sometime later this year will give many more replies.

I would like to thank everyone that responded to the survey.
Comments are welcome.

Dag M. Bruck

===============================================================================

Name: gperf
Type:	perfect hash function generator
Description: Generates C lookup routines that determine in O(1) time
             whether a key is a member of a static search set.  Very
             useful for reserved word lookups in compiler front-ends.
Machine(s): Any machine with a GNU G++ compiler
Compiler(s): GNU G++ and GNU libg++
Other requirements: (must be GNU G++ version 1.31 or later)
Availability:	Available in the libg++ distribution and from FTP 128.195.0.1
Costs money:	Subject to the GNU General Public License
Contact: Douglas C. Schmidt <schmidt@ics.uci.edu>

Other comments: Help stamp out software hoarding!

===============================================================================

Name: libg++
Type: class library
Description: The GNU G++ library
Machine(s): Any machine with a GNU G++ compiler
Compiler(s): GNU G++
Costs money: Subject to the GNU General Public License
Contact: Doug Lea (ld@rocky.oswego.edu)

===============================================================================

Name:		Symtab
Type:		class
Description:	Provides a table of name and association pairs
		with type information. These can be saved and loaded
		from file. They may also be traversed as a list.
		If you wished to use it, then you would have to
		modify it a little (The type information is very specific
		to its original use.)
Machine(s):	Sun (but should be widely portable, even off unix)
Compiler(s):	Glockenspiel, AT&T
Availability:	You can have it if you want it.
Status:		A bit messy.
Costs money:	public domain
Contact:
Fraser Orr ( Dept C.S., Univ. Glasgow, Glasgow, G12 8QQ, UK)
UseNet: {uk}!cs.glasgow.ac.uk!orr       JANET: orr@uk.ac.glasgow.cs
ARPANet(preferred xAtlantic): orr%cs.glasgow.ac.uk@nss.cs.ucl.ac.uk

===============================================================================

Name:		Various
Type:		library
Description:	My personal library of common routines. It includes :
		error : exit with an error
		Debug_Mesg : print a Debug message if
			     debugging is on.
		Wait_On_User : Pause to let user see screen
			       wait for a return to be typed.
		Soundex  : Give the soundex incoding for a string
		Blank_Lines : Skip all the blank lines
			      in input, returning the first non blank one.
		Get_Word    : Extract the next word from a string
			      returning also the rest of the string.
		Is_Blank_Line : indicate if a line is blank (whitespace only)
		Skip_Leading : return pointer to first non whitespace in line.
		Split_Into_Words : returns an array of words, that are the
				   whitespace seperated components
				   of the given line.
		Tidy_Up	: Convert a line to cannonical form (no leading white
			  space, only one space between words)
		getstr : internal version of gets that keeps a line number.
Machine(s):  Sun (ports easily to others, even off unix)
Status : A bit messy
Costs money:	public domain
Contact:
Fraser Orr ( Dept C.S., Univ. Glasgow, Glasgow, G12 8QQ, UK)
UseNet: {uk}!cs.glasgow.ac.uk!orr       JANET: orr@uk.ac.glasgow.cs
ARPANet(preferred xAtlantic): orr%cs.glasgow.ac.uk@nss.cs.ucl.ac.uk

Other comments: This library is written in C, with a header file
		to interface it to C++

		``Here is another not very good qualality piece of software
		that you can put in your library.''

===============================================================================

Name:			string
Type:			class library
Description:		Counted strings of static length. Also includes a
			character data type.

Full description in Swedish!

Jag har en klass f|r str{ngar. Str{ngarna {r statiska i sin l{ngd (det g}r
enkelt att {ndra s} att de blir dynamiska, men med viss overhead) och
l{ngden lagras i en separat variabel i klassen. Bort med null-terminerade
str{ngar! Jag {r dock inte helt n|jd med klassen. F|r att konvertera till
"vanliga" str{ngar, m}ste man explicit anv{nda en funktion som returnerar
en pekare till en char*. Man m}ste dessutom manuellt g|ra delete p} den
pekaren efter}t.

Machine(s):		Encore Multimax/UMAX V
Compiler(s):		G++
Other requirements:	-
Availability:		hack
Costs money:		public domain
Contact:		Robert Claeson, rclaeson@erbe.se

===============================================================================

Name: COOL
Type:	collection of integrated class libraries
Description:  class libraries for devices, files, images, and 3-D graphics
   plus miscellaneous items such as an FFT server, random variates,
   histograms, remote compute server connections, and more.
Machine(s): vax780, sun3, sun4
Compiler(s): I use AT&T Cfront but no Cfront-dependent hacks.
Other requirements:  Device classes would need to be modified for a
    new environment.  Image display requires color Sun3 or Sun4.
    Current image display tool uses SunView; X version is planned.
Availability:	About to be released through our department's SoftLab
    with source code and documentation.
Costs money:   nominal fee to cover SoftLab duplication/distribution/
    administrative costs only- something like $200 for univ; 
    $400 for companies is being discussed but not decided.  
    Technical specs and general info are free from contact below.
Contact:  for info/papers/software: softlab@cs.unc.edu
          for technical discussion: Dr. James Coggins <coggins@cs.unc.edu>
          Mailing address:  SoftLab Coordinator
                            Computer Science Department
                            University of North Carolina
                            Chapel Hill, NC  27599-3175
Other comments:
    COOL will probably be more widely useful as an example of
    an integrated, strictly object-oriented library illustrating 
    many variations on the themes of encapsulation and inheritance.
    We use it for image pattern recognition and computer graphics 
    research, and it's great for that too, but, I expect, for a smaller
    audience.  Official release of COOL is scheduled for mid-April 1989.
    The distribution will include a tape, a binder with papers and
    documentation, and test programs.

===============================================================================

Name: MacApp 2.0
Type:           class library
Description: Complete class library for developing Macintosh applications 
- includes support for menus, desk accessories, scrolling, resizing 
windows, printing, views, undo, cut & paste, etc.  It even has 
spreadsheet-style and text-editor views.  It also has an object inspector 
and a built-in debugger which supports browsing objects.  It comes with 
complete source code.  MacApp is written in Object Pascal, but there will 
be C++ header files supplied with it, so you can write C++ classes which 
inherit from MacApp classes.  

Machine(s): Apple Macintosh
Compiler(s): MPW C++, Object Pascal
Other requirements: Macintosh Programmer's Workshop (MPW) 3.0
Availability:   real product, in late beta
Costs money:    yes, < $1000, including the MPW programming environment + 
	        $100 yearly licence fee for commercial applications.
Contact: Apple Programmers & Developer's Association (APDA),
	 Apple Computer, Inc., 20525 Mariani Ave., MS: 33-G,
	 Cupertino, CA  95014-6299,USA

Other comments:  This is a very nice toolkit for putting together 
Macintosh applications.  It has been developed over the last five years, 
so it has had more time to mature than most oo-toolkits.  Object Pascal is 
an extended Pascal which is similar in power to (and inter-operable with) C++.

From: Palevich@apple.com (Jack Palevich)
Organization: Apple Computer, Inc.

===============================================================================

Name: ACL (A Class Library)
Type: class library
Description: A wide variety of classes. Includes lists, stacks,
	queues (priority, fifo), hashtables, symbol tables, unix
	ioctl interface, memory management, error logging and handling,
	network interface (stream sockets, distributed processing)

Machine(s): Sun 3
Compiler(s): AT&T 1.1
Other requirements: Unix (BSD or with BSD extensions)
Availability:	pretty stable hack
Costs money:	no
Contact:	Jim Nusbaum
		LLUMC Radiation Research Laboratory
		(714) 824-4077
		proton!nusbaum@ucrmath.ucr.edu
Other comments: My Masters project. Constructed in 1987 as a demonstration
	of the powers of object oriented implementation methods.  This
	library was well tested and documented and made extensive use of
	many C++ features for both efficiency and generality.
	Full users manual in LaTex form, well commented code.


===============================================================================

Name:     ClassKit(tm)
Type:     class library and development tool
Description: a complete application framework that will support user
interface development, printing, persistent objects, collection classes,
b-tree indexing, and more. Will provide development and debugging tools
including inspectors, browsers, and more.
Machine(s): Macintosh initially
Compiler(s): MPW C++ and C initially
Other requirements: Knowledge of Macintosh programming
Availability:     real product under development
Costs money:     yes 
Contacts: Mark Richer, Mountain Lake Software, Inc.,
     415-752-6515 AppleLink: D1036
Or  "richer@sumex-aim.stanford. edu" or Nick Pilch "Nicky@cup.portal.com"
Other comments: We will be demonstating ClassKit at
     MacWorld, Boston, August 1989.

===============================================================================

Type:		class library/development tool
Description:  Defines arithmetic types for variables residing on a
Connection Machine, including int, unsigned int, and float.  It is
implemented in C++/Paris for 5.0 Paris.  It facilitates programming
the Connection Machine from a C environment (and avoids C*).  C++
expressions can be passed to Paris calls interspersed in the user code.
Simple memory management is provided.

Machine(s):  Vax (tested) Sun (untested)
Compiler(s):  G++
Other requirements:  CM-2, relase 5.0 of CM software, C/Paris interface
	files (paris.h, cmtypes.h, etc.).
Availability:	hack/under development
Costs money:	not public domain
Contact: rjc@cs.ucla.edu (Robert Collins)

===============================================================================

Name: CommonView
Type: class library for user interface
Description: C++ User Interface - OS/2 PM, MS Windows and X Windows Drivers
Machine(s): ?
Compiler(s): ?
Other requirements:
Availability:	available
Costs money:	yes
Contact: OASys +1 617 890-7889

===============================================================================

Name:	`new' using shared heap
Type:   other
Description:
	Alternate _new and _delete using space off a shared data segment, 
	so that data structures are shared between a community of programs.
	Faster than the original (that use native 'malloc' and 'free'),
	but the main intent is to eliminate data transfer overhead
	among a suite of (separately developed) applications 
	operating on a common set of large objects.
Machine(s):  i80386
Compiler(s): Xenix CC, Oasys/Glockenspiel Designer C++
Other requirements:
Availability:	proprietary 
Costs money:	not distributed
Contact: Brad Fowlow 
		 Bell-Northern Research 
		...!mcvax!mcgill-vision!bnrmtl!brad
		brad%bnrmtl.UUCP
Questions/discussion invited.
We've also got a full suite of self-gc'ing object/collection classes.
All is part of window graphics system (in C++) built on GKS.

===============================================================================

Type:   class library
Description:
	I have a pretty complete set of bit manipulation classes
	that may be of interest to to hardware driver writers,
	etc, if anyone is interested.
Machine(s):   ?
Compiler(s):  ?
Contact: jima@hplsla.HP.COM (Jim Adcock)
	 HP Lake Stevens, WA

===============================================================================

Name:	NIH Class Library (used to be called OOPS)
Type:   class library
Description:	Portable selection of classes similar to those of 
		Smalltalk-80.  Contains strings, date, time, collection
		classes (indexed arrays), linked lists, hash tables,
		associative arrays, object i/o, and coroutines.
Machine(s):  ?
Compiler(s): AT&T C++ Translator, release 1.2.1
	     (will require an AT&T R2.0 compatible compiler)
Availability:	?
Costs money:	?
Contact: 	Keith Gorlen, National Institutes of Health
		keith@alw.nih.gov
		uunet!nih-csl!keith

===============================================================================

Name:	Kernel
Type:   class library
Description:	Co-routine package, including semaphores, events and the
		basics for writing monitors.  Has pre-emptive scheduling
		to enable addition of external interrupts.
Machine(s):  Sun, Silicon Graphics, ...
Compiler(s): AT&T 1.2.1 (easily ported)
Other requirements: none
Availability:	By E-mail
Costs money:	no
Contact:Dag Bruck
	Department of Automatic Control	    Internet:  dag@control.lth.se
	Lund Institute of Technology
	P. O. Box 118			    Phone:  +46 46-108779
	S-221 00 Lund, SWEDEN		    Fax:    +46 46-138118

===============================================================================

Name:	List
Type:   class library
Description: Linked lists with the usual operations.
Machine(s):  Sun, Silicon Graphics, ...
Compiler(s): AT&T 1.2.1 (easily ported)
Other requirements: none
Availability:	By E-mail
Costs money:	no
Contact:Dag Bruck
	Department of Automatic Control	    Internet:  dag@control.lth.se
	Lund Institute of Technology
	P. O. Box 118			    Phone:  +46 46-108779
	S-221 00 Lund, SWEDEN		    Fax:    +46 46-138118

===============================================================================

Name: Cynergy
Type: Development environment
Description: The environment itself is written in Smalltalk running as
a process under Unix; the compiler is an OEM version of the
Glockenspiel compiler, talking to the environment via UNIX IPC.
Therefore the system will run on the set of platforms which is the
intersection of the sets supported by PPS Smalltalk and Glockenspiel:
Sun 3 for first release.

The environment includes a code browser, a debugger, dependency
control for recompilation and linking, and an incremental linker.  All
the user interface code and the symbolic side of the debugger run as
Smalltalk code in the Smalltalk image; the C++ source code also
resides there (it is kept in memory during a user session).
Contact:  Jeannine Femia in Marketing at (415) 859-1051.
Other comments: This information was posted in comp.lang.c++ by
	Bruce Cohen
	Interactive Technologies Division, Tektronix, Inc.
	M/S 61-028, P.O. Box 1000, Wilsonville, OR  97070

	brucec@orca.wv.tek.com

===============================================================================
-- 
Department of Automatic Control		Internet:  dag@control.lth.se
Lund Institute of Technology
P. O. Box 118				Phone:	+46 46-108779
S-221 00 Lund, SWEDEN			Fax:    +46 46-138118

newsuser@LTH.Se (LTH network news server) (03/13/89)

The C++ Class Library Survey I posted not only resulted in people
sending in completed forms, but also in some interesting (to me...)
comments in comp.lang.c++.

I have taken the liberty of compiling these comments from people well
known to regular readers of this newsgroup.  I hope we can continue
the discussion, and also solve the practical problems of sharing C++
libraries. 

Dag M. Bruck		Department of Automatic Control
dag@control.lth.se	Lund Institute of Technology, Sweden

===============================================================================

In article <1989Feb27.090941.18193@LTH.Se> dag@Control.LTH.Se (Dag Bruck) writes:
>We all want good, reusable C++ class libraries, and other useful tools.
>I've expected to see a lot, but so far in vain. Now it's time to find out!
>
>If you have any code you think is useful, or have heard of some, try to
>answer the questions below.  I won't mind how ``trivial'' it may look --
>I want to see hundereds of linked list classes.  Include any other tools,
>class browsers, debuggers, you name it.  Even if your code is not
>generally available, please reply -- it would be interesting to know
>what's going on.

One thing that you should point out is that the code doesn't need to be
good.  I have discussed with various people why OOP class sharing hasn't
taken off in the way it was expected to, one of the main reasons I've
found is self conciousness, that is they don't want people to see the
disgusting hacks that most programmers produce.  When I'm reusing code I
don't really care if it is disgusting, all I want o do is use it!  It
would be good if you could emphasis this (unless you disagree of
course.) Another problem is that people are "just getting around to
documenting the code".  Code is pretty naff without documentation, but
it is still useful.  I find it easier to read code that write it, so I'm
prepared to do a bit of work to document the code myself.  i.e.  code
with no documetation is better than no code at all.  And if the writter
ever gets around to documenting the code, this could also be made
avaliable (in fact, someone else, who had done the work to understand
the code could even write the documentation and make it avaliable.)

One thing you don't make clear is how to get hold of the code and
documentation.  What might be good would be if someone became an editor,
and perhaps posted regular digests in comp.unix.sources (I supposed this
would have to be discussed with the moderator though).  Comments anyone?

Fraser Orr ( Dept C.S., Univ. Glasgow, Glasgow, G12 8QQ, UK)
UseNet: {uk}!cs.glasgow.ac.uk!orr       JANET: orr@uk.ac.glasgow.cs
ARPANet(preferred xAtlantic): orr%cs.glasgow.ac.uk@nss.cs.ucl.ac.uk

===============================================================================

In article <2491@crete.cs.glasgow.ac.uk> orr@cs.glasgow.ac.uk (Fraser Orr) writes:
>In article <1989Feb27.090941.18193@LTH.Se> dag@Control.LTH.Se (Dag Bruck) writes:
>>We all want good, reusable C++ class libraries, and other useful tools.
>>I've expected to see a lot, but so far in vain. Now it's time to find out!
>>
>I have discussed with various people why OOP class sharing hasn't
>taken off in the way it was expected to, one of the main reasons I've
>found is self conciousness, that is they don't want people to see the
>disgusting hacks that most programmers produce. 
>

Some time ago I made similar points in the article where I posted my
FFT server code.  There were no responses and there have been no
followups with postings of other interesting classes.  Programming is
still very much a private art, not a public practice (tip of the hat
to Gerald Weinberg). 

A deeper reason for the lack of class sharing, though, is that while
classes are intended to insulate users from implementation details
when we are WRITING client applications, we are most assuredly not so
insulated when we are RUNNING shared code in our client applications.
The operation of the application strongly depends on the
implementation in the shared code.  (Why do all Smalltalk programs
have the same look and feel?).  We are as yet unwilling to completely
abrogate control unless the shared code provides something more
valuable than control. 

I still think that sharing of low-level classes faces insurmountable
problems that can be stated in economic terms: I won't "buy" your
stack or linked list class because it would cost me control and return
little benefit (because those are small, easy classes to write myself,
and if I write them I understand -control- them).  The most successful
set of shared classes, the Smalltalk hierarchy, contains small
classes, but the corpus is large enough to compensate the loss of
control with the ability to rapidly prototype a multitude of
interesting client applications.  There is nothing better for
general-purpose prototyping, but it is not hard to develop something
better for any specific application area. 

Here's a proposal for consideration that takes into account the vague
public-spirited desire and critical technical need to share software
noted by Dag Bruck while also acknowledging the reality of the notable 
lack of code postings (other than my fft_server) and the 
self-consciousness noted by Fraser Orr above:

Don't share code. Offer sets of header files. Let interested parties
contact you about code if they decide they want it. 

We might get beyond the self-consciousness and, perhaps, get *moving*
on this whole issue of code sharing by SHARING ARCHITECTURES as
embodied in related sets of class definitions (our .h files) and
letting other folks provide their own implementations.  That way we
gain the benefits of the experience and expertise of great designers
by adopting their clever architectures without abrogating control or
adopting an implementation that does not really meet our needs. And we
don't expose our tacky code hacks to universal criticism.

Publishing architectures for free might actually serve as an
advertisement for a body of code that people might in fact "buy" or
even $buy$ while providing a public service for those whose needs
require some different kind of implementation. 

Comments are, of course, invited.
---------------------------------------------------------------------
Dr. James M. Coggins          coggins@cs.unc.edu
Computer Science Department   Question: "How 'bout them HEELS?"
UNC-Chapel Hill               correct response:
Chapel Hill, NC 27599-3175         "How 'BOUT them Heels?"
and NASA Center of Excellence in Space Data and Information Science

===============================================================================

In article <7101@thorin.cs.unc.edu> you write:
++ Some time ago I made similar points in the article where I posted my
++ FFT server code.  There were no responses and there have been no
++ followups with postings of other interesting classes.  

My main reason for not posting code and class examples is that I'm not
sure if comp.lang.c++ is the proper forum; it seems more oriented to
*discussion* of the language.  In a similar vein, large source
postings are generally discouraged on the already-bloated comp.lang.c.
Instead, there are the comp.source.unix, alt.sources, and
comp.sources.misc bboards for source submissions.

On the other hand, there really hasn't been much of a C++ focus on
those bboards.  I'd be happy to share some useful, concise, and
general-purpose classes, as long as doing so won't piss off the
comp.lang.c++ readers.  So the open question is:

                Are code postings relevant to comp.lang.c++?


++ Programming is still very much a private art, not a public practice
++ (tip of the hat to Gerald Weinberg). 

I appreciate your general point, but must disagree in this case.  As
far as finding a *large* collection of C++ library code and useful
(and well documented) class abstractions, check out the GNU libg++
library, available via ftp from prep.ai.mit.edu.  There is a
newsgroup, gnu.g++.lib.bug, that offers a potential forum for code
sharing and technical discussion, etc.  That's one of the big
advantages of the GNU project, i.e., it encourages wide-spread sharing
of code and design information.  And the price is right... ;-)

Thanks for raising this issue,

   Doug
--
schmidt@ics.uci.edu (ARPA) |   Per me si va nella citta' dolente.
office: (714) 856-4043     |   Per me si va nell'eterno dolore.
                           |   Per me si va tra la perduta gente.
                           |   Lasciate ogni speranza o voi ch'entrate.

===============================================================================

In article <8688@paris.ics.uci.edu> Doug Schmidt <schmidt@siam.ics.uci.edu> writes:
>...As
>far as finding a *large* collection of C++ library code and useful
>(and well documented) class abstractions, check out the GNU libg++
>library...  And the price is right... ;-)

The price is not right for many commercial users -- the price is acceptance
of the GNU licensing terms.  One may argue about the intrinsic rightness of
the licensing terms, but the fact is that they're unacceptable to many
commercial organizations today.
-- 
The Earth is our mother;       |     Henry Spencer at U of Toronto Zoology
our nine months are up.        | uunet!attcan!utzoo!henry henry@zoo.toronto.edu

===============================================================================
-- 
Department of Automatic Control		Internet:  dag@control.lth.se
Lund Institute of Technology
P. O. Box 118				Phone:	+46 46-108779
S-221 00 Lund, SWEDEN			Fax:    +46 46-138118