Daniel Tschinder 4bfececdad Fix leading comments added from previous node
This fixes an issue that comments were added as leading comments
to expressions, which are not immediately folowing the comment.
This was also reported and fixed in espree, and is basically a port to
babylon. eslint/espree#256

this also fixes an issue in babel-eslint with certain rules babel/babel-eslint#289
2016-04-23 12:24:20 +02:00
2016-02-14 23:25:14 +00:00
2016-03-10 06:24:44 +00:00
2016-03-10 06:24:44 +00:00
2016-03-10 06:24:44 +00:00
2016-03-10 08:28:33 -05:00
2016-03-10 06:24:44 +00:00
2015-07-30 12:57:23 +01:00
2016-03-10 06:24:44 +00:00
2016-03-10 06:24:44 +00:00
2015-07-30 12:57:23 +01:00
2016-03-10 14:48:46 +00:00
2016-03-10 09:45:41 -05:00

babylon

Babylon is a JavaScript parser used in Babel.

Travis Status

  • 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".

  • sourceFilename: Correlate output AST nodes with their source filename. Useful when generating code and source maps from the ASTs of multiple input files.

  • 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",

  plugins: [
    // 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
  • functionBind
  • functionSent
Description
No description provided
Readme 79 MiB
Languages
JavaScript 99.5%
Makefile 0.3%
HTML 0.1%