home *** CD-ROM | disk | FTP | other *** search
/ Peanuts NeXT Software Archives / Peanuts-1.iso / CDROM / FAQs / compilers / faq < prev    next >
Encoding:
Internet Message Format  |  1996-10-01  |  30.5 KB

  1. Path: informatik.tu-muenchen.de!fu-berlin.de!newshub.tc.umn.edu!mr.net!www.nntp.primenet.com!nntp.primenet.com!news.sgi.com!news.mathworks.com!uunet!news-in2.uu.net!ivan.iecc.com!ivan.iecc.com!not-for-mail
  2. From: compilers-request@iecc.com (John R. Levine)
  3. Newsgroups: comp.compilers,news.answers,comp.answers
  4. Subject: comp.compilers monthly message and Frequently Asked Questions
  5. Supersedes: <monthly-Sep-96@comp.compilers>
  6. Followup-To: poster
  7. Date: 1 Oct 1996 07:00:01 -0400
  8. Organization: Compilers Central
  9. Lines: 627
  10. Sender: johnl@iecc.com
  11. Approved: compilers@iecc.com
  12. Expires: 1 Nov 96 23:59:00 GMT
  13. Message-ID: <monthly-Oct-96@comp.compilers>
  14. NNTP-Posting-Host: ivan.iecc.com
  15. Keywords: administrivia
  16. Xref: informatik.tu-muenchen.de comp.compilers:11121 news.answers:83017 comp.answers:21373
  17.  
  18. Archive-name: compilers/faq
  19. Last-modified: 1 Sep 96
  20.  
  21. This is the comp.compilers monthly message.
  22.  
  23. Contents:
  24.  
  25. -- What is comp.compilers?
  26. -- How do I receive it?
  27. -- How do I submit a message?
  28. -- What happens to submitted messages?
  29. -- What message formats are appropriate?
  30. -- What topics are and aren't appropriate?
  31. -- How do I respond to the author of a message?
  32. -- How do I contact the moderator?
  33. -- Are back issues available?
  34.  
  35. -- Some Frequently Asked Questions:
  36.  
  37. * Where can I get a C or C++ grammar in yacc?
  38. * Where can I get the Gnu C compiler?
  39. * Are there other free C compilers?
  40. * Where can I get a Fortran grammar in yacc or a Fortran compiler?
  41. * Where can I get Modula-2, Pascal, Ada, or SQL grammars in yacc?
  42. * Where can I get a Cobol grammar in yacc?
  43. * Where can I get a Basic grammar in yacc?
  44. * Where can I get a QBasic compiler?
  45. * Where can I get a PL/M grammar?
  46. * Are there free versions of yacc and lex ?
  47. * Are there versions of yacc and lex for MS-DOS?
  48. * Are there C++ versions of yacc and lex?
  49. * What other compilers and tools are freely available?
  50. * How can I get started with yacc and lex and compiler writing in general?
  51. * Where can I FTP the sources to the programs in Holub's "Compiler
  52.   Design in C" or Mak's "Writing Compilers and Interpreters" ?
  53. * Where can I learn about garbage collection ?
  54.  
  55. -- What is comp.compilers?
  56.  
  57. It is a moderated usenet news group addressing the topics of compilers in
  58. particular and programming language design and implementation in general.
  59. It started in 1986 as a moderated mailing list, but interest quickly grew to
  60. the point where it was promoted to a news group.  Recent topics have
  61. included optimization techniques, language design issues, announcements of
  62. new compiler tools, and book reviews.
  63.  
  64. Messages come from a wide variety of people ranging from undergraduate
  65. students to well-known experts in industry and academia.  Authors live all
  66. over the world -- there are regular messages from the U.S, Canada, Europe,
  67. Australia, and Japan, with occasional ones from as far away as Malaysia.
  68. I cannot tell how large the readership is, since the anarchic nature of
  69. usenet makes it impossible to tell who reads it, but a reasonable guess is
  70. that the total is over 100,000, which would make it by far the most widely
  71. read medium on the topic in the world.
  72.  
  73. Unless there is specific language to the contrary, each message represents
  74. only the personal opinion of its author.  I claim no compilation copyright on
  75. comp.compilers.  As far as I am concerned, anyone can reproduce any message
  76. for any purpose.  Individual authors may retain rights to their messages,
  77. although I will not knowingly post anything that does not permit unlimited
  78. distribution in any form.  If you find comp.compilers useful in writing a
  79. book, producing a product, etc., I would appreciate an acknowledgement of
  80. usenet and comp.compilers.
  81.  
  82. -- How do I receive it?
  83.  
  84. The easiest way is to read comp.compilers on a system that gets usenet news.
  85.  
  86. If you don't have access to usenet news, it's also available via E-mail via
  87. a LISTSERV forwarder at the American University.  To subscribe a person
  88. should send e-mail to listserv@american.edu with one line in the mail
  89. message (not in the subject!)  That line should read:
  90.  
  91.                         SUBSCRIBE COMPIL-L full_name
  92. for example:
  93.                         SUBSCRIBE COMPIL-L Ima Hacker
  94.  
  95. To get off the list the subscriber should send e-mail to the same address
  96. with the message:       SIGNOFF COMPIL-L
  97.  
  98. If you have problems getting on or off the list, please contact me.  In
  99. particular, if you want to use an address other than your own personal mail
  100. address, you have to ask me to set it up.  If I receive bounce messages for
  101. an address on the mailing list for two days in a row, I delete it.  If this
  102. happens to you and your address subsequently becomes reachable again, you
  103. can resubscribe.
  104.  
  105. -- How do I submit a message?
  106.  
  107. Mail it to compilers@iecc.com.  I review messages nearly every day,
  108. usually including weekends, and most messages are posted to the net within
  109. a day after I receive them.  Occasionally when I go on vacation there may
  110. be up to a week's delay, though I try to send out a message when that will
  111. happen.
  112.  
  113. Most net news systems will automatically turn posted messages into mail to
  114. compilers, but some, particularly systems running notes, don't do that
  115. correctly.  As a result, I sometimes receive hundreds of copies of a
  116. message, all mangled slightly differently.  Please mail your contributions
  117. unless you're sure your posting software works correctly.
  118.  
  119. When you send a message to compilers, I understand that to mean that you
  120. want me to post it to usenet, which means it will be sent to tens of
  121. thousands of potential readers at thousands of computers all around the
  122. world.  It may also appear in a printed comp.compilers annual and other
  123. books, in printed journals, in on-line and off-line archives, CD-ROMs, and
  124. anywhere else that some reader decides to use it.
  125.  
  126. If you don't want me to post something, send it instead to
  127. compilers-request.  (See below.)
  128.  
  129. PLEASE: Format messages with lines of less than 70 characters, since many
  130. news readers (including mine) don't auto-wrap very well.  Also remove quoted
  131. material not immediately germane to your response.  Messages must be in plain
  132. ASCII, not TeX input, troff, SGML, RTF or any other markup language.
  133.  
  134. -- What happens to submitted messages?
  135.  
  136. Barring mail problems, they arrive in a special mailbox here at iecc.  I then
  137. edit the headers, trim down quoted text, fix typos and grammatical errors,
  138. remove cute signatures, and then post them to usenet.  If I think a message
  139. needs more editing than that, I return it to the author for rewriting.  The
  140. main reasons I return a message are that it appears more appropriate for
  141. another group, the message is too garbled to fix, it contains too much quoted
  142. material relative to the amount of new material, or I don't understand it.
  143. Another possibility is that a message doesn't have a valid return e-mail
  144. address.  See the next question for more about what's on and off topic.
  145.  
  146. I discard messages that say "reply to me because I don't read this group",
  147. and forward spams back to the appropriate postmaster.  Messages from
  148. anonymous or anonymized addresses are not acceptable, although I suppose I
  149. could be persuaded to post a message with the sender's identity removed
  150. given a persuasive enough reason.
  151.  
  152. If a message asks a simple question I sometimes answer it myself rather than
  153. posting it.  When two or three messages arrive with the same answer to a
  154. question, I usually post only one of them, with a comment crediting the
  155. others.
  156.  
  157. If you send in a message and don't either see it posted or receive
  158. something back in a few days, it probably got lost in the mail and you
  159. should contact me, preferably via a different mail route.  I post or
  160. respond to all messages except for ones that appear to have been sent by
  161. mistake, e.g. no contents, contents consisting only of another quoted
  162. message, or a personal message for the author of a previous message.
  163. Sometimes when I'm feeling exasperated I disregard messages that re-ask
  164. one of the frequently asked questions that are answered below.
  165.  
  166. One of the most time-consuming jobs in moderating the group is trimming down
  167. the quotes in followup articles.  In most cases, you can expect readers to
  168. have seen the previous article, so only a few lines of quoted text should be
  169. needed to remind the reader of the context.
  170.  
  171. I have installed a simple-minded quote filter that mechanically returns to
  172. the sender any message that contains more quoted than unquoted lines.  Please
  173. edit your quotes before you send in a response, to avoid having the filter
  174. bounce your message.  Since the quote filter is pretty dumb, I do look at
  175. bounced messages myself.  If the filter bounces a message of yours by mistake,
  176. don't panic -- it'll get posted anyway.  If you write to me and complain
  177. about the quote filter, I'll discard both your complaint and your original
  178. message.
  179.  
  180. -- What message formats are appropriate?
  181.  
  182. Plain old ASCII.  No MIME, uuencoded, zipped, LaTeX, HTML, NeXTmail, RTF, GIF,
  183. gzip, MSN Exchange, or anything else, just ASCII, because a substantial
  184. fraction of the readership still can't handle anything else.  And keep line
  185. lengths to between 70 and 80 characters, and don't justify lines with extra
  186. white space nor indent the whole message with white space.  (Your moderator
  187. has strong aesthetic opinions.)
  188.  
  189. If you want to make something non-ASCII available to the readership, put it on
  190. an FTP or WWW server and send in a descriptive note with the URL.  Material of
  191. general interest can go on the archive server here.  Send me a message at
  192. compilers-request@iecc.com if you have something for the archive.
  193.  
  194. -- What topics are and aren't appropriate?
  195.  
  196. Any message discussing aspects of compiler design and implementation is
  197. appropriate.  Language design is usually OK as well insofar as it affects
  198. compiler design, until it drifts off into theological issues like where the
  199. semicolon goes.
  200.  
  201. Questions about particular compilers, programming languages, and systems
  202. should go to newsgroups about the language or system.
  203.  
  204. "For sale" messages should go to one of the misc.forsale or regional
  205. forsale groups.
  206.  
  207. I post one announcement per conference, for any conference with a topic
  208. relevant to compilers.  I usually post student offers to share a room at a
  209. conference, and should probably digest them as well.
  210.  
  211. Postings announcing commercial products are welcome so long as there
  212. is substantially more technical content than hype.
  213.  
  214. ``Help wanted'' and ``Position Available'' messages are collected each week
  215. and posted in a digest every Sunday.  Resumes are discarded, since most of
  216. them come from robots mechanically sending them out in response to every
  217. message in misc.jobs.offered.
  218.  
  219. For technical reasons, I can't cross-post messages to other moderated groups,
  220. except one or two like comp.parallel with whom I have an informal agreement
  221. to allow cross-posts.
  222.  
  223. I usually return messages that directly attack individuals, since the net has
  224. plenty of other places for ad-hominem battles.
  225.  
  226. -- How do I respond to the author of a message?
  227.  
  228. I try to be sure that every message contains valid From: and Reply-To:
  229. headers.  The automatic "reply" commands in most news readers let you send
  230. mail to the author.  If you're replying to a message in a digest, be sure
  231. to respond to the author of the particular message, not to the pseudo-author
  232. of the digest.
  233.  
  234. Some obsolete news readers attempt to reply using the Path: header, but for
  235. technical reasons the Path: header in a moderated message cannot point to the
  236. actual author.  In fact, the Path: header in a compilers message is
  237. deliberately a bad mail address, so if you have such a news reader you'll
  238. have to edit the addresses in responses yourself and, I hope, encourage your
  239. system manager to update your news and mail software.
  240.  
  241. Sometimes mail to an author bounces, either because a gateway isn't working
  242. or because the return address is unregistered or otherwise bad.  Please don't
  243. ask me to forward it, since my machine is no better connected than anyone
  244. else's.  (It's just another node on the Internet.)  If you send me a message
  245. obviously intended for the author of an item, I will discard it on the theory
  246. that if it wasn't important enough for you to send it to the right place, it
  247. isn't important enough for me, either.
  248.  
  249. -- How do I contact the moderator?
  250.  
  251. Send me mail at compilers-request@iecc.com.  I treat messages to
  252. compilers-request as private messages to me unless they state that they are
  253. for publication.
  254.  
  255. -- Are back issues available?
  256.  
  257. I have complete archives going back to the original mailing list in 1986.
  258. The archives now fill over 36 megabytes, and are growing at over 700K per
  259. month.  People with ftp access can get them from iecc.com in directory
  260. pub/articles.  The archives contain a gzipped Unix mailbox format file for
  261. each month, with names like 91-08.gz.  Directory pub/index contains index
  262. files, one for each year.  You can retrieve messages by full text search or
  263. by message number at the compilers web site at
  264. http://www.iecc.com/compilers/.
  265.  
  266. There is now a mail server at compilers-server@iecc.com that can mail you
  267. indexes, messages, and the files mentioned below.  Send it a message
  268. containing "help" to get started.
  269.  
  270. I have also published a printed edition of the 1990 messages grouped by
  271. thread and topic, and with some indexes, and may publish subsequent
  272. editions.  (If you'd be intereted in editing books for later years, let me
  273. know.)  See the message which should immediately follow this one for
  274. further details on the 1990 book. 
  275.  
  276. -- Some Frequently Asked Questions:
  277.  
  278. NOTE: Many issues are discussed occasionally on comp.compilers, but not
  279. frequently enought to make the FAQ sheet.  If you have a question but the
  280. answer isn't in the FAQ, you may well be able to get good background by
  281. reading the appropriate articles in the archive.  If you can FTP, please
  282. at least get the index and look through it.
  283.  
  284. The various files that I mention below that I have are in the compilers
  285. FTP archive at iecc.com, and are also available from the mail server mentioned
  286. above.  If you can FTP them, please do so rather than using the mail
  287. server, since the mail bandwith is quite small.
  288.  
  289. * Where can I get a C or C++ grammar in yacc?
  290.  
  291. Jim Roskind's well-known C and C++ grammars are in the FTP archive, as is
  292. a C grammar written by Jeff Lee.  Dave Jones posted a parser as message
  293. 91-09-030.  Another C grammar was posted to comp.sources.misc in June
  294. 1990, v13 i52, archive name ansi-c_su.  GCC and G++ are based on yacc
  295. grammars, see below.
  296.  
  297. Also see ctree, which parses C code into parse trees and makes symbol
  298. tables, available from ftp.cs.wisc.edu:/coral/tmp/spf/ctree.0.0.tar.gz.
  299. It's described in message 95-07-114.
  300.  
  301. * Where can I get the Gnu C compiler?
  302.  
  303. GCC is a high-quality free C and C++ compiler.  (Free is not the same as
  304. public domain, see the GCC distribution for details.)  It is available in
  305. source from prep.ai.mit.edu.  You need an existing C compiler and
  306. libraries to bootstrap it.
  307.  
  308. A development system called "djgpp" by DJ Delorie <dj@ctron.com> is based
  309. on gcc and other GNU programs, and runs on 386 or higher PCs running
  310. MS-DOS.  This is available by FTP from the SimTel archives (primary mirror
  311. is oak.oakland.edu) in the directory pub/vendors/djgpp.  Another DOS version
  312. of GCC called EMX is at ftp.informatik.tu-muenchen.de [131.159.0.198] in
  313. /pub/comp/os/os2/devtools/emx+gcc.
  314.  
  315. * Are there other free C compilers?
  316.  
  317. lcc is the retargetable compiler for ANSI C described in `A Retargetable C
  318. Compiler: Design and Implementation' (Benjamin/Cummings, 1995, ISBN
  319. 0-8053-1670-1), which will be available in December 1994. lcc is in
  320. production use at Princeton University and AT&T Bell Laboratories.  The
  321. current version of lcc generates code for the SPARC, MIPS R3000 and 386
  322. under DOS (no libraries for DOS are available yet).  The code generator
  323. generator is available too as a icon program, a C version has been
  324. promised.  There are mailing lists lcc{,-bugs}@cs.princeton.edu, managed
  325. by majordomo@cs.princeton.edu.  The object code is not great, but the
  326. compiler is ANSI compatible and is small and fast.  You need a
  327. preprocessor such as the one in gcc to get lcc to run.  Lcc uses a
  328. hard-coded C parser because it's faster than yacc.
  329.  
  330. Thanks to Horst von Brand <vonbrand@inf.utfsm.cl> for this info.
  331.  
  332. * Where can I get a Fortran grammar in yacc or a Fortran compiler?
  333.  
  334. I have a small subset parser in the archive at iecc.com.  The F2C
  335. Fortran to C translator is a respectable Fortran system (so long as
  336. you have a C compiler to compile its output and its libraries) and
  337. contains a full F77 parser and is available in source form via FTP
  338. from netlib.att.com and by mail from netlib@research.att.com.
  339.  
  340. * Where can I get Modula-2, Pascal, Ada, or SQL grammars in yacc?
  341.  
  342. I have one each of those, too, in the archive at iecc.com, though I
  343. haven't tried to use any of them.
  344.  
  345. According to the comp.lang.ada FAQ, a yacc grammar for Ada 95 is available:
  346.  
  347. ftp://sw-eng.falls-church.va.us/public/AdaIC/standards/95lrm_rat/grammar9x.y
  348.  
  349. and a lex grammar for Ada 95 is available:
  350.  
  351. ftp://sw-eng.falls-church.va.us/public/AdaIC/standards/95lrm_rat/lexer9x.l
  352.  
  353. There's an Ada front end called GNAT for GCC, available at
  354. ftp://cs.nyu.edu/pub/gnat/.
  355.  
  356. * Where can I get a Cobol grammar in yacc?
  357.  
  358. Nowhere for free, as far as I can tell.  This question is asked every few
  359. months and there has never, ever, been any positive response. Perhaps some
  360. of the interested people could get together and write one.  The commercial
  361. PCYACC from Abraxas (see below) comes with a bunch of sample grammars
  362. including one for Cobol-85.
  363.  
  364. Also see the Cobol FAQ posted monthly to comp.lang.misc and comp.lang.cobol.
  365.  
  366. * Where can I get a Basic grammar in yacc?
  367.  
  368. Take a look at ftp.uu.net:usenet/comp.sources.unix/volume2/basic which
  369. contains a Basic interpreter with yacc parser.
  370.  
  371. * Where can I get a QBasic compiler?
  372.  
  373. You buy it from Microsoft.  A shareware compiler ASIC is available
  374. from simtel mirrors in /msdos/basic/asic???.zip, such as ftp.coast.net
  375. in /SimTel/msdos/basic/asic???.zip.  It handles a large subset of Qbasic.
  376.  
  377. * Where can I get a PL/M grammar?
  378.  
  379. There's one in the archives at iecc.com, called plm.shar.  Also see message
  380. 94-03-062 for a report on a PL/M to C translator.
  381.  
  382. * Are there free versions of yacc and lex ?
  383.  
  384. Vern Paxton's flex is a superior reimplementation of lex.  It is available
  385. from the same places as Gnu sources, but is not subject to the Gnu
  386. copyleft.  Berkeley Yacc is a quite compatible PD version of yacc by Bob
  387. Corbett, available on ftp.cs.berkeley.edu, in ~ftp/ucb/4bsd/byacc.tar.Z. Gnu
  388. Bison is derived from an earlier version of Corbett's work and is also
  389. fairly compatible with yacc.  A byacc extension that displays graphically
  390. the progress of a parse can be found in Jim Roskind's C++ grammar in the
  391. FTP compilers archive.  (The files are too big for the mail archive,
  392. sorry.)
  393.  
  394. * Are there versions of yacc and lex for MS-DOS?
  395.  
  396. There are several of them.  Commercial versions are MKS lex&yacc from MKS
  397. in Waterloo Ont., +1 519 884 2251, http://www.mks.com or inquiry@mks.com,
  398. and PCYACC from Abraxas Software in Portland OR, +1 503 244 5253.  Both
  399. include both yacc and lex along with a lot of sample code.
  400.  
  401. The standard flex source compiles under the usual DOS compilers, although
  402. you may want to make some of the buffers smaller.  A DOS version of Bison
  403. is on wuarchive.wustl.edu [128.252.135.4] and other servers under
  404. SimTel/msdos/pgmutil/bison111.zip. See message 92-07-012 for more info.
  405.  
  406. * Are there C++ versions of yacc and lex?
  407.  
  408. flexx++ and bison++ can be found at:
  409.  
  410. ftp://ftp.th-darmstadt.de/pub/programming/languages/C++/tools/flex++bison++/
  411.  
  412. * What other compilers and tools are freely available?
  413.  
  414. There is a five-part FAQ posting in comp.compilers and other groups listing
  415. compiler tools freely available in source form, maintained by Steve
  416. Robenalt <free-compilers@idiom.berkeley.ca.us>.  It is posted monthly,
  417. usually right after this message.  If it's not on your system, you can FTP
  418. it from rtfm.mit.edu in the directory
  419. /pub/usenet/news.answers/free-compilers, or via mail by sending a message
  420. to to mail-server@rtfm.mit.edu with the command "send
  421. usenet/news.answers/free-compilers/*" in the text.
  422.  
  423. Also visit the web page http://www.first.gmd.de/cogent/catalog/ which includes
  424. pointers to a variety of compiler tools and resources.
  425.  
  426. * How can I get started with yacc and lex and compiler writing in general?
  427.  
  428. By reading any of the many books on the topic.  Here are a few of them.
  429. Also see message 93-01-155 which reviews many compiler textbooks.
  430.  
  431. Aho, Sethi, and Ullman, "Compilers: Principles, Techniques, and Tools,"
  432. Addison Wesley, 1986, ISBN 0-201-10088-6, the "dragon book".
  433.  
  434. Describes clearly and completely lexing and parsing techniques including
  435. the ones in yacc and lex.  The authors work or have worked at Bell Labs
  436. with Steve Johnson and Mike Lesk, the authors of Yacc and Lex.
  437.  
  438. Alan Holub, "Compiler Design in C," Prentice-Hall, 1990, ISBN
  439. 0-13-155045-4.
  440.  
  441. A large book containing the complete source code to a reimplementation of
  442. yacc and lex and a C compiler.  Quite well written, too, though it has a
  443. lot of errors.  The fourth printing is supposed to correct most of them.
  444. An errata list is in message 90-06-081.
  445.  
  446. John R. Levine (that's me), Tony Mason, and Doug Brown, ``Lex & Yacc,''
  447. 2nd Edition, O'Reilly and Associates, 1992, ISBN 1-56592-000-7, $29.95.
  448.  
  449. A concise introduction with completely worked out examples and an
  450. extensive reference section.  The new edition is completely revised from
  451. the earlier 1990 edition.  Source code can be FTP'ed from ftp.ora.com.
  452.  
  453. Donnely and Stallman, "The Bison Manual," part of the on-line distrubution
  454. of the FSF's Bison, a reimplementation of yacc.  As with everything else from
  455. the FSF, full source code is included.
  456.  
  457. Axel T. Schreiner and H. George Friedman, Jr., "Introduction to Compiler
  458. Construction with UNIX," Prentice-Hall, 1985.
  459.  
  460. Oriented to tutorial work.  Good for beginners.  Develops a small
  461. subset-of-C compiler through the book.  (Recommended by Eric Hughes
  462. <hughes@ocf.Berkeley.EDU>.)  Richard Hash <rgh@shell.com> comments that
  463. the book has many typographical errors, and readers should be suspicious
  464. of the examples until they actually try them.  Richard Y. Kim
  465. <richard@ear.mit.edu> reports that sources are available for FTP as
  466. a.cs.uiuc.edu:pub/friedman/tar.
  467.  
  468. Bennett, J.P. "Introduction to Compiling Techniques - A First Course Using
  469. Ansi C, Lex and Yacc," McGraw Hill Book Co, 1990, ISBN 0-07-707215-4.
  470.  
  471. It's intended for a first course in modern compiler techniques, is very
  472. clearly written, and has a full chapter on YACC.  I found it to be a good
  473. introductory text before getting into the 'Dragon book'.  (Recommended by
  474. John Merlin <J.H.Merlin@ecs.southampton.ac.uk>.)  Source code is available
  475. at ftp.bath.ac.uk.
  476.  
  477. Charles N. Fischer & Richard J. LeBlanc, "Crafting A Compiler", Benjamin
  478. Cummings Publishing, Menlo Park, CA, 1988, ISBN 0-8053-3201-4.  There's
  479. also a revised version as of 1990 or 1991 titled "Crafting A Compiler in
  480. C", with all examples in C (the original used ADA/CS).  The C tools are at
  481. ftp://ftp.csc.ncsu.edu/pub/compilers/crafting_compiler/tools
  482.  
  483. Erich Nahum <nahum@cs.umass.edu> writes: A key compiler reference.  We
  484. used the original to great effect in Eliot Moss' graduate compiler
  485. construction class here at UMass.  My feeling is that Fischer & LeBlanc is
  486. a good tutorial, and one should use Aho, Sethi, & Ullman as a reference.
  487.  
  488. Des Watson, "High-Level Languages and Their Compilers," International
  489. Computer Science Series, Addison-Wesley Publishing Company, Wokingham
  490. England, 1989.
  491.  
  492. Adrian Howard <adrianh@cogs.sussex.ac.uk> writes: This is the kindest,
  493. most readable introduction to compilers at the graduate level I have ever
  494. read - an excellent example of what textbooks should all be like.
  495.  
  496. W.M. Waite and G. Goos, "Compiler Construction," Springer-Verlag, New
  497. York, 1984.
  498.  
  499. Dick Grune <dick@cs.vu.nl> writes: A theoretical approach to compiler
  500. construction. Refreshing in that it gives a completely new view of many
  501. subjects. Heavy reading, high information density.
  502.  
  503. J.P. Tremblay and P.G. Sorenson, "The Theory and Practice of Compiler
  504. Writing," McGraw-Hill, 1985.
  505.  
  506. Dick Grune <dick@cs.vu.nl> writes: Extensive and detailed. Heavy reading.
  507. To be consulted when other sources fail.
  508.  
  509. James E. Hendrix, "The Small-C Compiler", 2nd ed., M&T Books, ISBN
  510. 0-934375-88-7 <Book Alone>, 1-55851-007-9 <MS-DOS Disk>, 0-934375-97-6
  511. <Book and Disk>.
  512.  
  513. William Jhun <ec_ind03@oswego.edu> writes: It explaines the C-language is
  514. thorough....and explains every single aspect of the compiler. The book
  515. compares source code to p-code to assembly. It goes over a nice set of
  516. optimization routines, explains the parser, the back end, and even
  517. includes source code, which the compiler on the disk can actually compile
  518. itself. It's an extremely interesting book, check it out. (Out of print.)
  519.  
  520. Ronald Mak, "Writing Compilers and Interpreters: An Applied Approach",
  521. 1991, John Wiley and Sons, Inc. ISBN 0-471-50968-X.
  522.  
  523. Andrew Tucker <a_tucker@paul.spu.edu> writes: This 512-page book presents
  524. a strictly hands on approach, developing a Pascal interpreter and
  525. interactive debugger, then completing with a compiler which emits 8086
  526. assembly.  All source code is provided in print and on disk.  This book is
  527. very low to non-existent in theoretical content, but is very practical and
  528. readable for an introduction.  Taylor Hutt <thutt@access.digex.net>
  529. comments that the book is a piece of junk.  The code that is contained in
  530. the book is full of bugs, and the code that it generates will not work.
  531.  
  532. "The Art of Compiler Design", Thomas Pittman & James Peters, Prentice-Hall
  533. International, 1992, Englewood Cliffs, NJ 07632, 0-13-046160-1
  534.  
  535. Franklin L. Vermeulen <vfrank@vnet3.vub.ac.be> writes: This is a very
  536. nicely written and straightforward text on compiler construction.  There
  537. is a certain (unavoidable?) amount of overlap with a course on automata
  538. (as in Aho, Sethi and Ullman).  It is based on Modula-2 and on an
  539. experimental tool, the TAG compiler-compiler (Transformational Attribute
  540. Grammar) which seems to be a C-independent superset of lex/yacc, because
  541. its syntax allows you to specify all semantic actions without a single
  542. line of C-code (or any other implementation language, for that matter).
  543.  
  544. A. Pyster, "Compiler Design and Constuction (Tools and Techniques)",
  545. Second Ed., Van Nostrand Reinhold, ISBN: 0-442-27536-6.
  546.  
  547. Gabriela O. de Vivo <gdevivo@dino.conicit.ve> writes: The book covers the
  548. general principles of compiler design and presents a good number of
  549. examples focusing on the building of pieceparts of compilers for C and
  550. Pascal.  The implementation (construction) language is C.  Note that this
  551. edition (in contrast with the previous one) is very related to the Unix
  552. world, including the use of tools like Lex, Yacc, and standard utilities.
  553. (Out of print.)
  554.  
  555. Thomas W. Parsons, "Introduction to compiler construction",
  556. Computer Science Press, c1992, ISBN: 0-716782618.
  557.  
  558. Quinn Tyler Jackson <qjackson@direct.ca> writes: Provides a broad overview
  559. of the topics of finite state automaton theory (deterministic and
  560. non-deterministic), lexical analysis, parsing models, and target generation
  561. and optimization strategies.  Includes appendices on lex and yacc.  Most
  562. examples in Pascal.  (Recommended reading for the faint at heart.)
  563.  
  564. "Programming a Personal Computer" by Per Brinch Hansen
  565. Prentice-Hall 1982 ISBN 0-13-730283-5
  566.  
  567. Joe Snyder <joe@semaphorecorp.com> writes:  This unfortunately-titled book
  568. explains the design and creation of a single-user programming environment
  569. for micros, using a Pascal-like language called Edison.  The author presents
  570. all source code and explanations for the step-by-step implementation of an
  571. Edison compiler and simple supporting operating system, all written in
  572. Edison itself (except for a small supporting kernel written in a symbolic
  573. assembler for PDP 11/23; the complete source can also be ordered for the IBM
  574. PC).
  575.  
  576. The most interesting things about this book are:  1) its ability to
  577. demonstrate how to create a complete, self-contained, self-maintaining,
  578. useful compiler and operating system, and 2) the interesting discussion of
  579. language design and specification problems and trade-offs in Chapter 2.
  580.  
  581.  
  582. "Brinch Hansen on Pascal Compilers" by Per Brinch Hansen
  583. Prentice-Hall 1985 ISBN 0-13-083098-4
  584.  
  585. Joe Snyder <joe@semaphorecorp.com> writes:  Another light-on-theory
  586. heavy-on-pragmatics here's-how-to-code-it book.  The author presents the
  587. design, implementation, and complete source code for a compiler and p-code
  588. interpreter for Pascal- (Pascal "minus"), a Pascal subset with boolean and
  589. integer types (but no characters, reals, subranged or enumerated types),
  590. constant and variable definitions and array and record types (but no packed,
  591. variant, set, pointer, nameless, renamed, or file types), expressions,
  592. assignment statements, nested procedure definitions with value and variable
  593. parameters, if statements, while statements, and begin-end blocks (but no
  594. function definitions, procedural parameters, goto statements and labels,
  595. case statements, repeat statements, for statements, and with statements).
  596.  
  597. The compiler and interpreter are written in Pascal* (Pascal "star"), a
  598. Pascal subset extended with some Edison-style features for creating
  599. software development systems.  A Pascal* compiler for the IBM PC is sold by
  600. the author, but it's easy to port the book's Pascal- compiler to any
  601. convenient Pascal platform.
  602.  
  603. This book makes the design and implementation of a compiler look easy.  I
  604. particularly like the way the author is concerned with quality,
  605. reliability, and testing.  The compiler and interpreter can easily be used
  606. as the basis for a more involved language or compiler project, especially
  607. if you're pressed to quickly get something up and running.
  608.  
  609.  
  610. "A Model Implementation of Standard Pascal" by Jim Welsh & Atholl Hay
  611. Prentice-Hall 1986 ISBN 0-13-586454-2
  612.  
  613. Joe Snyder <joe@semaphorecorp.com> writes:  This book is only really useful
  614. if you need to implement a COMPLETE version of a platform-independent
  615. Pascal, but I find it interesting because the 483 pages consist entirely of
  616. the source code listing for the compiler and p-code interpreter, including
  617. copious {comments} to explain the code.  The code eagerly delves into the
  618. horrible minutiae necessary when implementing a complete language, and proves
  619. that no language designer should be allowed to present his design until
  620. AFTER being forced to write a complete compiler for the language.
  621.  
  622. If anyone sends in others, I'll be happy to add them to the list.
  623.  
  624. * Where can I FTP the sources to the programs in Holub's "Compiler
  625. Design in C" or Mak's "Writing Compilers and Interpreters" ?
  626.  
  627. You can't.  In Mak's book there's ordering information for diskettes with
  628. the code.  Holub sells disks direct, finger holub@violet.berkeley.edu for
  629. contact info.
  630.  
  631. * Where can I learn about garbage collection ?
  632.  
  633. Garbage collection (more properly, automatic storage management) has its own
  634. mailing list and FAQ.  The FAQ is:
  635.  
  636. http://www.centerline.com/people/chase/GC/GC-faq.html
  637.  
  638. To join the list, send "subscribe gclist" to majordomo@iecc.com.
  639.  
  640. Regards,
  641. John Levine, comp.compilers moderator
  642. --
  643. Send compilers articles to compilers@iecc.com,
  644. meta-mail to compilers-request@iecc.com.
  645.