目录

Pretty Fast

Pretty Fast is a source-map-generating JavaScript pretty printer, that is pretty fast.

Build Status

Install

npm install pretty-fast

Usage

var prettyFast = require("pretty-fast");

var uglyJS = "function ugly(){code()}";

var pretty = prettyFast(uglyJS, {
  url: "test.js",
  indent: "  "
});

console.log(pretty.code);
// function ugly() {
//   code()
// }

console.log(pretty.map);
// [object SourceMapGenerator]

(See the mozilla/source-map library for information on SourceMapGenerator instances, and source maps in general.)

Options

  • url - The URL of the JavaScript source being prettified. Used in the generated source map. If you are prettifying JS that isn’t from a file or doesn’t have a URL, you can use a dummy value, such as “(anonymous)”.

  • indent - The string that you want your code indented by. Most people want one of " ", " ", or "\t".

  • ecmaVersion - Indicates the ECMAScript version to parse. See acorn.parse documentation for more details. Defaults to "latest".

Issues

Please use Bugzilla

Goals

  • To be pretty fast, while still generating source maps.

  • To avoid fully parsing the source text; we should be able to get away with only a tokenizer and some heuristics.

  • Preserve comments.

  • Pretty Fast should be able to run inside Web Workers.

Non-goals

  • Extreme configurability of types of indentation, where curly braces go, etc.

  • To be the very fastest pretty printer in the universe. This goal is unattainable given that generating source maps is a requirement. We just need to be Pretty Fast.

  • To perfectly pretty print exactly as you would have written the code. This falls out from both not wanting to support extreme configurability, and avoiding full on parsing. We just aim to pretty print Pretty Well.

关于
284.0 KB
邀请码
    Gitlink(确实开源)
  • 加入我们
  • 官网邮箱:gitlink@ccf.org.cn
  • QQ群
  • QQ群
  • 公众号
  • 公众号

版权所有:中国计算机学会技术支持:开源发展技术委员会
京ICP备13000930号-9 京公网安备 11010802032778号