|
"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;
|
|
;
|