An implementation of Wadler's Pretty Printer; an efficient algebra that supports multiple layouts, choosing the best one for the available screen space.
var { pretty, text, bracket } = require('text.pretty-printing');
var { Extractor } = require('adt-simple');
// We define a simple binary tree
union Tree {
Leaf(*),
Branch(Tree, Tree)
} deriving (Extractor)
// And a toString method that returns the prettified document
Tree::toString = function(width, indent) {
return pretty(width, this.toDoc(indent))
}
// Transforming a tree into a document is just regular structural
// recursion. Here `a +++ b` is shorthand for `a.concat(b)`.
Tree::toDoc = function(i) {
return match this {
Leaf(v) =>
text('Leaf(') +++ text(v.toString()) +++ text(')'),
Branch(l, r) =>
bracket(i, 'Branch(', l.toDoc(i) +++ text(', ') +++ r.toDoc(i), ')')
}
}
var tree = new Branch(
new Branch(new Leaf(1), new Branch(new Leaf(2), new Leaf(3))),
new Leaf(4)
)
console.log(tree.toString(30, 4))
// => "Branch(
// Branch(
// Leaf(1), Branch(
// Leaf(2), Leaf(3)
// )
// ), Leaf(4)
// )"
console.log(tree.toString(80, 4))
// => "Branch( Branch( Leaf(1), Branch( Leaf(2), Leaf(3) ) ), Leaf(4) )"
See the examples/
folder for additional examples.
Grab the latest release from npm:
$ npm install text.pretty-printing
If you want to compile this library from the source, you'll need Git, Make, Node.js, and run the following commands:
$ git clone git://github.com/folktale/text.pretty-printing.git
$ cd text.pretty-printing
$ npm install
$ make bundle
This will generate the dist/text.pretty-printing.umd.js
file, which you can load in
any JavaScript environment.
You'll need Sphinx to generate the documentation:
$ git clone git://github.com/folktale/text.pretty-printing.git
$ cd text.pretty-printing
$ npm install
$ make documentation
Then open the file docs/build/html/index.html
.
This library assumes an ES5 environment, but can be easily supported in ES3 platforms by the use of shims. Just include es5-shim :)
Copyright (c) 2015 Quildreen Motta.
Released under the MIT licence.