Parsers in TEX and Using CWEB for General Pretty-Printing 72 Tugboat, Volume 35 (2014), No

Total Page:16

File Type:pdf, Size:1020Kb

Parsers in TEX and Using CWEB for General Pretty-Printing 72 Tugboat, Volume 35 (2014), No TUGboat, Volume 35 (2014), No. 1 71 Parsers in TEX and using CWEB for general and thus relies on a number of very clever techniques pretty-printing that are highly language-specific (out of necessity). Since TEX is a system well-suited for typeset- Alexander Shibakov ting technical documents, pretty-printing texts writ- In this article I describe a collection of TEX macros ten in formal languages is a common task and is also and a few simple C programs called SPLinT that one of the primary reasons to consider a parser writ- enable the use of the standard parser and scanner ten in TEX. generator tools, bison and flex, to produce very The author's initial motivation for writing the general parsers and scanners coded as TEX macros. software described in this article grew out of the SPLinT is freely available from http://ctan.org/ desire to fully document a few embedded micro- pkg/splint and http://math.tntech.edu/alex. controller projects that contain a mix of C code, Makefiles, linker scripts, etc. While the majority Introduction of code for such projects is written in C, superbly processed by CWEB itself, some crucial information The need to process formally structured languages resides in the kinds of files mentioned above and can inside TEX documents is neither new nor uncom- only be handled by CWEB's verbatim output (with mon. Several graphics extensions for TEX (and some minimal postprocessing, mainly to remove the LATEX) have introduced a variety of small special- #line directives left by CTANGLE). ized languages for their purposes that depend on simple (and not so simple) interpreters coded as Parsing with TEX vs. others TEX macros. A number of pretty-printing macros take advantage of different parsing techniques to Naturally, using TEX in isolation is not the only way achieve their goals (see [Go], [Do], and [Wo]). to produce pretty-printed output. The CWEB sys- Efforts to create general and robust parsing tem for writing structured documentation uses TEX frameworks inside TEX go back to the origins of merely as a typesetting engine, while handing over TEX itself. A well-known BASIC subset interpreter, the job of parsing and preprocessing the user's in- BASIX (see [Gr]) was written as a demonstration put to a program built specifically for that purpose. of the flexibility of TEX as a programming language Sometimes, however, a paper or a book written in and a showcase of TEX's ability to handle a variety TEX contains a few short examples of programs writ- of abstract data structures. On the other hand, ten in another programming language. Using a sys- a relatively recent addition to the LATEX toolbox, tem such as CWEB to process these fragments is cer- l3regex (see [La]), provides a powerful and very tainly possible (although it may become somewhat general way to perform regular expression matching involved) but a more natural approach would be to in LATEX, which can be used (among other things) create a parser that can process such texts (with to design parsers and scanners. some minimal help from the user) entirely inside Paper [Go] contains a very good overview of TEX itself. As an example, pascal (see [Go]) was several approaches to parsing and tokenizing in created to pretty-print Pascal programs using TEX. TEX and outlines a universal framework for parser It used a custom scanner for a subset of standard design using TEX macros. In an earlier article Pascal and a parser, generated from an LL(1) Pas- (see [Wo]), Marcin Woli´nski describes a parser cal grammar by a parser generator, called parTEX. creation suite paralleling the technique used by Even if CWEB or a similar tool is used, there may CWEB (CWEB's `grammar' is hard-coded into CWEAVE, still be a need to parse a formal language inside TEX. whereas Woli´nski'sapproach is more general). One One example would be the use of CWEB to handle a commonality between these two methods is a highly language other than C. customized tokenizer (or scanner) used as the input Before I proceed with the description of the tool to the parser proper. Woli´nski'sdesign uses a finite that is the main subject of this paper, allow me to automaton as the scanner engine with a `manually' pause for just a few moments to discuss the wisdom designed set of states. No backing up mechanism (or lack thereof) of laying the task of parsing for- was provided, so matching, say, the longest input mal texts entirely on TEX's shoulders. In addition would require some custom coding (it is, perhaps, to using an external program to preprocess a TEX worth mentioning here that a backup mechanism is document, some recent developments allow one to all one needs to turn any regular language scanner implement a parser in a language `meant for such into a general CWEB-type parser). The scanner in tasks' inside an extension of TEX. We are speaking [Go] was designed mainly with efficiency in mind of course about LuaTEX (see [Ha]) that essentially Parsers in TEX and using CWEB for general pretty-printing 72 TUGboat, Volume 35 (2014), No. 1 implements an entirely separate interface to TEX's use) framework for storing and manipulating ar- typesetting mechanisms and data structures in Lua rays and lists (see the discussion of list macros in (see [Lu]), `grafted' onto a TEX extension. Appendix D of The TEXbook and in [Gr]) but this Although I feel nothing but admiration for the limitation is readily overcome by putting some extra LuaTEX developers, and completely share their de- care into one's macros. sire to empower TEX by providing a general purpose programming language on top of its internal mecha- Languages, grammars, parsers, and TEX nisms, I would like to present three reasons to avoid taking advantage of LuaTEX's impressive capabili- Or ::: ties for this particular task. Tokens and tables keep macros in check. First, I am unaware of any standard tools for Make 'em with bison, use WEAVE as a tool. generating parsers and scanners in Lua (of course, it Add TEX and CTANGLE, and C to the pool. would be just as easy to use the approach described Reduce 'em with actions, look forward, not back. here to create such tools). At this point in time, Macros, productions, recursion and stack! it is just as easy to coax standard parser generators Computer generated (most likely) into outputting parsers in TEX as it is to make them The goal of the software described in this article, output Lua. SPLinT (Simple Parsing and Lexing in TEX, or, in Second, I am a great believer in generating the tradition of GNU, SPLinT Parses Languages in `archival quality' documents: standard TEX has TEX) is to give a macro writer the ability to use been around for almost three decades in a practi- standard parser/scanner generator tools to produce cally unchanged form, an eternity in the software TEX macros capable of parsing formal languages. world. The parser produced using the methods Let me begin by presenting a `bird's eye view' outlined in this paper uses standard (plain) TEX ex- of the setup and the workflow one would follow to clusively. Moreover, if the grammar is unchanged, create a new parser with this package. To take full the parser code itself (i.e. its semantic actions) is advantage of this software, two external programs very readable, and can be easily modified without (three if one counts a C compiler) are required: going through the whole pipeline (bison, flex, etc.) bison and flex (see [Bi] and [Pa]), the parser and again. A full record of the grammar is left with the scanner generators, respectively. Both are freely generated parser and scanner so even if the more available under the terms of the General Public `volatile' tools, such as bison and flex, become License version 3 or higher and are standard tools incompatible with the package, the parser can still included in practically every modern GNU/Linux be utilized with TEX alone. Perhaps the following distribution. Versions that run under a number of quote by D. Knuth (see [DEK2]) would help to re- other operating systems exist as well. inforce this point of view: \Of course I do not claim While the software allows the creation of both to have found the best solution to every problem. I parsers and scanners in TEX, the steps involved in simply claim that it is a great advantage to have a making a scanner are very similar to those required fixed point as a building block." to generate a parser, so only the parser generation Finally, the idea that TEX is somehow un- will be described below. suitable for such tasks may have been overstated. Setting the semantic actions aside for the mo- While it is true that TEX's macro language lacks ment, one begins by preparing a generic bison input some of the expressive ability of its `general purpose' file, following some simple guidelines. Not all bison brethren, it does possess a few qualities that make options are supported (the most glaring omission it quite adept at processing text (it is a typeset- is the ability to generate a general LR (glr) parser ting language after all!). Among these features are: but this may be added in the future) but in every a built-in hashing mechanism (accessible through other respect it is an ordinary bison grammar. In \csname...\endcsname and \string primitives) some cases, a bison grammar may already exist and for storing and accessing control sequence names can be turned into a TEX parser with just a few (or and creating associative arrays, a number of tools none!) modifications and a new set of semantic ac- and data structures for comparing and manipu- tions (written in TEX of course).
Recommended publications
  • Donald Knuth Fletcher Jones Professor of Computer Science, Emeritus Curriculum Vitae Available Online
    Donald Knuth Fletcher Jones Professor of Computer Science, Emeritus Curriculum Vitae available Online Bio BIO Donald Ervin Knuth is an American computer scientist, mathematician, and Professor Emeritus at Stanford University. He is the author of the multi-volume work The Art of Computer Programming and has been called the "father" of the analysis of algorithms. He contributed to the development of the rigorous analysis of the computational complexity of algorithms and systematized formal mathematical techniques for it. In the process he also popularized the asymptotic notation. In addition to fundamental contributions in several branches of theoretical computer science, Knuth is the creator of the TeX computer typesetting system, the related METAFONT font definition language and rendering system, and the Computer Modern family of typefaces. As a writer and scholar,[4] Knuth created the WEB and CWEB computer programming systems designed to encourage and facilitate literate programming, and designed the MIX/MMIX instruction set architectures. As a member of the academic and scientific community, Knuth is strongly opposed to the policy of granting software patents. He has expressed his disagreement directly to the patent offices of the United States and Europe. (via Wikipedia) ACADEMIC APPOINTMENTS • Professor Emeritus, Computer Science HONORS AND AWARDS • Grace Murray Hopper Award, ACM (1971) • Member, American Academy of Arts and Sciences (1973) • Turing Award, ACM (1974) • Lester R Ford Award, Mathematical Association of America (1975) • Member, National Academy of Sciences (1975) 5 OF 44 PROFESSIONAL EDUCATION • PhD, California Institute of Technology , Mathematics (1963) PATENTS • Donald Knuth, Stephen N Schiller. "United States Patent 5,305,118 Methods of controlling dot size in digital half toning with multi-cell threshold arrays", Adobe Systems, Apr 19, 1994 • Donald Knuth, LeRoy R Guck, Lawrence G Hanson.
    [Show full text]
  • An Interview with Donald Knuth 33
    Bijlage M An Interview with Donald Knuth 33 An Interview with Donald Knuth DDJ chats with one of the world's leading computer scientists Jack Woehr Dr. Dobb's Journal∗ [email protected] April 1996 For over 25 years, Donald E. Knuth has generally been honorable term, but to some people a computer program- considered one of the world's leading computer scientists. mer is somebody who just follows instructions without un- Although he's authored more than 150 publications, it is derstanding what he's doing, one who just knows how to Knuth's three-volume The Art of Computer Programming get through the idiosyncrasies of some language. which has become a staple on every programmer's book- To me, a computer scientist is somebody who has a way shelf. In 1974, Knuth was the recipient of computer sci- of thinking, which resonates with computer programming. ence's most prestigious prize, the Turing Award. He also The way a computer scientist views knowledge in general received the National Medal of Science in 1979. is different from the way a mathematician views knowl- In addition to his work developing fundamental algorithms edge, which is different from the way a physicist views for computer programming, Knuth was a pioneer in com- knowledge, which is different from the way a chemist, puter typesetting with his TEX, METAFONT, and WEB ap- lawyer, or poet views knowledge. plications. He has written on topics as singular as ancient There's about one person in every ®fty who has this pecu- Babylonian algorithms and has penned a novel.
    [Show full text]
  • The Annals of the UK TEX Users' Group Editor: Editor
    Baskerville The Annals of the UK TEX Users’ Group Editor: Editor: Sebastian Rahtz Vol. 4 No. 6 ISSN 1354–5930 February 1998 Articles may be submitted via electronic mail to [email protected], or on MSDOS-compatible discs, to Sebastian Rahtz, Elsevier Science Ltd, The Boulevard, Langford Lane, Kidlington, Oxford OX5 1GB, to whom any correspondence concerning Baskerville should also be addressed. This reprint of Baskerville is set in Times Roman, with Computer Modern Typewriter for literal text; the source is archived on CTAN in usergrps/uktug. Back issues from the previous 12 months may be ordered from UKTUG for £2 each; earlier issues are archived on CTAN in usergrps/uktug. Please send UKTUG subscriptions, and book or software orders, to Peter Abbott, 1 Eymore Close, Selly Oak, Birmingham B29 4LB. Fax/telephone: 0121 476 2159. Email enquiries about UKTUG to uktug- [email protected]. –1– I Editorial This is the first edition of Baskerville entirely devoted to a single topic. It arose from discussion within your committee of what we might reasonably do which helps our members, but which isn’t already done elsewhere. We hope it will prove useful to you. We would welcome comments on the utility or otherwise of the article, and on ways it could be improved; letters to the editor are always welcome. Future uses of this edition could include inserting it into a ‘new members pack’, publishing updated questions, and possibly republishing the whole thing. This edition of Baskerville was processed using a testing copy of the December 1994 release of LATEX2ε, but none of the answers to questions assume that that version is available (it’s scheduled for public release in the middle of December).
    [Show full text]
  • §1 1 1. Comments on Yac2o2's Readmev1 .1 File — Date
    x1 READMEV1.1 COMMENTS ON Yac2o2'S READMEV1 :1 FILE | DATE: February 16, 2015 1 1. Comments on Yac2o2's READMEv1 :1 file | Date: February 16, 2015. Project: Yac2o2 | Multi-threaded lr(1) Compiler/compiler system Distributed under license: Mozilla Public License, v. 2.0. Distribution Date: February 16, 2015 Distribution version: 1.1 Comments: Currently for the Unix flavoured Platforms Author: Dave Bone Support email: [email protected] Contributors list: Dave Bone The distribution contains the programs: compiler/compiler O2 and its linker O2linker, along with its runtime library yacco2. There are build scripts for platforms: Apple, GNU, Solaris. Various documents, grammars, reference manual, quality assurance suites, and generated c++ source code are included. These items are elaborated upon further within this document. 2. License. Yac2o2's distributed source code is subject to the terms of the Mozilla Public License, v. 2.0. If a copy of the MPL was not distributed with this file, you can obtain one at http://mozilla.org/MPL/2.0/. As best as I could, the \Literate programming" w type files contain a reference to this license along with their generated documents. The c++ source files generated from the w files do not and will not have any comments referencing this license but are also subject to its terms. The ctangle program generating the c++ code does not emit programmer c type comments. It emits \#line" macro references to the w file and only c comments to its gened document's section number. Any discovered license omissions required to be referenced within Yac2o2's Project files are still covered by this license and will be corrected in future distributions.
    [Show full text]
  • The Treasure Chest for Compatibility with Texpower and Seminar
    TUGboat, Volume 22 (2001), No. 1/2 67 the concept of pdfslide, but completely rewritten The Treasure Chest for compatibility with texpower and seminar. ifsym: in fonts Fonts with symbols for alpinistic, electronic, mete- orological, geometric, etc., usage. A LATEX2ε pack- age simplifies usage. Packages posted to CTAN jas99_m.bst: in biblio/bibtex/contrib “What’s in a name?” I did not realize that Jan Update of jas99.bst,modifiedforbetterconfor- Tschichold’s typographic standards lived on in the mity to the American Meteorological Society. koma-script package often mentioned on usenet (in LaTeX WIDE: in nonfree/systems/win32/LaTeX_WIDE comp.text.tex) until I happened upon the listing A demonstration version of an integrated editor for it in a previous edition of “The Treasure Chest”. and shell for TEX— free for noncommercial use, but without registration, customization is disabled. This column is an attempt to give TEX users an on- : LAT X2ε macro package of simple, “little helpers” going glimpse of the trove which is CTAN. lhelp E converted into dtx format. Includes common units This is a chronological list of packages posted with preceding thinspaces, framed boxes, start new to CTAN between June and December 2000 with odd or even pages, draft markers, notes, condi- descriptive text pulled from the announcement and tional includes (including EPS files), and versions edited for brevity — however, all errors are mine. of enumerate and itemize which allow spacing to Packages are in alphabetic order and are listed only be changed. in the last month they were updated. Individual files makecmds Provides commands to make commands, envi- / partial uploads are listed under their own name if ronments, counters and lengths.
    [Show full text]
  • A Literate Programming Approach for Hardware Description Language In- Struction
    Paper ID #26263 A Literate Programming Approach for Hardware Description Language In- struction Dr. J.W. Bruce, Tennessee Technological University J.W. Bruce is with the Department of Electrical & Computer Engineering at Tennessee Technological University in Cookeville, Tennessee USA Dr. Bryan A. Jones, Mississippi State University Bryan A. Jones received the B.S.E.E. and M.S. degrees in electrical engineering from Rice University, Houston, TX, in 1995 and 2002, respectively, and the Ph.D. degree in electrical engineering from Clemson University, Clemson, SC, in 2005. He is currently an Associate Professor at Mississippi State University, Mississippi State, MS. From 1996 to 2000, he was a Hardware Design Engineer with Compaq, where he specialized in board lay- out for high-availability redundant array of independent disks (RAID) controllers. His research interests include engineering education, robotics, and literate programming. Dr. Mahnas Jean Mohammadi-Aragh, Mississippi State University Dr. Jean Mohammadi-Aragh is an assistant professor in the Department of Electrical and Computer Engi- neering at Mississippi State University. Dr. Mohammadi-Aragh investigates the use of digital systems to measure and support engineering education, specifically through learning analytics and the pedagogical uses of digital systems. She also investigates fundamental questions critical to improving undergraduate engineering degree pathways. She earned her Ph.D. in Engineering Education from Virginia Tech. In 2013, Dr. Mohammadi-Aragh was honored as a promising new engineering education researcher when she was selected as an ASEE Educational Research and Methods Division Apprentice Faculty. c American Society for Engineering Education, 2019 A Literate Programming Approach for Hardware Description Language Instruction INTRODUCTION Digital devices are ubiquitous in modern life.
    [Show full text]
  • The UK Tex FAQ Your 469 Questions Answered Version 3.28, Date 2014-06-10
    The UK TeX FAQ Your 469 Questions Answered version 3.28, date 2014-06-10 June 10, 2014 NOTE This document is an updated and extended version of the FAQ article that was published as the December 1994 and 1995, and March 1999 editions of the UK TUG magazine Baskerville (which weren’t formatted like this). The article is also available via the World Wide Web. Contents Introduction 10 Licence of the FAQ 10 Finding the Files 10 A The Background 11 1 Getting started.............................. 11 2 What is TeX?.............................. 11 3 What’s “writing in TeX”?....................... 12 4 How should I pronounce “TeX”?................... 12 5 What is Metafont?........................... 12 6 What is Metapost?........................... 12 7 Things with “TeX” in the name.................... 13 8 What is CTAN?............................ 14 9 The (CTAN) catalogue......................... 15 10 How can I be sure it’s really TeX?................... 15 11 What is e-TeX?............................ 15 12 What is PDFTeX?........................... 16 13 What is LaTeX?............................ 16 14 What is LaTeX2e?........................... 16 15 How should I pronounce “LaTeX(2e)”?................. 17 16 Should I use Plain TeX or LaTeX?................... 17 17 How does LaTeX relate to Plain TeX?................. 17 18 What is ConTeXt?............................ 17 19 What are the AMS packages (AMSTeX, etc.)?............ 18 20 What is Eplain?............................ 18 21 What is Texinfo?............................ 19 22 Lollipop................................ 19 23 If TeX is so good, how come it’s free?................ 19 24 What is the future of TeX?....................... 19 25 Reading (La)TeX files......................... 19 26 Why is TeX not a WYSIWYG system?................. 20 27 TeX User Groups............................ 21 B Documentation and Help 21 28 Books relevant to TeX and friends...................
    [Show full text]
  • Luatex Reference Manual
    LuaTEX Reference Manual stable April 2021 Version 1.13 LuaTEX Reference Manual copyright : LuaTEX development team more info : www.luatex.org version : April 11, 2021 Contents Introduction 13 1 Preamble 17 2 Basic TEX enhancements 19 2.1 Introduction 19 2.1.1 Primitive behaviour 19 2.1.2 Version information 19 2.2 UNICODE text support 20 2.2.1 Extended ranges 20 2.2.2 \Uchar 21 2.2.3 Extended tables 21 2.3 Attributes 21 2.3.1 Nodes 21 2.3.2 Attribute registers 22 2.3.3 Box attributes 22 2.4 LUA related primitives 23 2.4.1 \directlua 23 2.4.2 \latelua and \lateluafunction 25 2.4.3 \luaescapestring 25 2.4.4 \luafunction, \luafunctioncall and \luadef 25 2.4.5 \luabytecode and \luabytecodecall 26 2.5 Catcode tables 27 2.5.1 Catcodes 27 2.5.2 \catcodetable 27 2.5.3 \initcatcodetable 27 2.5.4 \savecatcodetable 27 2.6 Suppressing errors 28 2.6.1 \suppressfontnotfounderror 28 2.6.2 \suppresslongerror 28 2.6.3 \suppressifcsnameerror 28 2.6.4 \suppressoutererror 28 2.6.5 \suppressmathparerror 28 2.6.6 \suppressprimitiveerror 29 2.7 Fonts 29 2.7.1 Font syntax 29 2.7.2 \fontid and \setfontid 29 2.7.3 \noligs and \nokerns 29 2.7.4 \nospaces 30 2.8 Tokens, commands and strings 30 2.8.1 \scantextokens 30 2.8.2 \toksapp, \tokspre, \etoksapp, \etokspre, \gtoksapp, \gtokspre, \xtoksapp, \xtokspre 30 2.8.3 \csstring, \begincsname and \lastnamedcs 31 1 2.8.4 \clearmarks 31 2.8.5 \alignmark and \aligntab 31 2.8.6 \letcharcode 31 2.8.7 \glet 32 2.8.8 \expanded, \immediateassignment and \immediateassigned 32 2.8.9 \ifcondition 33 2.9 Boxes, rules and leaders
    [Show full text]
  • Literate Programming, a Practioner's View
    Literate Programming, A Practioner’s View Bart Childs Texas A&M University Department of Computer Science College Station, TX 77843-3112 Phone (409) 845-5470; FAX (409) 847-8578 Internet: [email protected] Abstract I have been using the WEB style of Literate Programming since my first efforts to port TEX to the Data General AOS system. When I looked back at those efforts, the work in porting drivers that were not written in WEB and the writing of drivers in WEB (based upon DVITYPE, of course), the value of this method of programming became evident. I have concentrated my research (and some teaching) efforts upon this style of programming. I will relate my insights and opinions of the following: some quantitative and qualitative measures of the value of WEB programming; a description of some tools that are part of an environment for writing and maintaining literate programs; literate programming environments that are alternatives to the WEB style; an annotated list of some literate programming systems; and I will conclude with my perception of the future of literate programming. Introduction A Definition Donald Knuth created the WEB system of literate I use the following list of requirements to imply a programming when he wrote the TEX typesetting definition of a literate program and the minimum system a second time (see “The WEB system set of tools which are needed to prepare, use, and of structured documentation”, 1983; “Literate study the resulting code. programming”, 1984; TEX: The Program, 1986; • The high-level language code and the system METAFONT WEB and :TheProgram).
    [Show full text]
  • Donald E. Knuth Papers SC0097
    http://oac.cdlib.org/findaid/ark:/13030/kt2k4035s1 Online items available Guide to the Donald E. Knuth Papers SC0097 Daniel Hartwig & Jenny Johnson Department of Special Collections and University Archives August 2018 Green Library 557 Escondido Mall Stanford 94305-6064 [email protected] URL: http://library.stanford.edu/spc Note This encoded finding aid is compliant with Stanford EAD Best Practice Guidelines, Version 1.0. Guide to the Donald E. Knuth SC00973411 1 Papers SC0097 Language of Material: English Contributing Institution: Department of Special Collections and University Archives Title: Donald E. Knuth papers Creator: Knuth, Donald Ervin, 1938- source: Knuth, Donald Ervin, 1938- Identifier/Call Number: SC0097 Identifier/Call Number: 3411 Physical Description: 39.25 Linear Feet Physical Description: 4.3 gigabyte(s)email files Date (inclusive): 1962-2018 Abstract: Papers reflect his work in the study and teaching of computer programming, computer systems for publishing, and mathematics. Included are correspondence, notes, manuscripts, computer printouts, logbooks, proofs, and galleys pertaining to the computer systems TeX, METAFONT, and Computer Modern; and to his books THE ART OF COMPUTER PROGRAMMING, COMPUTERS & TYPESETTING, CONCRETE MATHEMATICS, THE STANFORD GRAPHBASE, DIGITAL TYPOGRAPHY, SELECTED PAPERS ON ANALYSIS OF ALGORITHMS, MMIXWARE : A RISC COMPUTER FOR THE THIRD MILLENNIUM, and THINGS A COMPUTER SCIENTIST RARELY TALKS ABOUT. Special Collections and University Archives materials are stored offsite and must be paged 36-48 hours in advance. For more information on paging collections, see the department's website: http://library.stanford.edu/depts/spc/spc.html. Immediate Source of Acquisition note Gift of Donald Knuth, 1972, 1980, 1983, 1989, 1996, 1998, 2001, 2014, 2015, 2019.
    [Show full text]
  • Literate Programming
    Literate Programming Yaniv Lefel Hagay Pollak Part of a Course by Dr. Shuly Wintner. 1 Literate Programming Literate Programming (1983) Donald E. Knuth Programming pearls – Literate Programming (1986) Jon Bentley ``Beware of bugs in the above code; I have only proved it correct, not tried it.'' 2 1 Introduction Improvements in programming methodologies - Structured programming. Programs are more reliable Easier to comprehend The next thing should be better documentation of programs. 4 Introduction – cont’ We should consider programs to be works of literature. We use the title “Literate Programming”. 5 2 Motivation Instead of instructing a computer what to do, let us concentrate rather on explaining to human beings what we want a computer to do. We introduce a new methodology: The WEB system. 6 Programming and weaving WEB - Three Letter Acronym. A program is like a WEB tangled and weaved, with relations and connections in the program parts. We express a program as a web of ideas. 7 3 The WEB System The WEB system was developed in Stanford University, by Knuth. The WEB system embodies the ideas of literate programming. WEB is a combination of A document formatting language. A program language. WEB does not make other languages obsolete, but rather enhances them. 8 The WEB System - cont TeX – document formatting language. Pascal – programming language. Other languages can be used (and indeed are used). WEB language I ... expect each member of the next generation of programmers to be familiar with a document and programming language. 9 4 The WEB System – processes Weaving – producing a document describing the program clearly Example: cob.w -> cob.tex -> cob.dvi dvi - Device Independent binary description.
    [Show full text]
  • Tutorial Literate Programming
    tutorial Literate Programming Michael A. Guravage tries to address these issues by integrating, or if you prefer NLR - blurring the distinction between, code and documenta- Anthony Fokkerweg 2 tion in such a way that code and documentation contribute 1059 CM Amsterdam NL to and complement each other. [email protected] The remainder of this article will be arranged as follows: abstract we begin by discussing the motives for and ideas behind This article is a short introduction to the theory and practice of literate programming. Next, we identify the properties that a programming style known as Literate Programming; a style characterize literate programs. The process of transform- that changes the focus of writing programs away from telling a ing literate programs into running code and typeset docu- computer what to do and toward explaining to a person what it is we are telling the computer to do. Literate Programming ments is explained. We compare language dependent and overcomes the limitations inherent in presenting traditionally language independent literate programming tools and enu- structured program text. Using a balanced mix of informal and merate the benefits and liabilities of each. Lastly, the costs formal methods, literate programs are presented in a way suit- of using literate programming are estimated. ed for human understanding. Processing a literate program source results in both a nicely typeset document describing the parts of the program in an order that elucidates their de- Motivation for Literate Programming sign, and source code in an order in which it will compile. Literate Programming originated in the early 1980’s as part keywords of Knuth’s work on TEX and digital typography.
    [Show full text]