Sebastian McKenzie 470d5738e1 Merge branch 'development'
Conflicts:
	VERSION
	packages/babel-cli/package.json
	packages/babel-generator/src/buffer.js
	packages/babel-runtime/package.json
	packages/babel-traverse/src/scope/index.js
	packages/babel-types/src/validators.js
	packages/babel/package.json
	packages/babel/src/generation/generators/expressions.js
	packages/babel/src/generation/generators/statements.js
	packages/babel/src/transformation/transformers/es6/tail-call.js
	packages/babel/src/transformation/transformers/es7/async-functions.js
	packages/babel/src/transformation/transformers/es7/exponentiation-operator.js
	packages/babel/src/types/retrievers.js
	packages/babel/test/fixtures/transformation/es6.tail-call/default-parameters/expected.js
	packages/babel/test/fixtures/transformation/es6.tail-call/factorial/expected.js
	packages/babel/test/fixtures/transformation/es6.tail-call/max-args/expected.js
	packages/babel/test/fixtures/transformation/es6.tail-call/recursion/expected.js
	packages/babylon/package.json
2015-10-30 00:48:36 +00:00
2015-09-15 06:19:49 +01:00
2015-07-12 12:51:20 +01:00
2015-10-29 17:51:24 +00:00
2015-10-29 17:51:24 +00:00
2015-07-14 16:48:43 +01:00
2015-07-30 12:57:23 +01:00
2015-07-30 12:57:23 +01:00
2015-10-29 18:06:55 +00:00
2015-10-29 17:51:24 +00:00

babylon

Babylon is a JavaScript parser used in Babel.

  • ES6 enabled by default.
  • Comment attachment.
  • Support for JSX and Flow.
  • Support for experimental language proposals.

Credits

Heavily based on acorn and acorn-jsx, thanks to the awesome work of @RReverser and @marijnh.

Significant diversions are expected to occur in the future such as streaming, EBNF definitions, sweet.js integration, interspacial parsing and more.

API

babylon.parse(code, [options])

Options

  • allowImportExportEverywhere: By default, import and export declarations can only appear at a program's top level. Setting this option to true allows them anywhere where a statement is allowed.

  • allowReturnOutsideFunction: By default, a return statement at the top level raises an error. Set this to true to accept such code.

  • allowSuperOutsideMethod TODO

  • sourceType: Indicate the mode the code should be parsed in. Can be either "script" or "module".

  • plugins: Array containing the plugins that you want to enable.

Example

require("babylon").parse("code", {
  // parse in strict mode and allow module declarations
  sourceType: "module",

  features: [
    // enable experimental async functions
    "asyncFunctions",

    // enable jsx and flow syntax
    "jsx",
    "flow"
  ]
});

Plugins

  • jsx
  • flow
  • asyncFunctions
  • classConstructorCall
  • doExpressions
  • trailingFunctionCommas
  • objectRestSpread
  • decorators
  • classProperties
  • exportExtensions
  • exponentiationOperator
  • asyncGenerators
Description
No description provided
Readme 79 MiB
Languages
JavaScript 99.5%
Makefile 0.3%
HTML 0.1%