fbpx
Wikipedia

Prettyprint

Pretty-printing (or prettyprinting) is the application of any of various stylistic formatting conventions to text files, such as source code, markup, and similar kinds of content. These formatting conventions may entail adhering to an indentation style, using different color and typeface to highlight syntactic elements of source code, or adjusting size, to make the content easier for people to read, and understand. Pretty-printers for source code are sometimes called code formatters or beautifiers.

Pretty-printing mathematics edit

 
A typeset mathematical expression

Pretty-printing usually refers to displaying mathematical expressions similar to the way they would be typeset professionally. For example, in computer algebra systems such as Maxima or Mathematica the system may write output like "x ^ 2 + 3 * x" as " ". Some graphing calculators, such as the Casio 9860 series, HP-49/50 series and HP Prime, TI-84 Plus, TI-89, and TI-Nspire, the TI-83 Plus with the PrettyPt[1] add-on, or the TI-84 Plus with the same add-on or the "MathPrint"-enabled OSes, can perform pretty-printing. Additionally, a number of newer scientific calculators are equipped with dot matrix screens capable of pretty-printing such as the Casio FX-ES series (Natural Display), Sharp EL-W series (WriteView), HP SmartCalc 300s, TI-30XB, and Numworks.

Many text formatting programs can also typeset mathematics: TeX was developed specifically for high-quality mathematical typesetting.

Pretty-printing markup and tag-based code edit

 
HTML source code, pretty-printed to better show the hierarchical relationships of its elements (called tags)

Pretty-printing in markup language instances is most typically associated with indentation of tags and string content to visually determine hierarchy and nesting. Although the syntactical structures of tag-based languages do not significantly vary, the indentation may vary significantly due to how a markup language is interpreted or due to the data it describes.

In MathML, whitespace characters do not reflect data, meaning, or syntax above what is required by XML syntax. In HTML, whitespace characters between tags are considered text and are parsed as text nodes into the parsed result.[2] While indentation may be generously applied to a MathML document, sufficient additional care must be taken in pretty-printing an HTML document to ensure additional text nodes are not created or destroyed in general proximity to the content or content-reflective tag elements. This difference in complexity is non-trivial from the perspective of an automated pretty-print operation where no special rules or edge cases are necessary, as in the more simple MathML example. The HTML example may require a series of progressive interrelated algorithms to account for various patterns of tag elements and content that conforms to a uniform style and is consistent in application across various instances, as evidenced by the markup.ts[3] application component used to beautify HTML, XML, and related technologies for the Pretty Diff tool.

Programming code formatting edit

Programmers often use tools to format programming language source code in a particular manner. Proper code formatting makes it easier to read and understand. Different programmers often prefer different styles of formatting, such as the use of code indentation and whitespace or positioning of braces. A code formatter or code indenter converts source code from one format style to another. This is relatively straightforward because of the unambiguous syntax of programming languages. Code beautification involves parsing the source code into component structures, such as assignment statements, if blocks, loops, etc. (see also control flow), and formatting them in a manner specified by the user in a configuration file.

Code beautifiers exist as standalone applications and built into text editors and integrated development environments. For example, Emacs' various language modes can correctly indent blocks of code attractively.[4]

HTML edit

Lisp pretty-printer edit

An early example of pretty-printing was Bill Gosper's "GRINDEF" (i.e. 'grind function') program (c. 1967), which used combinatorial search with pruning to format LISP programs. Early versions operated on the executable (list structure) form of the Lisp program and were oblivious to the special meanings of various functions. Later versions had special read conventions for incorporating non-executable comments and also for preserving read macros in unexpanded form. They also allowed special indentation conventions for special functions such as if.[5][6] The term "grind" was used in some Lisp circles as a synonym for pretty-printing.[7]

Project style rules edit

