|
|
- "use strict";
- var __importDefault = (this && this.__importDefault) || function (mod) {
- return (mod && mod.__esModule) ? mod : { "default": mod };
- };
- Object.defineProperty(exports, "__esModule", { value: true });
- var _babel_options_1 = __importDefault(require("./_babel_options"));
- // Prefer the new @babel/parser package, but fall back to babylon if
- // that's what's available.
- exports.parser = function () {
- try {
- return require("@babel/parser");
- }
- catch (e) {
- return require("babylon");
- }
- }();
- // This module is suitable for passing as options.parser when calling
- // recast.parse to process JavaScript code with Babel:
- //
- // const ast = recast.parse(source, {
- // parser: require("recast/parsers/babel")
- // });
- //
- function parse(source, options) {
- var babelOptions = _babel_options_1.default(options);
- babelOptions.plugins.push("jsx", "flow");
- return exports.parser.parse(source, babelOptions);
- }
- exports.parse = parse;
- ;
|