[net.wanted] Icon -- a worthy successor to SNOBOL

jiml@uwmacc.UUCP (Jim Leinweber) (01/17/85)

Some enquiries about SNOBOL under Unix have surfaced recently in
net.wanted and net.lang.  I don't personally know of a SNOBOL
implementation, but there is a wonderful grandchild of SNOBOL running
under Unix, namely Icon.  A recent version runs under V7 and BSD 4.?
on PDP11/70's and Vaxen; earlier versions run on many others as well.

Icon is an offspring of the same Ralph Griswold of SNOBOL fame, and can
be described in an oversimplified way as `SNOBOL meets structured
programming'.  It has untyped variables, associative tables, automatic
storage assignment and reclamation, and string scanning operations,
much in the manner of SNOBOL.  It also has lists with flexible access,
records, and modern control structures, such as recursion, procedures,
nesting loops, IF's, etc.

In place of SNOBOL's pattern matching operations, failure-driven
alternation and co-expressions (co-routines which can pass and return
values) are provided as additional control structures.  These are
completely integrated into the language, and have *great* expressive
power.

The result is programs 5% the size of comparable ones in, say, Pascal;
but with more power and much better readibility than SNOBOL.  I prefer
Icon to PROLOG too.

For more information, try /usr/src/new/icon on BSD 4.2 systems, or

   icon-project@arizona.UUCP  (via gi, mcnc, ucbvax, utah-cs)
   icon-project.arizona@rand-relay  (CS-NET, ARPA)

A book `The Icon Programming Language', by Ralph & Madge Griswold,
is available from Prentice-Hall.

			Jim Leinweber

UUCP:  ...!{allegra,ihnp4,seismo,...}!uwvax!uwmacc!jiml
ARPA:  uwmacc!jiml@wisc-rsch.arpa
POST:  MACC, UW-Madison, 1210 W. Dayton St., Madison, Wi, 53706

david@ukma.UUCP (David Herron, NPR Lover) (01/24/85)

If Icon is a successor, then why did you use a -- operator? :-)

ndiamond@watdaisy.UUCP (Norman Diamond) (01/25/85)

> If Icon is a successor, then why did you use a -- operator? :-)

Don't forget that (Icon--) has the same value as (Icon), and it is a worthy
successor.  After a while, as language design continues to improve, Icon's
relative worth will decline; hence the value of Icon should decrease after
sufficient usage.  (:-)++)

-- Norman Diamond

UUCP:  {decvax|utzoo|ihnp4|allegra|clyde}!watmath!watdaisy!ndiamond
CSNET: ndiamond%watdaisy@waterloo.csnet
ARPA:  ndiamond%watdaisy%waterloo.csnet@csnet-relay.arpa

"Opinions are those of the keyboard, and do not reflect on me or higher-ups."

chris@byucsa.UUCP (Chris J. Grevstad) (02/06/85)

<>

We are running ICON here (4.2BSD) and it compiles abysmally slow!
We use it for our programming languages class.

-- 

	Chris Grevstad
	{ihnp4,noao,mcnc,utah-cs}!arizona!byucsa!chris

	If things don't change they will probably remain the same.

whm@arizona.UUCP (Bill Mitchell) (02/06/85)

> 
> We are running ICON here (4.2BSD) and it compiles abysmally slow!
> We use it for our programming languages class.
> 
> 	Chris Grevstad
> 	{ihnp4,noao,mcnc,utah-cs}!arizona!byucsa!chris

Your comment is a little vague, but a couple of comments are in order.

First of all, if you're using the Icon compiler, throw it away.  UNIX
Icon was first implemented as a compiler, turning Icon programs into assembly
language that was then assembled and linked against a huge run-time library.
It worked, but was very slow.  In response to this problem, the compiler
was cloned and turned into an interpretive system in which the Icon
translator and linker produce an interpretable file that the Icon
interpreter can run to effect program execution.

The Icon interpreter is probably an order of magnitude faster than the
compiler wrt. to producing an executable unit and program execution is
usually no worse than 10% slower.  About a year ago, the maintenance
overhead for the compiler began to outweigh the benefits and the compiler
was deleted from the distribution.  The Icon system on 4.2bsd has both
the compiler and the interpreter, but there's really no reason to even
think about using the compiler if you're using it for a programming languages
class.  (The only good reason to use the compiler is to incorporate C
subroutines and the current release of Icon has an alternate means of
doing this.)

If you're already using the interpreter and used the term "compiles" to
mean the production of the interpretable file, I have fewer answers.  We've
improved the speed of the system a bit since the 4.2 release, but it's
not a lot faster.  I *think* the current speed of the translator is about
50 lines/second on a 780 and while that's not smoking, I don't think it's
much worse than the C compiler.  And after all, it's only the first
implementation; give us a break!

					Bill Mitchell
					Icon Project
					The University of Arizona
					whm.arizona@csnet-relay
					{ihnp4,noao,mcnc,utah-cs}!arizona!whm
p.s.
The proper way to spell Icon is I-c-o-n, not I-C-O-N.