Many open source projects have established rules for code layout. The most typical are the GNU formatting[8] and the BSD style.[9] The biggest difference between the two is the location of the braces: in the GNU style, opening and closing braces are on lines by themselves, with the same indent. BSD style places an opening brace at the end of the preceding line, and the closing braces can be followed by else. The size of indent and location of whitespace also differs.

Example of formatting and beautifying code edit

The following example shows some typical C structures and how various indentation style rules format them. Without any formatting at all, it looks like this:

int foo(int k){if(k<1||k>2){printf("out of range\n"); printf("this function requires a value of 1 or 2\n");}else{ printf("Switching\n");switch(k){case 1:printf("1\n");break;case 2:printf("2\n");break;}}} 

The GNU indent program produces the following output when asked to indent according to the GNU rules:

int foo (int k) {  if (k < 1 || k > 2)  {  printf ("out of range\n");  printf ("this function requires a value of 1 or 2\n");  }  else  {  printf ("Switching\n");  switch (k)  {  case 1:  printf ("1\n");  break;  case 2:  printf ("2\n");  break;  }  } } 

It produces this output when formatting according to BSD rules:

int foo(int k) {  if (k < 1 || k > 2) {  printf("out of range\n");  printf("this function requires a value of 1 or 2\n");  } else {  printf("Switching\n");  switch (k) {  case 1:  printf("1\n");  break;  case 2:  printf("2\n");  break;  }  } } 

See also edit

Related concepts

  • Elastic tabstop, a feature of many source code editors that detects and maintains aligned indents
  • Minification, making source code compact, even if it becomes harder for humans to understand
  • Obfuscation, deliberately making source code very difficult for humans to understand, even if it becomes somewhat convoluted

Utilities

  • enscript, a text-to-PostScript converter, with pretty-printing features

References edit

  1. ^ "PrettyPrint - ticalc.org". www.ticalc.org. Retrieved 2022-04-13.
  2. ^ Baron, L. David. "Whitespace in the DOM". Mozilla Developer Network. Retrieved 2012-08-27.
  3. ^ markup.ts
  4. ^ Stallman, Richard M. "Indentation for Programs". GNU Emacs Manual. Free Software Foundation. Retrieved 2011-10-20.
  5. ^ Ira Goldstein, "Pretty Printing : Converting List to Linear Structure", Artificial Intelligence Memo 279, Massachusetts Institute of Technology, February 1973. full text
  6. ^ Richard C. Waters, "Using the new common Lisp pretty printer", ACM SIGPLAN Lisp Pointers 5:2:27-34, April–June 1992.
  7. ^ Jargon File, s.v. grind
  8. ^ GNU style
  9. ^ BSD style

External links edit

  • Algorithm 268: ALGOL 60 reference language editor William M. McKeeman: Commun. ACM 8(11): 667-668 (1965)
  • lgrind, Comprehensive TEX Archive Network
  • NEATER2: a PL/I source statement reformatter Kenneth Conrow, Ronald G. Smith: Commun. ACM 13(11): 669-675 (1970)
  • SOAP - Simplify Obscure Algol Programs R. S. Scowen, D. Allin, A. L. Hillman, M. Shimell: National Physical Laboratory Central Computer Unit report CCU6 (April, 1969) Includes formatted listing of SOAP source code.
    • R. S. Scowen, D. Allin, A. L. Hillman, M. Shimell: Comput. J. 14(2): 133-135 (1971)
    • Original SOAP Source Code from the KDF9
  • SOAP User's Guide. (for Edinburgh IMP) Peter Salkeld Robertson (1976)
    • SOAP Source Code in/for IMP9
  • Soap80: A Program for Formatting IMP80 Source Programs. J.M. Murison, Edinburgh Regional Computer Center (1980)
    • SOAP Source Code in/for IMP80 E. N. Gregory, University of Kent at Canterbury; Peter D. Stephens, Edinburgh Regional Computer Center
  • PRETTYP.PAS Early pascal prettyprinter. Ledgard et al.
  • Pascal With Style (1979)
  • style(9) FreeBSD style guidelines
  • vgrind, The [Unix] Heirloom Project
  • Formatting your source code GNU style guidelines

prettyprint, pretty, printing, prettyprinting, application, various, stylistic, formatting, conventions, text, files, such, source, code, markup, similar, kinds, content, these, formatting, conventions, entail, adhering, indentation, style, using, different, c. Pretty printing or prettyprinting is the application of any of various stylistic formatting conventions to text files such as source code markup and similar kinds of content These formatting conventions may entail adhering to an indentation style using different color and typeface to highlight syntactic elements of source code or adjusting size to make the content easier for people to read and understand Pretty printers for source code are sometimes called code formatters or beautifiers Contents 1 Pretty printing mathematics 2 Pretty printing markup and tag based code 3 Programming code formatting 3 1 HTML 3 2 Lisp pretty printer 3 3 Project style rules 3 4 Example of formatting and beautifying code 4 See also 5 References 6 External linksPretty printing mathematics edit nbsp A typeset mathematical expressionPretty printing usually refers to displaying mathematical expressions similar to the way they would be typeset professionally For example in computer algebra systems such as Maxima or Mathematica the system may write output like x 2 3 x as x 2 3 x displaystyle x 2 3x nbsp Some graphing calculators such as the Casio 9860 series HP 49 50 series and HP Prime TI 84 Plus TI 89 and TI Nspire the TI 83 Plus with the PrettyPt 1 add on or the TI 84 Plus with the same add on or the MathPrint enabled OSes can perform pretty printing Additionally a number of newer scientific calculators are equipped with dot matrix screens capable of pretty printing such as the Casio FX ES series Natural Display Sharp EL W series WriteView HP SmartCalc 300s TI 30XB and Numworks Many text formatting programs can also typeset mathematics TeX was developed specifically for high quality mathematical typesetting Pretty printing markup and tag based code edit nbsp HTML source code pretty printed to better show the hierarchical relationships of its elements called tags Pretty printing in markup language instances is most typically associated with indentation of tags and string content to visually determine hierarchy and nesting Although the syntactical structures of tag based languages do not significantly vary the indentation may vary significantly due to how a markup language is interpreted or due to the data it describes In MathML whitespace characters do not reflect data meaning or syntax above what is required by XML syntax In HTML whitespace characters between tags are considered text and are parsed as text nodes into the parsed result 2 While indentation may be generously applied to a MathML document sufficient additional care must be taken in pretty printing an HTML document to ensure additional text nodes are not created or destroyed in general proximity to the content or content reflective tag elements This difference in complexity is non trivial from the perspective of an automated pretty print operation where no special rules or edge cases are necessary as in the more simple MathML example The HTML example may require a series of progressive interrelated algorithms to account for various patterns of tag elements and content that conforms to a uniform style and is consistent in application across various instances as evidenced by the markup ts 3 application component used to beautify HTML XML and related technologies for the Pretty Diff tool Programming code formatting editProgrammers often use tools to format programming language source code in a particular manner Proper code formatting makes it easier to read and understand Different programmers often prefer different styles of formatting such as the use of code indentation and whitespace or positioning of braces A code formatter or code indenter converts source code from one format style to another This is relatively straightforward because of the unambiguous syntax of programming languages Code beautification involves parsing the source code into component structures such as assignment statements if blocks loops etc see also control flow and formatting them in a manner specified by the user in a configuration file Code beautifiers exist as standalone applications and built into text editors and integrated development environments For example Emacs various language modes can correctly indent blocks of code attractively 4 HTML edit Further information HTML Tidy Lisp pretty printer edit An early example of pretty printing was Bill Gosper s GRINDEF i e grind function program c 1967 which used combinatorial search with pruning to format LISP programs Early versions operated on the executable list structure form of the Lisp program and were oblivious to the special meanings of various functions Later versions had special read conventions for incorporating non executable comments and also for preserving read macros in unexpanded form They also allowed special indentation conventions for special functions such as if 5 6 The term grind was used in some Lisp circles as a synonym for pretty printing 7 Project style rules edit Many open source projects have established rules for code layout The most typical are the GNU formatting 8 and the BSD style 9 The biggest difference between the two is the location of the braces in the GNU style opening and closing braces are on lines by themselves with the same indent BSD style places an opening brace at the end of the preceding line and the closing braces can be followed by else The size of indent and location of whitespace also differs Example of formatting and beautifying code edit The following example shows some typical C structures and how various indentation style rules format them Without any formatting at all it looks like this int foo int k if k lt 1 k gt 2 printf out of range n printf this function requires a value of 1 or 2 n else printf Switching n switch k case 1 printf 1 n break case 2 printf 2 n break The GNU indent program produces the following output when asked to indent according to the GNU rules int foo int k if k lt 1 k gt 2 printf out of range n printf this function requires a value of 1 or 2 n else printf Switching n switch k case 1 printf 1 n break case 2 printf 2 n break It produces this output when formatting according to BSD rules int foo int k if k lt 1 k gt 2 printf out of range n printf this function requires a value of 1 or 2 n else printf Switching n switch k case 1 printf 1 n break case 2 printf 2 n break See also editRelated concepts Elastic tabstop a feature of many source code editors that detects and maintains aligned indents Minification making source code compact even if it becomes harder for humans to understand Obfuscation deliberately making source code very difficult for humans to understand even if it becomes somewhat convolutedUtilities enscript a text to PostScript converter with pretty printing featuresReferences edit PrettyPrint ticalc org www ticalc org Retrieved 2022 04 13 Baron L David Whitespace in the DOM Mozilla Developer Network Retrieved 2012 08 27 markup ts Stallman Richard M Indentation for Programs GNU Emacs Manual Free Software Foundation Retrieved 2011 10 20 Ira Goldstein Pretty Printing Converting List to Linear Structure Artificial Intelligence Memo 279 Massachusetts Institute of Technology February 1973 full text Richard C Waters Using the new common Lisp pretty printer ACM SIGPLAN Lisp Pointers 5 2 27 34 April June 1992 full text Jargon File s v grind GNU style BSD styleExternal links editAlgorithm 268 ALGOL 60 reference language editor William M McKeeman Commun ACM 8 11 667 668 1965 lgrind Comprehensive TEX Archive Network NEATER2 a PL I source statement reformatter Kenneth Conrow Ronald G Smith Commun ACM 13 11 669 675 1970 SOAP Simplify Obscure Algol Programs R S Scowen D Allin A L Hillman M Shimell National Physical Laboratory Central Computer Unit report CCU6 April 1969 Includes formatted listing of SOAP source code SOAP A Program which Documents and Edits ALGOL 60 Programs R S Scowen D Allin A L Hillman M Shimell Comput J 14 2 133 135 1971 Original SOAP Source Code from the KDF9 SOAP User s Guide for Edinburgh IMP Peter Salkeld Robertson 1976 SOAP Source Code in for IMP9 Soap80 A Program for Formatting IMP80 Source Programs J M Murison Edinburgh Regional Computer Center 1980 SOAP Source Code in for IMP80 E N Gregory University of Kent at Canterbury Peter D Stephens Edinburgh Regional Computer Center PRETTYP PAS Early pascal prettyprinter Ledgard et al Pascal With Style 1979 style 9 FreeBSD style guidelines vgrind The Unix Heirloom Project Formatting your source code GNU style guidelines Retrieved from https en wikipedia org w index php title Prettyprint amp oldid 1203351781, wikipedia, wiki, book, books, library,

article

, read, download, free, free download, mp3, video, mp4, 3gp, jpg, jpeg, gif, png, picture, music, song, movie, book, game, games.